aboutsummaryrefslogtreecommitdiffstats
path: root/mm/rmap.c
diff options
context:
space:
mode:
Diffstat (limited to 'mm/rmap.c')
-rw-r--r--mm/rmap.c18
1 files changed, 16 insertions, 2 deletions
diff --git a/mm/rmap.c b/mm/rmap.c
index c6044761617e..cc140811af56 100644
--- a/mm/rmap.c
+++ b/mm/rmap.c
@@ -320,8 +320,22 @@ void __init anon_vma_init(void)
320} 320}
321 321
322/* 322/*
323 * Getting a lock on a stable anon_vma from a page off the LRU is 323 * Getting a lock on a stable anon_vma from a page off the LRU is tricky!
324 * tricky: page_lock_anon_vma rely on RCU to guard against the races. 324 *
325 * Since there is no serialization what so ever against page_remove_rmap()
326 * the best this function can do is return a locked anon_vma that might
327 * have been relevant to this page.
328 *
329 * The page might have been remapped to a different anon_vma or the anon_vma
330 * returned may already be freed (and even reused).
331 *
332 * All users of this function must be very careful when walking the anon_vma
333 * chain and verify that the page in question is indeed mapped in it
334 * [ something equivalent to page_mapped_in_vma() ].
335 *
336 * Since anon_vma's slab is DESTROY_BY_RCU and we know from page_remove_rmap()
337 * that the anon_vma pointer from page->mapping is valid if there is a
338 * mapcount, we can dereference the anon_vma after observing those.
325 */ 339 */
326struct anon_vma *page_lock_anon_vma(struct page *page) 340struct anon_vma *page_lock_anon_vma(struct page *page)
327{ 341{