armv7A 架构的页表

当cpu访问cache时 会发送虚拟地址到TLB上 TLB是一个

TLB 是一块高速缓存,用于缓存页表转换的结果,从而
减少内存访问的时间。一个完整的页表翻译和查找的过程叫作页表查询(Translation table
walk),页表查询的过程由硬件自动完成,但是页表的维护需要软件来完成。页表查询是一
个相对耗时的过程,理想的状态下是TLB 里存有页表相关信息。当TLB Miss 时,才会去
查询页表,并且开始读入页表的内容。

1.armv7a的架构页表
armv7A 架构的页表_第1张图片
ARMv7-A 架构支持安全扩展(Security
Extensions),其中Cortex-A15 开始支持大物
理地址扩展( Large Physical Address
Extension,LPAE)和虚拟化扩展,使得MMU
的实现比以前的ARM 处理器要复杂得多。如图 所示
,如果使能了安全扩展,
ARMv7-A 处理器分成安全世界( Secure
World)和非安全世界(Non-secure World,也
称为Normal World)。
如果处理器使能了虚拟化扩展,那么处理
器会在非安全世界中增加一个Hyp 模式
在非安全世界中,运行特权被划分为PL0、
PL1 和PL2。
PL0 等级:这个特权等级运行在用户模式(User Mode),用于运行用户程序,它是没有系统特权的,比如没有权限访
问处理器内部的硬件资源。
PL1 等级:这个等级包括ARMv6 架构中的System 模式、SVC 模式、FIQ 模式、
IRQ 模式、Undef 模式,以及Abort 模式。Linux 内核运行在PL1 等级,应用程序
运行在PL0 等级。如果使能了安全扩展,那么安全模式里有一个Monitor 模式也是
运行在secure PL1 等级,管理安全世界和非安全世界的状态转换。
PL2 等级:如果使能了虚拟化扩展,那么超级管理程序(Hypervisor)就运行这个
等级,它运行在Hyp 模式,管理GuestOS 之间的切换。

GuestOS是虚拟机系统
比如uboot在一开始的arch初始化的时候 设置SVC模式的时候 就去检验了HYP模式
armv7A 架构的页表_第2张图片

你可能感兴趣的:(ARMBSP)