hypervisor -- guest OS之间的通讯方式

本文探讨了Hypervisor下的内存管理技术,包括内存页面共享、空想机制、granttable等,以及基于IO环的异步通讯机制。深入解析了不同机制的工作原理,如共享内存的映射和传递,I/O环的通信流程等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

基于内存页面共享机制

Hypervisor提供内存页面共享机制,各个Domain可以在此之上建立更高层次的抽象,该方法进行Domain间通信,功能类似于传统的IPC。(IPC三种通信机制是指:信号量、共享内存、消息队列)。

内存空想机制

内存空想机制有两种实现机制:
system v中使用的较老的机制, 每块内存都与一个key值对应,其他进程获得这个key,并将这块内存映射到自己的map中。
POSIX采用Unix系统的理念,所有数据都是文件的思想,内存页面以文件的形式进行共享,如果没有合适的文件可供使用过,那么就是/dev/null来显示一个匿名内存给内存区域。

grant table (Xen)

Xen的内存共享机制更加靠近底层,并且只能以页面为单位进行,一个共享区域都是用一个唯一的正数来进行标识,称grant reference。
Grant table支持的内存共享的操作包含两类:映射(Mapping)和传递(Transferring)。
执行Mapping操作后,被共享的内存依然保持在原来的domain地址空间,而Tansferring操作则是把共享的内存从页面一个domain到另一个domain。

基于IO环的异步通讯

I/O环为半虚拟化的设备提供同行手段,是建立在内存共享机制的一层抽象,他提供了简单的消息传递机制。

I/O环提供了一种domain间异步通信的方法,一个domain在环上放置I/O请求,而负责驱动的domain则响应请求,取走请求处理并且在完成操作会插入一个响应,应为请求和响应几乎是以相同的速率产生的,所以一个简单的环就可以满足通信需求。
每个I/O环都由5个部分组成:生产者和消费者的起始指针、结束指针以及缓冲区本身,所有缓冲区的大小都是2的正数次幂。
在这里插入图片描述

参考

https://blog.csdn.net/afxcontrolbars/article/details/46663335

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值