armv7A 架构的页表

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

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

1.armv7a的架构页表
这里写图片描述
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模式
这里写图片描述

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值