基于内存页面共享机制
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