summaryrefslogtreecommitdiffstats
path: root/arch/x86/include/asm/x86_init.h
diff options
context:
space:
mode:
authorMatt Fleming <matt.fleming@intel.com>2012-04-15 16:06:04 +0100
committerH. Peter Anvin <hpa@linux.intel.com>2012-04-16 11:41:44 -0700
commitb1994304fc399f5d3a5368c81111d713490c4799 (patch)
treefda4b1fa900378abddf71bc8d815543a49783fee /arch/x86/include/asm/x86_init.h
parentd7de8649f34d45041409d1af4ba4a521971a9075 (diff)
downloadop-kernel-dev-b1994304fc399f5d3a5368c81111d713490c4799.zip
op-kernel-dev-b1994304fc399f5d3a5368c81111d713490c4799.tar.gz
x86, efi: Add dedicated EFI stub entry point
The method used to work out whether we were booted by EFI firmware or via a boot loader is broken. Because efi_main() is always executed when booting from a boot loader we will dereference invalid pointers either on the stack (CONFIG_X86_32) or contained in %rdx (CONFIG_X86_64) when searching for an EFI System Table signature. Instead of dereferencing these invalid system table pointers, add a new entry point that is only used when booting from EFI firmware, when we know the pointer arguments will be valid. With this change legacy boot loaders will no longer execute efi_main(), but will instead skip EFI stub initialisation completely. [ hpa: Marking this for urgent/stable since it is a regression when the option is enabled; without the option the patch has no effect ] Signed-off-by: Matt Fleming <matt.hfleming@intel.com> Link: http://lkml.kernel.org/r/1334584744.26997.14.camel@mfleming-mobl1.ger.corp.intel.com Reported-by: Jordan Justen <jordan.l.justen@intel.com> Signed-off-by: H. Peter Anvin <hpa@linux.intel.com> Cc: <stable@vger.kernel.org> v3.3
Diffstat (limited to 'arch/x86/include/asm/x86_init.h')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud