关于QEMU模拟器本身以及和CXL功能模拟相关内容的学习

前言:在写Paper的时候,发现直接引用QEMU官网关于QEMU的介绍实在是一个图省事儿的方法,但是并不可取。即使是一小段,也要去真正了解QEMU的基本原理,如何实现功能模拟,以及目前实现的与CXL相关的内容。
注:本文主要是一些概念性的内容,关于具体如何通过QEMU模拟CXL type 3 设备,已经有其他文章阐述,在此不赘述。

需要关注以下几个问题:

  1. QEMU是什么?QEMU有哪些工作模式?
  2. QEMU是如何都支持哪些CXL相关的功能?是如何支持这些功能的?
  3. 另外,很多文章在谈到QEMU的时候都会提到KVM,什么是KVM?KVM又是如何与QEMU交互协作的?

问题一

QEMU全称Quick EMUlator,是一种开源的虚拟机监视器和仿真器,主要是为了实现功能上的模拟,并不关注系统内部的实现和真实世界是否一致。(很多文章将其译为模拟器,实际上是不准确的)

QEMU主要有2种用法,一种是作为emulator使用,另外一种是作为virtualizer使用。当作为emulator使用时,有2种具体的操作模式分别是full-system和user-mode。full-system会模拟系统的全部组件,包括处理器和外围设备,可以直接在其上运行操作系统;user-mode只是在当前宿主机的环境下,运行与当前CPU不同指令集的进程,即在CPUA上的可执行程序同样可以在CPUB上执行,但是二者的OS需要相同,因为用户层可执行程序仅仅是对OS的调用,所以通过qemu可以将arm指令描述的对OS 的调用翻译为对x86 指令描述的对OS的调用调用即可。当作为virtualizer使用时,通过底层的硬件支持(Intel-VT,AMD-V等虚拟化技术)和Xen或者KVM等系统级虚拟化技术相结合,高效运行虚拟化系统。一个arch (x86)的cpu + 外设,虚拟为多台相同arch + 不同外设的虚拟机器(不同层级虚拟化技术的结合+QEMU)。

那么emulator和virtualizer的区别是什么呢?
emulator通常是为了模拟不同指令集、不同体系架构的 CPU,所以多数情况要对微指令进行解释执行,效率相对与虚拟化慢很多;virtualizer基本都是去虚拟出来另外一套相同指令集相同架构的硬件平台,因此在做好保护的前提下,很多时候可以直接利用 CPU 去执行目标指令。虽然还是模拟物理 CPU 而不借助于 Host OS 的功能,少了一层指令集转换,运行速度会提高不少。

问题二

QEMU主要支持CXL2.0及更高版本。并实现了许多CXL系统标准组件,CXL系统的控制和功能通过系统软件使用CXL2.0 spec中描述的方法发现。
QEMU实现的CXL系统标准组件主要包括:CXL主机桥(Host Bridge),CXL根端口(CXL RP),CXL交换机以及CXL type 3设备等。

问题三

QEMU本身可以模拟底层的全部硬件,包括CPU,内存和硬件设备等,Guest OS将QEMU模拟出的硬件当成真实硬件进行交互,实际上QEMU会将操作系统的指令转译给真正的硬件。所有的指令都要通过QEMU进行转译,因此性能较差。
QEMU模拟架构
上图来自:https://blog.csdn.net/whatday/article/details/78445932

KVM本身是Linux内核的模块,它能够让Linux主机成为一个Hypervisor,KVM的主要功能是打开并初始化Virtual Machine Extension(VMX)功能,提供相应的接口以支持虚拟机运行。KVM只模拟CPU和内存,Guest OS的CPU指令不需要经过QEMU转译,直接运行,大大提高速度。

QEMU-KVM的出现主要是为了同时满足虚拟化性能和与底层模拟硬件的交互。此方式将QEMU模拟CPU、内存的代码换成KVM,而网卡,显示器等IO设备仍由QEMU负责,从而实现真正意义上的服务器虚拟化。

virtio_blk, virtio_net,由于QEMU模拟其他的硬件同样会影响设备的性能,于是又产生了pass through半虚拟化设备,以提高性能。

