diff options
Diffstat (limited to 'common/recipes-kernel/linux/linux-yocto-4.9.21/0032-kaiser-asm-tlbflush.h-handle-noPGE-at-lower-level.patch')
-rw-r--r-- | common/recipes-kernel/linux/linux-yocto-4.9.21/0032-kaiser-asm-tlbflush.h-handle-noPGE-at-lower-level.patch | 88 |
1 files changed, 0 insertions, 88 deletions
diff --git a/common/recipes-kernel/linux/linux-yocto-4.9.21/0032-kaiser-asm-tlbflush.h-handle-noPGE-at-lower-level.patch b/common/recipes-kernel/linux/linux-yocto-4.9.21/0032-kaiser-asm-tlbflush.h-handle-noPGE-at-lower-level.patch deleted file mode 100644 index 7cc0ba33..00000000 --- a/common/recipes-kernel/linux/linux-yocto-4.9.21/0032-kaiser-asm-tlbflush.h-handle-noPGE-at-lower-level.patch +++ /dev/null @@ -1,88 +0,0 @@ -From 3b5d03bec6defac520ec0d6c5620f0c44392df39 Mon Sep 17 00:00:00 2001 -From: Hugh Dickins <hughd@google.com> -Date: Sat, 4 Nov 2017 18:23:24 -0700 -Subject: [PATCH 032/103] kaiser: asm/tlbflush.h handle noPGE at lower level - -I found asm/tlbflush.h too twisty, and think it safer not to avoid -__native_flush_tlb_global_irq_disabled() in the kaiser_enabled case, -but instead let it handle kaiser_enabled along with cr3: it can just -use __native_flush_tlb() for that, no harm in re-disabling preemption. - -(This is not the same change as Kirill and Dave have suggested for -upstream, flipping PGE in cr4: that's neat, but needs a cpu_has_pge -check; cr3 is enough for kaiser, and thought to be cheaper than cr4.) - -Also delete the X86_FEATURE_INVPCID invpcid_flush_all_nonglobals() -preference from __native_flush_tlb(): unlike the invpcid_flush_all() -preference in __native_flush_tlb_global(), it's not seen in upstream -4.14, and was recently reported to be surprisingly slow. - -Signed-off-by: Hugh Dickins <hughd@google.com> -Acked-by: Jiri Kosina <jkosina@suse.cz> -Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> ---- - arch/x86/include/asm/tlbflush.h | 27 +++------------------------ - 1 file changed, 3 insertions(+), 24 deletions(-) - -diff --git a/arch/x86/include/asm/tlbflush.h b/arch/x86/include/asm/tlbflush.h -index 13a74f6..bc6f979 100644 ---- a/arch/x86/include/asm/tlbflush.h -+++ b/arch/x86/include/asm/tlbflush.h -@@ -153,14 +153,6 @@ static inline void kaiser_flush_tlb_on_return_to_user(void) - - static inline void __native_flush_tlb(void) - { -- if (this_cpu_has(X86_FEATURE_INVPCID)) { -- /* -- * Note, this works with CR4.PCIDE=0 or 1. -- */ -- invpcid_flush_all_nonglobals(); -- return; -- } -- - /* - * If current->mm == NULL then we borrow a mm which may change during a - * task switch and therefore we must not be preempted while we write CR3 -@@ -184,11 +176,8 @@ static inline void __native_flush_tlb_global_irq_disabled(void) - /* restore PGE as it was before */ - native_write_cr4(cr4); - } else { -- /* -- * x86_64 microcode update comes this way when CR4.PGE is not -- * enabled, and it's safer for all callers to allow this case. -- */ -- native_write_cr3(native_read_cr3()); -+ /* do it with cr3, letting kaiser flush user PCID */ -+ __native_flush_tlb(); - } - } - -@@ -196,12 +185,6 @@ static inline void __native_flush_tlb_global(void) - { - unsigned long flags; - -- if (kaiser_enabled) { -- /* Globals are not used at all */ -- __native_flush_tlb(); -- return; -- } -- - if (this_cpu_has(X86_FEATURE_INVPCID)) { - /* - * Using INVPCID is considerably faster than a pair of writes -@@ -257,11 +240,7 @@ static inline void __native_flush_tlb_single(unsigned long addr) - - static inline void __flush_tlb_all(void) - { -- if (boot_cpu_has(X86_FEATURE_PGE)) -- __flush_tlb_global(); -- else -- __flush_tlb(); -- -+ __flush_tlb_global(); - /* - * Note: if we somehow had PCID but not PGE, then this wouldn't work -- - * we'd end up flushing kernel translations for the current ASID but --- -2.7.4 - |