讲解颗粒度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属性,安全属性,执行属性等等配置页表需求。
标签:SMMU,initial,转换,VMSAv8,granule,地址,64,table,translation From: https://blog.csdn.net/weixin_42664351/article/details/140921883