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