virtio_pci_deviceRegular
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 ✅