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

2024-04-12 19:28

本文主要是介绍关于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的关系

这篇关于关于QEMU模拟器本身以及和CXL功能模拟相关内容的学习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/898025

相关文章

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

在Windows上使用qemu安装ubuntu24.04服务器的详细指南

《在Windows上使用qemu安装ubuntu24.04服务器的详细指南》本文介绍了在Windows上使用QEMU安装Ubuntu24.04的全流程:安装QEMU、准备ISO镜像、创建虚拟磁盘、配置... 目录1. 安装QEMU环境2. 准备Ubuntu 24.04镜像3. 启动QEMU安装Ubuntu4

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

CSS3中的字体及相关属性详解

《CSS3中的字体及相关属性详解》:本文主要介绍了CSS3中的字体及相关属性,详细内容请阅读本文,希望能对你有所帮助... 字体网页字体的三个来源:用户机器上安装的字体,放心使用。保存在第三方网站上的字体,例如Typekit和Google,可以link标签链接到你的页面上。保存在你自己Web服务器上的字

MybatisPlus service接口功能介绍

《MybatisPlusservice接口功能介绍》:本文主要介绍MybatisPlusservice接口功能介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录Service接口基本用法进阶用法总结:Lambda方法Service接口基本用法MyBATisP

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Java反射实现多属性去重与分组功能

《Java反射实现多属性去重与分组功能》在Java开发中,​​List是一种非常常用的数据结构,通常我们会遇到这样的问题:如何处理​​List​​​中的相同字段?无论是去重还是分组,合理的操作可以提高... 目录一、开发环境与基础组件准备1.环境配置:2. 代码结构说明:二、基础反射工具:BeanUtils

Python实现自动化Word文档样式复制与内容生成

《Python实现自动化Word文档样式复制与内容生成》在办公自动化领域,高效处理Word文档的样式和内容复制是一个常见需求,本文将展示如何利用Python的python-docx库实现... 目录一、为什么需要自动化 Word 文档处理二、核心功能实现:样式与表格的深度复制1. 表格复制(含样式与内容)2

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio