免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1071 | 回复: 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
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2016-10-18 11:52 |只看该作者 |倒序浏览
    盘上页面与1个虚拟页面建立映射时,使用计数为2,这样当该虚拟页面恢复与物理页面的映射,即发生换入后,这个盘上页面使用计数为1,仍然可以为该虚拟页面维持着,从而保证了换入的物理页面,到下次再换出的期间内,如果没有写入操作,就被标记为“干净”,换出就不需要再往磁盘写。
   

    也就是说不可能靠换入时执行的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
2 [报告]
发表于 2016-10-18 12:43 |只看该作者
回复 1# _nosay



按照问题中的例子,虚拟页面恢复了与物理页面的映射,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
3 [报告]
发表于 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
4 [报告]
发表于 2016-10-20 10:10 |只看该作者
本帖最后由 _nosay 于 2016-10-20 10:11 编辑

回复 3# _nosay

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

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



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

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP