diff options
author | David S. Miller <davem@davemloft.net> | 2012-06-09 22:12:36 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-06-09 22:12:36 -0400 |
commit | c0efc887dcadbdbfe171f028acfab9c7c00e9dde (patch) | |
tree | d2f628d6c222c6328a6f310378d7227c32ebf183 /net | |
parent | 8b51b064a6da90c68af5385a874968829a2a0ed7 (diff) |
inet: Pass inetpeer root into inet_getpeer*() interfaces.
Otherwise we reference potentially non-existing members when
ipv6 is disabled.
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
-rw-r--r-- | net/ipv4/inetpeer.c | 9 | ||||
-rw-r--r-- | net/ipv4/ip_fragment.c | 2 | ||||
-rw-r--r-- | net/ipv4/route.c | 6 | ||||
-rw-r--r-- | net/ipv6/route.c | 2 |
4 files changed, 6 insertions, 13 deletions
diff --git a/net/ipv4/inetpeer.c b/net/ipv4/inetpeer.c index 9d89a381f0e1..e4cba56a5349 100644 --- a/net/ipv4/inetpeer.c +++ b/net/ipv4/inetpeer.c | |||
@@ -391,12 +391,6 @@ static void unlink_from_pool(struct inet_peer *p, struct inet_peer_base *base, | |||
391 | call_rcu(&p->rcu, inetpeer_free_rcu); | 391 | call_rcu(&p->rcu, inetpeer_free_rcu); |
392 | } | 392 | } |
393 | 393 | ||
394 | static struct inet_peer_base *family_to_base(struct net *net, | ||
395 | int family) | ||
396 | { | ||
397 | return family == AF_INET ? net->ipv4.peers : net->ipv6.peers; | ||
398 | } | ||
399 | |||
400 | /* perform garbage collect on all items stacked during a lookup */ | 394 | /* perform garbage collect on all items stacked during a lookup */ |
401 | static int inet_peer_gc(struct inet_peer_base *base, | 395 | static int inet_peer_gc(struct inet_peer_base *base, |
402 | struct inet_peer __rcu **stack[PEER_MAXDEPTH], | 396 | struct inet_peer __rcu **stack[PEER_MAXDEPTH], |
@@ -434,12 +428,11 @@ static int inet_peer_gc(struct inet_peer_base *base, | |||
434 | return cnt; | 428 | return cnt; |
435 | } | 429 | } |
436 | 430 | ||
437 | struct inet_peer *inet_getpeer(struct net *net, | 431 | struct inet_peer *inet_getpeer(struct inet_peer_base *base, |
438 | const struct inetpeer_addr *daddr, | 432 | const struct inetpeer_addr *daddr, |
439 | int create) | 433 | int create) |
440 | { | 434 | { |
441 | struct inet_peer __rcu **stack[PEER_MAXDEPTH], ***stackptr; | 435 | struct inet_peer __rcu **stack[PEER_MAXDEPTH], ***stackptr; |
442 | struct inet_peer_base *base = family_to_base(net, daddr->family); | ||
443 | struct inet_peer *p; | 436 | struct inet_peer *p; |
444 | unsigned int sequence; | 437 | unsigned int sequence; |
445 | int invalidated, gccnt = 0; | 438 | int invalidated, gccnt = 0; |
diff --git a/net/ipv4/ip_fragment.c b/net/ipv4/ip_fragment.c index 22c6bab9717a..8d07c973409c 100644 --- a/net/ipv4/ip_fragment.c +++ b/net/ipv4/ip_fragment.c | |||
@@ -184,7 +184,7 @@ static void ip4_frag_init(struct inet_frag_queue *q, void *a) | |||
184 | qp->daddr = arg->iph->daddr; | 184 | qp->daddr = arg->iph->daddr; |
185 | qp->user = arg->user; | 185 | qp->user = arg->user; |
186 | qp->peer = sysctl_ipfrag_max_dist ? | 186 | qp->peer = sysctl_ipfrag_max_dist ? |
187 | inet_getpeer_v4(net, arg->iph->saddr, 1) : NULL; | 187 | inet_getpeer_v4(net->ipv4.peers, arg->iph->saddr, 1) : NULL; |
188 | } | 188 | } |
189 | 189 | ||
190 | static __inline__ void ip4_frag_free(struct inet_frag_queue *q) | 190 | static __inline__ void ip4_frag_free(struct inet_frag_queue *q) |
diff --git a/net/ipv4/route.c b/net/ipv4/route.c index cf78343940de..2aa663a6ae9e 100644 --- a/net/ipv4/route.c +++ b/net/ipv4/route.c | |||
@@ -1328,7 +1328,7 @@ void rt_bind_peer(struct rtable *rt, __be32 daddr, int create) | |||
1328 | struct net *net = dev_net(rt->dst.dev); | 1328 | struct net *net = dev_net(rt->dst.dev); |
1329 | struct inet_peer *peer; | 1329 | struct inet_peer *peer; |
1330 | 1330 | ||
1331 | peer = inet_getpeer_v4(net, daddr, create); | 1331 | peer = inet_getpeer_v4(net->ipv4.peers, daddr, create); |
1332 | 1332 | ||
1333 | if (peer && cmpxchg(&rt->peer, NULL, peer) != NULL) | 1333 | if (peer && cmpxchg(&rt->peer, NULL, peer) != NULL) |
1334 | inet_putpeer(peer); | 1334 | inet_putpeer(peer); |
@@ -1684,7 +1684,7 @@ unsigned short ip_rt_frag_needed(struct net *net, const struct iphdr *iph, | |||
1684 | unsigned short est_mtu = 0; | 1684 | unsigned short est_mtu = 0; |
1685 | struct inet_peer *peer; | 1685 | struct inet_peer *peer; |
1686 | 1686 | ||
1687 | peer = inet_getpeer_v4(net, iph->daddr, 1); | 1687 | peer = inet_getpeer_v4(net->ipv4.peers, iph->daddr, 1); |
1688 | if (peer) { | 1688 | if (peer) { |
1689 | unsigned short mtu = new_mtu; | 1689 | unsigned short mtu = new_mtu; |
1690 | 1690 | ||
@@ -1929,7 +1929,7 @@ static void rt_init_metrics(struct rtable *rt, const struct flowi4 *fl4, | |||
1929 | if (fl4 && (fl4->flowi4_flags & FLOWI_FLAG_PRECOW_METRICS)) | 1929 | if (fl4 && (fl4->flowi4_flags & FLOWI_FLAG_PRECOW_METRICS)) |
1930 | create = 1; | 1930 | create = 1; |
1931 | 1931 | ||
1932 | rt->peer = peer = inet_getpeer_v4(net, rt->rt_dst, create); | 1932 | rt->peer = peer = inet_getpeer_v4(net->ipv4.peers, rt->rt_dst, create); |
1933 | if (peer) { | 1933 | if (peer) { |
1934 | rt->rt_peer_genid = rt_peer_genid(); | 1934 | rt->rt_peer_genid = rt_peer_genid(); |
1935 | if (inet_metrics_new(peer)) | 1935 | if (inet_metrics_new(peer)) |
diff --git a/net/ipv6/route.c b/net/ipv6/route.c index 9586c27e069c..8fc41d502bbd 100644 --- a/net/ipv6/route.c +++ b/net/ipv6/route.c | |||
@@ -306,7 +306,7 @@ void rt6_bind_peer(struct rt6_info *rt, int create) | |||
306 | struct net *net = dev_net(rt->dst.dev); | 306 | struct net *net = dev_net(rt->dst.dev); |
307 | struct inet_peer *peer; | 307 | struct inet_peer *peer; |
308 | 308 | ||
309 | peer = inet_getpeer_v6(net, &rt->rt6i_dst.addr, create); | 309 | peer = inet_getpeer_v6(net->ipv6.peers, &rt->rt6i_dst.addr, create); |
310 | if (peer && cmpxchg(&rt->rt6i_peer, NULL, peer) != NULL) | 310 | if (peer && cmpxchg(&rt->rt6i_peer, NULL, peer) != NULL) |
311 | inet_putpeer(peer); | 311 | inet_putpeer(peer); |
312 | else | 312 | else |