tcf_blockRegular
4.4: Absent ⚠️
4.8: Absent ⚠️
4.10: Absent ⚠️
4.13: ✅struct tcf_block {
struct list_head chain_list;
};
4.15: ✅struct tcf_block {
struct list_head chain_list;
struct net *net;
struct Qdisc *q;
struct list_head cb_list;
};
4.18: ✅struct tcf_block {
struct list_head chain_list;
u32 index;
unsigned int refcnt;
struct net *net;
struct Qdisc *q;
struct list_head cb_list;
struct list_head owner_list;
bool keep_dst;
unsigned int offloadcnt;
unsigned int nooffloaddevcnt;
};
5.0: ✅struct tcf_block {
struct list_head chain_list;
u32 index;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct list_head cb_list;
struct list_head owner_list;
bool keep_dst;
unsigned int offloadcnt;
unsigned int nooffloaddevcnt;
struct (anon) chain0;
struct callback_head rcu;
};
5.3: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
unsigned int offloadcnt;
unsigned int nooffloaddevcnt;
struct (anon) chain0;
struct callback_head rcu;
};
5.4: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
5.8: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
u32 classid;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
5.11: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
u32 classid;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
5.13: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
u32 classid;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
5.15: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
u32 classid;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
5.19: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
u32 classid;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
6.2: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
u32 classid;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
6.5: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
u32 classid;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
6.8: ✅struct tcf_block {
struct xarray ports;
struct mutex lock;
struct list_head chain_list;
u32 index;
u32 classid;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
arm64: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
armhf: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
ppc64el: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
riscv64: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
aws: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
azure: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
gcp: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
lowlatency: ✅struct tcf_block {
struct mutex lock;
struct list_head chain_list;
u32 index;
refcount_t refcnt;
struct net *net;
struct Qdisc *q;
struct rw_semaphore cb_lock;
struct flow_block flow_block;
struct list_head owner_list;
bool keep_dst;
atomic_t offloadcnt;
unsigned int nooffloaddevcnt;
unsigned int lockeddevcnt;
struct (anon) chain0;
struct callback_head rcu;
struct hlist_head proto_destroy_ht[128];
struct mutex proto_destroy_lock;
};
Regular
4.13 and 4.15 ⚠️struct net *net
struct Qdisc *q
struct list_head cb_list
4.15 and 4.18 ⚠️u32 index
unsigned int refcnt
struct list_head owner_list
bool keep_dst
unsigned int offloadcnt
unsigned int nooffloaddevcnt
4.18 and 5.0 ⚠️struct (anon) chain0
struct callback_head rcu
unsigned int refcnt ➡️ refcount_t refcnt
5.0 and 5.3 ⚠️struct mutex lock
struct flow_block flow_block
struct list_head cb_list
5.3 and 5.4 ⚠️struct rw_semaphore cb_lock
unsigned int lockeddevcnt
struct hlist_head proto_destroy_ht[128]
struct mutex proto_destroy_lock
unsigned int offloadcnt ➡️ atomic_t offloadcnt
5.4 and 5.8 ⚠️u32 classid
5.8 and 5.11 ✅
5.11 and 5.13 ✅
5.13 and 5.15 ✅
5.15 and 5.19 ✅
5.19 and 6.2 ✅
6.2 and 6.5 ✅
6.5 and 6.8 ⚠️struct xarray ports
amd64 and arm64 ✅
amd64 and armhf ✅
amd64 and ppc64el ✅
amd64 and riscv64 ✅
generic and aws ✅
generic and azure ✅
generic and gcp ✅
generic and lowlatency ✅