]> git.baikalelectronics.ru Git - kernel.git/commit
Merge branch 'tlb-fixes'
authorLinus Torvalds <torvalds@linux-foundation.org>
Thu, 23 Aug 2018 21:55:01 +0000 (14:55 -0700)
committerLinus Torvalds <torvalds@linux-foundation.org>
Thu, 23 Aug 2018 21:55:01 +0000 (14:55 -0700)
commit84aa6d36949566fd0b2ce5725318741cd4cf3b05
tree2c0ca7652ac5398c05f389bdd7d5b5377d43fee7
parent70b414475a43b3a67db36e050358ad1fb0e707b3
parent6ab3cf3bf110074b5058363b487d181988e08572
Merge branch 'tlb-fixes'

Merge fixes for missing TLB shootdowns.

This fixes a couple of cases that involved us possibly freeing page
table structures before the required TLB shootdown had been done.

There are a few cleanup patches to make the code easier to follow, and
to avoid some of the more problematic cases entirely when not necessary.

To make this easier for backports, it undoes the recent lazy TLB
patches, because the cleanups and fixes are more important, and Rik is
ok with re-doing them later when things have calmed down.

The missing TLB flush was only delayed, and the wrong ordering only
happened under memory pressure (and in theory under a couple of other
fairly theoretical situations), so this may have been all very unlikely
to have hit people in practice.

But getting the TLB shootdown wrong is _so_ hard to debug and see that I
consider this a crticial fix.

Many thanks to Jann Horn for having debugged this.

* tlb-fixes:
  x86/mm: Only use tlb_remove_table() for paravirt
  mm: mmu_notifier fix for tlb_end_vma
  mm/tlb, x86/mm: Support invalidating TLB caches for RCU_TABLE_FREE
  mm/tlb: Remove tlb_remove_table() non-concurrent condition
  mm: move tlb_table_flush to tlb_flush_mmu_free
  x86/mm/tlb: Revert the recent lazy TLB patches
arch/Kconfig
arch/x86/xen/mmu_pv.c