netfront_queue
Regular
4.4
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
union skb_entry tx_skbs[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
};
4.8
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
union skb_entry tx_skbs[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
};
4.10
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
union skb_entry tx_skbs[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
};
4.13
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
union skb_entry tx_skbs[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
};
4.15
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
union skb_entry tx_skbs[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
};
4.18
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
union skb_entry tx_skbs[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
};
5.0
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
union skb_entry tx_skbs[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
};
5.3
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
union skb_entry tx_skbs[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
};
5.4
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
union skb_entry tx_skbs[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
};
5.8
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
union skb_entry tx_skbs[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
};
5.11
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct bpf_prog *xdp_prog;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
union skb_entry tx_skbs[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
struct page_pool *page_pool;
struct xdp_rxq_info xdp_rxq;
};
5.13
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct bpf_prog *xdp_prog;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
union skb_entry tx_skbs[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
struct page_pool *page_pool;
struct xdp_rxq_info xdp_rxq;
};
5.15
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct bpf_prog *xdp_prog;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
struct sk_buff * tx_skbs[256];
short unsigned int tx_link[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
unsigned int tx_pend_queue;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
unsigned int rx_rsp_unconsumed;
spinlock_t rx_cons_lock;
struct page_pool *page_pool;
struct xdp_rxq_info xdp_rxq;
};
5.19
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct bpf_prog *xdp_prog;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
struct sk_buff * tx_skbs[256];
short unsigned int tx_link[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
unsigned int tx_pend_queue;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
unsigned int rx_rsp_unconsumed;
spinlock_t rx_cons_lock;
struct page_pool *page_pool;
struct xdp_rxq_info xdp_rxq;
};
6.2
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct bpf_prog *xdp_prog;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
struct sk_buff * tx_skbs[256];
short unsigned int tx_link[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
unsigned int tx_pend_queue;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
unsigned int rx_rsp_unconsumed;
spinlock_t rx_cons_lock;
struct page_pool *page_pool;
struct xdp_rxq_info xdp_rxq;
};
6.5
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct bpf_prog *xdp_prog;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
struct sk_buff * tx_skbs[256];
short unsigned int tx_link[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
unsigned int tx_pend_queue;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
unsigned int rx_rsp_unconsumed;
spinlock_t rx_cons_lock;
struct page_pool *page_pool;
struct xdp_rxq_info xdp_rxq;
};
6.8
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct bpf_prog *xdp_prog;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
struct sk_buff * tx_skbs[256];
short unsigned int tx_link[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
unsigned int tx_pend_queue;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
unsigned int rx_rsp_unconsumed;
spinlock_t rx_cons_lock;
struct page_pool *page_pool;
struct xdp_rxq_info xdp_rxq;
};
arm64
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
union skb_entry tx_skbs[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
};
armhf
: Absent ⚠️
ppc64el
: Absent ⚠️
riscv64
: Absent ⚠️
aws
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
union skb_entry tx_skbs[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
};
azure
: Absent ⚠️
gcp
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
union skb_entry tx_skbs[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
};
lowlatency
: ✅struct netfront_queue {
unsigned int id;
char name[22];
struct netfront_info *info;
struct napi_struct napi;
unsigned int tx_evtchn;
unsigned int rx_evtchn;
unsigned int tx_irq;
unsigned int rx_irq;
char tx_irq_name[25];
char rx_irq_name[25];
spinlock_t tx_lock;
struct xen_netif_tx_front_ring tx;
int tx_ring_ref;
union skb_entry tx_skbs[256];
grant_ref_t gref_tx_head;
grant_ref_t grant_tx_ref[256];
struct page * grant_tx_page[256];
unsigned int tx_skb_freelist;
spinlock_t rx_lock;
struct xen_netif_rx_front_ring rx;
int rx_ring_ref;
struct timer_list rx_refill_timer;
struct sk_buff * rx_skbs[256];
grant_ref_t gref_rx_head;
grant_ref_t grant_rx_ref[256];
};
Regular
4.4
and 4.8
✅
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
✅
5.3
and 5.4
✅
5.4
and 5.8
✅
5.8
and 5.11
⚠️struct bpf_prog *xdp_prog
struct page_pool *page_pool
struct xdp_rxq_info xdp_rxq
5.11
and 5.13
✅
5.13
and 5.15
⚠️short unsigned int tx_link[256]
unsigned int tx_pend_queue
unsigned int rx_rsp_unconsumed
spinlock_t rx_cons_lock
union skb_entry tx_skbs[256]
➡️ struct sk_buff * tx_skbs[256]
5.15
and 5.19
✅
5.19
and 6.2
✅
6.2
and 6.5
✅
6.5
and 6.8
✅
amd64
and arm64
✅
generic
and aws
✅
generic
and gcp
✅
generic
and lowlatency
✅