免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 4950 | 回复: 12
打印 上一主题 下一主题

[内存管理] PG_swapbacked 是做什么用的? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-02-04 10:22 |只看该作者 |倒序浏览
本帖最后由 a_kernel_newbie 于 2013-02-04 10:37 编辑

PG_swapbacked 是用于设置struct page中flags的一个标志位,表示物理页面的用途和状态。该位在内核里面的注释是:page is backed by RAM/swap

作为一个Kernel 菜鸟,不太明白其中的意思。
查找了一下啊kernel code中的SetPageSwapBacked()函数和ClearPageSwapBacked()函数,仍然没有弄明白。

请大牛帮忙解释一下吧,万分感谢!

论坛徽章:
0
2 [报告]
发表于 2013-02-04 14:23 |只看该作者
  1.   6 /**
  2.   7  * page_is_file_cache - should the page be on a file LRU or anon LRU?
  3.   8  * @page: the page to test
  4.   9  *
  5. 10  * Returns 1 if @page is page cache page backed by a regular filesystem,
  6. 11  * or 0 if @page is anonymous, tmpfs or otherwise ram or swap backed.
  7. 12  * Used by functions that manipulate the LRU lists, to sort a page
  8. 13  * onto the right LRU list.
  9. 14  *
  10. 15  * We would like to get this info without a page flag, but the state
  11. 16  * needs to survive until the page is last deleted from the LRU, which
  12. 17  * could be as far down as __page_cache_release.
  13. 18  */
  14. 19 static inline int page_is_file_cache(struct page *page)
  15. 20 {
  16. 21         return !PageSwapBacked(page);
  17. 22 }
复制代码
从这个函数以及注释上看,PG_SwapBacked标识的页是:page is anonymous, tmpfs or otherwise ram or swap backed.

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
3 [报告]
发表于 2013-02-04 16:40 |只看该作者
回复 1# a_kernel_newbie
PG_swapbacked is the bit for marking if page is backed by swap.

   

论坛徽章:
0
4 [报告]
发表于 2013-02-04 16:57 |只看该作者
回复 3# 瀚海书香


    感谢大牛的回复。不过,“只有被swap backed的页才设置PG_swapbacked标志” 并不完整呀,因为:
在缺页处理流程中,对于匿名页,刚被分配,便设置了PG_swapbacked位(这个时候还没有完成backed):

__do_fault->
  page_add_new_anon_rmap:
  1. void page_add_new_anon_rmap(struct page *page,
  2.         struct vm_area_struct *vma, unsigned long address)
  3. {
  4.         VM_BUG_ON(address < vma->vm_start || address >= vma->vm_end);
  5.         SetPageSwapBacked(page);
  6.         atomic_set(&page->_mapcount, 0); /* increment count (starts at -1) */
  7.         if (!PageTransHuge(page))
  8.                 __inc_zone_page_state(page, NR_ANON_PAGES);
  9.         else
  10.                 __inc_zone_page_state(page, NR_ANON_TRANSPARENT_HUGEPAGES);
  11.         __page_set_anon_rmap(page, vma, address, 1);
  12.         if (page_evictable(page, vma))
  13.                 lru_cache_add_lru(page, LRU_ACTIVE_ANON);
  14.         else
  15.                 add_page_to_unevictable_list(page);
  16. }
复制代码

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
5 [报告]
发表于 2013-02-04 17:05 |只看该作者
a_kernel_newbie 发表于 2013-02-04 16:57
回复 3# 瀚海书香


page_add_new_anon, 这就是交换设备地址空间

论坛徽章:
0
6 [报告]
发表于 2013-02-04 17:24 |只看该作者
回复 5# zylthinking


    恩.我的意思是,还没有被backed,就已经设置了PG_SwapBacked 位。

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
7 [报告]
发表于 2013-02-04 17:44 |只看该作者
a_kernel_newbie 发表于 2013-02-04 17:24
回复 5# zylthinking


这个标志位的意思是 page 属于交换空间, 如果已经被交换了, page 另作他用, 和交换空间一点关系也没有了, 你要他在这个时候才设置这个位?

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
8 [报告]
发表于 2013-02-04 17:46 |只看该作者
回复 6# a_kernel_newbie
Maybe you are confused by PG_swapcache and PG_swapbacked

   

论坛徽章:
0
9 [报告]
发表于 2013-02-04 17:48 |只看该作者
回复 8# 瀚海书香

回复 7# zylthinking

是啊,按照zylthinking大牛的意思,我真的将PG_SwapCache和PG_SwapBacked搞混了,能否明确的对比一下两者的不同?非常感谢!
   

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
10 [报告]
发表于 2013-02-04 18:06 |只看该作者
a_kernel_newbie 发表于 2013-02-04 17:48
回复 8# 瀚海书香

回复 7# zylthinking


我才混了呢, 我看成 PG_SwapCache 了, 刚才看了一下, 貌似 PG_SwapBacked 标志位只是用在 procfs 中, 似乎是显示哪些页面是可交换到 swap 设备的, 那么当然是只要加入了 anon 自然要设置这个位, 否则 procfs 显示什么
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP