Skip to content

Commit 01026ed

Browse files
Florian Westphalummakynes
authored andcommitted
nefilter: eache: reduce struct size from 32 to 24 byte
Only "cache" needs to use ulong (its used with set_bit()), missed can use u16. Also add build-time assertion to ensure event bits fit. Signed-off-by: Florian Westphal <fw@strlen.de> Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
1 parent c6dd940 commit 01026ed

File tree

3 files changed

+8
-2
lines changed

3 files changed

+8
-2
lines changed

include/net/netfilter/nf_conntrack_ecache.h

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -20,11 +20,11 @@ enum nf_ct_ecache_state {
2020

2121
struct nf_conntrack_ecache {
2222
unsigned long cache; /* bitops want long */
23-
unsigned long missed; /* missed events */
23+
u16 missed; /* missed events */
2424
u16 ctmask; /* bitmask of ct events to be delivered */
2525
u16 expmask; /* bitmask of expect events to be delivered */
26+
enum nf_ct_ecache_state state:8;/* ecache state */
2627
u32 portid; /* netlink portid of destroyer */
27-
enum nf_ct_ecache_state state; /* ecache state */
2828
};
2929

3030
static inline struct nf_conntrack_ecache *

include/uapi/linux/netfilter/nf_conntrack_common.h

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -119,6 +119,9 @@ enum ip_conntrack_events {
119119
IPCT_NATSEQADJ = IPCT_SEQADJ,
120120
IPCT_SECMARK, /* new security mark has been set */
121121
IPCT_LABEL, /* new connlabel has been set */
122+
#ifdef __KERNEL__
123+
__IPCT_MAX
124+
#endif
122125
};
123126

124127
enum ip_conntrack_expect_events {

net/netfilter/nf_conntrack_ecache.c

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -420,6 +420,9 @@ int nf_conntrack_ecache_init(void)
420420
int ret = nf_ct_extend_register(&event_extend);
421421
if (ret < 0)
422422
pr_err("nf_ct_event: Unable to register event extension.\n");
423+
424+
BUILD_BUG_ON(__IPCT_MAX >= 16); /* ctmask, missed use u16 */
425+
423426
return ret;
424427
}
425428

0 commit comments

Comments
 (0)