KVM基本原理及架构四-内存虚拟化

KVM通过影子页表和EPT技术实现内存虚拟化,允许客户机使用独立的地址空间。影子页表是软件实现,通过哈希表维护GVA到HPA的映射,但存在实现复杂和内存开销大的问题。EPT(Intel的Extended Page Table)是硬件支持的地址转换,通过硬件自动完成GVA到HPA的转换,提高性能,减少了VM-Exit的发生。
摘要由CSDN通过智能技术生成
4 内存虚拟化

4.1 客户机物理地址空间

在物理机上,虚拟地址通过Guest页表即可转换为物理地址。但是在虚拟化环境中,由于VMMVM都需要独立的地址空间,则产生了冲突。

为实现内存虚拟化,让客户机使用一个隔离的、从零开始且具有连续的内存空间,KVM 引入一层新的地址空间,即客户机物理地址空间 (Guest Physical Address, GPA),该地址空间并不是真正的物理地址空间,它只是宿主机(Host主机)虚拟地址空间在Guest地址空间的一个映射。对Guest来说,客户机物理地址空间都是从零开始的连续地址空间,但对于宿主机来说,客户机的物理地址空间并不一定是连续的,客户机物理地址空间有可能映射在若干个不连续的宿主机地址区间,如下图所示:



    由于物理
MMU只能通过Host机的物理地址(Host Physical Address, HPA)进行寻址,所以实现内存虚拟化,关键是需要将Guest机的虚拟地址(Guest Virtual Address, GVA)转换为HPA。传统的实现方案中,这个过程需要经历:GVAàGPAàHVAàHPA的转换过程,需要对地址进行多次转换,而且需要KVM的介入,效率非常低。为提供GVAHPA的地址转换效率,KVM提供了两种地址转换方式:

1、    影子页表(Shadow Page Table),是纯软件的实现方式

2、    基于硬件特性的地址转换。如基于Intel EPT(Extended Page Table,扩展页表),或AMD NPT(Nested Page Table,嵌套页表)

4.2 影子页表

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值