On Tue, 23 May 2023 08:12:28 +0000
Akhil Goyal <gak...@marvell.com> wrote:

> > 
> > This could happen if the passed in length to this routine was larger than
> > the amount of data in the mbuf. Should the function check and return an 
> > error?
> > 
> > Panic should only be reserved for seriously corrupted input (like invalid 
> > mbuf).
> > 
> > Also, this is a big enough function that it really should not be inlined.  
> 
> This is a datapath API. RTE_ASSERT is normally not enabled in release build.
> So, this assert is not doing any check for normal scenario.
> We normally avoid these type of error checks in the datapath.
> And while building in debug mode, we need these asserts to give a backtrace 
> also
> To debug the rootcause of the issue.
> 
> I would suggest fixing the assert itself instead of adding a check.
> Current patch will affect performance.
> 
> Agreed, that the function is big for being an inline function,
> but that is what all the datapath APIs are and
> we keep them inline to improve the performance.

Inline is not a magic go fast switch. Turns out that the compilers and cpu's
already do good job with functions.  Using LTO helps too.

Reply via email to