MMU部件以及对内存权限的控制

MMU(内存管理单元)在CPU中负责虚拟地址到物理地址的转换,通过页表和内部缓存提高效率。操作系统构建并更新页表,CR3寄存器保存页目录地址。MMU还实现内存权限控制,12位低序位用于设定访问权限,权限错误会导致程序异常,如Linux下的段错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

MMU部件以及对内存权限的控制

通过页表完成虚拟地址和物理地址映射时,要经过多次转换,还要进行计算,如果由操作系统来完成这项工作,那将会成倍降低程序性能,得不偿失,所以这种方式是不现实的。

MMU

在CPU内部,有一个部件叫做MMU(Memory Management Unit,内存管理单元),由它来负责将虚拟地址映射为物理地址,如下图所示:

MMU运行原理图

在页映射模式下,CPU发出的是虚拟地址,也就是我们在程序中看到的地址,这个地址会先交给MMU,经过MMU的转换以后才能变成物理地址。

即便是这样,MMU也要访问好几次内存,性能依然堪忧,所以在MMU内部又增加了一个缓存,专门用来存储页目录和页表。MMU内部的缓存有限,当页表过大时,也只能将部分常用的页表加载到缓存,但这已经足够了,因为经过算法的巧妙设计,可以将缓存的命中率提高到90%,剩下的10%的情况无法命中,再去物理内存中加载页表。

有了硬件的支持,使用虚拟地址和使用物理地址相比,损失的性能已经很小,在可接受的范围内。

MMU只是通过页表来完成虚拟地址到物理地址的映射,但不会构建页表,构建页表是操作系统的任务。在程序加载到内存以及程序运行过程中,操作系统会不断更新程序对应的页表,并将页目录的物理地址保存

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JayerZhou

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值