On Fri, 2006-06-23 at 12:33 -0700, Michael Chan wrote: > On Thu, 2006-06-22 at 18:14 +1000, Herbert Xu wrote: > > [NET]: Add software TSOv4 > > > > This patch adds the GSO implementation for IPv4 TCP. > > Herbert, Looks like there were some problems in the CHECKSUM_HW case. > This patch should fix it. Please double-check my checksum math.
This patch is more correct. Please ignore the previous one. [NET]: Fix CHECKSUM_HW GSO problems. Fix checksum problems in the GSO code path for CHECKSUM_HW packets. The ipv4 TCP pseudo header checksum has to be adjusted for GSO segmented packets. Signed-off-by: Michael Chan <[EMAIL PROTECTED]> diff --git a/net/ipv4/tcp.c b/net/ipv4/tcp.c index 0e029c4..b9c37f1 100644 --- a/net/ipv4/tcp.c +++ b/net/ipv4/tcp.c @@ -2186,7 +2186,8 @@ struct sk_buff *tcp_tso_segment(struct s if (skb->ip_summed == CHECKSUM_NONE) { th->check = csum_fold(csum_partial( skb->h.raw, thlen, csum_add(skb->csum, delta))); - } + } else if (skb->ip_summed == CHECKSUM_HW) + th->check = ~csum_fold(csum_add(th->check, delta)); seq += len; skb = skb->next; @@ -2200,6 +2201,10 @@ struct sk_buff *tcp_tso_segment(struct s delta = csum_add(oldlen, htonl(skb->tail - skb->h.raw)); th->check = csum_fold(csum_partial( skb->h.raw, thlen, csum_add(skb->csum, delta))); + } else if (skb->ip_summed == CHECKSUM_HW) { + delta = csum_add(oldlen, htonl(skb->len - + (skb->h.raw - skb->data))); + th->check = ~csum_fold(csum_add(th->check, delta)); } out: - 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