diff options
Diffstat (limited to 'net/ipv4/route.c')
| -rw-r--r-- | net/ipv4/route.c | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/net/ipv4/route.c b/net/ipv4/route.c index 34d094cadb11..db1e0da871f4 100644 --- a/net/ipv4/route.c +++ b/net/ipv4/route.c | |||
| @@ -1129,7 +1129,7 @@ static void ipv4_link_failure(struct sk_buff *skb) | |||
| 1129 | dst_set_expires(&rt->dst, 0); | 1129 | dst_set_expires(&rt->dst, 0); |
| 1130 | } | 1130 | } |
| 1131 | 1131 | ||
| 1132 | static int ip_rt_bug(struct sk_buff *skb) | 1132 | static int ip_rt_bug(struct sock *sk, struct sk_buff *skb) |
| 1133 | { | 1133 | { |
| 1134 | pr_debug("%s: %pI4 -> %pI4, %s\n", | 1134 | pr_debug("%s: %pI4 -> %pI4, %s\n", |
| 1135 | __func__, &ip_hdr(skb)->saddr, &ip_hdr(skb)->daddr, | 1135 | __func__, &ip_hdr(skb)->saddr, &ip_hdr(skb)->daddr, |
| @@ -1700,8 +1700,7 @@ static int ip_route_input_slow(struct sk_buff *skb, __be32 daddr, __be32 saddr, | |||
| 1700 | 1700 | ||
| 1701 | if (res.type == RTN_LOCAL) { | 1701 | if (res.type == RTN_LOCAL) { |
| 1702 | err = fib_validate_source(skb, saddr, daddr, tos, | 1702 | err = fib_validate_source(skb, saddr, daddr, tos, |
| 1703 | LOOPBACK_IFINDEX, | 1703 | 0, dev, in_dev, &itag); |
| 1704 | dev, in_dev, &itag); | ||
| 1705 | if (err < 0) | 1704 | if (err < 0) |
| 1706 | goto martian_source_keep_err; | 1705 | goto martian_source_keep_err; |
| 1707 | goto local_input; | 1706 | goto local_input; |
| @@ -2218,7 +2217,7 @@ struct dst_entry *ipv4_blackhole_route(struct net *net, struct dst_entry *dst_or | |||
| 2218 | 2217 | ||
| 2219 | new->__use = 1; | 2218 | new->__use = 1; |
| 2220 | new->input = dst_discard; | 2219 | new->input = dst_discard; |
| 2221 | new->output = dst_discard; | 2220 | new->output = dst_discard_sk; |
| 2222 | 2221 | ||
| 2223 | new->dev = ort->dst.dev; | 2222 | new->dev = ort->dst.dev; |
| 2224 | if (new->dev) | 2223 | if (new->dev) |
| @@ -2357,7 +2356,7 @@ static int rt_fill_info(struct net *net, __be32 dst, __be32 src, | |||
| 2357 | } | 2356 | } |
| 2358 | } else | 2357 | } else |
| 2359 | #endif | 2358 | #endif |
| 2360 | if (nla_put_u32(skb, RTA_IIF, rt->rt_iif)) | 2359 | if (nla_put_u32(skb, RTA_IIF, skb->dev->ifindex)) |
| 2361 | goto nla_put_failure; | 2360 | goto nla_put_failure; |
| 2362 | } | 2361 | } |
| 2363 | 2362 | ||
