DPDK Ring and ivshmem
大约 1 分钟
DPDK Ring and ivshmem
DPDK Ring
DPDK Ring
提供了一个FIFO
无锁队列,支持丰富的队列操作,比如
- Multi-consumer or single-consumer dequeue
- Multi-producer or single-producer enqueue
- Bulk dequeue - Dequeues the specified count of objects if successful; otherwise fails
- Bulk enqueue - Enqueues the specified count of objects if successful; otherwise fails
- Burst dequeue - Dequeue the maximum available objects if the specified count cannot be fulfilled
- Burst enqueue - Enqueue the maximum available objects if the specified count cannot be fulfilled
data:image/s3,"s3://crabby-images/6b251/6b25171276420f02b9b0387221b5d68b51109252" alt="dpdk ring enqueue"
ivshmem
ivshmem
则通过把内存映射成虚拟机PCI设备提供了虚拟机间(host-to-guest or guest-to-guest
)共享内存的机制。
data:image/s3,"s3://crabby-images/80c1c/80c1c13df0415b5c9ac2a90cccbf3426767450e8" alt="Typical ivshmem use case"
DPDK ivshmem
:
data:image/s3,"s3://crabby-images/5a6c2/5a6c26956321a161c9b6750cb16e181c0c7a9c24" alt="DPDK nics"
ivshmem使用示例
# on the host
mount tmpfs /dev/shm -t tmpfs -osize=32m
ivshmem_server -m 64 -p/tmp/nahanni &
# start VM
qemu-system-x86_64 -hda mg -L /pc-bios/ --smp 4 –chardev socket,path=/tmp/nahanni,id=nahanni-device ivshmem,chardev=nahanni,size=32m,msi=off -serial telnet:0.0.0.0:4000,server,nowait,nodelay-enable-kvm&
# inside VM
modprobe kvm_ivshmem
cat/proc/devices | grep kvm_ivshmem
mknod-mode=666 /dev/ivshmem c 245 0
参考文档
链接到当前文件 0
没有文件链接到当前文件