[NETNS]: Correct namespace for connect-time routing.

ip_route_connect and ip_route_newports are a part of routing API
presented to the socket layer. The namespace is available inside them
through a socket.

Signed-off-by: Denis V. Lunev <den@openvz.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Denis V. Lunev 2008-01-22 23:49:35 -08:00 committed by David S. Miller
parent 7ba699c604
commit eee80592c3
1 changed files with 5 additions and 3 deletions

View File

@ -33,6 +33,7 @@
#include <linux/ip.h> #include <linux/ip.h>
#include <linux/cache.h> #include <linux/cache.h>
#include <linux/security.h> #include <linux/security.h>
#include <net/sock.h>
#ifndef __KERNEL__ #ifndef __KERNEL__
#warning This file is not supposed to be used outside of kernel. #warning This file is not supposed to be used outside of kernel.
@ -157,8 +158,9 @@ static inline int ip_route_connect(struct rtable **rp, __be32 dst,
.dport = dport } } }; .dport = dport } } };
int err; int err;
struct net *net = sk->sk_net;
if (!dst || !src) { if (!dst || !src) {
err = __ip_route_output_key(&init_net, rp, &fl); err = __ip_route_output_key(net, rp, &fl);
if (err) if (err)
return err; return err;
fl.fl4_dst = (*rp)->rt_dst; fl.fl4_dst = (*rp)->rt_dst;
@ -167,7 +169,7 @@ static inline int ip_route_connect(struct rtable **rp, __be32 dst,
*rp = NULL; *rp = NULL;
} }
security_sk_classify_flow(sk, &fl); security_sk_classify_flow(sk, &fl);
return ip_route_output_flow(&init_net, rp, &fl, sk, flags); return ip_route_output_flow(net, rp, &fl, sk, flags);
} }
static inline int ip_route_newports(struct rtable **rp, u8 protocol, static inline int ip_route_newports(struct rtable **rp, u8 protocol,
@ -184,7 +186,7 @@ static inline int ip_route_newports(struct rtable **rp, u8 protocol,
ip_rt_put(*rp); ip_rt_put(*rp);
*rp = NULL; *rp = NULL;
security_sk_classify_flow(sk, &fl); security_sk_classify_flow(sk, &fl);
return ip_route_output_flow(&init_net, rp, &fl, sk, 0); return ip_route_output_flow(sk->sk_net, rp, &fl, sk, 0);
} }
return 0; return 0;
} }