dmar_domain
Regular
4.4
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
struct list_head devices;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_coherency;
int iommu_snooping;
int iommu_count;
int iommu_superpage;
u64 max_addr;
struct iommu_domain domain;
};
4.8
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
bool has_iotlb_device;
struct list_head devices;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_coherency;
int iommu_snooping;
int iommu_count;
int iommu_superpage;
u64 max_addr;
struct iommu_domain domain;
};
4.10
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
bool has_iotlb_device;
struct list_head devices;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_coherency;
int iommu_snooping;
int iommu_count;
int iommu_superpage;
u64 max_addr;
struct iommu_domain domain;
};
4.13
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
bool has_iotlb_device;
struct list_head devices;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_coherency;
int iommu_snooping;
int iommu_count;
int iommu_superpage;
u64 max_addr;
struct iommu_domain domain;
};
4.15
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
bool has_iotlb_device;
struct list_head devices;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_coherency;
int iommu_snooping;
int iommu_count;
int iommu_superpage;
u64 max_addr;
struct iommu_domain domain;
};
4.18
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
bool has_iotlb_device;
struct list_head devices;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_coherency;
int iommu_snooping;
int iommu_count;
int iommu_superpage;
u64 max_addr;
struct iommu_domain domain;
};
5.0
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
bool has_iotlb_device;
struct list_head devices;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_coherency;
int iommu_snooping;
int iommu_count;
int iommu_superpage;
u64 max_addr;
struct iommu_domain domain;
};
5.3
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
unsigned int auxd_refcnt;
bool has_iotlb_device;
struct list_head devices;
struct list_head auxd;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_coherency;
int iommu_snooping;
int iommu_count;
int iommu_superpage;
u64 max_addr;
int default_pasid;
struct iommu_domain domain;
};
5.4
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
unsigned int auxd_refcnt;
bool has_iotlb_device;
struct list_head devices;
struct list_head auxd;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_coherency;
int iommu_snooping;
int iommu_count;
int iommu_superpage;
u64 max_addr;
int default_pasid;
struct iommu_domain domain;
};
5.8
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
unsigned int auxd_refcnt;
bool has_iotlb_device;
struct list_head devices;
struct list_head auxd;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_coherency;
int iommu_snooping;
int iommu_count;
int iommu_superpage;
u64 max_addr;
int default_pasid;
struct iommu_domain domain;
};
5.11
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
bool has_iotlb_device;
struct list_head devices;
struct list_head subdevices;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_coherency;
int iommu_snooping;
int iommu_count;
int iommu_superpage;
u64 max_addr;
u32 default_pasid;
struct iommu_domain domain;
};
5.13
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
bool has_iotlb_device;
struct list_head devices;
struct list_head subdevices;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_coherency;
int iommu_snooping;
int iommu_count;
int iommu_superpage;
u64 max_addr;
u32 default_pasid;
struct iommu_domain domain;
};
5.15
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
u8 has_iotlb_device;
u8 iommu_coherency;
u8 iommu_snooping;
struct list_head devices;
struct list_head subdevices;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_superpage;
u64 max_addr;
u32 default_pasid;
struct iommu_domain domain;
};
5.19
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
u8 has_iotlb_device;
u8 iommu_coherency;
u8 force_snooping;
u8 set_pte_snp;
struct list_head devices;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_superpage;
u64 max_addr;
struct iommu_domain domain;
};
6.2
: ✅struct dmar_domain {
int nid;
struct xarray iommu_array;
u8 has_iotlb_device;
u8 iommu_coherency;
u8 force_snooping;
u8 set_pte_snp;
u8 use_first_level;
spinlock_t lock;
struct list_head devices;
struct dma_pte *pgd;
int gaw;
int agaw;
int iommu_superpage;
u64 max_addr;
struct iommu_domain domain;
};
6.5
: ✅struct dmar_domain {
int nid;
struct xarray iommu_array;
u8 has_iotlb_device;
u8 iommu_coherency;
u8 force_snooping;
u8 set_pte_snp;
u8 use_first_level;
spinlock_t lock;
struct list_head devices;
struct dma_pte *pgd;
int gaw;
int agaw;
int iommu_superpage;
u64 max_addr;
struct iommu_domain domain;
};
6.8
: ✅struct dmar_domain {
int nid;
struct xarray iommu_array;
u8 has_iotlb_device;
u8 iommu_coherency;
u8 force_snooping;
u8 set_pte_snp;
u8 use_first_level;
u8 dirty_tracking;
u8 nested_parent;
u8 has_mappings;
spinlock_t lock;
struct list_head devices;
struct list_head dev_pasids;
int iommu_superpage;
struct dma_pte *pgd;
int gaw;
int agaw;
u64 max_addr;
spinlock_t s1_lock;
struct list_head s1_domains;
struct dmar_domain *s2_domain;
long unsigned int s1_pgtbl;
struct iommu_hwpt_vtd_s1 s1_cfg;
struct list_head s2_link;
struct iommu_domain domain;
};
arm64
: Absent ⚠️
armhf
: Absent ⚠️
ppc64el
: Absent ⚠️
riscv64
: Absent ⚠️
aws
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
unsigned int auxd_refcnt;
bool has_iotlb_device;
struct list_head devices;
struct list_head auxd;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_coherency;
int iommu_snooping;
int iommu_count;
int iommu_superpage;
u64 max_addr;
int default_pasid;
struct iommu_domain domain;
};
azure
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
unsigned int auxd_refcnt;
bool has_iotlb_device;
struct list_head devices;
struct list_head auxd;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_coherency;
int iommu_snooping;
int iommu_count;
int iommu_superpage;
u64 max_addr;
int default_pasid;
struct iommu_domain domain;
};
gcp
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
unsigned int auxd_refcnt;
bool has_iotlb_device;
struct list_head devices;
struct list_head auxd;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_coherency;
int iommu_snooping;
int iommu_count;
int iommu_superpage;
u64 max_addr;
int default_pasid;
struct iommu_domain domain;
};
lowlatency
: ✅struct dmar_domain {
int nid;
unsigned int iommu_refcnt[128];
u16 iommu_did[128];
unsigned int auxd_refcnt;
bool has_iotlb_device;
struct list_head devices;
struct list_head auxd;
struct iova_domain iovad;
struct dma_pte *pgd;
int gaw;
int agaw;
int flags;
int iommu_coherency;
int iommu_snooping;
int iommu_count;
int iommu_superpage;
u64 max_addr;
int default_pasid;
struct iommu_domain domain;
};
Regular
4.4
and 4.8
⚠️bool has_iotlb_device
4.8
and 4.10
✅
4.10
and 4.13
✅
4.13
and 4.15
✅
4.15
and 4.18
✅
4.18
and 5.0
✅
5.0
and 5.3
⚠️unsigned int auxd_refcnt
struct list_head auxd
int default_pasid
5.3
and 5.4
✅
5.4
and 5.8
✅
5.8
and 5.11
⚠️struct list_head subdevices
unsigned int auxd_refcnt
struct list_head auxd
int default_pasid
➡️ u32 default_pasid
5.11
and 5.13
✅
5.13
and 5.15
⚠️int iommu_count
bool has_iotlb_device
➡️ u8 has_iotlb_device
int iommu_coherency
➡️ u8 iommu_coherency
int iommu_snooping
➡️ u8 iommu_snooping
5.15
and 5.19
⚠️u8 force_snooping
u8 set_pte_snp
u8 iommu_snooping
struct list_head subdevices
u32 default_pasid
5.19
and 6.2
⚠️struct xarray iommu_array
u8 use_first_level
spinlock_t lock
unsigned int iommu_refcnt[128]
u16 iommu_did[128]
struct iova_domain iovad
int flags
6.2
and 6.5
✅
6.5
and 6.8
⚠️u8 dirty_tracking
u8 nested_parent
u8 has_mappings
struct list_head dev_pasids
spinlock_t s1_lock
struct list_head s1_domains
struct dmar_domain *s2_domain
long unsigned int s1_pgtbl
struct iommu_hwpt_vtd_s1 s1_cfg
struct list_head s2_link
generic
and aws
✅
generic
and azure
✅
generic
and gcp
✅
generic
and lowlatency
✅