ipvs: do not use dest after ip_vs_dest_put in LBLC
authorJulian Anastasov <ja@ssi.bg>
Thu, 12 Sep 2013 08:21:08 +0000 (11:21 +0300)
committerSimon Horman <horms@verge.net.au>
Wed, 18 Sep 2013 19:39:09 +0000 (14:39 -0500)
commit2f3d771a35fee21a1f17364b46b3c8cc66dc6892
tree353158f116b4b25c89f7526f85e75002d98e3190
parentbcbde4c0a7556cca72874c5e1efa4dccb5198a2b
ipvs: do not use dest after ip_vs_dest_put in LBLC

commit c2a4ffb70eef39 ("ipvs: convert lblc scheduler to rcu")
allows RCU readers to use dest after calling ip_vs_dest_put().
In the corner case it can race with ip_vs_dest_trash_expire()
which can release the dest while it is being returned to the
RCU readers as scheduling result.

To fix the problem do not allow en->dest to be replaced and
defer the ip_vs_dest_put() call by using RCU callback. Now
en->dest does not need to be RCU pointer.

Signed-off-by: Julian Anastasov <ja@ssi.bg>
Signed-off-by: Simon Horman <horms@verge.net.au>
net/netfilter/ipvs/ip_vs_lblc.c