On Thu, Mar 10, 2022 at 3:55 PM Ananyev, Konstantin
<konstantin.anan...@intel.com> wrote:
> > Calls to rte_memcpy for 1 < n < 16 could result in unaligned
> > loads/stores, which is undefined behaviour according to the C
> > standard, and strict aliasing violations.
> >
> > The code was changed to use a packed structure that allows aliasing
> > (using the __may_alias__ attribute) to perform the load/store
> > operations. This results in code that has the same performance as the
> > original code and that is also C standards-compliant.
> >
> > Fixes: d35cc1fe6a7a ("eal/x86: revert select optimized memcpy at run-time")
> > Cc: sta...@dpdk.org
> >
> > Signed-off-by: Luc Pelletier <lucp.at.w...@gmail.com>
> Acked-by: Konstantin Ananyev <konstantin.anan...@intel.com>
> Tested-by: Konstantin Ananyev <konstantin.anan...@intel.com>

Thanks, applied.


> As a side note, we probably need to check other similar places in DPDK code.

What would be the best way to detect those problematic places?

I tried UBsan, and it did report some of the issues fixed with this patch.


-- 
David Marchand

Reply via email to