tunnels: missing rcu_assign_pointer()
xfrm4_tunnel_register() & xfrm6_tunnel_register() should use rcu_assign_pointer() to make sure previous writes (to handler->next) are committed to memory before chain insertion. deregister functions dont need a particular barrier. Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
f39234d606
commit
49d61e2390
|
@ -39,7 +39,7 @@ int xfrm4_tunnel_register(struct xfrm_tunnel *handler, unsigned short family)
|
||||||
}
|
}
|
||||||
|
|
||||||
handler->next = *pprev;
|
handler->next = *pprev;
|
||||||
*pprev = handler;
|
rcu_assign_pointer(*pprev, handler);
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
|
|
|
@ -51,7 +51,7 @@ int xfrm6_tunnel_register(struct xfrm6_tunnel *handler, unsigned short family)
|
||||||
}
|
}
|
||||||
|
|
||||||
handler->next = *pprev;
|
handler->next = *pprev;
|
||||||
*pprev = handler;
|
rcu_assign_pointer(*pprev, handler);
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue