免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: cluter

do_page_fault函数处理流程 [复制链接]

论坛徽章:
0
发表于 2011-05-30 14:44 |显示全部楼层
"操作"是指执行内存映射吗? 如果是的话这个过程应该由mmu来进行吧? 不切换pgd怎么操作呢?

论坛徽章:
0
发表于 2011-05-30 15:58 |显示全部楼层
另外,楼主的问题好像不是很正确,似乎只是复制到pmd_t中的内容,而没有继续复制pte_t, 也就是说页表其实是和init_mm.pgd共用的。每复制一次有4M地址空间的map,不算少了吧?

论坛徽章:
0
发表于 2011-06-04 10:06 |显示全部楼层
回复 8# hauto


    页表不管在物理内存的什么地址,都应该由内核管理,所以我们认为这种是内核态。所以不会出现切换时造成“缺页”。
    就是 肯定COPY了pte_t。要不然进程进入“内核态”,访问不存在的地址,肯定出错。

论坛徽章:
0
发表于 2011-06-04 10:22 |显示全部楼层
回复 10# futex


    阁下认识的还是满深刻的,如果不拷贝的话,使用内核页表,当再次访问进程空间时,映射就会丢失,因为内核没有进程空间的地址“映射表”。而系统调用经常需要用到进程空间的数据。

论坛徽章:
0
发表于 2011-08-18 00:31 |显示全部楼层
只解释下关键代码的流程,附件里是关于缺页处理思路更清晰的一个整理,无代码的。

顺便提出几个问题:
...
cluter 发表于 2011-05-28 00:58



    hi, 这个附件失效了,能否再传一个,多谢了

论坛徽章:
0
发表于 2011-08-21 17:10 |显示全部楼层
对第一个问题,我的理解是:
内核维护的是一个“主内核页表”,所有的用户进程都是在这个主内核页表的基础上通过修改用户地址空间部分的页表来为自己所用,所以用户进程陷入内核时不需要切换页表,因为在内核态使用的页表其内容跟主内核页表是一样的(非缺页的情况)。
而内核在使用非连续物理内存时,就需要修改内核页表,此时内核修改的只是主内核页表,而不会修改其他用户进程的页表。此时当其他用户进程陷入内核后访问内核地址空间发生缺页中断时,就会判断如果不是其他的异常情况,就把主内核页表的内容拷贝到自己的页表中来(使自己页表的内核页表部分与主内核页表保持一致)。
这样,所有的用户进程在陷入内核态访问内核地址空间发生缺页时,都要这么做,因为他们自己页表的内核部分不是最新的,这就是为什么使用非连续物理内存的效率会比较低了。

论坛徽章:
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
发表于 2011-09-06 17:33 |显示全部楼层
回复 16# allen303allen


    allen303allen兄对内存管理的理解很透彻阿

论坛徽章:
0
发表于 2015-08-07 10:44 |显示全部楼层
附件访问不了, 无法打开
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP