x86/efi: Save and restore FPU context around efi_calls (x86_64)
authorRicardo Neri <ricardo.neri-calderon@linux.intel.com>
Thu, 27 Mar 2014 22:10:42 +0000 (15:10 -0700)
committerMatt Fleming <matt.fleming@intel.com>
Thu, 17 Apr 2014 12:26:32 +0000 (13:26 +0100)
Do a complete FPU context save/restore around the EFI calls. This required
as runtime EFI firmware may potentially use the FPU.

This change covers only the x86_64 configuration.

Signed-off-by: Ricardo Neri <ricardo.neri-calderon@linux.intel.com>
Cc: Borislav Petkov <bp@suse.de>
Signed-off-by: Matt Fleming <matt.fleming@intel.com>
arch/x86/include/asm/efi.h

index 19292e7cae580399d27b5abcc319e78f700297ba..0b19187cc88268f04dfcb49b4433ed5fe8b6d463 100644 (file)
@@ -1,6 +1,7 @@
 #ifndef _ASM_X86_EFI_H
 #define _ASM_X86_EFI_H
 
+#include <asm/i387.h>
 /*
  * We map the EFI regions needed for runtime services non-contiguously,
  * with preserved alignment on virtual addresses starting from -4G down
@@ -54,7 +55,9 @@ extern u64 asmlinkage efi_call(void *fp, ...);
                                                                        \
        efi_sync_low_kernel_mappings();                                 \
        preempt_disable();                                              \
+       __kernel_fpu_begin();                                           \
        __s = efi_call((void *)efi.systab->runtime->f, __VA_ARGS__);    \
+       __kernel_fpu_end();                                             \
        preempt_enable();                                               \
        __s;                                                            \
 })