页面回收请教一下。。
Hello all.static unsigned long shrink_page_list(struct list_head *page_list, struct scan_control *sc, enum pageout_io sync_writeback)
{
...
...
if (!mapping || !__remove_mapping(mapping, page))
goto keep_locked;
...
...
}
static int __remove_mapping(struct address_space *mapping, struct page *page)
{
BUG_ON(!PageLocked(page));
BUG_ON(mapping != page_mapping(page));
spin_lock_irq(&mapping->tree_lock);
if (!page_freeze_refs(page, 2))
goto cannot_free;
/* note: atomic_cmpxchg in page_freeze_refs provides the smp_rmb */
if (unlikely(PageDirty(page))) {
page_unfreeze_refs(page, 2);
goto cannot_free;
}
if (PageSwapCache(page)) {
swp_entry_t swap = { .val = page_private(page) };
__delete_from_swap_cache(page);
spin_unlock_irq(&mapping->tree_lock);
mem_cgroup_uncharge_swapcache(page, swap);
swap_free(swap);
} else {
__remove_from_page_cache(page);
spin_unlock_irq(&mapping->tree_lock);
mem_cgroup_uncharge_cache_page(page);
}
return 1;
cannot_free:
spin_unlock_irq(&mapping->tree_lock);
return 0;
}
请教一下,这里为什么是判断_count的计数值是不是为2?
一个要回收的page它也许是在page cahe或者是swap cache。应该也有可能page cache和swap cache都指向吧。
那么_count=2的,是被谁指向的?
对于anon page和file page都是怎样的情况呢。。
谢谢。 本帖最后由 镇水铁牛 于 2016-03-18 22:52 编辑
在pagecache逻辑中,刚申请的page的会设置page的count为1,当准备写访问前,会置为2,写的过程中,该值增加为3,当写结束后,其值变为2,但此时page是dirty的。
我个人理解当count为2时,该page就一定是dirty的,前提是获得page lock成功。
页:
[1]