early_init_fdt_scan_reserved_mem() invoks fdt_get_mem_rsv(), and it will
use uninitialized variables @base and @size once the callee suffers error.
Fix by checking fdt_get_mem_rsv() error as other callers do.
Signed-off-by: Zijun Hu <quic_zijuhu@quicinc.com>
Link: https://lore.kernel.org/r/20250109-of_core_fix-v4-13-db8a72415b8c@quicinc.com
Signed-off-by: Rob Herring (Arm) <robh@kernel.org>
 void __init early_init_fdt_scan_reserved_mem(void)
 {
        int n;
+       int res;
        u64 base, size;
 
        if (!initial_boot_params)
 
        /* Process header /memreserve/ fields */
        for (n = 0; ; n++) {
-               fdt_get_mem_rsv(initial_boot_params, n, &base, &size);
+               res = fdt_get_mem_rsv(initial_boot_params, n, &base, &size);
+               if (res) {
+                       pr_err("Invalid memory reservation block index %d\n", n);
+                       break;
+               }
                if (!size)
                        break;
                memblock_reserve(base, size);