Commit f791620f authored by David Woodhouse's avatar David Woodhouse Committed by H. Peter Anvin

x86, efi: Fix 32-bit EFI handover protocol entry point

If the bootloader calls the EFI handover entry point as a standard function
call, then it'll have a return address on the stack. We need to pop that
before calling efi_main(), or the arguments will all be out of position on
the stack.
Signed-off-by: default avatarDavid Woodhouse <David.Woodhouse@intel.com>
Cc: <stable@kernel.org>
Link: http://lkml.kernel.org/r/1358513837.2397.247.camel@shinybook.infradead.orgSigned-off-by: default avatarH. Peter Anvin <hpa@linux.intel.com>
Cc: Matt Fleming <matt.fleming@intel.com>
parent 70a479cb
...@@ -50,8 +50,10 @@ ENTRY(startup_32) ...@@ -50,8 +50,10 @@ ENTRY(startup_32)
pushl %eax pushl %eax
pushl %esi pushl %esi
pushl %ecx pushl %ecx
sub $0x4, %esp
.org 0x30,0x90 .org 0x30,0x90
add $0x4, %esp
call efi_main call efi_main
cmpl $0, %eax cmpl $0, %eax
movl %eax, %esi movl %eax, %esi
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment