-
- Downloads
x86/mm/tlb: Only trim the mm_cpumask once a second
[ Upstream commit 6db2526c1d694c91c6e05e2f186c085e9460f202 ] Setting and clearing CPU bits in the mm_cpumask is only ever done by the CPU itself, from the context switch code or the TLB flush code. Synchronization is handled by switch_mm_irqs_off() blocking interrupts. Sending TLB flush IPIs to CPUs that are in the mm_cpumask, but no longer running the program causes a regression in the will-it-scale tlbflush2 test. This test is contrived, but a large regression here might cause a small regression in some real world workload. Instead of always sending IPIs to CPUs that are in the mm_cpumask, but no longer running the program, send these IPIs only once a second. The rest of the time we can skip over CPUs where the loaded_mm is different from the target mm. Reported-by:kernel test roboto <oliver.sang@intel.com> Signed-off-by:
Rik van Riel <riel@surriel.com> Signed-off-by:
Ingo Molnar <mingo@kernel.org> Cc: Dave Hansen <dave.hansen@linux.intel.com> Cc: Andy Lutomirski <luto@kernel.org> Cc: Mathieu Desnoyers <mathieu.desnoyers@efficios.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Linus Torvalds <torvalds@linux-foundation.org> Link: https://lore.kernel.org/r/20241204210316.612ee573@fangorn Closes: https://lore.kernel.org/oe-lkp/202411282207.6bd28eae-lkp@intel.com/ Signed-off-by:
Sasha Levin <sashal@kernel.org>
Showing
- arch/x86/include/asm/mmu.h 2 additions, 0 deletionsarch/x86/include/asm/mmu.h
- arch/x86/include/asm/mmu_context.h 1 addition, 0 deletionsarch/x86/include/asm/mmu_context.h
- arch/x86/include/asm/tlbflush.h 1 addition, 0 deletionsarch/x86/include/asm/tlbflush.h
- arch/x86/mm/tlb.c 32 additions, 3 deletionsarch/x86/mm/tlb.c
Loading
Please register or sign in to comment