免费注册 查看新帖 |

Chinaunix

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

[CPU及多核] TLB lazy模式的一个问题 [复制链接]

论坛徽章:
0
发表于 2017-01-22 16:44 |显示全部楼层
blog.chinaunix.net/uid-14528823-id-4808877.html

看的这篇文章,看完有个问题,我一个普通线程,切换成内核线程,就进了lazy TLB模式,

那么,如果这时我内核空间页表有变化,比如我另外一个cpu释放掉了vmalloc获取的一片内存,那么内核页表对应项的修改并没有反映到当前内核线程,如果访问了,不就血崩了?

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-08-17 06:20:00程序设计版块每日发帖之星
日期:2016-07-16 06:20:00程序设计版块每日发帖之星
日期:2016-07-18 06:20:00每日论坛发贴之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16赛季CBA联赛之江苏
日期:2017-06-26 11:05:5615-16赛季CBA联赛之上海
日期:2017-07-21 18:12:5015-16赛季CBA联赛之青岛
日期:2017-09-04 17:32:0515-16赛季CBA联赛之吉林
日期:2018-03-26 10:02:16程序设计版块每日发帖之星
日期:2016-07-15 06:20:0015-16赛季CBA联赛之江苏
日期:2016-07-07 18:37:512015亚冠之萨济拖拉机
日期:2015-08-17 12:21:08
发表于 2017-01-22 19:41 |显示全部楼层
个人理解是vfree的过程中修改了mm0的页表,特别是最后一级。
最后一级页表在多个内核线程之间是共享的关系,而不是复制的关系。<=========不确定是否正确……
所以在内核线程里访问已释放的vmalloc地址导致pagefault。

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-08-17 06:20:00程序设计版块每日发帖之星
日期:2016-07-16 06:20:00程序设计版块每日发帖之星
日期:2016-07-18 06:20:00每日论坛发贴之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16赛季CBA联赛之江苏
日期:2017-06-26 11:05:5615-16赛季CBA联赛之上海
日期:2017-07-21 18:12:5015-16赛季CBA联赛之青岛
日期:2017-09-04 17:32:0515-16赛季CBA联赛之吉林
日期:2018-03-26 10:02:16程序设计版块每日发帖之星
日期:2016-07-15 06:20:0015-16赛季CBA联赛之江苏
日期:2016-07-07 18:37:512015亚冠之萨济拖拉机
日期:2015-08-17 12:21:08
发表于 2017-01-22 20:08 |显示全部楼层

论坛徽章:
9
程序设计版块每日发帖之星
日期:2016-02-13 06:20:00数据库技术版块每日发帖之星
日期:2016-06-15 06:20:00数据库技术版块每日发帖之星
日期:2016-06-16 06:20:00数据库技术版块每日发帖之星
日期:2016-06-18 06:20:00程序设计版块每日发帖之星
日期:2016-06-27 06:20:00程序设计版块每日发帖之星
日期:2016-07-09 06:20:00IT运维版块每日发帖之星
日期:2016-07-15 06:20:00IT运维版块每日发帖之星
日期:2016-07-27 06:20:00程序设计版块每日发帖之星
日期:2016-08-18 06:20:00
发表于 2017-02-06 17:13 |显示全部楼层
本帖最后由 mordorwww 于 2017-02-06 17:15 编辑

vmalloc_pagefault来同步吧 ,这个既同步页表,也会flush TLB吧
大佬们指正

论坛徽章:
0
发表于 2021-05-04 09:11 |显示全部楼层
vmalloc的页映射修改到init_mm->pdt, 当前进程内核缺页异常时,页表和init_mm->pdt同步,同步到pmd一级。相关函数,vmalloc,do_page_fault,vmalloc_fault

论坛徽章:
0
发表于 2021-05-04 09:13 |显示全部楼层
这是内核页表的同步,至于用户空间页表(具有相同vma的线程),才用到lazy tlb技术。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP