mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-08 02:03:56 -06:00
vfio/container: Move space field to base container
Move the space field to the base object. Also the VFIOAddressSpace now contains a list of base containers. No functional change intended. Signed-off-by: Eric Auger <eric.auger@redhat.com> Signed-off-by: Yi Liu <yi.l.liu@intel.com> Signed-off-by: Yi Sun <yi.y.sun@linux.intel.com> Signed-off-by: Zhenzhong Duan <zhenzhong.duan@intel.com> Reviewed-by: Cédric Le Goater <clg@redhat.com> Signed-off-by: Cédric Le Goater <clg@redhat.com>
This commit is contained in:
parent
dddf83ab99
commit
e559706338
6 changed files with 29 additions and 26 deletions
|
@ -84,27 +84,27 @@ static int vfio_eeh_container_op(VFIOContainer *container, uint32_t op)
|
|||
static VFIOContainer *vfio_eeh_as_container(AddressSpace *as)
|
||||
{
|
||||
VFIOAddressSpace *space = vfio_get_address_space(as);
|
||||
VFIOContainer *container = NULL;
|
||||
VFIOContainerBase *bcontainer = NULL;
|
||||
|
||||
if (QLIST_EMPTY(&space->containers)) {
|
||||
/* No containers to act on */
|
||||
goto out;
|
||||
}
|
||||
|
||||
container = QLIST_FIRST(&space->containers);
|
||||
bcontainer = QLIST_FIRST(&space->containers);
|
||||
|
||||
if (QLIST_NEXT(container, next)) {
|
||||
if (QLIST_NEXT(bcontainer, next)) {
|
||||
/*
|
||||
* We don't yet have logic to synchronize EEH state across
|
||||
* multiple containers
|
||||
*/
|
||||
container = NULL;
|
||||
bcontainer = NULL;
|
||||
goto out;
|
||||
}
|
||||
|
||||
out:
|
||||
vfio_put_address_space(space);
|
||||
return container;
|
||||
return container_of(bcontainer, VFIOContainer, bcontainer);
|
||||
}
|
||||
|
||||
static bool vfio_eeh_as_ok(AddressSpace *as)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue