All of lore.kernel.org
 help / color / mirror / Atom feed
From: Olivier Matz <olivier.matz@6wind.com>
To: "Morten Brørup" <mb@smartsharesystems.com>
Cc: Hongzhi Guo <guohongzhi1@huawei.com>,
	dev@dpdk.org, stable@dpdk.org, stephen@networkplumber.org,
	thomas@monjalon.net, konstantin.ananyev@intel.com,
	ferruh.yigit@intel.com, nicolas.chautru@intel.com,
	zhoujingbin@huawei.com, chenchanghu@huawei.com,
	jerry.lilijun@huawei.com, haifeng.lin@huawei.com
Subject: Re: [dpdk-dev] [PATCH] net: fix checksum on big endian CPUs
Date: Fri, 10 Jul 2020 14:37:22 +0200	[thread overview]
Message-ID: <20200710123722.GX5869@platinum> (raw)
In-Reply-To: <98CBD80474FA8B44BF855DF32C47DC35C61117@smartserver.smartshare.dk>

On Fri, Jul 10, 2020 at 02:20:08PM +0200, Morten Brørup wrote:
> > From: dev [mailto:dev-bounces@dpdk.org] On Behalf Of Hongzhi Guo
> > Sent: Friday, July 10, 2020 1:43 PM
> > 
> > With current code, the checksum of odd-length buffers is wrong on
> > big endian CPUs: the last byte is not properly summed to the
> > accumulator.
> > 
> > Fix this by left-shifting the remaining byte by 8. For instance,
> > if the last byte is 0x42, we should add 0x4200 to the accumulator
> > on big endian CPUs.
> > 
> > This change is similar to what is suggested in Errata 3133 of
> > RFC 1071.
> > 
> > Fixes: 6006818cfb26("net: new checksum functions")
> > Cc: stable@dpdk.org
> > 
> > Signed-off-by: Hongzhi Guo <guohongzhi1@huawei.com>
> > ---
> > v2:
> > * Explain the logic in the commit log
> > * Fixed commit title
> > ---
> > ---
> >  lib/librte_net/rte_ip.h | 7 +++++--
> >  1 file changed, 5 insertions(+), 2 deletions(-)
> > 
> > diff --git a/lib/librte_net/rte_ip.h b/lib/librte_net/rte_ip.h
> > index 292f63fd7..4fb0e314a 100644
> > --- a/lib/librte_net/rte_ip.h
> > +++ b/lib/librte_net/rte_ip.h
> > @@ -139,8 +139,11 @@ __rte_raw_cksum(const void *buf, size_t len,
> > uint32_t sum)
> >  	}
> > 
> >  	/* if length is in odd bytes */
> > -	if (len == 1)
> > -		sum += *((const uint8_t *)u16_buf);
> > +	if (len == 1) {
> > +		uint16_t left = 0;
> > +		*(uint8_t *)&left = *(const uint8_t *)u16_buf;
> > +		sum += left;
> > +	}
> > 
> >  	return sum;
> >  }
> > --
> > 2.21.0.windows.1
> > 
> 
> This is correct for both big and little endian CPUs.
> 
> Reviewed-by: Morten Brørup <mb@smartsharesystems.com>

Acked-by: Olivier Matz <olivier.matz@6wind.com>

Thanks!


  reply	other threads:[~2020-07-10 12:37 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-07-10 11:43 [dpdk-dev] [PATCH] net: fix checksum on big endian CPUs Hongzhi Guo
2020-07-10 12:20 ` Morten Brørup
2020-07-10 12:37   ` Olivier Matz [this message]
2020-07-10 21:11     ` [dpdk-dev] [dpdk-stable] " Thomas Monjalon

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=20200710123722.GX5869@platinum \
    --to=olivier.matz@6wind.com \
    --cc=chenchanghu@huawei.com \
    --cc=dev@dpdk.org \
    --cc=ferruh.yigit@intel.com \
    --cc=guohongzhi1@huawei.com \
    --cc=haifeng.lin@huawei.com \
    --cc=jerry.lilijun@huawei.com \
    --cc=konstantin.ananyev@intel.com \
    --cc=mb@smartsharesystems.com \
    --cc=nicolas.chautru@intel.com \
    --cc=stable@dpdk.org \
    --cc=stephen@networkplumber.org \
    --cc=thomas@monjalon.net \
    --cc=zhoujingbin@huawei.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.