mirror of
https://gitee.com/bianbu-linux/linux-6.6
synced 2025-04-24 14:07:52 -04:00
netfilter: conntrack: Fix data-races around ct mark
nf_conn:mark can be read from and written to in parallel. Use
READ_ONCE()/WRITE_ONCE() for reads and writes to prevent unwanted
compiler optimizations.
Fixes: 1da177e4c3
("Linux-2.6.12-rc2")
Signed-off-by: Daniel Xu <dxu@dxuuu.xyz>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
This commit is contained in:
parent
40b9d1ab63
commit
52d1aa8b82
11 changed files with 45 additions and 39 deletions
|
@ -152,7 +152,7 @@ static u8 ovs_ct_get_state(enum ip_conntrack_info ctinfo)
|
|||
static u32 ovs_ct_get_mark(const struct nf_conn *ct)
|
||||
{
|
||||
#if IS_ENABLED(CONFIG_NF_CONNTRACK_MARK)
|
||||
return ct ? ct->mark : 0;
|
||||
return ct ? READ_ONCE(ct->mark) : 0;
|
||||
#else
|
||||
return 0;
|
||||
#endif
|
||||
|
@ -340,9 +340,9 @@ static int ovs_ct_set_mark(struct nf_conn *ct, struct sw_flow_key *key,
|
|||
#if IS_ENABLED(CONFIG_NF_CONNTRACK_MARK)
|
||||
u32 new_mark;
|
||||
|
||||
new_mark = ct_mark | (ct->mark & ~(mask));
|
||||
if (ct->mark != new_mark) {
|
||||
ct->mark = new_mark;
|
||||
new_mark = ct_mark | (READ_ONCE(ct->mark) & ~(mask));
|
||||
if (READ_ONCE(ct->mark) != new_mark) {
|
||||
WRITE_ONCE(ct->mark, new_mark);
|
||||
if (nf_ct_is_confirmed(ct))
|
||||
nf_conntrack_event_cache(IPCT_MARK, ct);
|
||||
key->ct.mark = new_mark;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue