【ARM】SMMU系统虚拟化(3)_ VMSAv8-64 address translation stages

讲解颗粒度granule size如何影响地址转换的过程:

对于每个颗粒度来说:

  • 输入的地址范围如何影响起始的lookup levels。
  • 对于stage2 转换来说,给链接的转换页表造成的可能的影响。
  • TTBR 地址和indexing对于起始的lookup

1.以4KB的translation granule size为例

由上面的例子我们知道,当超过39的时候,initial level会从level0 开始,但是level0不支持block 的分配方式,只有level1和level2支持block,所以只有table。

由这个例子可以推测出如果系统的地址空间是44bit,使用4KB的translation granule的时候,那么TTBR[47:44]必须是0,TTBR[43:12]持有translation table base address。

Level0 阶段地址的转换方式如下:

如果initial level是level1的时候转换的方式如下:

那整体的flow是什么样子的呢?

initial level0 开始经历4次转换

initial level1 开始经历3次转换

每次转换之后会得到一个table descriptor,然后再拿到下一级进行转换。

那这些descriptor的不同位都是代表什么意思呢?

由上可以知道table中不同的descriptor需要如何配置,根据memory属性,安全属性,执行属性等等配置页表需求。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值