iommu_dev_data
Regular
4.4
: ✅struct iommu_dev_data {
struct list_head list;
struct list_head dev_data_list;
struct protection_domain *domain;
u16 devid;
bool iommu_v2;
bool passthrough;
struct (anon) ats;
bool pri_tlp;
u32 errata;
};
4.8
: ✅struct iommu_dev_data {
struct list_head list;
struct list_head dev_data_list;
struct protection_domain *domain;
u16 devid;
u16 alias;
bool iommu_v2;
bool passthrough;
struct (anon) ats;
bool pri_tlp;
u32 errata;
};
4.10
: ✅struct iommu_dev_data {
struct list_head list;
struct list_head dev_data_list;
struct protection_domain *domain;
u16 devid;
u16 alias;
bool iommu_v2;
bool passthrough;
struct (anon) ats;
bool pri_tlp;
u32 errata;
bool use_vapic;
};
4.13
: ✅struct iommu_dev_data {
struct list_head list;
struct list_head dev_data_list;
struct protection_domain *domain;
u16 devid;
u16 alias;
bool iommu_v2;
bool passthrough;
struct (anon) ats;
bool pri_tlp;
u32 errata;
bool use_vapic;
struct ratelimit_state rs;
};
4.15
: ✅struct iommu_dev_data {
struct list_head list;
struct list_head dev_data_list;
struct protection_domain *domain;
u16 devid;
u16 alias;
bool iommu_v2;
bool passthrough;
struct (anon) ats;
bool pri_tlp;
u32 errata;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
4.18
: ✅struct iommu_dev_data {
struct list_head list;
struct llist_node dev_data_list;
struct protection_domain *domain;
u16 devid;
u16 alias;
bool iommu_v2;
bool passthrough;
struct (anon) ats;
bool pri_tlp;
u32 errata;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
5.0
: ✅struct iommu_dev_data {
struct list_head list;
struct llist_node dev_data_list;
struct protection_domain *domain;
u16 devid;
u16 alias;
bool iommu_v2;
bool passthrough;
struct (anon) ats;
bool pri_tlp;
u32 errata;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
5.3
: ✅struct iommu_dev_data {
struct list_head list;
struct llist_node dev_data_list;
struct protection_domain *domain;
u16 devid;
u16 alias;
bool iommu_v2;
bool passthrough;
struct (anon) ats;
bool pri_tlp;
u32 errata;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
5.4
: ✅struct iommu_dev_data {
spinlock_t lock;
struct list_head list;
struct llist_node dev_data_list;
struct protection_domain *domain;
struct pci_dev *pdev;
u16 devid;
bool iommu_v2;
bool passthrough;
struct (anon) ats;
bool pri_tlp;
u32 errata;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
5.8
: ✅struct iommu_dev_data {
spinlock_t lock;
struct list_head list;
struct llist_node dev_data_list;
struct protection_domain *domain;
struct pci_dev *pdev;
u16 devid;
bool iommu_v2;
struct (anon) ats;
bool pri_tlp;
u32 errata;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
5.11
: ✅struct iommu_dev_data {
spinlock_t lock;
struct list_head list;
struct llist_node dev_data_list;
struct protection_domain *domain;
struct pci_dev *pdev;
u16 devid;
bool iommu_v2;
struct (anon) ats;
bool pri_tlp;
u32 errata;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
5.13
: ✅struct iommu_dev_data {
spinlock_t lock;
struct list_head list;
struct llist_node dev_data_list;
struct protection_domain *domain;
struct pci_dev *pdev;
u16 devid;
bool iommu_v2;
struct (anon) ats;
bool pri_tlp;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
5.15
: ✅struct iommu_dev_data {
spinlock_t lock;
struct list_head list;
struct llist_node dev_data_list;
struct protection_domain *domain;
struct pci_dev *pdev;
u16 devid;
bool iommu_v2;
struct (anon) ats;
bool pri_tlp;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
5.19
: ✅struct iommu_dev_data {
spinlock_t lock;
struct list_head list;
struct llist_node dev_data_list;
struct protection_domain *domain;
struct pci_dev *pdev;
u16 devid;
bool iommu_v2;
struct (anon) ats;
bool pri_tlp;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
6.2
: ✅struct iommu_dev_data {
spinlock_t lock;
struct list_head list;
struct llist_node dev_data_list;
struct protection_domain *domain;
struct device *dev;
u16 devid;
bool iommu_v2;
struct (anon) ats;
bool pri_tlp;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
6.5
: ✅struct iommu_dev_data {
spinlock_t lock;
struct list_head list;
struct llist_node dev_data_list;
struct protection_domain *domain;
struct device *dev;
u16 devid;
bool iommu_v2;
struct (anon) ats;
bool pri_tlp;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
6.8
: ✅struct iommu_dev_data {
spinlock_t lock;
struct list_head list;
struct llist_node dev_data_list;
struct protection_domain *domain;
struct device *dev;
u16 devid;
u32 flags;
int ats_qdep;
u8 ats_enabled;
u8 pri_enabled;
u8 pasid_enabled;
u8 pri_tlp;
u8 ppr;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
arm64
: Absent ⚠️
armhf
: Absent ⚠️
ppc64el
: Absent ⚠️
riscv64
: Absent ⚠️
aws
: ✅struct iommu_dev_data {
spinlock_t lock;
struct list_head list;
struct llist_node dev_data_list;
struct protection_domain *domain;
struct pci_dev *pdev;
u16 devid;
bool iommu_v2;
bool passthrough;
struct (anon) ats;
bool pri_tlp;
u32 errata;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
azure
: ✅struct iommu_dev_data {
spinlock_t lock;
struct list_head list;
struct llist_node dev_data_list;
struct protection_domain *domain;
struct pci_dev *pdev;
u16 devid;
bool iommu_v2;
bool passthrough;
struct (anon) ats;
bool pri_tlp;
u32 errata;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
gcp
: ✅struct iommu_dev_data {
spinlock_t lock;
struct list_head list;
struct llist_node dev_data_list;
struct protection_domain *domain;
struct pci_dev *pdev;
u16 devid;
bool iommu_v2;
bool passthrough;
struct (anon) ats;
bool pri_tlp;
u32 errata;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
lowlatency
: ✅struct iommu_dev_data {
spinlock_t lock;
struct list_head list;
struct llist_node dev_data_list;
struct protection_domain *domain;
struct pci_dev *pdev;
u16 devid;
bool iommu_v2;
bool passthrough;
struct (anon) ats;
bool pri_tlp;
u32 errata;
bool use_vapic;
bool defer_attach;
struct ratelimit_state rs;
};
Regular
4.4
and 4.8
⚠️u16 alias
4.8
and 4.10
⚠️bool use_vapic
4.10
and 4.13
⚠️struct ratelimit_state rs
4.13
and 4.15
⚠️bool defer_attach
4.15
and 4.18
⚠️struct list_head dev_data_list
➡️ struct llist_node dev_data_list
4.18
and 5.0
✅
5.0
and 5.3
✅
5.3
and 5.4
⚠️spinlock_t lock
struct pci_dev *pdev
u16 alias
5.4
and 5.8
⚠️bool passthrough
5.8
and 5.11
✅
5.11
and 5.13
⚠️u32 errata
5.13
and 5.15
✅
5.15
and 5.19
✅
5.19
and 6.2
⚠️struct device *dev
struct pci_dev *pdev
6.2
and 6.5
✅
6.5
and 6.8
⚠️u32 flags
int ats_qdep
u8 ats_enabled
u8 pri_enabled
u8 pasid_enabled
u8 ppr
bool iommu_v2
struct (anon) ats
bool pri_tlp
➡️ u8 pri_tlp
generic
and aws
✅
generic
and azure
✅
generic
and gcp
✅
generic
and lowlatency
✅