summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJulian Anastasov2015-06-27 13:39:30 +0200
committerSimon Horman2015-07-14 09:41:27 +0200
commit4754957f04f5f368792a0eb7dab0ae89fb93dcfd (patch)
treeb26da24dccaaa7d2a30c40cb06290efcc1cada26
parentipvs: fix ipv6 route unreach panic (diff)
downloadkernel-qcow2-linux-4754957f04f5f368792a0eb7dab0ae89fb93dcfd.tar.gz
kernel-qcow2-linux-4754957f04f5f368792a0eb7dab0ae89fb93dcfd.tar.xz
kernel-qcow2-linux-4754957f04f5f368792a0eb7dab0ae89fb93dcfd.zip
ipvs: do not use random local source address for tunnels
Michael Vallaly reports about wrong source address used in rare cases for tunneled traffic. Looks like __ip_vs_get_out_rt in 3.10+ is providing uninitialized dest_dst->dst_saddr.ip because ip_vs_dest_dst_alloc uses kmalloc. While we retry after seeing EINVAL from routing for data that does not look like valid local address, it still succeeded when this memory was previously used from other dests and with different local addresses. As result, we can use valid local address that is not suitable for our real server. Fix it by providing 0.0.0.0 every time our cache is refreshed. By this way we will get preferred source address from routing. Reported-by: Michael Vallaly <lvs@nolatency.com> Fixes: 026ace060dfe ("ipvs: optimize dst usage for real server") Signed-off-by: Julian Anastasov <ja@ssi.bg> Signed-off-by: Simon Horman <horms@verge.net.au>
-rw-r--r--net/netfilter/ipvs/ip_vs_xmit.c1
1 files changed, 0 insertions, 1 deletions
diff --git a/net/netfilter/ipvs/ip_vs_xmit.c b/net/netfilter/ipvs/ip_vs_xmit.c
index b99d80695b1f..ec30d68ccc0b 100644
--- a/net/netfilter/ipvs/ip_vs_xmit.c
+++ b/net/netfilter/ipvs/ip_vs_xmit.c
@@ -130,7 +130,6 @@ static struct rtable *do_output_route4(struct net *net, __be32 daddr,
memset(&fl4, 0, sizeof(fl4));
fl4.daddr = daddr;
- fl4.saddr = (rt_mode & IP_VS_RT_MODE_CONNECT) ? *saddr : 0;
fl4.flowi4_flags = (rt_mode & IP_VS_RT_MODE_KNOWN_NH) ?
FLOWI_FLAG_KNOWN_NH : 0;