设为首页 收藏本站
查看: 1014|回复: 0

[经验分享] qemu-kvm虚拟化 vpid 代码分析

[复制链接]

尚未签到

发表于 2015-12-24 14:15:19 | 显示全部楼层 |阅读模式
qemu-kvm虚拟化 vpid 代码分析

1.页表实现线性地址到物理地址转换。

2.ept (Extended Page Tables)实现客户机物理地址到宿主机物理地址装换。

3.tlb (Translation lookaside buffer )旁路装换缓冲区,改进虚拟地址(线性地址)到物理地址转换速度的缓存。
操作系统中我们知道每个进程都有自己页表,进程切换重新设置cr3寄存器,同时刷新tlb。但是进程切换并不一定要刷新tlb,相同页表的进程切换和内核线程与普通进程切换,其实就不需要。
对于虚拟化来说,Vm-Entry 和Vm-Exit时,会强制cpu刷新tlb,全部内容失效, 不管是VMM页表, 还是各个虚拟机的ept页表的tlb缓存。

4.vpid 就是避免tlb刷新整体失效,区分是vmm ,各个vm页表,这样提高虚拟机切换效率。要使用vpid很简单,首先判断cpu是否支持vpid(读取VMCS相应域),然后分配vcpu时同时分配vpid(设置VMCS相应域),剩下事情属于硬件事情了。
1).硬件是否支持
cat /proc/cpuinfo | grep vpid
cat /proc/cpuinfo | grep ept
2).模块是否启用
cat /sys/module/kvm_intel/parameters/ept
cat /sys/module/kvm_intel/parameters/vpid

代码分析

判断cpu是否支持vpid
static inline int cpu_has_vmx_vpid(void)
{
        return vmcs_config.cpu_based_2nd_exec_ctrl &
                SECONDARY_EXEC_ENABLE_VPID;
}  

分配vpid
static void allocate_vpid(struct vcpu_vmx *vmx)
{
        int vpid;
        
        vmx->vpid = 0;
        if (!enable_vpid)
                return;
        spin_lock(&vmx_vpid_lock);
        vpid = find_first_zero_bit(vmx_vpid_bitmap, VMX_NR_VPIDS);
        if (vpid < VMX_NR_VPIDS) {
                vmx->vpid = vpid;
                __set_bit(vpid, vmx_vpid_bitmap);
        }
        spin_unlock(&vmx_vpid_lock);
}
释放vpid
static void free_vpid(struct vcpu_vmx *vmx)
{
        if (!enable_vpid)
                return;
        spin_lock(&vmx_vpid_lock);
        if (vmx->vpid != 0)
                __clear_bit(vmx->vpid, vmx_vpid_bitmap);
        spin_unlock(&vmx_vpid_lock);
}
刷新vpid
static inline void vpid_sync_vcpu_all(struct vcpu_vmx *vmx)
{
        if (vmx->vpid == 0)
                return;

        __invvpid(VMX_VPID_EXTENT_SINGLE_CONTEXT, vmx->vpid, 0);
}

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-155778-1-1.html 上篇帖子: qemu-kvm 内存虚拟化 下篇帖子: KVM虚拟机代码揭秘——中断虚拟化
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表