mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-07-31 06:13:53 -06:00

Register a legacy container for cpr-transfer, replacing the generic CPR register call with a more specific legacy container register call. Add a blocker if the kernel does not support VFIO_UPDATE_VADDR or VFIO_UNMAP_ALL. This is mostly boiler plate. The fields to to saved and restored are added in subsequent patches. Signed-off-by: Steve Sistare <steven.sistare@oracle.com> Reviewed-by: Cédric Le Goater <clg@redhat.com> Link: https://lore.kernel.org/qemu-devel/1749569991-25171-4-git-send-email-steven.sistare@oracle.com Signed-off-by: Cédric Le Goater <clg@redhat.com>
38 lines
912 B
C
38 lines
912 B
C
/*
|
|
* VFIO container
|
|
*
|
|
* Copyright Red Hat, Inc. 2025
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0-or-later
|
|
*/
|
|
|
|
#ifndef HW_VFIO_CONTAINER_H
|
|
#define HW_VFIO_CONTAINER_H
|
|
|
|
#include "hw/vfio/vfio-container-base.h"
|
|
#include "hw/vfio/vfio-cpr.h"
|
|
|
|
typedef struct VFIOContainer VFIOContainer;
|
|
typedef struct VFIODevice VFIODevice;
|
|
|
|
typedef struct VFIOGroup {
|
|
int fd;
|
|
int groupid;
|
|
VFIOContainer *container;
|
|
QLIST_HEAD(, VFIODevice) device_list;
|
|
QLIST_ENTRY(VFIOGroup) next;
|
|
QLIST_ENTRY(VFIOGroup) container_next;
|
|
bool ram_block_discard_allowed;
|
|
} VFIOGroup;
|
|
|
|
typedef struct VFIOContainer {
|
|
VFIOContainerBase bcontainer;
|
|
int fd; /* /dev/vfio/vfio, empowered by the attached groups */
|
|
unsigned iommu_type;
|
|
QLIST_HEAD(, VFIOGroup) group_list;
|
|
VFIOContainerCPR cpr;
|
|
} VFIOContainer;
|
|
|
|
OBJECT_DECLARE_SIMPLE_TYPE(VFIOContainer, VFIO_IOMMU_LEGACY);
|
|
|
|
#endif /* HW_VFIO_CONTAINER_H */
|