From: vanshika.shukla@nxp.com
To: dev@dpdk.org, Gagandeep Singh <g.singh@nxp.com>,
Sachin Saxena <sachin.saxena@nxp.com>,
Vanshika Shukla <vanshika.shukla@nxp.com>
Subject: [v2 12/12] net/enetc: Add support for deferred queue and queue info callbacks
Date: Fri, 17 Oct 2025 14:49:29 +0530 [thread overview]
Message-ID: <20251017091929.2723044-13-vanshika.shukla@nxp.com> (raw)
In-Reply-To: <20251017091929.2723044-1-vanshika.shukla@nxp.com>
From: Vanshika Shukla <vanshika.shukla@nxp.com>
This patch adds:
- Support for deferred queue start/stop functionality to the ENETC4 driver.
- rxq_info_get and txq_info_get callbacks to report queue information
Signed-off-by: Vanshika Shukla <vanshika.shukla@nxp.com>
---
drivers/net/enetc/enetc.h | 2 ++
drivers/net/enetc/enetc4_ethdev.c | 57 ++++++++++++++++++++++++++++++-
2 files changed, 58 insertions(+), 1 deletion(-)
diff --git a/drivers/net/enetc/enetc.h b/drivers/net/enetc/enetc.h
index 09168c90db..4d99b5b0cf 100644
--- a/drivers/net/enetc/enetc.h
+++ b/drivers/net/enetc/enetc.h
@@ -92,6 +92,8 @@ struct enetc_bdr {
struct rte_mempool *mb_pool; /* mbuf pool to populate RX ring. */
struct rte_eth_dev *ndev;
uint64_t ierrors;
+ uint8_t rx_deferred_start;
+ uint8_t tx_deferred_start;
};
struct enetc_eth_hw {
diff --git a/drivers/net/enetc/enetc4_ethdev.c b/drivers/net/enetc/enetc4_ethdev.c
index 988c60aa68..b0d52e0058 100644
--- a/drivers/net/enetc/enetc4_ethdev.c
+++ b/drivers/net/enetc/enetc4_ethdev.c
@@ -28,10 +28,32 @@ enetc4_dev_start(struct rte_eth_dev *dev)
struct enetc_eth_hw *hw =
ENETC_DEV_PRIVATE_TO_HW(dev->data->dev_private);
struct enetc_hw *enetc_hw = &hw->hw;
+ struct enetc_bdr *txq, *rxq;
uint32_t val;
+ int i, ret;
PMD_INIT_FUNC_TRACE();
+ /* Start TX queues that are not deferred */
+ for (i = 0; i < dev->data->nb_tx_queues; i++) {
+ txq = dev->data->tx_queues[i];
+ if (txq && !txq->tx_deferred_start) {
+ ret = enetc4_tx_queue_start(dev, i);
+ if (ret < 0)
+ return ret;
+ }
+ }
+
+ /* Start RX queues that are not deferred */
+ for (i = 0; i < dev->data->nb_rx_queues; i++) {
+ rxq = dev->data->rx_queues[i];
+ if (rxq && !rxq->rx_deferred_start) {
+ ret = enetc4_rx_queue_start(dev, i);
+ if (ret < 0)
+ return ret;
+ }
+ }
+
val = enetc4_port_rd(enetc_hw, ENETC4_PM_CMD_CFG(0));
enetc4_port_wr(enetc_hw, ENETC4_PM_CMD_CFG(0),
val | PM_CMD_CFG_TX_EN | PM_CMD_CFG_RX_EN);
@@ -281,6 +303,7 @@ enetc4_tx_queue_setup(struct rte_eth_dev *dev,
tx_ring->ndev = dev;
enetc4_setup_txbdr(&priv->hw.hw, tx_ring);
data->tx_queues[queue_idx] = tx_ring;
+ tx_ring->tx_deferred_start = tx_conf->tx_deferred_start;
if (!tx_conf->tx_deferred_start) {
/* enable ring */
enetc4_txbdr_wr(&priv->hw.hw, tx_ring->index,
@@ -429,6 +452,7 @@ enetc4_rx_queue_setup(struct rte_eth_dev *dev,
rx_ring->ndev = dev;
enetc4_setup_rxbdr(&adapter->hw.hw, rx_ring, mb_pool);
data->rx_queues[rx_queue_id] = rx_ring;
+ rx_ring->rx_deferred_start = rx_conf->rx_deferred_start;
if (!rx_conf->rx_deferred_start) {
/* enable ring */
@@ -447,7 +471,7 @@ enetc4_rx_queue_setup(struct rte_eth_dev *dev,
fail:
rte_free(rx_ring);
- return err;
+return err;
}
void
@@ -837,6 +861,35 @@ enetc4_tx_queue_stop(struct rte_eth_dev *dev, uint16_t qidx)
return 0;
}
+static void
+enetc4_rxq_info_get(struct rte_eth_dev *dev, uint16_t queue_id,
+ struct rte_eth_rxq_info *qinfo)
+{
+ struct enetc_bdr *rxq = dev->data->rx_queues[queue_id];
+
+ qinfo->mp = rxq->mb_pool;
+ qinfo->scattered_rx = dev->data->scattered_rx;
+ qinfo->nb_desc = rxq->bd_count;
+ qinfo->conf.rx_free_thresh = 0;
+ qinfo->conf.rx_deferred_start = rxq->rx_deferred_start;
+ qinfo->conf.rx_drop_en = 0;
+}
+
+static void
+enetc4_txq_info_get(struct rte_eth_dev *dev, uint16_t queue_id,
+ struct rte_eth_txq_info *qinfo)
+{
+ struct enetc_bdr *txq = dev->data->tx_queues[queue_id];
+
+ qinfo->nb_desc = txq->bd_count;
+ qinfo->conf.tx_thresh.pthresh = 0;
+ qinfo->conf.tx_thresh.hthresh = 0;
+ qinfo->conf.tx_thresh.wthresh = 0;
+ qinfo->conf.tx_deferred_start = txq->tx_deferred_start;
+ qinfo->conf.tx_free_thresh = 0;
+ qinfo->conf.tx_rs_thresh = 0;
+}
+
const uint32_t *
enetc4_supported_ptypes_get(struct rte_eth_dev *dev __rte_unused,
size_t *no_of_elements)
@@ -883,10 +936,12 @@ static const struct eth_dev_ops enetc4_ops = {
.rx_queue_start = enetc4_rx_queue_start,
.rx_queue_stop = enetc4_rx_queue_stop,
.rx_queue_release = enetc4_rx_queue_release,
+ .rxq_info_get = enetc4_rxq_info_get,
.tx_queue_setup = enetc4_tx_queue_setup,
.tx_queue_start = enetc4_tx_queue_start,
.tx_queue_stop = enetc4_tx_queue_stop,
.tx_queue_release = enetc4_tx_queue_release,
+ .txq_info_get = enetc4_txq_info_get,
.dev_supported_ptypes_get = enetc4_supported_ptypes_get,
};
--
2.25.1
prev parent reply other threads:[~2025-10-17 9:20 UTC|newest]
Thread overview: 34+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-10-09 11:16 [v1 00/12] ENETC4 PMD support vanshika.shukla
2025-10-09 11:16 ` [v1 01/12] net/enetc: Add initial ENETC4 PMD driver support vanshika.shukla
2025-10-09 16:06 ` Hemant Agrawal
2025-10-15 21:34 ` Stephen Hemminger
2025-10-09 11:16 ` [v1 02/12] net/enetc: Add RX and TX queue APIs for ENETC4 PMD vanshika.shukla
2025-10-15 21:36 ` Stephen Hemminger
2025-10-15 21:42 ` Stephen Hemminger
2025-10-15 21:43 ` Stephen Hemminger
2025-10-15 21:50 ` Stephen Hemminger
2025-10-09 11:16 ` [v1 03/12] net/enetc: Optimize ENETC4 data path vanshika.shukla
2025-10-09 11:16 ` [v1 04/12] net/enetc: Add TX checksum offload and RX checksum validation vanshika.shukla
2025-10-09 11:16 ` [v1 05/12] net/enetc: Add basic statistics vanshika.shukla
2025-10-09 11:16 ` [v1 06/12] net/enetc: Add packet type parsing support vanshika.shukla
2025-10-09 11:16 ` [v1 07/12] net/enetc: Add support for multiple queues with RSS vanshika.shukla
2025-10-09 11:16 ` [v1 08/12] net/enetc: Add VF to PF messaging support and primary MAC setup vanshika.shukla
2025-10-15 21:53 ` Stephen Hemminger
2025-10-09 11:16 ` [v1 09/12] net/enetc: Add multicast and promiscuous mode support vanshika.shukla
2025-10-09 11:16 ` [v1 10/12] net/enetc: Add link speed and status support vanshika.shukla
2025-10-09 11:16 ` [v1 11/12] net/enetc: Add link status notification support vanshika.shukla
2025-10-09 11:16 ` [v1 12/12] net/enetc: Add MAC and VLAN filter support vanshika.shukla
2025-10-15 22:10 ` [v1 00/12] ENETC4 PMD support Stephen Hemminger
2025-10-17 9:19 ` [v2 " vanshika.shukla
2025-10-17 9:19 ` [v2 01/12] net/enetc: Add initial ENETC4 PMD driver support vanshika.shukla
2025-10-17 9:19 ` [v2 02/12] net/enetc: Add RX and TX queue APIs for ENETC4 PMD vanshika.shukla
2025-10-17 9:19 ` [v2 03/12] net/enetc: Optimize ENETC4 data path vanshika.shukla
2025-10-17 9:19 ` [v2 04/12] net/enetc: Add TX checksum offload and RX checksum validation vanshika.shukla
2025-10-17 9:19 ` [v2 05/12] net/enetc: Add basic statistics vanshika.shukla
2025-10-17 9:19 ` [v2 06/12] net/enetc: Add packet type parsing support vanshika.shukla
2025-10-17 9:19 ` [v2 07/12] net/enetc: Add VF to PF messaging support and primary MAC setup vanshika.shukla
2025-10-17 9:19 ` [v2 08/12] net/enetc: Add multicast and promiscuous mode support vanshika.shukla
2025-10-17 9:19 ` [v2 09/12] net/enetc: Add link speed and status support vanshika.shukla
2025-10-17 9:19 ` [v2 10/12] net/enetc: Add link status notification support vanshika.shukla
2025-10-17 9:19 ` [v2 11/12] net/enetc: Add MAC and VLAN filter support vanshika.shukla
2025-10-17 9:19 ` vanshika.shukla [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20251017091929.2723044-13-vanshika.shukla@nxp.com \
--to=vanshika.shukla@nxp.com \
--cc=dev@dpdk.org \
--cc=g.singh@nxp.com \
--cc=sachin.saxena@nxp.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).