参考文献

[1]QEMU入门指南
[2]QEMU的编译与使用
[3]Qemu: User mode emulation and Full system emulation
[4]QEMU支持3种运行模式的理解
[5]CXL-QEMU
[6]KVM-Qemu-Libvirt三者之间的关系
[7]QEMU和KVM的关系

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/807198.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

成功的环保企业:四大核心能力的深度剖析|中联环保圈

在追求可持续发展的道路上,环保企业不仅承载着社会责任,还要面对市场的考验。为了在激烈的竞争中脱颖而出,环保企业需要练就四大基本功:挣钱、要钱、省钱和花钱。这四大能力相互关联,共同构成了企业稳健运营的基石&…

Web 前端性能优化之七:数据存储与缓存技术

7、数据存储 在开发Web应用的过程中,会涉及一些数据的存储需求,常见的存储方式可能有: 保存登录态的Cookie; 使用浏览器本地存储进行保存的Local Storage和Session Storage; 客户端数据持久化存储方案涉及的Web SQ…

关于MCU产品开发参数存储的几种方案

关于MCU产品开发参数存储的几种方案 Chapter1 关于MCU产品开发参数存储的几种方案Chapter2 单片机参数处理[保存与读取]Chapter3 嵌入式设备参数存储技巧Chapter4 STM32硬件I2C的一点心得(AT24C32C和AT24C64C) Chapter1 关于MCU产品开发参数存储的几种方案 原文链接 在工作中…

【随笔】Git 高级篇 -- 纠缠不清的分支 rebase | cherry-pick(二十四)

💌 所属专栏:【Git】 😀 作  者:我是夜阑的狗🐶 🚀 个人简介:一个正在努力学技术的CV工程师,专注基础和实战分享 ,欢迎咨询! 💖 欢迎大…

位图布隆过滤器的原理及实现

目录 位图的概念: 位图的前置知识:位运算 位图的实现: 位图的基本参数和构造方法: 位图的插入: 位图的查找: 位图的删除: 布隆过滤器概念: 布隆过滤器的实现: …

TI-ST论文速读

Domain Adaptation for Medical Image Segmentation Using Transformation-Invariant Self-training 摘要 能够利用未标记数据的模型对于克服不同成像设备和配置中获取的数据集之间的巨大分布差距至关重要。在这方面,基于伪标记的自训练技术已被证明对半监督域适应…

微商商城源码小程序好用么?

商城APP作为电子商务行业的重要组成部分,已经成为了人们购物的主要方式之一。为了在竞争激烈的市场中脱颖而出,开发一款专业且思考深度的商城APP方案显得尤为关键。本文将从专业性和思考深度两个方面,探讨商城APP的开发方案。 一、专业性的重…

HTML+CSS+JS实现京东首页[web课设代码+模块说明+效果图]

系列文章目录 Web前端大作业htmlcss静态页面–掌****有限公司 Web前端大作业起点小说静态页面 Web前端大作业网易云页面 Web前端大作业商城页面 Web前端大作业游戏官网页面 Web前端大作业网上商城页面 HTMLCSS淘宝首页[web课设代码模块说明效果图] 文章目录 系列文章目录前言一…

Java Set基础篇

目录 前言一、常用Set1.1 Set1.1.1 特点 1.2 HashSet1.2.1 特点1.2.2 使用 1.3 TreeSet1.3.1 特点1.3.2 使用 1.4 LinkedHashSet1.4.1 特点1.4.2 使用 二、对比总结 目录 前言 一、常用Set 1.1 Set Set是一个继承自Collection的接口&#xff1a; public interface Set<…

如何在Rust中操作JSON

❝ 越努力&#xff0c;越幸运 ❞ 大家好&#xff0c;我是「柒八九」。一个「专注于前端开发技术/Rust及AI应用知识分享」的Coder。 前言 我们之前在Rust 赋能前端-开发一款属于你的前端脚手架中有过在Rust项目中如何操作JSON。 由于文章篇幅的原因&#xff0c;我们就没详细介绍…

基于SSM的教材管理系统

