Commit eee80592 authored by Denis V. Lunev's avatar Denis V. Lunev Committed by David S. Miller

[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: default avatarDenis V. Lunev <den@openvz.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 7ba699c6
...@@ -33,6 +33,7 @@ ...@@ -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, ...@@ -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, ...@@ -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, ...@@ -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;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment