hw/mips/boston: Check for error return from boston_fdt_filter()
authorPeter Maydell <peter.maydell@linaro.org>
Thu, 6 Feb 2025 15:12:11 +0000 (15:12 +0000)
committerPeter Maydell <peter.maydell@linaro.org>
Mon, 24 Feb 2025 15:03:42 +0000 (15:03 +0000)
The function boston_fdt_filter() can return NULL on errors (in which
case it will print an error message).  When we call this from the
non-FIT-image codepath, we aren't checking the return value, so we
will plough on with a NULL pointer, and segfault in fdt_totalsize().
Check for errors here.

Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Message-id: 20250206151214.2947842-4-peter.maydell@linaro.org

hw/mips/boston.c

index 4690b254dda28529c69d3d4df3d9cc390ffbfdc7..de6ce1f163d1eb58f986b22703b5fe1bae25ed83 100644 (file)
@@ -810,6 +810,10 @@ static void boston_mach_init(MachineState *machine)
 
             dtb_load_data = boston_fdt_filter(s, dtb_file_data,
                                               NULL, &dtb_vaddr);
+            if (!dtb_load_data) {
+                /* boston_fdt_filter() already printed the error for us */
+                exit(1);
+            }
 
             /* Calculate real fdt size after filter */
             dt_size = fdt_totalsize(dtb_load_data);