|
@@ -2187,8 +2187,9 @@ static int rt6_fill_node(struct sk_buff *skb, struct rt6_info *rt,
|
|
#endif
|
|
#endif
|
|
NLA_PUT_U32(skb, RTA_IIF, iif);
|
|
NLA_PUT_U32(skb, RTA_IIF, iif);
|
|
} else if (dst) {
|
|
} else if (dst) {
|
|
|
|
+ struct inet6_dev *idev = ip6_dst_idev(&rt->u.dst);
|
|
struct in6_addr saddr_buf;
|
|
struct in6_addr saddr_buf;
|
|
- if (ipv6_dev_get_saddr(ip6_dst_idev(&rt->u.dst)->dev,
|
|
|
|
|
|
+ if (ipv6_dev_get_saddr(idev ? idev->dev : NULL,
|
|
dst, 0, &saddr_buf) == 0)
|
|
dst, 0, &saddr_buf) == 0)
|
|
NLA_PUT(skb, RTA_PREFSRC, 16, &saddr_buf);
|
|
NLA_PUT(skb, RTA_PREFSRC, 16, &saddr_buf);
|
|
}
|
|
}
|