&#x1f449;文末查看项目功能视频演示获取源码sql脚本视频导入教程视频 1 、功能描述 基于SSM的教材管理系统2拥有两种角色 管理员&#xff1a;教师管理、分类管理、教材管理、入库和出库管理、教材申请管理等 教师&#xff1a;查看教材、申请教材 1.1 背景描述 SSM教材管…

服务器数据恢复—EqualLogic PS6100系列存储数据恢复案例

服务器数据恢复环境&#xff1a; 某品牌EqualLogic PS6100系列存储阵列是一款容错功能较强的存储设备&#xff0c;具有较高的安全性能。一些硬件故障或者误操作也会破坏该系列存储内的数据&#xff0c;下面分享一个北亚企安数据恢复工程师接到的一个关于EQ PS6100存储的数据恢复…

java版数字藏品深色UI仿鲸探数藏盲盒合成短视频卡牌模式支持高并发

Java版数字藏品深色UI仿鲸探数藏盲盒合成短视频卡牌模式支持高并发&#xff0c;是一种结合了Java技术、深色用户界面&#xff08;UI&#xff09;设计、数字藏品概念、盲盒合成玩法以及短视频卡牌模式的综合性应用。该模式旨在为用户提供一种新颖、有趣的数字藏品体验&#xff0…

LC 450.删除二叉搜索树中的节点

450.删除二叉搜索树中的节点 给定一个二叉搜索树的根节点 root 和一个值 key&#xff0c;删除二叉搜索树中的 key 对应的节点&#xff0c;并保证二叉搜索树的性质不变。返回二叉搜索树&#xff08;有可能被更新&#xff09;的根节点的引用。 一般来说&#xff0c;删除节点可分…

解锁CodeGeeX智能问答中3项独有的隐藏技能

CodeGeeX是一款强大的AI编程助手&#xff0c;它能帮你快速解决编程中的各种问题。无论是代码调试、功能实现&#xff0c;还是学习新语言&#xff0c;CodeGeeX都能助你一臂之力。 在IDE中搜索“CodeGeeX”就可以免费下载使用 CodeGeeX在侧边栏提供的Ask CodeGeeX智能问答功能&a…

代码随想录-算法训练营day04【链表02:两两交换链表中的节点、删除链表的倒数第N个节点、链表相交、环形链表II】

代码随想录-035期-算法训练营【博客笔记汇总表】-CSDN博客 第二章 链表part02● day 1 任务以及具体安排&#xff1a;https://docs.qq.com/doc/DUG9UR2ZUc3BjRUdY ● day 2 任务以及具体安排&#xff1a;https://docs.qq.com/doc/DUGRwWXNOVEpyaVpG ● day 3 任务以及具体安排…

C++第十六弹---string使用(上)

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】【C详解】 目录 1、标准库中的string类 1.1、string类的常用接口说明 1.1.1、string类对象的常见构造 1.1.2、string类对象的容量操作 1.1.3、string类对象的…

网上打印a4纸大概多少钱一张

在快节奏的现代生活中&#xff0c;网上打印服务因其便捷性而受到越来越多用户的青睐。对于许多需要打印大量文件的用户来说&#xff0c;了解网上打印A4纸的价格至关重要。那么&#xff0c;网上打印A4纸300页大概需要多少钱呢&#xff1f; 网上打印价格取决于多个因素&#xff…

Severt和tomcat的使用(补充)

打包程序 在pom.xml中添加上述代码之后打包时会生成war包并且包的名称是test 默认情况打的是jar包.jar里量但是tomcat要求的是war包. war包Tomcat专属的压缩包. war里面不光有.class还有一些tomcat要求的配置文件(web.xml等)还有前端的一些代码(html, css, js) 点击其右边的m…

前端学习<四>JavaScript基础——14-基本包装类型

基本数据类型不能绑定属性和方法 属性和方法只能添加给对象&#xff0c;不能添加给基本数据类型。我们拿字符串来举例。 1、基本数据类型&#xff1a; 基本数据类型string是无法绑定属性和方法的。 var str qianguyihao;​str.aaa 12;console.log(typeof str); //打印结果…