]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
ACPI: APEI: EINJ: Fix check and iounmap of uninitialized pointer p
authorColin Ian King <colin.i.king@gmail.com>
Tue, 24 Jun 2025 20:29:37 +0000 (21:29 +0100)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Thu, 26 Jun 2025 18:52:26 +0000 (20:52 +0200)
In the case where a request_mem_region call fails and pointer r is null
the error exit path via label 'out' will check for a non-null pointer
p and try to iounmap it. However, pointer p has not been assigned a
value at this point, so it may potentially contain any garbage value.
Fix this by ensuring pointer p is initialized to NULL.

Fixes: 1a35c88302a3 ("ACPI: APEI: EINJ: Fix kernel test sparse warnings")
Signed-off-by: Colin Ian King <colin.i.king@gmail.com>
Link: https://patch.msgid.link/20250624202937.523013-1-colin.i.king@gmail.com
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
drivers/acpi/apei/einj-core.c

index 59777a292ffcbe01e57cbb853c64591b886f149d..3d37978418e876187065e3a432ba7f2b0a419617 100644 (file)
@@ -401,7 +401,7 @@ static int __einj_error_trigger(u64 trigger_paddr, u32 type,
        u32 table_size;
        int rc = -EIO;
        struct acpi_generic_address *trigger_param_region = NULL;
-       struct acpi_einj_trigger __iomem *p;
+       struct acpi_einj_trigger __iomem *p = NULL;
 
        r = request_mem_region(trigger_paddr, sizeof(trigger_tab),
                               "APEI EINJ Trigger Table");