Joakim Koskela wrote:
> On Thursday 19 July 2007 17:46:42 Patrick McHardy wrote:
> 
>>Joakim Koskela wrote:
>>
>>>+            skb_push(skb, hdrlen);
>>>+            iphv6 = ipv6_hdr(skb);
>>>+
>>>+            skb_reset_network_header(skb);
>>>+            top_iphv6 = ipv6_hdr(skb);
>>>+
>>>+            protocol = iphv6->nexthdr;
>>>+            skb_pull(skb, delta);
>>>+            skb_reset_network_header(skb);
>>>+            top_iphv4 = ip_hdr(skb);
>>>+            skb_set_transport_header(skb, hdrlen);
>>>+            top_iphv4->ihl = (sizeof(struct iphdr) >> 2);
>>>+            top_iphv4->version = 4;
>>>+            top_iphv4->id = 0;
>>>+            top_iphv4->frag_off = htons(IP_DF);
>>>+            top_iphv4->ttl = dst_metric(dst->child, RTAX_HOPLIMIT);
>>>+            top_iphv4->saddr = x->props.saddr.a4;
>>>+            top_iphv4->daddr = x->id.daddr.a4;
>>>+            skb->transport_header += top_iphv4->ihl*4;
>>>+            top_iphv4->protocol = protocol;
>>>+
>>>+            skb->protocol = htons(ETH_P_IP);
>>>+#endif
>>
>>The output function in the IPv6/IPv4 case is called from
>>xfrm6_output_one, which loops until after a tunnel mode
>>encapsulation is done and then returns to the outer loop
>>in xfrm6_output_finish2, which passes the packet through
>>the netfilter hooks and continues with the next transform.
>>
> 
> 
> I'm not sure I really got this. IPv6/IPv4 means IPv6 inner, IPv4 outer, 
> right? 
> Isn't that called from xfrm4_output_one and subsequently passed through the 
> right filters as well (as it has a ipv4 header by then)?


I think you're right, it uses xfrm4_output. But there's a mismatch
in either case, in both cases (IPv4 and IPv6) we first call the
POSTROUTING hook for this family, than do the transform (changing
the family), then call the OUTPUT hook for the same family. So
either the POSTROUTING or the OUTPUT hook is called for the wrong
family.

>>There are multiple problems resulting from the inter-family
>>encapsulation. First of all, the inner loop continues after
>>beet mode encapsulation, skipping the netfilter hooks in
>>case there are more transforms. It should (as with decaps = 1
>>on input) at least call netfilter hooks after an inter-family
>>transform. If the beet transform is the last one, the IPv4
>>skb will be passed through the IPv6 netfilter hooks, which is
>>clearly wrong. To fix these problems some restructuring in
>>xfrm[46]_output.c seems to be necessary.
> 
> 
> Couldn't this be solved just by ending the inner loop in case of beet mode 
> (as 
> it is done for tunnel)?


If the assumption that xfrm4_output is used for IPv6 in IPv4
encapsulation is correct and the problem mentioned above is
fixed, that should work fine.
-
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to