mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-09-09 00:07:57 -06:00
vfio: add vfio_attach_device_by_iommu_type()
Allow attachment by explicitly passing a TYPE_VFIO_IOMMU_* string; vfio-user will use this later. Reviewed-by: Cédric Le Goater <clg@redhat.com> Signed-off-by: John Levon <john.levon@nutanix.com> Link: https://lore.kernel.org/qemu-devel/20250507152020.1254632-4-john.levon@nutanix.com Signed-off-by: Cédric Le Goater <clg@redhat.com>
This commit is contained in:
parent
d60fb709cf
commit
ef73671f0b
2 changed files with 18 additions and 7 deletions
|
@ -376,21 +376,29 @@ VFIODevice *vfio_get_vfio_device(Object *obj)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool vfio_device_attach(char *name, VFIODevice *vbasedev,
|
bool vfio_device_attach_by_iommu_type(const char *iommu_type, char *name,
|
||||||
AddressSpace *as, Error **errp)
|
VFIODevice *vbasedev, AddressSpace *as,
|
||||||
|
Error **errp)
|
||||||
{
|
{
|
||||||
const VFIOIOMMUClass *ops =
|
const VFIOIOMMUClass *ops =
|
||||||
VFIO_IOMMU_CLASS(object_class_by_name(TYPE_VFIO_IOMMU_LEGACY));
|
VFIO_IOMMU_CLASS(object_class_by_name(iommu_type));
|
||||||
|
|
||||||
if (vbasedev->iommufd) {
|
|
||||||
ops = VFIO_IOMMU_CLASS(object_class_by_name(TYPE_VFIO_IOMMU_IOMMUFD));
|
|
||||||
}
|
|
||||||
|
|
||||||
assert(ops);
|
assert(ops);
|
||||||
|
|
||||||
return ops->attach_device(name, vbasedev, as, errp);
|
return ops->attach_device(name, vbasedev, as, errp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool vfio_device_attach(char *name, VFIODevice *vbasedev,
|
||||||
|
AddressSpace *as, Error **errp)
|
||||||
|
{
|
||||||
|
const char *iommu_type = vbasedev->iommufd ?
|
||||||
|
TYPE_VFIO_IOMMU_IOMMUFD :
|
||||||
|
TYPE_VFIO_IOMMU_LEGACY;
|
||||||
|
|
||||||
|
return vfio_device_attach_by_iommu_type(iommu_type, name, vbasedev,
|
||||||
|
as, errp);
|
||||||
|
}
|
||||||
|
|
||||||
void vfio_device_detach(VFIODevice *vbasedev)
|
void vfio_device_detach(VFIODevice *vbasedev)
|
||||||
{
|
{
|
||||||
if (!vbasedev->bcontainer) {
|
if (!vbasedev->bcontainer) {
|
||||||
|
|
|
@ -127,6 +127,9 @@ bool vfio_device_hiod_create_and_realize(VFIODevice *vbasedev,
|
||||||
const char *typename, Error **errp);
|
const char *typename, Error **errp);
|
||||||
bool vfio_device_attach(char *name, VFIODevice *vbasedev,
|
bool vfio_device_attach(char *name, VFIODevice *vbasedev,
|
||||||
AddressSpace *as, Error **errp);
|
AddressSpace *as, Error **errp);
|
||||||
|
bool vfio_device_attach_by_iommu_type(const char *iommu_type, char *name,
|
||||||
|
VFIODevice *vbasedev, AddressSpace *as,
|
||||||
|
Error **errp);
|
||||||
void vfio_device_detach(VFIODevice *vbasedev);
|
void vfio_device_detach(VFIODevice *vbasedev);
|
||||||
VFIODevice *vfio_get_vfio_device(Object *obj);
|
VFIODevice *vfio_get_vfio_device(Object *obj);
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue