aboutsummaryrefslogtreecommitdiffstats
path: root/net/ipv6/ip6_output.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/ip6_output.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/ip6_output.c')
-rw-r--r--net/ipv6/ip6_output.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/net/ipv6/ip6_output.c b/net/ipv6/ip6_output.c
index d54da616e3af..4686646058d3 100644
--- a/net/ipv6/ip6_output.c
+++ b/net/ipv6/ip6_output.c
@@ -1126,7 +1126,7 @@ int ip6_append_data(struct sock *sk, int getfrag(void *from, char *to,
1126 sk->sk_sndmsg_page = NULL; 1126 sk->sk_sndmsg_page = NULL;
1127 sk->sk_sndmsg_off = 0; 1127 sk->sk_sndmsg_off = 0;
1128 exthdrlen = rt->u.dst.header_len + (opt ? opt->opt_flen : 0) - 1128 exthdrlen = rt->u.dst.header_len + (opt ? opt->opt_flen : 0) -
1129 rt->nfheader_len; 1129 rt->rt6i_nfheader_len;
1130 length += exthdrlen; 1130 length += exthdrlen;
1131 transhdrlen += exthdrlen; 1131 transhdrlen += exthdrlen;
1132 } else { 1132 } else {
@@ -1141,7 +1141,7 @@ int ip6_append_data(struct sock *sk, int getfrag(void *from, char *to,
1141 1141
1142 hh_len = LL_RESERVED_SPACE(rt->u.dst.dev); 1142 hh_len = LL_RESERVED_SPACE(rt->u.dst.dev);
1143 1143
1144 fragheaderlen = sizeof(struct ipv6hdr) + rt->nfheader_len + 1144 fragheaderlen = sizeof(struct ipv6hdr) + rt->rt6i_nfheader_len +
1145 (opt ? opt->opt_nflen : 0); 1145 (opt ? opt->opt_nflen : 0);
1146 maxfraglen = ((mtu - fragheaderlen) & ~7) + fragheaderlen - sizeof(struct frag_hdr); 1146 maxfraglen = ((mtu - fragheaderlen) & ~7) + fragheaderlen - sizeof(struct frag_hdr);
1147 1147