[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PULL 37/42] vfio/container: Switch to QOM
From: |
Cédric Le Goater |
Subject: |
[PULL 37/42] vfio/container: Switch to QOM |
Date: |
Mon, 24 Jun 2024 23:24:51 +0200 |
Instead of allocating the container struct, create a QOM object of the
appropriate type.
Reviewed-by: Zhenzhong Duan <zhenzhong.duan@intel.com>
Reviewed-by: Eric Auger <eric.auger@redhat.com>
Tested-by: Eric Auger <eric.auger@redhat.com>
Signed-off-by: Cédric Le Goater <clg@redhat.com>
---
hw/vfio/container.c | 6 +++---
hw/vfio/iommufd.c | 4 ++--
2 files changed, 5 insertions(+), 5 deletions(-)
diff --git a/hw/vfio/container.c b/hw/vfio/container.c
index
3ae52530a9b500bd53ec9f9e66c73253d97c9aba..ff3a6831da83c0fe11060cd57918c4d87b10197c
100644
--- a/hw/vfio/container.c
+++ b/hw/vfio/container.c
@@ -435,7 +435,7 @@ static VFIOContainer *vfio_create_container(int fd,
VFIOGroup *group,
vioc_name = vfio_get_iommu_class_name(iommu_type);
vioc = VFIO_IOMMU_CLASS(object_class_by_name(vioc_name));
- container = g_malloc0(sizeof(*container));
+ container = VFIO_IOMMU_LEGACY(object_new(vioc_name));
container->fd = fd;
container->iommu_type = iommu_type;
vfio_container_init(&container->bcontainer, vioc);
@@ -674,7 +674,7 @@ unregister_container_exit:
vfio_cpr_unregister_container(bcontainer);
free_container_exit:
- g_free(container);
+ object_unref(container);
close_fd_exit:
close(fd);
@@ -718,7 +718,7 @@ static void vfio_disconnect_container(VFIOGroup *group)
trace_vfio_disconnect_container(container->fd);
vfio_cpr_unregister_container(bcontainer);
close(container->fd);
- g_free(container);
+ object_unref(container);
vfio_put_address_space(space);
}
diff --git a/hw/vfio/iommufd.c b/hw/vfio/iommufd.c
index
3e9d642034c2d2234ea701952c94a78ab32e9147..d59df858407f3cadb9405386ad673c99cdad61d0
100644
--- a/hw/vfio/iommufd.c
+++ b/hw/vfio/iommufd.c
@@ -239,7 +239,7 @@ static void
iommufd_cdev_container_destroy(VFIOIOMMUFDContainer *container)
memory_listener_unregister(&bcontainer->listener);
vfio_container_destroy(bcontainer);
iommufd_backend_free_id(container->be, container->ioas_id);
- g_free(container);
+ object_unref(container);
}
static int iommufd_cdev_ram_block_discard_disable(bool state)
@@ -352,7 +352,7 @@ static bool iommufd_cdev_attach(const char *name,
VFIODevice *vbasedev,
trace_iommufd_cdev_alloc_ioas(vbasedev->iommufd->fd, ioas_id);
- container = g_malloc0(sizeof(*container));
+ container = VFIO_IOMMU_IOMMUFD(object_new(TYPE_VFIO_IOMMU_IOMMUFD));
container->be = vbasedev->iommufd;
container->ioas_id = ioas_id;
--
2.45.2
- [PULL 25/42] memory: Remove IOMMU MR iommu_set_iova_range API, (continued)
- [PULL 25/42] memory: Remove IOMMU MR iommu_set_iova_range API, Cédric Le Goater, 2024/06/24
- [PULL 29/42] vfio/common: Extract vIOMMU code from vfio_sync_dirty_bitmap(), Cédric Le Goater, 2024/06/24
- [PULL 27/42] vfio: Remove unused declarations from vfio-common.h, Cédric Le Goater, 2024/06/24
- [PULL 32/42] vfio/container: Modify vfio_get_iommu_type() to use a container fd, Cédric Le Goater, 2024/06/24
- [PULL 33/42] vfio/container: Introduce vfio_get_iommu_class_name(), Cédric Le Goater, 2024/06/24
- [PULL 30/42] vfio/container: Introduce vfio_address_space_insert(), Cédric Le Goater, 2024/06/24
- [PULL 28/42] vfio/common: Move dirty tracking ranges update to helper, Cédric Le Goater, 2024/06/24
- [PULL 31/42] vfio/container: Simplify vfio_container_init(), Cédric Le Goater, 2024/06/24
- [PULL 34/42] vfio/container: Introduce vfio_create_container(), Cédric Le Goater, 2024/06/24
- [PULL 35/42] vfio/container: Discover IOMMU type before creating the container, Cédric Le Goater, 2024/06/24
- [PULL 37/42] vfio/container: Switch to QOM,
Cédric Le Goater <=
- [PULL 38/42] vfio/container: Introduce an instance_init() handler, Cédric Le Goater, 2024/06/24
- [PULL 36/42] vfio/container: Change VFIOContainerBase to use QOM, Cédric Le Goater, 2024/06/24
- [PULL 39/42] vfio/container: Remove VFIOContainerBase::ops, Cédric Le Goater, 2024/06/24
- [PULL 41/42] vfio/container: Introduce vfio_iommu_legacy_instance_init(), Cédric Le Goater, 2024/06/24
- [PULL 42/42] vfio/container: Move vfio_container_destroy() to an instance_finalize() handler, Cédric Le Goater, 2024/06/24
- [PULL 40/42] vfio/container: Remove vfio_container_init(), Cédric Le Goater, 2024/06/24
- Re: [PULL 00/42] vfio queue, Richard Henderson, 2024/06/25