darling54454 发表于 2016-03-16 21:44

页面回收请教一下。。

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:51

本帖最后由 镇水铁牛 于 2016-03-18 22:52 编辑

在pagecache逻辑中,刚申请的page的会设置page的count为1,当准备写访问前,会置为2,写的过程中,该值增加为3,当写结束后,其值变为2,但此时page是dirty的。
我个人理解当count为2时,该page就一定是dirty的,前提是获得page lock成功。
页: [1]
查看完整版本: 页面回收请教一下。。