徒手hypervisor(三)
来源:互联网 发布:在线画板软件 编辑:程序博客网 时间:2024/05/02 00:14
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手册)
- 徒手hypervisor(三)
- 徒手hypervisor(一)
- 徒手hypervisor(二)
- 徒手hypervisor
- hypervisor
- hypervisor
- hypervisor
- hypervisor
- 徒手撸个http服务器(三)------epoll 实现
- 嵌入式实时Hypervisor:XtratuM (2)
- 嵌入式实时Hypervisor:XtratuM (3)
- 嵌入式实时Hypervisor:XtratuM (4)
- 嵌入式实时Hypervisor:XtratuM (5)
- 嵌入式实时Hypervisor:XtratuM (6)
- 嵌入式实时Hypervisor:XtratuM (7)
- 嵌入式实时Hypervisor:XtratuM (8)
- 嵌入式实时Hypervisor:XtratuM (9)
- 嵌入式实时Hypervisor:XtratuM (10)
- FFMPEG解码流程理解搜集整理及tutorial5的理解,主要是音视频同步
- Android API Level、sdk版本与发行日期 对照表
- java中父类和子类初始化顺序
- 【嵌入式】STM32的库函数使用
- 欢迎使用CSDN-markdown编辑器
- 徒手hypervisor(三)
- UML类图的几种关系和序列图总结
- 工作线程不要对界面操作
- JAVA使用FTPClient类获取linux上的文件最后修改日期少了8小时
- 采用邻接矩阵实现有向网的存储,建立有向网,并实现单源最短路径
- C#在XP系统下调用C++ dll时报找不到指定模块
- DataGridView左键选中行改变行背景色,右键选中行不改变背景色。左键选中行的背景色不变
- phpstorm 2016.2 学习笔记
- LeetCode No.97 Interleaving String