virtio_pci_device
Regular
4.4
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
struct msix_entry *msix_entries;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
4.8
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
struct msix_entry *msix_entries;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
4.10
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
4.13
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
4.15
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
4.18
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
5.0
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
5.3
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
5.4
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
5.8
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
5.11
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
5.13
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
struct virtio_pci_modern_device mdev;
u8 *isr;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
5.15
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
struct virtio_pci_modern_device mdev;
u8 *isr;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
5.19
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
struct virtio_pci_legacy_device ldev;
struct virtio_pci_modern_device mdev;
bool is_legacy;
u8 *isr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
6.2
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
struct virtio_pci_legacy_device ldev;
struct virtio_pci_modern_device mdev;
bool is_legacy;
u8 *isr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
6.5
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
struct virtio_pci_legacy_device ldev;
struct virtio_pci_modern_device mdev;
bool is_legacy;
u8 *isr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
6.8
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
struct virtio_pci_legacy_device ldev;
struct virtio_pci_modern_device mdev;
bool is_legacy;
u8 *isr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
struct virtio_pci_admin_vq admin_vq;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
bool (*is_avq)(struct virtio_device *, unsigned int);
};
arm64
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
armhf
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
ppc64el
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
riscv64
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
aws
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
azure
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
gcp
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
lowlatency
: ✅struct virtio_pci_device {
struct virtio_device vdev;
struct pci_dev *pci_dev;
u8 *isr;
struct virtio_pci_common_cfg *common;
void *device;
void *notify_base;
size_t notify_len;
size_t device_len;
int notify_map_cap;
u32 notify_offset_multiplier;
int modern_bars;
void *ioaddr;
spinlock_t lock;
struct list_head virtqueues;
struct virtio_pci_vq_info **vqs;
int msix_enabled;
int intx_enabled;
cpumask_var_t *msix_affinity_masks;
char[256] *msix_names;
unsigned int msix_vectors;
unsigned int msix_used_vectors;
bool per_vq_vectors;
struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16);
void (*del_vq)(struct virtio_pci_vq_info *);
u16 (*config_vector)(struct virtio_pci_device *, u16);
};
Regular
4.4
and 4.8
✅
4.8
and 4.10
⚠️struct msix_entry *msix_entries
4.10
and 4.13
⚠️struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, u16)
➡️ struct virtqueue * (*setup_vq)(struct virtio_pci_device *, struct virtio_pci_vq_info *, unsigned int, void(*)(struct virtqueue *), const char *, bool, u16)
4.13
and 4.15
✅
4.15
and 4.18
✅
4.18
and 5.0
✅
5.0
and 5.3
✅
5.3
and 5.4
✅
5.4
and 5.8
✅
5.8
and 5.11
✅
5.11
and 5.13
⚠️struct virtio_pci_modern_device mdev
struct virtio_pci_common_cfg *common
void *device
void *notify_base
size_t notify_len
size_t device_len
int notify_map_cap
u32 notify_offset_multiplier
int modern_bars
5.13
and 5.15
✅
5.15
and 5.19
⚠️struct virtio_pci_legacy_device ldev
bool is_legacy
void *ioaddr
5.19
and 6.2
✅
6.2
and 6.5
✅
6.5
and 6.8
⚠️struct virtio_pci_admin_vq admin_vq
bool (*is_avq)(struct virtio_device *, unsigned int)
amd64
and arm64
✅
amd64
and armhf
✅
amd64
and ppc64el
✅
amd64
and riscv64
✅
generic
and aws
✅
generic
and azure
✅
generic
and gcp
✅
generic
and lowlatency
✅