[NETFILTER]: Fix NULL pointer dereference in nf_nat_move_storage()
Reported by Chuck Ebbert as: https://bugzilla.redhat.com/show_bug.cgi?id=259501#c14 This routine is called each time hash should be replaced, nf_conn has extension list which contains pointers to connection tracking users (like nat, which is right now the only such user), so when replace takes place it should copy own extensions. Loop above checks for own extension, but tries to move higer-layer one, which can lead to above oops. Signed-off-by: Evgeniy Polyakov <johnpol@2ka.mipt.ru> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
a5a97263a9
commit
7799652557
1 changed files with 1 additions and 1 deletions
|
@ -109,7 +109,7 @@ void *__nf_ct_ext_add(struct nf_conn *ct, enum nf_ct_ext_id id, gfp_t gfp)
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
t = rcu_dereference(nf_ct_ext_types[i]);
|
t = rcu_dereference(nf_ct_ext_types[i]);
|
||||||
if (t && t->move)
|
if (t && t->move)
|
||||||
t->move(ct, ct->ext + ct->ext->offset[id]);
|
t->move(ct, ct->ext + ct->ext->offset[i]);
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
}
|
}
|
||||||
kfree(ct->ext);
|
kfree(ct->ext);
|
||||||
|
|
Loading…
Reference in a new issue