[NETFILTER]: Fix HW checksum handling in ECN target Signed-off-by: Patrick McHardy --- commit f1929b1a15a9a7d9761b344d3522698bd656154e tree d2da13822149bfa1c49a8ae82930d4795f08f69f parent a811712706846bff6ad796394ce4aa3abcc657b0 author Patrick McHardy Sat, 20 Aug 2005 03:28:22 +0200 committer Patrick McHardy Sat, 20 Aug 2005 03:28:22 +0200 net/ipv4/netfilter/ipt_ECN.c | 9 +++++---- 1 files changed, 5 insertions(+), 4 deletions(-) diff --git a/net/ipv4/netfilter/ipt_ECN.c b/net/ipv4/netfilter/ipt_ECN.c --- a/net/ipv4/netfilter/ipt_ECN.c +++ b/net/ipv4/netfilter/ipt_ECN.c @@ -70,6 +70,10 @@ set_ect_tcp(struct sk_buff **pskb, const return 0; tcph = (void *)(*pskb)->nh.iph + (*pskb)->nh.iph->ihl*4; + if ((*pskb)->ip_summed == CHECKSUM_HW && + skb_checksum_help(*pskb, inward)) + return 0; + diffs[0] = ((u_int16_t *)tcph)[6]; if (einfo->operation & IPT_ECN_OP_SET_ECE) tcph->ece = einfo->proto.tcp.ece; @@ -78,13 +82,10 @@ set_ect_tcp(struct sk_buff **pskb, const diffs[1] = ((u_int16_t *)tcph)[6]; diffs[0] = diffs[0] ^ 0xFFFF; - if ((*pskb)->ip_summed != CHECKSUM_HW) + if ((*pskb)->ip_summed != CHECKSUM_UNNECESSARY) tcph->check = csum_fold(csum_partial((char *)diffs, sizeof(diffs), tcph->check^0xFFFF)); - else - if (skb_checksum_help(*pskb, inward)) - return 0; return 1; }