免费注册 查看新帖 |

Chinaunix

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

[内存管理] try_to_unmap_one问题 [复制链接]

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-05-24 15:20 |只看该作者 |倒序浏览


try_to_unmap_one
    |
    |---------------->address = vma_address(page, vma);
    |
    |---------------->pte = page_check_address(page,mm,address,&ptl);
    |

page_check_address部分代码:

if(pte_present(*pte) && page_to_pfn(page) == pte_pfn(*pte)){
    *ptlp = ptl;
    return pte;
}

不知到为什么要检查 pte与page对应的pfn是否相等,那么什么情况下不相等呢?

论坛徽章:
0
2 [报告]
发表于 2012-05-24 16:21 |只看该作者
你看的太细了,友情顶下。

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
3 [报告]
发表于 2012-05-24 16:24 |只看该作者
回复 2# blake326


之前有个帖子,http://bbs.chinaunix.net/thread-1929162-1-1.html,看2楼回复:

try_to_unmap_anon的主要思路是根据page -> anon_vma -> vma_area_struct链, 查找到可能影射了page的vma, 根据page -> index,查找到如果vma影射了page,那么到底是哪个pte影射了page.


以上都说的是可能性,而不是page必然影射在计算出来的pte中.

最后的精确判断,还要依靠根据page和pte计算出来的pfn. 相等则解除影射; 不等则证明已经经过COW.



但我还是不明白什么时候不相等!





   

论坛徽章:
4
戌狗
日期:2013-08-15 18:22:43技术图书徽章
日期:2013-08-21 13:48:45巨蟹座
日期:2013-09-26 17:06:39处女座
日期:2013-12-25 11:26:10
4 [报告]
发表于 2012-05-24 16:25 |只看该作者
COW后,虽然pte映射了一个新分配的页,但是vma仍保持还在address space的prio树,同时新加入一个anon_vma链。
此时通过page->address space->prio树->vma->pte->page检索,两端的page是不一样的。

论坛徽章:
4
戌狗
日期:2013-08-15 18:22:43技术图书徽章
日期:2013-08-21 13:48:45巨蟹座
日期:2013-09-26 17:06:39处女座
日期:2013-12-25 11:26:10
5 [报告]
发表于 2012-05-24 16:28 |只看该作者
embeddedlwp 发表于 2012-05-24 16:24
回复 2# blake326


靠,这不是我以前回的帖子么?

论坛徽章:
0
6 [报告]
发表于 2012-05-24 17:30 |只看该作者
本帖最后由 blake326 于 2012-05-24 17:31 编辑

塑料袋 果然牛B啊。。。

就是说cow的后的page,就会存在这个不相等的情况。

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
7 [报告]
发表于 2012-05-26 09:22 |只看该作者
回复 4# 塑料袋

COW后,虽然pte映射了一个新分配的页,但是vma仍保持还在address space的prio树,同时新加入一个anon_vma链。
此时通过page->address space->prio树->vma->pte->page检索,两端的page是不一样的。

=========================================================

prio tree只用于file mapping吧,anon mapping不用这个吧?

   

论坛徽章:
4
戌狗
日期:2013-08-15 18:22:43技术图书徽章
日期:2013-08-21 13:48:45巨蟹座
日期:2013-09-26 17:06:39处女座
日期:2013-12-25 11:26:10
8 [报告]
发表于 2012-05-26 12:28 |只看该作者
embeddedlwp 发表于 2012-05-26 09:22
prio tree只用于file mapping吧,anon mapping不用这个吧?
...


truncate一个文件时,需要把所有映射了这段被truncate区间的vma都删除掉。

私有映射也是如此,也需要查找并删除之。所以私有映射的vma与其他两个数据结构发生了联系,一是address space,一是anon vma。

而且进一步说,私有vma的各page中,很有可能是一部分经过了COW,是匿名页;一部分还没有COW,是有名页。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP