09/06/2022 09:09, Morten Brørup:
> > From: Stephen Hemminger [mailto:step...@networkplumber.org]
> > Sent: Wednesday, 8 June 2022 17.27
> > 
> > On Wed, 8 Jun 2022 09:19:20 +0100
> > Konstantin Ananyev <konstantin.v.anan...@yandex.ru> wrote:
> > 
> > > 07/06/2022 18:17, Stephen Hemminger пишет:
> > > > The function rte_memcpy can derference past source buffer which
> > > > will cause array out of bounds warnings. But there is no good
> > reason
> > > > to use rte_memcpy instead of memcpy in this code. Memcpy is just
> > > > as fast for these small inputs, and compiler will optimize.
> > >
> > >
> > > AFAIK, rte_memcpy() will outperform memcpy() when _size_ parameter
> > > is a variable. Unfortunately that's exactly the case here.
> > > So not sure it is a good change, at least without extensive perf
> > testing.
> > > BTW, if rte_memcpy() really access src buffer beyond it's boundaries,
> > > I think that's definitely a bug that needs to be fixed.
> > 
> > Yes and no.
> > IMHO DPDK should not in the C library business, and glibc etc should be
> > more optimized if necessary.
> 
> A very big +1 to that!
> 
> DPDK contains a lot of optimizations that really belong in the compiler 
> and/or C library, but weren't back then, so the clever DPDK developers put 
> them inside DPDK instead.
> 
> Over time, the compilers and C libraries have improved, and many of these 
> manually implemented optimizations have become obsolete. They should be 
> cleaned up and replaced by simpler code, and the documentation about 
> optimizing code should be updated accordingly.
> 
> Until that happens, we have to expect contributors to use rte_memcpy() and 
> other obsolete optimizations - they are only doing what the DPDK 
> documentation and reference code tells them. Just like application developers 
> are using KNI, because it is so heavily promoted in DPDK documentation.
> 
> The DPDK community has a very high focus on the risk of performance 
> regressions when touching DPDK Core libraries, so a general cleaning is 
> probably not going to happen. Luckily, there are exceptions to every rule, 
> such as Georg Sauthoff's patch removing the manual loop unroll in 
> __rte_raw_cksum() [1], which allowed the compiler to generate something 
> better.
> 
> I guess that "if it isn't broken, don't fix it" applies to DPDK Core 
> libraries too. ;-)

No it doesn't apply, the only limitation is the number of contributions.
Feel free to propose cleanups.


Reply via email to