cbfs_and_run_core() did not check the return code of cbfs_load_stage()
and jumped to (void*)-1 on error.
Die properly instead.
I didn't use die() because that caused a linker error.

Signed-off-by: Carl-Daniel Hailfinger <[email protected]>

Index: LinuxBIOSv2-asus_m2a-vm/src/arch/i386/lib/cbfs_and_run.c
===================================================================
--- LinuxBIOSv2-asus_m2a-vm/src/arch/i386/lib/cbfs_and_run.c    (Revision 4589)
+++ LinuxBIOSv2-asus_m2a-vm/src/arch/i386/lib/cbfs_and_run.c    (Arbeitskopie)
@@ -11,6 +11,11 @@
        u8 *dst;
        print_debug("Jumping to image.\r\n");
        dst = cbfs_load_stage(filename);
+       if (dst == (void *) -1) {
+               /* We should use die() here. */
+               print_emerg("Loading stage failed!\n");
+               for (;;);
+       }
        print_debug("Jumping to image.\r\n");
 
        __asm__ volatile (


-- 
http://www.hailfinger.org/


-- 
coreboot mailing list: [email protected]
http://www.coreboot.org/mailman/listinfo/coreboot

Reply via email to