> -----Original Message-----
> From: Pavan Nikhilesh Bhagavatula <pbhagavat...@marvell.com>
> Sent: Wednesday, May 26, 2021 2:02 PM
> To: Van Haaren, Harry <harry.van.haa...@intel.com>; bugzi...@dpdk.org;
> dev@dpdk.org; Rao, Nikhil <nikhil....@intel.com>; Jayatheerthan, Jay
> <jay.jayatheert...@intel.com>; heng.w...@ericsson.com
> Subject: RE: [dpdk-dev] [Bug 721] Wrong event pointer in rx adapter
> 
> >> From: dev <dev-boun...@dpdk.org> On Behalf Of bugzi...@dpdk.org
<snip original bug report for brevity>
> >>  797                 if (dropped)
> >>  798                         rx_adapter->stats.rx_dropped += dropped;
> >>  799         }
> >
> >+CC RX Adapter Maintainer, and Pavan as this code has been changed
> >recently.
> >
> >I've done a quick review of the above report, and believe it to be a
> >genuine bug,
> >however this code has been refactored in commit d7c428e557b as part
> >of series
> >to " eventdev: support Rx adapter event vector".
> >
> >The relevant diff here for reference:
> >Note "ev" pointer replaced with "&buf->events[buf->count]"
> >
> >                dropped = 0;
> >                nb_cb = dev_info->cb_fn(eth_dev_id, rx_queue_id,
> >-                                       ETH_EVENT_BUFFER_SIZE, buf->count, 
> >ev,
> >-                                       num, dev_info->cb_arg, &dropped);
> >+                                       ETH_EVENT_BUFFER_SIZE, buf->count,
> >+                                       &buf->events[buf->count], num,
> >+                                       dev_info->cb_arg, &dropped);
> >                if (unlikely(nb_cb > num))
> >
> >
> >Based on this investigation, although the code changed, the same bug
> >seems present,
> >as really &buf->events[0] should be passed to the callback?
> 
> The callback semantics are pretty ambiguous. There are two cases:
> 1. Is the callback allowed to modify the entire event buffer?
> Or
> 2. Is it only allowed to modify the events received in the current Rx cycle?
> 
> The current code only takes into account case 2 as handling case 1 requires
> additional modification of nb_cb etc..

Ah, I'm not actually familiar with the rx-adapter code at all, or the callback
semantics/design... I presumed it was the same as Ethdev RX/TX callbacks.

Jay, would you mind taking a look and identifying what the desired behavior is?

It would be good to fix this ASAP as it seems like a genuine issue, and the 
workaround
of "moving the pointer to where it should be in App code" is... a workaround :) 

> Cheers,
> Pavan.

Thanks for the input Pavan! Regards, -Harry

Reply via email to