intel_iommu
Regular
4.4
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct pasid_entry *pasid_table;
struct pasid_state_entry *pasid_state_table;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct idr pasid_idr;
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct device *iommu_dev;
int node;
u32 flags;
};
4.8
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct pasid_entry *pasid_table;
struct pasid_state_entry *pasid_state_table;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct idr pasid_idr;
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct device *iommu_dev;
int node;
u32 flags;
};
4.10
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct pasid_entry *pasid_table;
struct pasid_state_entry *pasid_state_table;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct idr pasid_idr;
u32 pasid_max;
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct device *iommu_dev;
int node;
u32 flags;
};
4.13
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct pasid_entry *pasid_table;
struct pasid_state_entry *pasid_state_table;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct idr pasid_idr;
u32 pasid_max;
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct iommu_device iommu;
int node;
u32 flags;
};
4.15
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct pasid_entry *pasid_table;
struct pasid_state_entry *pasid_state_table;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct idr pasid_idr;
u32 pasid_max;
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct iommu_device iommu;
int node;
u32 flags;
};
4.18
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct pasid_entry *pasid_table;
struct pasid_state_entry *pasid_state_table;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct idr pasid_idr;
u32 pasid_max;
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct iommu_device iommu;
int node;
u32 flags;
};
5.0
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct iommu_device iommu;
int node;
u32 flags;
};
5.3
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct iommu_device iommu;
int node;
u32 flags;
};
5.4
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct iommu_device iommu;
int node;
u32 flags;
};
5.8
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u64 vccap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct completion prq_complete;
struct ioasid_allocator_ops pasid_allocator;
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct iommu_device iommu;
int node;
u32 flags;
struct dmar_drhd_unit *drhd;
};
5.11
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u64 vccap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct completion prq_complete;
struct ioasid_allocator_ops pasid_allocator;
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct iommu_device iommu;
int node;
u32 flags;
struct dmar_drhd_unit *drhd;
};
5.13
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u64 vccap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct completion prq_complete;
struct ioasid_allocator_ops pasid_allocator;
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct iommu_device iommu;
int node;
u32 flags;
struct dmar_drhd_unit *drhd;
};
5.15
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u64 vccap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct completion prq_complete;
struct ioasid_allocator_ops pasid_allocator;
struct iopf_queue *iopf_queue;
unsigned char iopfq_name[16];
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct iommu_device iommu;
int node;
u32 flags;
struct dmar_drhd_unit *drhd;
void *perf_statistic;
};
5.19
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u64 vccap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct completion prq_complete;
struct ioasid_allocator_ops pasid_allocator;
struct iopf_queue *iopf_queue;
unsigned char iopfq_name[16];
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct iommu_device iommu;
int node;
u32 flags;
struct dmar_drhd_unit *drhd;
void *perf_statistic;
};
6.2
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u64 vccap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
long unsigned int *copied_tables;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct page_req_dsc *prq;
unsigned char prq_name[16];
long unsigned int prq_seq_number;
struct completion prq_complete;
struct ioasid_allocator_ops pasid_allocator;
struct iopf_queue *iopf_queue;
unsigned char iopfq_name[16];
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct iommu_device iommu;
int node;
u32 flags;
struct dmar_drhd_unit *drhd;
void *perf_statistic;
};
6.5
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u64 vccap;
u64 ecmdcap[4];
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
unsigned int perf_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
long unsigned int *copied_tables;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct page_req_dsc *prq;
unsigned char prq_name[16];
long unsigned int prq_seq_number;
struct completion prq_complete;
struct iopf_queue *iopf_queue;
unsigned char iopfq_name[16];
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct iommu_device iommu;
int node;
u32 flags;
struct dmar_drhd_unit *drhd;
void *perf_statistic;
struct iommu_pmu *pmu;
};
6.8
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u64 vccap;
u64 ecmdcap[4];
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
unsigned int perf_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
long unsigned int *copied_tables;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct page_req_dsc *prq;
unsigned char prq_name[16];
long unsigned int prq_seq_number;
struct completion prq_complete;
struct iopf_queue *iopf_queue;
unsigned char iopfq_name[16];
struct q_inval *qi;
u32 iommu_state[4];
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct iommu_device iommu;
int node;
u32 flags;
struct dmar_drhd_unit *drhd;
void *perf_statistic;
struct iommu_pmu *pmu;
};
arm64
: Absent ⚠️
armhf
: Absent ⚠️
ppc64el
: Absent ⚠️
riscv64
: Absent ⚠️
aws
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct iommu_device iommu;
int node;
u32 flags;
};
azure
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct iommu_device iommu;
int node;
u32 flags;
};
gcp
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct iommu_device iommu;
int node;
u32 flags;
};
lowlatency
: ✅struct intel_iommu {
void *reg;
u64 reg_phys;
u64 reg_size;
u64 cap;
u64 ecap;
u32 gcmd;
raw_spinlock_t register_lock;
int seq_id;
int agaw;
int msagaw;
unsigned int irq;
unsigned int pr_irq;
u16 segment;
unsigned char name[13];
long unsigned int *domain_ids;
struct dmar_domain ***domains;
spinlock_t lock;
struct root_entry *root_entry;
struct iommu_flush flush;
struct page_req_dsc *prq;
unsigned char prq_name[16];
struct q_inval *qi;
u32 *iommu_state;
struct ir_table *ir_table;
struct irq_domain *ir_domain;
struct irq_domain *ir_msi_domain;
struct iommu_device iommu;
int node;
u32 flags;
};
Regular
4.4
and 4.8
✅
4.8
and 4.10
⚠️u32 pasid_max
4.10
and 4.13
⚠️struct iommu_device iommu
struct device *iommu_dev
4.13
and 4.15
✅
4.15
and 4.18
✅
4.18
and 5.0
⚠️struct pasid_entry *pasid_table
struct pasid_state_entry *pasid_state_table
struct idr pasid_idr
u32 pasid_max
5.0
and 5.3
✅
5.3
and 5.4
✅
5.4
and 5.8
⚠️u64 vccap
struct completion prq_complete
struct ioasid_allocator_ops pasid_allocator
struct dmar_drhd_unit *drhd
5.8
and 5.11
✅
5.11
and 5.13
✅
5.13
and 5.15
⚠️struct iopf_queue *iopf_queue
unsigned char iopfq_name[16]
void *perf_statistic
5.15
and 5.19
⚠️struct dmar_domain ***domains
5.19
and 6.2
⚠️long unsigned int *copied_tables
long unsigned int prq_seq_number
struct irq_domain *ir_msi_domain
6.2
and 6.5
⚠️u64 ecmdcap[4]
unsigned int perf_irq
struct iommu_pmu *pmu
struct ioasid_allocator_ops pasid_allocator
6.5
and 6.8
⚠️u32 *iommu_state
➡️ u32 iommu_state[4]
generic
and aws
✅
generic
and azure
✅
generic
and gcp
✅
generic
and lowlatency
✅