]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
net: introduce a trivial netdev_queue_config()
authorJakub Kicinski <kuba@kernel.org>
Thu, 22 Jan 2026 00:51:09 +0000 (16:51 -0800)
committerJakub Kicinski <kuba@kernel.org>
Fri, 23 Jan 2026 19:49:01 +0000 (11:49 -0800)
We may choose to extend or reimplement the logic which renders
the per-queue config. The drivers should not poke directly into
the queue state. Add a helper for drivers to use when they want
to query the config for a specific queue.

Link: https://patch.msgid.link/20260122005113.2476634-3-kuba@kernel.org
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/broadcom/bnxt/bnxt.c
include/net/netdev_queues.h
net/core/Makefile
net/core/netdev_config.c [new file with mode: 0644]

index 0b95100a7c361c0aeaf4c827ee0ae1480801452e..d57e833ce69039dcf77481c44c3127abc65a1484 100644 (file)
@@ -4326,12 +4326,12 @@ static void bnxt_init_ring_struct(struct bnxt *bp)
 
        for (i = 0; i < bp->cp_nr_rings; i++) {
                struct bnxt_napi *bnapi = bp->bnapi[i];
+               struct netdev_queue_config qcfg;
                struct bnxt_ring_mem_info *rmem;
                struct bnxt_cp_ring_info *cpr;
                struct bnxt_rx_ring_info *rxr;
                struct bnxt_tx_ring_info *txr;
                struct bnxt_ring_struct *ring;
-               struct netdev_rx_queue *rxq;
 
                if (!bnapi)
                        continue;
@@ -4349,8 +4349,8 @@ static void bnxt_init_ring_struct(struct bnxt *bp)
                if (!rxr)
                        goto skip_rx;
 
-               rxq = __netif_get_rx_queue(bp->dev, i);
-               rxr->rx_page_size = rxq->qcfg.rx_page_size;
+               netdev_queue_config(bp->dev, i, &qcfg);
+               rxr->rx_page_size = qcfg.rx_page_size;
 
                ring = &rxr->rx_ring_struct;
                rmem = &ring->ring_mem;
index 2ab3eae8e8c3cbe95fb601a9b1a753789eab3936..725bf69ef86c140075df2a69a275cab25bacaba0 100644 (file)
@@ -170,6 +170,9 @@ struct netdev_queue_mgmt_ops {
        unsigned int supported_params;
 };
 
+void netdev_queue_config(struct net_device *dev, int rxq,
+                        struct netdev_queue_config *qcfg);
+
 bool netif_rxq_has_unreadable_mp(struct net_device *dev, int idx);
 
 /**
index 9ef2099c5426336f135f2889a6a8dba71d274a47..d643a5a7fd18bd22ba8f62593f6bf0e99f9ccd2b 100644 (file)
@@ -19,6 +19,7 @@ obj-$(CONFIG_NETDEV_ADDR_LIST_TEST) += dev_addr_lists_test.o
 
 obj-y += net-sysfs.o
 obj-y += hotdata.o
+obj-y += netdev_config.o
 obj-y += netdev_rx_queue.o
 obj-y += netdev_queues.o
 obj-$(CONFIG_PAGE_POOL) += page_pool.o page_pool_user.o
diff --git a/net/core/netdev_config.c b/net/core/netdev_config.c
new file mode 100644 (file)
index 0000000..562087b
--- /dev/null
@@ -0,0 +1,32 @@
+// SPDX-License-Identifier: GPL-2.0-only
+
+#include <linux/netdevice.h>
+#include <net/netdev_queues.h>
+#include <net/netdev_rx_queue.h>
+
+/**
+ * netdev_queue_config() - get configuration for a given queue
+ * @dev:      net_device instance
+ * @rxq_idx:  index of the queue of interest
+ * @qcfg: queue configuration struct (output)
+ *
+ * Render the configuration for a given queue. This helper should be used
+ * by drivers which support queue configuration to retrieve config for
+ * a particular queue.
+ *
+ * @qcfg is an output parameter and is always fully initialized by this
+ * function. Some values may not be set by the user, drivers may either
+ * deal with the "unset" values in @qcfg, or provide the callback
+ * to populate defaults in queue_management_ops.
+ */
+void netdev_queue_config(struct net_device *dev, int rxq_idx,
+                        struct netdev_queue_config *qcfg)
+{
+       struct netdev_queue_config *stored;
+
+       memset(qcfg, 0, sizeof(*qcfg));
+
+       stored = &__netif_get_rx_queue(dev, rxq_idx)->qcfg;
+       qcfg->rx_page_size = stored->rx_page_size;
+}
+EXPORT_SYMBOL(netdev_queue_config);