免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 658 | 回复: 3

[内核入门] 盘上页面计数什么时候恢复到0? [复制链接]

论坛徽章:
13
15-16赛季CBA联赛之八一
日期:2016-07-08 21:00:1415-16赛季CBA联赛之同曦
日期:2017-02-15 14:26:1515-16赛季CBA联赛之佛山
日期:2017-02-20 14:19:2615-16赛季CBA联赛之青岛
日期:2017-05-07 16:49:1115-16赛季CBA联赛之广夏
日期:2017-07-30 09:13:1215-16赛季CBA联赛之广东
日期:2018-07-05 22:34:3615-16赛季CBA联赛之江苏
日期:2018-09-03 12:10:2115-16赛季CBA联赛之上海
日期:2018-09-25 03:49:2215-16赛季CBA联赛之广东
日期:2018-09-25 04:09:12
发表于 2016-10-18 11:52 |显示全部楼层
    盘上页面与1个虚拟页面建立映射时,使用计数为2,这样当该虚拟页面恢复与物理页面的映射,即发生换入后,这个盘上页面使用计数为1,仍然可以为该虚拟页面维持着,从而保证了换入的物理页面,到下次再换出的期间内,如果没有写入操作,就被标记为“干净”,换出就不需要再往磁盘写。
    disk-page-count.png

    也就是说不可能靠换入时执行的swap_free()将盘上页面的计数减到0的,那应该是在释放虚拟页面的时候才能释放这个盘上页面吧?
    do_munmap()
      |--> zap_page_range()
               |--> zap_pmd_range()
                        |--> zap_pte_range()
                                 |--> free_pte()
                                          |--> swap_free()

论坛徽章:
13
15-16赛季CBA联赛之八一
日期:2016-07-08 21:00:1415-16赛季CBA联赛之同曦
日期:2017-02-15 14:26:1515-16赛季CBA联赛之佛山
日期:2017-02-20 14:19:2615-16赛季CBA联赛之青岛
日期:2017-05-07 16:49:1115-16赛季CBA联赛之广夏
日期:2017-07-30 09:13:1215-16赛季CBA联赛之广东
日期:2018-07-05 22:34:3615-16赛季CBA联赛之江苏
日期:2018-09-03 12:10:2115-16赛季CBA联赛之上海
日期:2018-09-25 03:49:2215-16赛季CBA联赛之广东
日期:2018-09-25 04:09:12
发表于 2016-10-18 12:43 |显示全部楼层
回复 1# _nosay

free_pte.png

按照问题中的例子,虚拟页面恢复了与物理页面的映射,pte_present()就成立,不会调用到swap_free(),那么盘上页面的1是从哪减掉的呢?

论坛徽章:
13
15-16赛季CBA联赛之八一
日期:2016-07-08 21:00:1415-16赛季CBA联赛之同曦
日期:2017-02-15 14:26:1515-16赛季CBA联赛之佛山
日期:2017-02-20 14:19:2615-16赛季CBA联赛之青岛
日期:2017-05-07 16:49:1115-16赛季CBA联赛之广夏
日期:2017-07-30 09:13:1215-16赛季CBA联赛之广东
日期:2018-07-05 22:34:3615-16赛季CBA联赛之江苏
日期:2018-09-03 12:10:2115-16赛季CBA联赛之上海
日期:2018-09-25 03:49:2215-16赛季CBA联赛之广东
日期:2018-09-25 04:09:12
发表于 2016-10-18 13:33 |显示全部楼层
回复 1# _nosay

换个问题:
物理页面刚换出的时候,释放虚拟页面,就会调用到swap_free(),但仅会调用一次呀,那么说盘上页面的使用计数还是剩1次没减。到底是哪里理解错了?
do_munmap()
  |--> zap_page_range()
           |--> zap_pmd_range()
                    |--> zap_pte_range()
                             |--> free_pte()
                                      |--> swap_free()

论坛徽章:
13
15-16赛季CBA联赛之八一
日期:2016-07-08 21:00:1415-16赛季CBA联赛之同曦
日期:2017-02-15 14:26:1515-16赛季CBA联赛之佛山
日期:2017-02-20 14:19:2615-16赛季CBA联赛之青岛
日期:2017-05-07 16:49:1115-16赛季CBA联赛之广夏
日期:2017-07-30 09:13:1215-16赛季CBA联赛之广东
日期:2018-07-05 22:34:3615-16赛季CBA联赛之江苏
日期:2018-09-03 12:10:2115-16赛季CBA联赛之上海
日期:2018-09-25 03:49:2215-16赛季CBA联赛之广东
日期:2018-09-25 04:09:12
发表于 2016-10-20 10:10 |显示全部楼层
本帖最后由 _nosay 于 2016-10-20 10:11 编辑

回复 3# _nosay

从不活跃链表回收页面时,会减1次,再加上释放虚拟页面时减1次,就是2次。

mm/vmscan.c, 381~463: reclaim_page()
reclaim_page(2).png


您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

DTCC2020中国数据库技术大会

【架构革新 高效可控】2020年12月21日-23日第十一届中国数据库技术大会将在北京隆重召开。

大会设置2大主会场,20+技术专场,将邀请超百位行业专家,重点围绕数据架构、AI与大数据、传统企业数据库实践和国产开源数据库等内容展开分享和探讨,为广大数据领域从业人士提供一场年度盛会和交流平台。

http://dtcc.it168.com


大会官网>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP