diff options
author | David S. Miller <davem@davemloft.net> | 2012-07-23 16:57:45 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-07-23 19:36:27 -0400 |
commit | 13378cad02afc2adc6c0e07fca03903c7ada0b37 (patch) | |
tree | e12625227f409a7b658c4f39a2dc926cf60bb27e /net/ipv4/route.c | |
parent | b68581778cd0051a3fb9a2b614dee7eccb5127ff (diff) |
ipv4: Change rt->rt_iif encoding.
On input packet processing, rt->rt_iif will be zero if we should
use skb->dev->ifindex.
Since we access rt->rt_iif consistently via inet_iif(), that is
the only spot whose interpretation have to adjust.
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4/route.c')
-rw-r--r-- | net/ipv4/route.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/net/ipv4/route.c b/net/ipv4/route.c index f6be78119396..6bcb8fc71cbc 100644 --- a/net/ipv4/route.c +++ b/net/ipv4/route.c | |||
@@ -1309,7 +1309,7 @@ static int ip_route_input_mc(struct sk_buff *skb, __be32 daddr, __be32 saddr, | |||
1309 | rth->rt_flags = RTCF_MULTICAST; | 1309 | rth->rt_flags = RTCF_MULTICAST; |
1310 | rth->rt_type = RTN_MULTICAST; | 1310 | rth->rt_type = RTN_MULTICAST; |
1311 | rth->rt_is_input= 1; | 1311 | rth->rt_is_input= 1; |
1312 | rth->rt_iif = dev->ifindex; | 1312 | rth->rt_iif = 0; |
1313 | rth->rt_pmtu = 0; | 1313 | rth->rt_pmtu = 0; |
1314 | rth->rt_gateway = 0; | 1314 | rth->rt_gateway = 0; |
1315 | if (our) { | 1315 | if (our) { |
@@ -1435,7 +1435,7 @@ static int __mkroute_input(struct sk_buff *skb, | |||
1435 | rth->rt_flags = flags; | 1435 | rth->rt_flags = flags; |
1436 | rth->rt_type = res->type; | 1436 | rth->rt_type = res->type; |
1437 | rth->rt_is_input = 1; | 1437 | rth->rt_is_input = 1; |
1438 | rth->rt_iif = in_dev->dev->ifindex; | 1438 | rth->rt_iif = 0; |
1439 | rth->rt_pmtu = 0; | 1439 | rth->rt_pmtu = 0; |
1440 | rth->rt_gateway = 0; | 1440 | rth->rt_gateway = 0; |
1441 | 1441 | ||
@@ -1608,7 +1608,7 @@ local_input: | |||
1608 | rth->rt_flags = flags|RTCF_LOCAL; | 1608 | rth->rt_flags = flags|RTCF_LOCAL; |
1609 | rth->rt_type = res.type; | 1609 | rth->rt_type = res.type; |
1610 | rth->rt_is_input = 1; | 1610 | rth->rt_is_input = 1; |
1611 | rth->rt_iif = dev->ifindex; | 1611 | rth->rt_iif = 0; |
1612 | rth->rt_pmtu = 0; | 1612 | rth->rt_pmtu = 0; |
1613 | rth->rt_gateway = 0; | 1613 | rth->rt_gateway = 0; |
1614 | if (res.type == RTN_UNREACHABLE) { | 1614 | if (res.type == RTN_UNREACHABLE) { |
@@ -1772,7 +1772,7 @@ static struct rtable *__mkroute_output(const struct fib_result *res, | |||
1772 | rth->rt_flags = flags; | 1772 | rth->rt_flags = flags; |
1773 | rth->rt_type = type; | 1773 | rth->rt_type = type; |
1774 | rth->rt_is_input = 0; | 1774 | rth->rt_is_input = 0; |
1775 | rth->rt_iif = orig_oif ? : dev_out->ifindex; | 1775 | rth->rt_iif = orig_oif ? : 0; |
1776 | rth->rt_pmtu = 0; | 1776 | rth->rt_pmtu = 0; |
1777 | rth->rt_gateway = 0; | 1777 | rth->rt_gateway = 0; |
1778 | 1778 | ||