3.4 vhost-net基本运作原理 在这套实现中,QEMU和vhost-net内核驱动使用ioctl来交换vhost消息,并且用eventfd来实现前后端的通知。当vhost-net内核驱动加载后,它会暴露一个字符设备在/dev/vhost-net。而QEMU会打开并初始化这个字符设备,并调用ioctl来与vhost-net进行控制面通信,其内容包含virtio的特性协商、将虚拟机内存...
vhost-net 是一个实现了 vhost 协议 handler 侧的内核驱动,旨在实现高效的数据面,也就是 packet 转发。该实现下,qemu 与 vhost-net 内核驱动(handler)通过 ioctl 交换 vhost 信息,以及一组类似 eventfd 的 fd,被称为 irqfd 以及 ioeventfd,这些 fd 用来在 handler 和 guest 之间交换 notification。 当vhost-ne...
简述了 virtio spec 及 vhost 协议,纵览了实现 virtio 接口的前后端架构,以及 vhost-net(host kernel) 与 virtio-net(guest kernel) 之间通信的 vhost-net/virtio-net 架构。 行文最大的挑战是本文所涉及概念、术语其背后的历史包袱。举例来说,virtio-net 既包含 virtio 标准中所定义的 virtio networking 设备实...
vhost-net内核模块的层次结构如下图: struct vhost_net:用于描述Vhost-Net设备。它包含几个关键字段:1)struct vhost_dev,通用的vhost设备,可以类比struct device结构体内嵌在其他特定设备的结构体中;2)struct vhost_net_virtqueue,实际上对struct vhost_virtqueue进行了封装,用于网络包的数据传输;3)struct vhost_poll,...
本文将分析vhost-net的原理,只说重点,进入主题。 2. 数据结构 vhost-net内核模块的层次结构如下图:struct vhost_net:用于描述Vhost-Net设备。它包含几个关键字段:1)struct vhost_dev,通用的vhost设备,可以类比struct device结构体内嵌在其他特定设备的结构体中;2)struct vhost_net_virtqueue,实际上对struct vhost_...
virtio-net 是前端组件,运行在 guest 的内核空间。 vhost-net 是后端组件,运行在 host 的内核空间。 需要注意几点: vhost-net 与 virtio-net 均运行在 host 与 guest 的内核空间,因此我们有时也称其为 vhost-net/virtio-net 驱动。 我们在前端和后端之间拥有独立的控制面和数据面。vhost-net 使用 vhost 协议...
Vhost 协议可以在内核态(vhost-net)或者用户态(vhost-user)中实现, 本文主要描述 virtio 数据面在内核中的实现方式,也被称为 vhost-net 架构。 Part III:Vhost-net/Virtio-net 架构 virtio 接口有一个前端组件和一个后端组件: 前端组件是 virtio 接口的 guest 端。
vhost-net的框架图如下: 从图中可以看出,Guest的网络数据交互直接可以通过vhost-net内核模块进行处理,而不再需要从内核态切换回用户态的Qemu进程中进行处理; 之前的文章分析过virtio设备与驱动,针对数据传遵循virtio协议,因此vhost-net中需要去实现virtqueue的相关机制; ...
Vhost 协议可以在内核态(vhost-net)或者用户态(vhost-user)中实现, 本文主要描述 virtio 数据面在内核中的实现方式,也被称为 vhost-net 架构。 Part III:Vhost-net/Virtio-net 架构 virtio 接口有一个前端组件和一个后端组件: 前端组件是 virtio 接口的 guest 端。
open = vhost_net_open, .llseek = noop_llseek, }; 另一方面,当qemu创建tap设备时会调用到net_init_tap()函数。net_init_tap()其中会检查选项是否指定vhost=on,如果指定,则会调用到vhost_net_init()进行初始化,其中通过open(“/dev/vhost-net”, O_RDWR)打开了vhost-net driver;并通过ioctl(vhost_fd...