aboutsummaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorDavid Ahern <dsahern@gmail.com>2018-04-18 18:39:03 -0400
committerDavid S. Miller <davem@davemloft.net>2018-04-19 15:40:13 -0400
commit6fe749414446d86cfaae1c84bfdd556fe4fa8fca (patch)
tree698e52234d27958caf294af6a6dd26995d94c44c /include
parenteea68cd371a8fa7d8dbfcf75bc076e8379526119 (diff)
net/ipv6: Change ip6_route_get_saddr to get dev from route
Prior to 4832c30d5458 ("net: ipv6: put host and anycast routes on device with address") host routes and anycast routes were installed with the device set to loopback (or VRF device once that feature was added). In the older code dst.dev was set to loopback (needed for packet tx) and rt6i_idev was used to denote the actual interface. Commit 4832c30d5458 changed the code to have dst.dev pointing to the real device with the switch to lo or vrf device done on dst clones. As a consequence of this change ip6_route_get_saddr can just pass the nexthop device to ipv6_dev_get_saddr. Signed-off-by: David Ahern <dsahern@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include')
-rw-r--r--include/net/ip6_route.h11
1 files changed, 6 insertions, 5 deletions
diff --git a/include/net/ip6_route.h b/include/net/ip6_route.h
index 31e24f821ef6..c0620330035c 100644
--- a/include/net/ip6_route.h
+++ b/include/net/ip6_route.h
@@ -114,14 +114,15 @@ static inline int ip6_route_get_saddr(struct net *net, struct fib6_info *f6i,
114 unsigned int prefs, 114 unsigned int prefs,
115 struct in6_addr *saddr) 115 struct in6_addr *saddr)
116{ 116{
117 struct inet6_dev *idev = f6i ? f6i->fib6_idev : NULL;
118 int err = 0; 117 int err = 0;
119 118
120 if (f6i && f6i->fib6_prefsrc.plen) 119 if (f6i && f6i->fib6_prefsrc.plen) {
121 *saddr = f6i->fib6_prefsrc.addr; 120 *saddr = f6i->fib6_prefsrc.addr;
122 else 121 } else {
123 err = ipv6_dev_get_saddr(net, idev ? idev->dev : NULL, 122 struct net_device *dev = f6i ? fib6_info_nh_dev(f6i) : NULL;
124 daddr, prefs, saddr); 123
124 err = ipv6_dev_get_saddr(net, dev, daddr, prefs, saddr);
125 }
125 126
126 return err; 127 return err;
127} 128}