iova_domainRegular
4.4: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
};
4.8: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
struct iova_rcache rcaches[6];
};
4.10: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
struct iova_rcache rcaches[6];
};
4.13: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
struct iova_rcache rcaches[6];
};
4.15: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
struct iova anchor;
struct iova_rcache rcaches[6];
iova_flush_cb flush_cb;
iova_entry_dtor entry_dtor;
struct iova_fq *fq;
atomic64_t fq_flush_start_cnt;
atomic64_t fq_flush_finish_cnt;
struct timer_list fq_timer;
atomic_t fq_timer_on;
};
4.18: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
struct iova anchor;
struct iova_rcache rcaches[6];
iova_flush_cb flush_cb;
iova_entry_dtor entry_dtor;
struct iova_fq *fq;
atomic64_t fq_flush_start_cnt;
atomic64_t fq_flush_finish_cnt;
struct timer_list fq_timer;
atomic_t fq_timer_on;
};
5.0: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
long unsigned int max32_alloc_size;
struct iova anchor;
struct iova_rcache rcaches[6];
iova_flush_cb flush_cb;
iova_entry_dtor entry_dtor;
struct iova_fq *fq;
atomic64_t fq_flush_start_cnt;
atomic64_t fq_flush_finish_cnt;
struct timer_list fq_timer;
atomic_t fq_timer_on;
};
5.3: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
long unsigned int max32_alloc_size;
struct iova_fq *fq;
atomic64_t fq_flush_start_cnt;
atomic64_t fq_flush_finish_cnt;
struct iova anchor;
struct iova_rcache rcaches[6];
iova_flush_cb flush_cb;
iova_entry_dtor entry_dtor;
struct timer_list fq_timer;
atomic_t fq_timer_on;
};
5.4: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
long unsigned int max32_alloc_size;
struct iova_fq *fq;
atomic64_t fq_flush_start_cnt;
atomic64_t fq_flush_finish_cnt;
struct iova anchor;
struct iova_rcache rcaches[6];
iova_flush_cb flush_cb;
iova_entry_dtor entry_dtor;
struct timer_list fq_timer;
atomic_t fq_timer_on;
};
5.8: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
long unsigned int max32_alloc_size;
struct iova_fq *fq;
atomic64_t fq_flush_start_cnt;
atomic64_t fq_flush_finish_cnt;
struct iova anchor;
struct iova_rcache rcaches[6];
iova_flush_cb flush_cb;
iova_entry_dtor entry_dtor;
struct timer_list fq_timer;
atomic_t fq_timer_on;
};
5.11: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
long unsigned int max32_alloc_size;
struct iova_fq *fq;
atomic64_t fq_flush_start_cnt;
atomic64_t fq_flush_finish_cnt;
struct iova anchor;
struct iova_rcache rcaches[6];
iova_flush_cb flush_cb;
iova_entry_dtor entry_dtor;
struct timer_list fq_timer;
atomic_t fq_timer_on;
};
5.13: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
long unsigned int max32_alloc_size;
struct iova_fq *fq;
atomic64_t fq_flush_start_cnt;
atomic64_t fq_flush_finish_cnt;
struct iova anchor;
struct iova_rcache rcaches[6];
iova_flush_cb flush_cb;
iova_entry_dtor entry_dtor;
struct timer_list fq_timer;
atomic_t fq_timer_on;
struct hlist_node cpuhp_dead;
};
5.15: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
long unsigned int max32_alloc_size;
struct iova_fq *fq;
atomic64_t fq_flush_start_cnt;
atomic64_t fq_flush_finish_cnt;
struct iova anchor;
struct iova_rcache rcaches[6];
iova_flush_cb flush_cb;
iova_entry_dtor entry_dtor;
struct timer_list fq_timer;
atomic_t fq_timer_on;
struct hlist_node cpuhp_dead;
};
5.19: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
long unsigned int max32_alloc_size;
struct iova anchor;
struct iova_rcache *rcaches;
struct hlist_node cpuhp_dead;
};
6.2: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
long unsigned int max32_alloc_size;
struct iova anchor;
struct iova_rcache *rcaches;
struct hlist_node cpuhp_dead;
};
6.5: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
long unsigned int max32_alloc_size;
struct iova anchor;
struct iova_rcache *rcaches;
struct hlist_node cpuhp_dead;
};
6.8: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
long unsigned int max32_alloc_size;
struct iova anchor;
struct iova_rcache *rcaches;
struct hlist_node cpuhp_dead;
};
arm64: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
long unsigned int max32_alloc_size;
struct iova_fq *fq;
atomic64_t fq_flush_start_cnt;
atomic64_t fq_flush_finish_cnt;
struct iova anchor;
struct iova_rcache rcaches[6];
iova_flush_cb flush_cb;
iova_entry_dtor entry_dtor;
struct timer_list fq_timer;
atomic_t fq_timer_on;
};
armhf: Absent ⚠️
ppc64el: Absent ⚠️
riscv64: Absent ⚠️
aws: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
long unsigned int max32_alloc_size;
struct iova_fq *fq;
atomic64_t fq_flush_start_cnt;
atomic64_t fq_flush_finish_cnt;
struct iova anchor;
struct iova_rcache rcaches[6];
iova_flush_cb flush_cb;
iova_entry_dtor entry_dtor;
struct timer_list fq_timer;
atomic_t fq_timer_on;
};
azure: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
long unsigned int max32_alloc_size;
struct iova_fq *fq;
atomic64_t fq_flush_start_cnt;
atomic64_t fq_flush_finish_cnt;
struct iova anchor;
struct iova_rcache rcaches[6];
iova_flush_cb flush_cb;
iova_entry_dtor entry_dtor;
struct timer_list fq_timer;
atomic_t fq_timer_on;
};
gcp: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
long unsigned int max32_alloc_size;
struct iova_fq *fq;
atomic64_t fq_flush_start_cnt;
atomic64_t fq_flush_finish_cnt;
struct iova anchor;
struct iova_rcache rcaches[6];
iova_flush_cb flush_cb;
iova_entry_dtor entry_dtor;
struct timer_list fq_timer;
atomic_t fq_timer_on;
};
lowlatency: ✅struct iova_domain {
spinlock_t iova_rbtree_lock;
struct rb_root rbroot;
struct rb_node *cached_node;
struct rb_node *cached32_node;
long unsigned int granule;
long unsigned int start_pfn;
long unsigned int dma_32bit_pfn;
long unsigned int max32_alloc_size;
struct iova_fq *fq;
atomic64_t fq_flush_start_cnt;
atomic64_t fq_flush_finish_cnt;
struct iova anchor;
struct iova_rcache rcaches[6];
iova_flush_cb flush_cb;
iova_entry_dtor entry_dtor;
struct timer_list fq_timer;
atomic_t fq_timer_on;
};
Regular
4.4 and 4.8 ⚠️struct iova_rcache rcaches[6]
4.8 and 4.10 ✅
4.10 and 4.13 ✅
4.13 and 4.15 ⚠️struct rb_node *cached_node
struct iova anchor
iova_flush_cb flush_cb
iova_entry_dtor entry_dtor
struct iova_fq *fq
atomic64_t fq_flush_start_cnt
atomic64_t fq_flush_finish_cnt
struct timer_list fq_timer
atomic_t fq_timer_on
4.15 and 4.18 ✅
4.18 and 5.0 ⚠️long unsigned int max32_alloc_size
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 hlist_node cpuhp_dead
5.13 and 5.15 ✅
5.15 and 5.19 ⚠️struct iova_fq *fq
atomic64_t fq_flush_start_cnt
atomic64_t fq_flush_finish_cnt
iova_flush_cb flush_cb
iova_entry_dtor entry_dtor
struct timer_list fq_timer
atomic_t fq_timer_on
struct iova_rcache rcaches[6] ➡️ struct iova_rcache *rcaches
5.19 and 6.2 ✅
6.2 and 6.5 ✅
6.5 and 6.8 ✅
amd64 and arm64 ✅
generic and aws ✅
generic and azure ✅
generic and gcp ✅
generic and lowlatency ✅