From: Ben Greear <greearb@candelatech.com>
To: Tom Herbert <tom@herbertland.com>
Cc: netdev <netdev@vger.kernel.org>
Subject: Re: How to do TCP tx checksums
Date: Tue, 17 Nov 2015 09:19:36 -0800 [thread overview]
Message-ID: <564B61A8.5050205@candelatech.com> (raw)
In-Reply-To: <CALx6S37AZz6UZctRxY9DOO+-x6MQ2gB9FQ2wSt8frEnegyh82Q@mail.gmail.com>
On 11/16/2015 09:02 PM, Tom Herbert wrote:
> On Mon, Nov 16, 2015 at 4:20 PM, Ben Greear <greearb@candelatech.com> wrote:
>> Hello!
>>
>> I'm hacking on (my already hacked) pktgen, trying to get it to send TCP
>> frames.
>>
>> And, having issues getting checksums to work properly.
>>
>> I'm trying this:
>> struct iphdr *iph = ip_hdr(skb);
>> struct net_device *odev = pkt_dev->odev;
>>
>> if (pkt_dev->flags & F_TCP) {
>> if (odev->features & NETIF_F_V4_CSUM) {
>> skb->ip_summed = CHECKSUM_PARTIAL;
>> } else {
>> skb->ip_summed = CHECKSUM_NONE;
>> }
>> skb->csum = 0;
>> __tcp_v4_send_check(skb, iph->saddr, iph->daddr);
>>
>> I added an export so I could call that __tcp_v4_send_check method
>> w/out having to put a fake socket struct on the stack.
>>
>> But, the receiving NIC reports 100% checksum failure, so obviously
>> I'm not doing it correct.
>>
>> Any suggestions on what I might be doing wrong or the proper method(s)
>> to call?
>>
> It's really hard to tell what is happening without seeing the full
> patch your using. Maybe you're not setting the TCP correctly or
> transport header is not set right in skb.
Unfortunately, my pktgen has diverged significantly from upstream, so
a patch is probably not so useful.
The full pktgen.[ch] files are here:
http://www.candelatech.com/~greearb/patches/
If you look for 'F_TCP' you can find the pertinent bits
that I'm mucking with. I have changed it a bit since I last posted
the patch above...but still the receiving NIC is reporting 100%
csum failure, so I must still be doing something wrong.
I have also tweaked how UDP is done, but that seems to be working.
Thanks,
Ben
--
Ben Greear <greearb@candelatech.com>
Candela Technologies Inc http://www.candelatech.com
next prev parent reply other threads:[~2015-11-17 17:19 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-11-17 0:20 How to do TCP tx checksums Ben Greear
2015-11-17 5:02 ` Tom Herbert
2015-11-17 5:47 ` Eric Dumazet
2015-11-17 17:19 ` Ben Greear [this message]
2015-11-17 17:44 ` Ben Greear
2015-11-17 18:26 ` Eric Dumazet
2015-11-17 18:32 ` Ben Greear
2015-11-17 19:40 ` Daniel Borkmann
2015-11-17 19:28 ` David Miller
2015-11-17 21:22 ` Ben Greear
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=564B61A8.5050205@candelatech.com \
--to=greearb@candelatech.com \
--cc=netdev@vger.kernel.org \
--cc=tom@herbertland.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).