On Thu, Jan 18, 2024 at 3:47 PM Konstantin Ananyev
<konstantin.anan...@huawei.com> wrote:
>
>
> Hi Jerin,

Hi Konstantin,


>
> > > > Introduce a new API to retrieve the number of used descriptors
> > > > in a Tx queue. Applications can leverage this API in the fast path to
> > > > inspect the Tx queue occupancy and take appropriate actions based on the
> > > > available free descriptors.
> > > >
> > > > A notable use case could be implementing Random Early Discard (RED)
> > > > in software based on Tx queue occupancy.
> > > >
> > > > Signed-off-by: Jerin Jacob <jer...@marvell.com>
> >
> > > > @@ -6803,6 +6803,80 @@ rte_eth_recycle_mbufs(uint16_t rx_port_id, 
> > > > uint16_t rx_queue_id,
> > > >  __rte_experimental
> > > >  int rte_eth_buffer_split_get_supported_hdr_ptypes(uint16_t port_id, 
> > > > uint32_t *ptypes, int num);
> > > >
> > > > +/**
> > > > + * @warning
> > > > + * @b EXPERIMENTAL: this API may change, or be removed, without prior 
> > > > notice
> > > > + *
> > > > + * Get the number of used descriptors of a Tx queue
> > > > + *
> > > > + * This function retrieves the number of used descriptors of a 
> > > > transmit queue.
> > > > + * Applications can use this API in the fast path to inspect Tx queue 
> > > > occupancy and take
> > > > + * appropriate actions based on the available free descriptors.
> > > > + * An example action could be implementing the Random Early Discard 
> > > > (RED).
> > >
> > > Sorry, I probably misunderstood your previous mails, but wouldn't it be 
> > > more convenient
> > > for user to have rte_eth_tx_queue_free_count(...) as fast-op, and
> > > have rte_eth_tx_queue_count(...) {  queue_txd_num - 
> > > rte_eth_tx_queue_free_count(...);}
> > > as a slow-path function in rte_ethdev.c?
> >
> > The general feedback is to align with the Rx queue API, specifically
> > rte_eth_rx_queue_count,
> > and it's noted that there is no equivalent rte_eth_rx_queue_free_count.
> >
> > Given that the free count can be obtained by subtracting the used
> > count from queue_txd_num,
> > it is considered that either approach is acceptable.
> >
> > The application configures queue_txd_num with tx_queue_setup(), and
> > the application can store that value in its structure.
> > This would enable fast-path usage for both base cases (whether the
> > application needs information about free or used descriptors)
> > with just one API(rte_eth_tx_queue_count())
>
> Right now I don't use these functions, but if I think what most people are 
> interested in:
> - how many packets you can receive immediately (rx_queue_count)
> - how many packets you can transmit immediately (tx_queue_free_count)

Yes. That's why initially I kept the free version.

It seems like other prominent use cases for _used_ version is for QoS
to enable something  like
in positive logic,

if < 98% % used then action Tail drop
else if  < 60% used then action RED

> Sure, I understand that user can store txd_num  somewhere and then do 
> subtraction himself.
> Though it means more effort for the user, and the only reason for that, as I 
> can see,
> is to have RX and TX function naming symmetric.
> Which seems much less improtant to me comparing to user convenience.
> Anyway, as I stated above, I don't use these functions right now,
> so if the majority of users are happy with current approach, I would not 
> insist :)

No strong opinion for me either. Looks like majority users like used version.
Let's go with. I am open for changing to free version, if the majority
of users like that.

> Konstantin
>

Reply via email to