aboutsummaryrefslogtreecommitdiff
path: root/hw/virtio/virtio-mem.c
diff options
context:
space:
mode:
authorEugenio Pérez <eperezma@redhat.com>2022-03-14 18:34:50 +0100
committerJason Wang <jasowang@redhat.com>2022-03-15 13:57:44 +0800
commitec6122d8828e0e1268ec520542f8a7622d84f571 (patch)
tree5e4d9ae114742353a3e972da46026729dd99663f /hw/virtio/virtio-mem.c
parent193d17be0b84cce87db4426622cd4e6b827cae2a (diff)
downloadqemu-ec6122d8828e0e1268ec520542f8a7622d84f571.zip
qemu-ec6122d8828e0e1268ec520542f8a7622d84f571.tar.gz
qemu-ec6122d8828e0e1268ec520542f8a7622d84f571.tar.bz2
vhost: Add VhostIOVATree
This tree is able to look for a translated address from an IOVA address. At first glance it is similar to util/iova-tree. However, SVQ working on devices with limited IOVA space need more capabilities, like allocating IOVA chunks or performing reverse translations (qemu addresses to iova). The allocation capability, as "assign a free IOVA address to this chunk of memory in qemu's address space" allows shadow virtqueue to create a new address space that is not restricted by guest's addressable one, so we can allocate shadow vqs vrings outside of it. It duplicates the tree so it can search efficiently in both directions, and it will signal overlap if iova or the translated address is present in any tree. Signed-off-by: Eugenio Pérez <eperezma@redhat.com> Acked-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Jason Wang <jasowang@redhat.com>
Diffstat (limited to 'hw/virtio/virtio-mem.c')
0 files changed, 0 insertions, 0 deletions