当前位置:网站首页>Hypervisor related knowledge points
Hypervisor related knowledge points
2022-08-05 01:53:00 【Chasing Dreams - Polaris】
1、QNX网站
2、guest os之间的通信方式
Memory sharing
Guests in a hypervisor system can share memory regions through which they can pass data to each other.
In a QNX Hypervisor system, client applications running in guests create and manage shared memory, and can use shared memory regions to share data. If data needs to be shared between a guest or guests and the hypervisor host domain, applications running in the hypervisor host domain can also create shared memory regions, or attach to regions created by guests.
Assuming that all sharing is between guests, and not with the hypervisor host, to set up memory sharing in your hypervisor system:
- Edit the qvm configuration files (*.qvmconf) for the VMs hosting the guests that will share memory to enable shared memory services (see “Configuring the VMs” below).
- Create a client application that runs in the guests and uses shared memory services, and run it on multiple guests.
The hypervisor-shmem-examples-march31.tgz archive available in the QNX Hypervisor package includes source code for example memory sharing programs: ghstest.c for a QNX guest, and for the hypervisor host.
The binaries for a QNX Neutrino OS 7.0 guest are included in the hypervisor files. If you want to try this shared memory program with a QNX Neutrino OS 6.6 guest, you can download and unpack the example program binary files (see “Additional files for QNX Neutrino OS 6.6 guests” in the “Assembling a Hypervisor System and Its Components” chapter).
How shared memory works
To use shared memory, a client (an application running in a guest or in the hypervisor host) needs:
- a mapping of the shared memory region
- a hardware interrupt it can use to signal other users of the shared memory regions that this region has been updated
The hypervisor includes the vdev-shmem vdev, which implements setting up the shared memory mapping and the interrupts you need to use shared memory. This vdev provides additional functionality to simplify using shared memory. These include:
- shared memory region names (a hypervisor system may include multiple named shared regions)
- selective signaling (e.g., signal Guest 0, but not Guest 3)
- signal knowledge (the ability to know which guests have been signaled)
The figure below illustrates memory sharing between two guests. Guest 0 attempts to attach to a 128 MB shared memory area first. Since no such area exists at the specified location, the attempt to attach creates the area and allows the guest to attach to it. Guest 1 can simply attach to the same name to share data memory with Guest 0.
Figure 1. A 128 MB memory allocation shared by Guest 0 and Guest 1
For more information about shared memory regions, see “Factory and control pages” below.
All the connections to a shared memory region are peers. That is, there is no distinction between the guest that creates a shared memory region and the guest that attaches to it. Simply, the first attempt to attach to a shared memory region creates the region. As far as the guest is concerned, it simply attaches to the region.
This design avoids ordering problems where the system designer would have to make sure that one guest always comes up and creates the shared memory region before another guest tries to attach to it.
边栏推荐
猜你喜欢
Chapter 09 Use of Performance Analysis Tools [2. Index and Tuning] [MySQL Advanced]
释放技术创新引擎,英特尔携手生态合作伙伴推动智慧零售蓬勃发展
【七夕如何根据情侣倾听的音乐进行薅羊毛】背景音乐是否会影响情侣对酒的选择
第09章 性能分析工具的使用【2.索引及调优篇】【MySQL高级】
高数_复习_第1章:函数、极限、连续
张驰咨询:揭晓六西格玛管理(6 Sigma)长盛不衰的秘密
Live playback including PPT download | Build Online Deep Learning based on Flink & DeepRec
Why is this problem reported when installing oracle11
“嘀哩哩,等灯等灯”,工厂安全生产的提示音
Transfer Learning - Distant Domain Transfer Learning
随机推荐
Interview summary: Why do interviewers in large factories always ask about the underlying principles of Framework?
蓝牙Mesh系统开发五 ble mesh设备增加与移除
原生js实现多选框全部选中和取消效果
How DHCP works
[parameters of PyQT5 binding functions]
第十一章 开关级建模
软件测试技术之最有效的七大性能测试技术
Gartner Hype Cycle:超融合技术将在2年内到达“生产力成熟期”
1349. 参加考试的最大学生数 状态压缩
.Net C# 控制台 使用 Win32 API 创建一个窗口
树形查找(二叉查找树)
Short domain name bypass and xss related knowledge
Are testing jobs so hard to find?I am 32 this year and I have been unemployed for 2 months. What should an older test engineer do next to support his family?
从一次数据库误操作开始了解MySQL日志【bin log、redo log、undo log】
sqlite--nested exception is org.apache.ibatis.exceptions.PersistenceException:
10年测试经验,在35岁的生理年龄面前,一文不值
linux(centOs7)部署mysql(8.0.20)数据库
VOC格式数据集转COCO格式数据集
新唐NUC980使用记录:在用户应用中使用GPIO
如何创建rpm包