2015年(3)
分类: LINUX
2015-08-02 13:00:11
第一种:就是页框到线性地址的一 一映射关系。这是在分页阶段,已经建立好的(这部分我可以深入讲一下,但是这部分内容不是很难酸痛,就不写了,以后在补上),就是为物理内存前896M的每个页框建立页表,并写进页表项。当进程请求这部分内存时,可以直接访问到这些页表,而不并现场创建页表。
第二种:永久内核映射。这种技术的映射可以阻塞进程,使进程去睡眠。(这种技术,将在下一篇博文详细介绍)
第三种:临时内核映射。其实道理差不多。任何一个页框与权限合成的页表可以写进预留的几个页表项中,但这种技术是不能阻塞的内核映射技术,因此可以用到中断处理函数和可延迟函数中。
第四种:非连续内存映射技术。用slab分配器分配线性区描述符,然后在非连续内存区找到一块空闲的线性区。然后把申请到的每一个零散的物理页框描述符和权限合成页表,并将此页表写到查找到的线性区对应的页表项中。(其实道理都是差不多的,只要领悟了永久内核映射思想,那么此种技术的思想也是一样的:查找物理页框,合成页表,写进页表项,返回线性地址)
后3种技术会重写页表,导致tlb中的页表无效。
大道至简,只要记住以下几句话那么面对各种映射技术就不会恐慌:
查找页框,合成页表,写进页表项,返回页表项的线性地址