diff options
author | Steffen Klassert <steffen.klassert@secunet.com> | 2014-09-22 10:07:24 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-09-28 22:19:46 +0200 |
commit | 2b0bb01b6edb3e13c7f71e43bf3a173a795b7b66 (patch) | |
tree | 7b5aa53470eadec8abbd7ddb586ba14bc4af86e4 /net/ipv6/ip6_tunnel.c | |
parent | ip6gre: add a rtnl link alias for ip6gretap (diff) | |
download | linux-2b0bb01b6edb3e13c7f71e43bf3a173a795b7b66.tar.xz linux-2b0bb01b6edb3e13c7f71e43bf3a173a795b7b66.zip |
ip6_tunnel: Return an error when adding an existing tunnel.
ip6_tnl_locate() should not return an existing tunnel if
create is true. Otherwise it is possible to add the same
tunnel multiple times without getting an error.
So return NULL if the tunnel that should be created already
exists.
Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv6/ip6_tunnel.c')
-rw-r--r-- | net/ipv6/ip6_tunnel.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/net/ipv6/ip6_tunnel.c b/net/ipv6/ip6_tunnel.c index f9de5a695072..69a84b464009 100644 --- a/net/ipv6/ip6_tunnel.c +++ b/net/ipv6/ip6_tunnel.c @@ -364,8 +364,12 @@ static struct ip6_tnl *ip6_tnl_locate(struct net *net, (t = rtnl_dereference(*tp)) != NULL; tp = &t->next) { if (ipv6_addr_equal(local, &t->parms.laddr) && - ipv6_addr_equal(remote, &t->parms.raddr)) + ipv6_addr_equal(remote, &t->parms.raddr)) { + if (create) + return NULL; + return t; + } } if (!create) return NULL; |