|
@@ -24,7 +24,8 @@ int ip6_route_me_harder(struct net *net, struct sk_buff *skb)
|
|
|
unsigned int hh_len;
|
|
|
struct dst_entry *dst;
|
|
|
struct flowi6 fl6 = {
|
|
|
- .flowi6_oif = sk ? sk->sk_bound_dev_if : 0,
|
|
|
+ .flowi6_oif = sk && sk->sk_bound_dev_if ? sk->sk_bound_dev_if :
|
|
|
+ rt6_need_strict(&iph->daddr) ? skb_dst(skb)->dev->ifindex : 0,
|
|
|
.flowi6_mark = skb->mark,
|
|
|
.flowi6_uid = sock_net_uid(net, sk),
|
|
|
.daddr = iph->daddr,
|