mirror of
https://github.com/torvalds/linux.git
synced 2026-06-06 13:37:36 +02:00
netfilter: ctnetlink: disable helper autoassign
[ Upstream commitd1ca60efc5] When userspace, e.g. conntrackd, inserts an entry with a specified helper, its possible that the helper is lost immediately after its added: ctnetlink_create_conntrack -> nf_ct_helper_ext_add + assign helper -> ctnetlink_setup_nat -> ctnetlink_parse_nat_setup -> parse_nat_setup -> nfnetlink_parse_nat_setup -> nf_nat_setup_info -> nf_conntrack_alter_reply -> __nf_ct_try_assign_helper ... and __nf_ct_try_assign_helper will zero the helper again. Set IPS_HELPER bit to bypass auto-assign logic, its unwanted, just like when helper is assigned via ruleset. Dropped old 'not strictly necessary' comment, it referred to use of rcu_assign_pointer() before it got replaced by RCU_INIT_POINTER(). NB: Fixes tag intentionally incorrect, this extends the referenced commit, but this change won't build without IPS_HELPER introduced there. Fixes:6714cf5465("netfilter: nf_conntrack: fix explicit helper attachment and NAT") Reported-by: Pham Thanh Tuyen <phamtyn@gmail.com> Signed-off-by: Florian Westphal <fw@strlen.de> Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
a5ce7ee5fc
commit
04fe6569a7
|
|
@ -106,7 +106,7 @@ enum ip_conntrack_status {
|
||||||
IPS_NAT_CLASH = IPS_UNTRACKED,
|
IPS_NAT_CLASH = IPS_UNTRACKED,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Conntrack got a helper explicitly attached via CT target. */
|
/* Conntrack got a helper explicitly attached (ruleset, ctnetlink). */
|
||||||
IPS_HELPER_BIT = 13,
|
IPS_HELPER_BIT = 13,
|
||||||
IPS_HELPER = (1 << IPS_HELPER_BIT),
|
IPS_HELPER = (1 << IPS_HELPER_BIT),
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -2283,7 +2283,8 @@ ctnetlink_create_conntrack(struct net *net,
|
||||||
if (helper->from_nlattr)
|
if (helper->from_nlattr)
|
||||||
helper->from_nlattr(helpinfo, ct);
|
helper->from_nlattr(helpinfo, ct);
|
||||||
|
|
||||||
/* not in hash table yet so not strictly necessary */
|
/* disable helper auto-assignment for this entry */
|
||||||
|
ct->status |= IPS_HELPER;
|
||||||
RCU_INIT_POINTER(help->helper, helper);
|
RCU_INIT_POINTER(help->helper, helper);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user