徒手hypervisor(三)

Stage-2

从系统安全的角度来看,hypervisor的主要功能是内存管理和中断拦截,通过这两种方式,hypervisor可以很好地监控kernel的运行。先看看怎么把一个的简单的内存管理模块加入到hypervisor中。

通常情况下,PL0和PL1 在MMU打开的情况下,只会进行一层翻译Stage-1:VA->PA。但是在hypervisor可以令PL0和PL1开启第二层MMU的翻译Stage-2(EPT on x86),这时候地址翻译就先通过Stage-1:VA->IPA, 再由Stage-2:IPA->PA. Hypervisor可以通过设置HCR寄存器来控制Stage-2的开启或者关闭,Stage-2的这层翻译对于kernel或者user space来说是透明,它们认为IPA就是真正的“物理地址”,全然不知道还有第二层翻译的存在。我对Stage-2 translation的理解是它虚拟化技术最核心部分,hypervisor通过Stage-2来实现内存管理,VMs的隔离等。需要强调的一点是:Stage-2只对kernel和user space有效,它和hypervisor自己的memory space毫无关系。

和Stage-2相关的寄存器主要有三个:HCR, VTTBR, VTCR. VTCR决定Stage-2 page table的格式,VTTBR指向了Stage-2 page table的入口地址,HCR的最后一位决定了Stage-2 MMU的开关。打开Stage-2这一层翻译的步骤是:分配内存填写好mapping,在HYP mode配置好这三个寄存器,flush TLB。(具体的code可以参考KVM/ARM中的interrupt.S,寄存器的介绍可以参考ARM手册)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值