Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
mm: remove folio from deferred split list before uncharging it
When freeing a large folio, we must remove it from the deferred split list before we uncharge it as each memcg has its own deferred split list (with associated lock) and removing a folio from the deferred split list while holding the wrong lock will corrupt that list and cause various related problems. Link: https://lore.kernel.org/linux-mm/[email protected]/ Link: https://lkml.kernel.org/r/[email protected] Fixes: f77171d (mm: allow non-hugetlb large folios to be batch processed) Fixes: 29f3843 (mm: free folios directly in move_folios_to_lru()) Fixes: bc2ff4c (mm: free folios in a batch in shrink_folio_list()) Signed-off-by: Matthew Wilcox (Oracle) <[email protected]> Debugged-by: Ryan Roberts <[email protected]> Tested-by: Ryan Roberts <[email protected]> Signed-off-by: Andrew Morton <[email protected]>
- Loading branch information