diff options
Diffstat (limited to 'arch/x86/include/asm/tlbflush.h')
-rw-r--r-- | arch/x86/include/asm/tlbflush.h | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/arch/x86/include/asm/tlbflush.h b/arch/x86/include/asm/tlbflush.h index 4e5be94e079a..6fa85944af83 100644 --- a/arch/x86/include/asm/tlbflush.h +++ b/arch/x86/include/asm/tlbflush.h | |||
@@ -135,7 +135,14 @@ static inline void cr4_set_bits_and_update_boot(unsigned long mask) | |||
135 | 135 | ||
136 | static inline void __native_flush_tlb(void) | 136 | static inline void __native_flush_tlb(void) |
137 | { | 137 | { |
138 | /* | ||
139 | * If current->mm == NULL then we borrow a mm which may change during a | ||
140 | * task switch and therefore we must not be preempted while we write CR3 | ||
141 | * back: | ||
142 | */ | ||
143 | preempt_disable(); | ||
138 | native_write_cr3(native_read_cr3()); | 144 | native_write_cr3(native_read_cr3()); |
145 | preempt_enable(); | ||
139 | } | 146 | } |
140 | 147 | ||
141 | static inline void __native_flush_tlb_global_irq_disabled(void) | 148 | static inline void __native_flush_tlb_global_irq_disabled(void) |