标题: qnx / qnx hypervisor [打印本页] 作者: 小秦哥 时间: 2024-9-3 18:31 标题: qnx / qnx hypervisor three criteria of hypervisor:
Equivalence 假造机(VM)与底层硬件相同
Virtual machines (VMs) running in the hypervisor are essentially the same as the underlying hardware. A guest does not need to be aware that it is running in a VM in order to function properly.
Safety 管理程序始终保持对硬件的控制
With the exception of guest access to pass-through device memory, the hypervisor maintains control of the hardware at all times, regardless of what the guests are doing. It controls guests' abilities to access hardware devices, limits guests' ability to access host-physical memory to their assigned memory regions, has ultimate control over scheduling, manages interrupt routing, and has the ability to terminate a guest, regardless of what the guest may be attempting to do.
除客户访问直通装备内存外,无论客户在做什么,管理程序始终保持对硬件的控制。它控制客户机访问硬件装备的能力,将客户机访问主机物理内存的能力限制在其分配的内存区域内,对调度拥有终极控制权,管理停止路由,并有能力终止客户机,无论客户机试图做什么。
Performance 性能只比在硬件上稍慢一些
Execution of programs running in VMs is only minimally slower than when running directly on the hardware.
Terminology
device 真实存在的硬件装备,和vdev相反
We use device or to mean a hardware device that exists as a physical component on the system. Contrast vdev.
guest 在 qvm 中运行的操作系统或此中的应用程序
In most cases, the term host refers not to a host computer (the desktop or laptop, which you can connect to your target system to load a new image or debug), but to the hypervisor or something in the hypervisor (e.g., the CPU instructs the guest thread to exit guest mode and continue in host mode).
When the context doesn't make the meaning of host clear, we'll use development host to refer to the laptop or desktop, and host domain or hypervisor host to indicate the hypervisor and all its components.
When discussing privilege or exception levels, we'll use hypervisor host or hypervisor host domain (e.g., processes running in the hypervisor host domain sometimes run at EL2 on ARM boards, or at VMX root mode on x86 boards).
在大多数情况下,"主机 "一词指的不是主机(台式机或笔记本电脑,你可以将其连接到目标系统以加载新映像或进行调试),而是管理程序(hypervisor)或管理程序中的某些部分(例如,CPU 指示客户线程退出客户模式并继承在主机模式下运行)。
当上下文无法明白主机的含义时,我们会用开发主机(development host)来指笔记本电脑或台式机,用主机域或管理程序主机(host domain or hypervisor host )来指管理程序及其所有组件。
hypervisor
A qvm (or qvm process) is a process in the hypervisor that hosts guests.
The hypervisor starts qvm process instances; each qvm process instance presents a virtual machine (VM) in which a guest can run.
qvm (或 qvm 进程)是管理程序中用于托管客户机的进程。
管理程序会启动 qvm 进程实例;每个 qvm 进程实例都会出现一个假造机(VM),客户可在此中运行。
vdev
We use virtual device (or vdev) to mean any device that the hypervisor virtualizes in some way . Examples of vdevs include an interrupt controller (virtualized), or an Ethernet device controller (para-virtualized).
假造装备可以模仿物理装备,或者也可以是半假造装备,⼀个假造装备没有确定的与之相对的物理装备
存在。
VM
A virtual machine or VM is presented by a qvm process instance to a guest, which runs in the VM; the VM hosts the guest.
device
假造机的进程标识符(Process ID)通过进程标识符,可以在操作系统级别对假造机进行管理和监控。
What is a process?
– a program loaded into memory
– identified by a process id, commonly
abbreviated as pid
bootimage
pass-through方式下,pass-through device可以直接独占访问,比访问Vdev或者share访问更快。使用pass-through的时间,guest os需要有相应的driver for the physical device,此时所有的交互都在guest 和physical device之间直接进行,hypervisor只需要辨认和允许来自guest的信号和device的停止