From: Peifeng Li <lipeifeng@xxxxxxxx> Commit 6d4675e60135 ("mm: don't be stuck to rmap lock on reclaim path") prevents the reclaim path from becoming stuck on the rmap lock. However, it reinserts those folios at the head of the LRU during shrink_folio_list, even if those folios are very cold. This can have a detrimental effect on performance by increasing refaults and the likelihood of OOM (Out of Memory) killing. This patchset introduces a new kthread:kshrinkd thread to asynchronously reclaim contended folios rather than promoting them, thereby preventing excessive violations of LRU rules. We observed a noticeable decrease in refaults and OOM killing as a result. -v2: * rewrite the commit messages; * rebase on top of mm-unstable -v1: https://lore.kernel.org/linux-mm/20240219141703.3851-1-lipeifeng@xxxxxxxx/ Peifeng Li (2): mm/rmap: provide folio_referenced with the options to try_lock or lock mm: vmscan: reclaim contended folios asynchronously instead of promoting them include/linux/mmzone.h | 6 + include/linux/rmap.h | 5 +- include/linux/swap.h | 3 + include/linux/vm_event_item.h | 2 + mm/memory_hotplug.c | 2 + mm/rmap.c | 5 +- mm/vmscan.c | 205 +++++++++++++++++++++++++++++++++- mm/vmstat.c | 2 + 8 files changed, 221 insertions(+), 9 deletions(-) -- 2.34.1