Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 01026ede authored by Florian Westphal's avatar Florian Westphal Committed by Pablo Neira Ayuso
Browse files

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: default avatarFlorian Westphal <fw@strlen.de>
Signed-off-by: default avatarPablo Neira Ayuso <pablo@netfilter.org>
parent c6dd940b
Loading
Loading
Loading
Loading
+2 −2
Original line number Diff line number Diff line
@@ -20,11 +20,11 @@ enum nf_ct_ecache_state {

struct nf_conntrack_ecache {
	unsigned long cache;		/* bitops want long */
	unsigned long missed;		/* missed events */
	u16 missed;			/* missed events */
	u16 ctmask;			/* bitmask of ct events to be delivered */
	u16 expmask;			/* bitmask of expect events to be delivered */
	enum nf_ct_ecache_state state:8;/* ecache state */
	u32 portid;			/* netlink portid of destroyer */
	enum nf_ct_ecache_state state;	/* ecache state */
};

static inline struct nf_conntrack_ecache *
+3 −0
Original line number Diff line number Diff line
@@ -119,6 +119,9 @@ enum ip_conntrack_events {
	IPCT_NATSEQADJ = IPCT_SEQADJ,
	IPCT_SECMARK,		/* new security mark has been set */
	IPCT_LABEL,		/* new connlabel has been set */
#ifdef __KERNEL__
	__IPCT_MAX
#endif
};

enum ip_conntrack_expect_events {
+3 −0
Original line number Diff line number Diff line
@@ -420,6 +420,9 @@ int nf_conntrack_ecache_init(void)
	int ret = nf_ct_extend_register(&event_extend);
	if (ret < 0)
		pr_err("nf_ct_event: Unable to register event extension.\n");

	BUILD_BUG_ON(__IPCT_MAX >= 16);	/* ctmask, missed use u16 */

	return ret;
}