aboutsummaryrefslogtreecommitdiffstats
path: root/net/ipv6/xfrm6_policy.c
diff options
context:
space:
mode:
authorMasahide NAKAMURA <nakam@linux-ipv6.org>2007-12-20 23:41:12 -0500
committerDavid S. Miller <davem@davemloft.net>2008-01-28 17:59:36 -0500
commita1b051405bc16222d92c73b0c26d65b333a154ee (patch)
tree2950e34bbb51838f8da3e1d03c8ee608d3b56f55 /net/ipv6/xfrm6_policy.c
parentbd515c3e48ececd774eb3128e81b669dbbd32637 (diff)
[XFRM] IPv6: Fix dst/routing check at transformation.
IPv6 specific thing is wrongly removed from transformation at net-2.6.25. This patch recovers it with current design. o Update "path" of xfrm_dst since IPv6 transformation should care about routing changes. It is required by MIPv6 and off-link destined IPsec. o Rename nfheader_len which is for non-fragment transformation used by MIPv6 to rt6i_nfheader_len as IPv6 name space. Signed-off-by: Masahide NAKAMURA <nakam@linux-ipv6.org> Acked-by: Herbert Xu <herbert@gondor.apana.org.au> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv6/xfrm6_policy.c')
-rw-r--r--net/ipv6/xfrm6_policy.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/net/ipv6/xfrm6_policy.c b/net/ipv6/xfrm6_policy.c
index d26b7dc3f33b..cf373b46a1ba 100644
--- a/net/ipv6/xfrm6_policy.c
+++ b/net/ipv6/xfrm6_policy.c
@@ -98,6 +98,20 @@ static int xfrm6_get_tos(struct flowi *fl)
98 return 0; 98 return 0;
99} 99}
100 100
101static int xfrm6_init_path(struct xfrm_dst *path, struct dst_entry *dst,
102 int nfheader_len)
103{
104 if (dst->ops->family == AF_INET6) {
105 struct rt6_info *rt = (struct rt6_info*)dst;
106 if (rt->rt6i_node)
107 path->path_cookie = rt->rt6i_node->fn_sernum;
108 }
109
110 path->u.rt6.rt6i_nfheader_len = nfheader_len;
111
112 return 0;
113}
114
101static int xfrm6_fill_dst(struct xfrm_dst *xdst, struct net_device *dev) 115static int xfrm6_fill_dst(struct xfrm_dst *xdst, struct net_device *dev)
102{ 116{
103 struct rt6_info *rt = (struct rt6_info*)xdst->route; 117 struct rt6_info *rt = (struct rt6_info*)xdst->route;
@@ -115,6 +129,8 @@ static int xfrm6_fill_dst(struct xfrm_dst *xdst, struct net_device *dev)
115 RTF_LOCAL); 129 RTF_LOCAL);
116 xdst->u.rt6.rt6i_metric = rt->rt6i_metric; 130 xdst->u.rt6.rt6i_metric = rt->rt6i_metric;
117 xdst->u.rt6.rt6i_node = rt->rt6i_node; 131 xdst->u.rt6.rt6i_node = rt->rt6i_node;
132 if (rt->rt6i_node)
133 xdst->route_cookie = rt->rt6i_node->fn_sernum;
118 xdst->u.rt6.rt6i_gateway = rt->rt6i_gateway; 134 xdst->u.rt6.rt6i_gateway = rt->rt6i_gateway;
119 xdst->u.rt6.rt6i_dst = rt->rt6i_dst; 135 xdst->u.rt6.rt6i_dst = rt->rt6i_dst;
120 xdst->u.rt6.rt6i_src = rt->rt6i_src; 136 xdst->u.rt6.rt6i_src = rt->rt6i_src;
@@ -266,6 +282,7 @@ static struct xfrm_policy_afinfo xfrm6_policy_afinfo = {
266 .find_bundle = __xfrm6_find_bundle, 282 .find_bundle = __xfrm6_find_bundle,
267 .decode_session = _decode_session6, 283 .decode_session = _decode_session6,
268 .get_tos = xfrm6_get_tos, 284 .get_tos = xfrm6_get_tos,
285 .init_path = xfrm6_init_path,
269 .fill_dst = xfrm6_fill_dst, 286 .fill_dst = xfrm6_fill_dst,
270}; 287};
271 288