[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v3 09/13] virtio-iommu: Record whether a probe request has been i
|
From: |
Eric Auger |
|
Subject: |
[PATCH v3 09/13] virtio-iommu: Record whether a probe request has been issued |
|
Date: |
Wed, 11 Oct 2023 19:52:25 +0200 |
Add an IOMMUDevice 'probe_done' flag to record that the driver
already issued a probe request on that device.
This will be useful to double check host reserved regions aren't
notified after the probe and hence are not taken into account
by the driver.
Signed-off-by: Eric Auger <eric.auger@redhat.com>
Suggested-by: Jean-Philippe Brucker <jean-philippe@linaro.org>
---
include/hw/virtio/virtio-iommu.h | 1 +
hw/virtio/virtio-iommu.c | 20 +++++++++++---------
2 files changed, 12 insertions(+), 9 deletions(-)
diff --git a/include/hw/virtio/virtio-iommu.h b/include/hw/virtio/virtio-iommu.h
index 70b8ace34d..1dd11ae81a 100644
--- a/include/hw/virtio/virtio-iommu.h
+++ b/include/hw/virtio/virtio-iommu.h
@@ -40,6 +40,7 @@ typedef struct IOMMUDevice {
MemoryRegion root; /* The root container of the device */
MemoryRegion bypass_mr; /* The alias of shared memory MR */
GList *resv_regions;
+ bool probe_done;
} IOMMUDevice;
typedef struct IOMMUPciBus {
diff --git a/hw/virtio/virtio-iommu.c b/hw/virtio/virtio-iommu.c
index 0e2370663d..13c3c087fe 100644
--- a/hw/virtio/virtio-iommu.c
+++ b/hw/virtio/virtio-iommu.c
@@ -639,19 +639,13 @@ static int virtio_iommu_unmap(VirtIOIOMMU *s,
return ret;
}
-static ssize_t virtio_iommu_fill_resv_mem_prop(VirtIOIOMMU *s, uint32_t ep,
+static ssize_t virtio_iommu_fill_resv_mem_prop(IOMMUDevice *sdev, uint32_t ep,
uint8_t *buf, size_t free)
{
struct virtio_iommu_probe_resv_mem prop = {};
size_t size = sizeof(prop), length = size - sizeof(prop.head), total;
- IOMMUDevice *sdev;
GList *l;
- sdev = container_of(virtio_iommu_mr(s, ep), IOMMUDevice, iommu_mr);
- if (!sdev) {
- return -EINVAL;
- }
-
total = size * g_list_length(sdev->resv_regions);
if (total > free) {
return -ENOSPC;
@@ -688,19 +682,27 @@ static int virtio_iommu_probe(VirtIOIOMMU *s,
uint8_t *buf)
{
uint32_t ep_id = le32_to_cpu(req->endpoint);
+ IOMMUMemoryRegion *iommu_mr = virtio_iommu_mr(s, ep_id);
size_t free = VIOMMU_PROBE_SIZE;
+ IOMMUDevice *sdev;
ssize_t count;
- if (!virtio_iommu_mr(s, ep_id)) {
+ if (!iommu_mr) {
return VIRTIO_IOMMU_S_NOENT;
}
- count = virtio_iommu_fill_resv_mem_prop(s, ep_id, buf, free);
+ sdev = container_of(iommu_mr, IOMMUDevice, iommu_mr);
+ if (!sdev) {
+ return -EINVAL;
+ }
+
+ count = virtio_iommu_fill_resv_mem_prop(sdev, ep_id, buf, free);
if (count < 0) {
return VIRTIO_IOMMU_S_INVAL;
}
buf += count;
free -= count;
+ sdev->probe_done = true;
return VIRTIO_IOMMU_S_OK;
}
--
2.41.0
- [PATCH v3 01/13] memory: Let ReservedRegion use Range, (continued)
- [PATCH v3 01/13] memory: Let ReservedRegion use Range, Eric Auger, 2023/10/11
- [PATCH v3 03/13] vfio: Collect container iova range info, Eric Auger, 2023/10/11
- [PATCH v3 02/13] memory: Introduce memory_region_iommu_set_iova_ranges, Eric Auger, 2023/10/11
- [PATCH v3 05/13] range: Make range_compare() public, Eric Auger, 2023/10/11
- [PATCH v3 04/13] virtio-iommu: Rename reserved_regions into prop_resv_regions, Eric Auger, 2023/10/11
- [PATCH v3 08/13] range: Introduce range_inverse_array(), Eric Auger, 2023/10/11
- [PATCH v3 06/13] util/reserved-region: Add new ReservedRegion helpers, Eric Auger, 2023/10/11
- [PATCH v3 09/13] virtio-iommu: Record whether a probe request has been issued,
Eric Auger <=
- [PATCH v3 07/13] virtio-iommu: Introduce per IOMMUDevice reserved regions, Eric Auger, 2023/10/11
- [PATCH v3 12/13] test: Add some tests for range and resv-mem helpers, Eric Auger, 2023/10/11
- [PATCH v3 11/13] virtio-iommu: Consolidate host reserved regions and property set ones, Eric Auger, 2023/10/11
- [PATCH v3 13/13] vfio: Remove 64-bit IOVA address space assumption, Eric Auger, 2023/10/11
- [PATCH v3 10/13] virtio-iommu: Implement set_iova_ranges() callback, Eric Auger, 2023/10/11
- Re: [PATCH v3 00/13] VIRTIO-IOMMU/VFIO: Don't assume 64b IOVA space, Michael S. Tsirkin, 2023/10/18