On Fri, Sep 9, 2022 at 9:12 AM Naga Harish K S V <s.v.naga.haris...@intel.com> wrote: > > This patch adds support to start or stop a particular queue > that is associated with the adapter. > > Start function enables the Tx Adapter to start enqueueing > packets to the Tx queue. > > Stop function stops the Tx Adapter from transmitting any > mbufs to the Tx queue. The Tx Adapter also frees any mbufs > that it may have buffered for this queue. All inflight packets > destined to the queue are freed until the queue is started again. > > Signed-off-by: Naga Harish K S V <s.v.naga.haris...@intel.com>
In general, new APIs look good to me if it is helping the SW driver. I will wait for comment from @Jayatheerthan, Jay Some comments below > --- > lib/eventdev/eventdev_pmd.h | 41 +++++++++ > lib/eventdev/rte_event_eth_tx_adapter.c | 114 +++++++++++++++++++++++- > lib/eventdev/rte_event_eth_tx_adapter.h | 39 ++++++++ > lib/eventdev/version.map | 2 + Please squash 3/3 to 1/3. Please update doc/guides/prog_guide/event_ethernet_tx_adapter.rst for new APIs doc for What is this API and when to use this API etc. > 4 files changed, 192 insertions(+), 4 deletions(-) > > diff --git a/lib/eventdev/eventdev_pmd.h b/lib/eventdev/eventdev_pmd.h > index f514a37575..a27c0883c6 100644 > --- a/lib/eventdev/eventdev_pmd.h > +++ b/lib/eventdev/eventdev_pmd.h > @@ -1294,6 +1294,43 @@ typedef int > (*eventdev_eth_tx_adapter_stats_reset_t)(uint8_t id, > typedef int (*eventdev_eth_tx_adapter_instance_get_t) > (uint16_t eth_dev_id, uint16_t tx_queue_id, uint8_t *txa_inst_id); > > +/** > + * Start a Tx queue that is assigned to TX adapter instance Tx adapter > + * > + * @param id > + * Adapter identifier > + * > + * @param eth_dev_id > + * Port identifier of Ethernet device > + * > + * @param tx_queue_id > + * Ethernet device TX queue index Tx > + * > + * @return > + * - 0: Success > + * - <0: Error code on failure > + */ > +typedef int (*eventdev_eth_tx_adapter_queue_start) > + (uint8_t id, uint16_t eth_dev_id, uint16_t tx_queue_id); > + > +/** > + * Stop a Tx queue that is assigned to TX adapter instance Tx > +int > +rte_event_eth_tx_adapter_queue_start(uint16_t eth_dev_id, uint16_t > tx_queue_id) > +{ > + return txa_queue_state_set(eth_dev_id, tx_queue_id, true); Make it is NOP with return 0 if eventdev_eth_tx_adapter_queue_start is NULL > +} > + > +int > +rte_event_eth_tx_adapter_queue_stop(uint16_t eth_dev_id, uint16_t > tx_queue_id) > +{ > + return txa_queue_state_set(eth_dev_id, tx_queue_id, false); Make it is NOP with return 0 if eventdev_eth_tx_adapter_queue_start is NULL > +}