Description
In the Linux kernel, the following vulnerability has been resolved: mm: fix deferred split queue races during migration migrate_folio_move() records the deferred split queue state from src and replays it on dst. Replaying it after remove_migration_ptes(src, dst, 0) makes dst visible before it is requeued, so a concurrent rmap-removal path can mark dst partially mapped and trip the WARN in deferred_split_folio(). Move the requeue before remove_migration_ptes() so dst is back on the deferred split queue before it becomes visible again. Because migration still holds dst locked at that point, teach deferred_split_scan() to requeue a folio when folio_trylock() fails. Otherwise a fully mapped underused folio can be dequeued by the shrinker and silently lost from split_queue. [ziy@nvidia.com: move the comment]
Product status
1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 (git) before cbf75cf212ee6e499abc1757fb4b5ae6d70ed0aa
1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 (git) before 3bac01168982ec3e3bf87efdc1807c7933590a85
Any version before 7.0.4
7.0.4 (semver)
7.1-rc1 (original_commit_for_fix)
References
git.kernel.org/...c/cbf75cf212ee6e499abc1757fb4b5ae6d70ed0aa
git.kernel.org/...c/3bac01168982ec3e3bf87efdc1807c7933590a85