aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid S. Miller <davem@davemloft.net>2012-07-17 17:44:26 -0400
committerDavid S. Miller <davem@davemloft.net>2012-07-20 16:40:02 -0400
commit9917e1e8762745191eba5a3bf2040278cbddbee1 (patch)
tree9c538b6598b005e91b08b37e91dcb6638c26c4a0
parent4fd551d7bed93af60af61c5a324b8f5dff37953a (diff)
ipv4: Turn rt->rt_route_iif into rt->rt_is_input.
That is this value's only use, as a boolean to indicate whether a route is an input route or not. So implement it that way, using a u16 gap present in the struct already. Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--include/net/route.h6
-rw-r--r--net/ipv4/route.c10
-rw-r--r--net/ipv4/xfrm4_policy.c2
3 files changed, 9 insertions, 9 deletions
diff --git a/include/net/route.h b/include/net/route.h
index e789a92fd602..4bafe0bfe829 100644
--- a/include/net/route.h
+++ b/include/net/route.h
@@ -47,8 +47,8 @@ struct rtable {
47 int rt_genid; 47 int rt_genid;
48 unsigned int rt_flags; 48 unsigned int rt_flags;
49 __u16 rt_type; 49 __u16 rt_type;
50 __u16 rt_is_input;
50 51
51 int rt_route_iif;
52 int rt_iif; 52 int rt_iif;
53 53
54 /* Info on neighbour */ 54 /* Info on neighbour */
@@ -61,12 +61,12 @@ struct rtable {
61 61
62static inline bool rt_is_input_route(const struct rtable *rt) 62static inline bool rt_is_input_route(const struct rtable *rt)
63{ 63{
64 return rt->rt_route_iif != 0; 64 return rt->rt_is_input != 0;
65} 65}
66 66
67static inline bool rt_is_output_route(const struct rtable *rt) 67static inline bool rt_is_output_route(const struct rtable *rt)
68{ 68{
69 return rt->rt_route_iif == 0; 69 return rt->rt_is_input == 0;
70} 70}
71 71
72static inline __be32 rt_nexthop(const struct rtable *rt, __be32 daddr) 72static inline __be32 rt_nexthop(const struct rtable *rt, __be32 daddr)
diff --git a/net/ipv4/route.c b/net/ipv4/route.c
index a280b6ac8eb2..fac4c4acdbac 100644
--- a/net/ipv4/route.c
+++ b/net/ipv4/route.c
@@ -1330,7 +1330,7 @@ static int ip_route_input_mc(struct sk_buff *skb, __be32 daddr, __be32 saddr,
1330 rth->rt_genid = rt_genid(dev_net(dev)); 1330 rth->rt_genid = rt_genid(dev_net(dev));
1331 rth->rt_flags = RTCF_MULTICAST; 1331 rth->rt_flags = RTCF_MULTICAST;
1332 rth->rt_type = RTN_MULTICAST; 1332 rth->rt_type = RTN_MULTICAST;
1333 rth->rt_route_iif = dev->ifindex; 1333 rth->rt_is_input= 1;
1334 rth->rt_iif = dev->ifindex; 1334 rth->rt_iif = dev->ifindex;
1335 rth->rt_pmtu = 0; 1335 rth->rt_pmtu = 0;
1336 rth->rt_gateway = 0; 1336 rth->rt_gateway = 0;
@@ -1460,7 +1460,7 @@ static int __mkroute_input(struct sk_buff *skb,
1460 rth->rt_genid = rt_genid(dev_net(rth->dst.dev)); 1460 rth->rt_genid = rt_genid(dev_net(rth->dst.dev));
1461 rth->rt_flags = flags; 1461 rth->rt_flags = flags;
1462 rth->rt_type = res->type; 1462 rth->rt_type = res->type;
1463 rth->rt_route_iif = in_dev->dev->ifindex; 1463 rth->rt_is_input = 1;
1464 rth->rt_iif = in_dev->dev->ifindex; 1464 rth->rt_iif = in_dev->dev->ifindex;
1465 rth->rt_pmtu = 0; 1465 rth->rt_pmtu = 0;
1466 rth->rt_gateway = 0; 1466 rth->rt_gateway = 0;
@@ -1638,7 +1638,7 @@ local_input:
1638 rth->rt_genid = rt_genid(net); 1638 rth->rt_genid = rt_genid(net);
1639 rth->rt_flags = flags|RTCF_LOCAL; 1639 rth->rt_flags = flags|RTCF_LOCAL;
1640 rth->rt_type = res.type; 1640 rth->rt_type = res.type;
1641 rth->rt_route_iif = dev->ifindex; 1641 rth->rt_is_input = 1;
1642 rth->rt_iif = dev->ifindex; 1642 rth->rt_iif = dev->ifindex;
1643 rth->rt_pmtu = 0; 1643 rth->rt_pmtu = 0;
1644 rth->rt_gateway = 0; 1644 rth->rt_gateway = 0;
@@ -1803,7 +1803,7 @@ static struct rtable *__mkroute_output(const struct fib_result *res,
1803 rth->rt_genid = rt_genid(dev_net(dev_out)); 1803 rth->rt_genid = rt_genid(dev_net(dev_out));
1804 rth->rt_flags = flags; 1804 rth->rt_flags = flags;
1805 rth->rt_type = type; 1805 rth->rt_type = type;
1806 rth->rt_route_iif = 0; 1806 rth->rt_is_input = 0;
1807 rth->rt_iif = orig_oif ? : dev_out->ifindex; 1807 rth->rt_iif = orig_oif ? : dev_out->ifindex;
1808 rth->rt_pmtu = 0; 1808 rth->rt_pmtu = 0;
1809 rth->rt_gateway = 0; 1809 rth->rt_gateway = 0;
@@ -2079,7 +2079,7 @@ struct dst_entry *ipv4_blackhole_route(struct net *net, struct dst_entry *dst_or
2079 if (new->dev) 2079 if (new->dev)
2080 dev_hold(new->dev); 2080 dev_hold(new->dev);
2081 2081
2082 rt->rt_route_iif = ort->rt_route_iif; 2082 rt->rt_is_input = ort->rt_is_input;
2083 rt->rt_iif = ort->rt_iif; 2083 rt->rt_iif = ort->rt_iif;
2084 rt->rt_pmtu = ort->rt_pmtu; 2084 rt->rt_pmtu = ort->rt_pmtu;
2085 2085
diff --git a/net/ipv4/xfrm4_policy.c b/net/ipv4/xfrm4_policy.c
index 3c99b4cdd290..c6281847f16a 100644
--- a/net/ipv4/xfrm4_policy.c
+++ b/net/ipv4/xfrm4_policy.c
@@ -79,7 +79,6 @@ static int xfrm4_fill_dst(struct xfrm_dst *xdst, struct net_device *dev,
79 struct rtable *rt = (struct rtable *)xdst->route; 79 struct rtable *rt = (struct rtable *)xdst->route;
80 const struct flowi4 *fl4 = &fl->u.ip4; 80 const struct flowi4 *fl4 = &fl->u.ip4;
81 81
82 xdst->u.rt.rt_route_iif = fl4->flowi4_iif;
83 xdst->u.rt.rt_iif = fl4->flowi4_iif; 82 xdst->u.rt.rt_iif = fl4->flowi4_iif;
84 83
85 xdst->u.dst.dev = dev; 84 xdst->u.dst.dev = dev;
@@ -87,6 +86,7 @@ static int xfrm4_fill_dst(struct xfrm_dst *xdst, struct net_device *dev,
87 86
88 /* Sheit... I remember I did this right. Apparently, 87 /* Sheit... I remember I did this right. Apparently,
89 * it was magically lost, so this code needs audit */ 88 * it was magically lost, so this code needs audit */
89 xdst->u.rt.rt_is_input = rt->rt_is_input;
90 xdst->u.rt.rt_flags = rt->rt_flags & (RTCF_BROADCAST | RTCF_MULTICAST | 90 xdst->u.rt.rt_flags = rt->rt_flags & (RTCF_BROADCAST | RTCF_MULTICAST |
91 RTCF_LOCAL); 91 RTCF_LOCAL);
92 xdst->u.rt.rt_type = rt->rt_type; 92 xdst->u.rt.rt_type = rt->rt_type;