Chinaunix

标题: TLB lazy模式的一个问题 [打印本页]

作者: 今天不吃面    时间: 2017-01-22 16:44
标题: TLB lazy模式的一个问题
blog.chinaunix.net/uid-14528823-id-4808877.html

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

那么,如果这时我内核空间页表有变化,比如我另外一个cpu释放掉了vmalloc获取的一片内存,那么内核页表对应项的修改并没有反映到当前内核线程,如果访问了,不就血崩了?
作者: nswcfd    时间: 2017-01-22 19:41
个人理解是vfree的过程中修改了mm0的页表,特别是最后一级。
最后一级页表在多个内核线程之间是共享的关系,而不是复制的关系。<=========不确定是否正确……
所以在内核线程里访问已释放的vmalloc地址导致pagefault。
作者: nswcfd    时间: 2017-01-22 20:08
http://lxr.free-electrons.com/source/arch/x86/mm/fault.c#L323
http://lxr.free-electrons.com/source/arch/x86/mm/fault.c#L251
好像只处理到pmd level,没有到pte level。

作者: mordorwww    时间: 2017-02-06 17:13
本帖最后由 mordorwww 于 2017-02-06 17:15 编辑

vmalloc_pagefault来同步吧 ,这个既同步页表,也会flush TLB吧
大佬们指正
作者: aweii    时间: 2021-05-04 09:11
vmalloc的页映射修改到init_mm->pdt, 当前进程内核缺页异常时,页表和init_mm->pdt同步,同步到pmd一级。相关函数,vmalloc,do_page_fault,vmalloc_fault
作者: aweii    时间: 2021-05-04 09:13
这是内核页表的同步,至于用户空间页表(具有相同vma的线程),才用到lazy tlb技术。




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2