netdev-genl: Add an XSK attribute to queues
authorJoe Damato <jdamato@fastly.com>
Fri, 14 Feb 2025 21:12:30 +0000 (21:12 +0000)
committerJakub Kicinski <kuba@kernel.org>
Tue, 18 Feb 2025 00:46:03 +0000 (16:46 -0800)
Expose a new per-queue nest attribute, xsk, which will be present for
queues that are being used for AF_XDP. If the queue is not being used for
AF_XDP, the nest will not be present.

In the future, this attribute can be extended to include more data about
XSK as it is needed.

Signed-off-by: Joe Damato <jdamato@fastly.com>
Suggested-by: Jakub Kicinski <kuba@kernel.org>
Link: https://patch.msgid.link/20250214211255.14194-3-jdamato@fastly.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Documentation/netlink/specs/netdev.yaml
include/uapi/linux/netdev.h
net/core/netdev-genl.c
tools/include/uapi/linux/netdev.h

index 288923e965aed39ff30032ef540462046c9f2e4e..85402a2e289c409b36ddfbcb52c9ae26c6ea9938 100644 (file)
@@ -276,6 +276,9 @@ attribute-sets:
         doc: The timeout, in nanoseconds, of how long to suspend irq
              processing, if event polling finds events
         type: uint
+  -
+    name: xsk-info
+    attributes: []
   -
     name: queue
     attributes:
@@ -294,6 +297,9 @@ attribute-sets:
       -
         name: type
         doc: Queue type as rx, tx. Each queue type defines a separate ID space.
+             XDP TX queues allocated in the kernel are not linked to NAPIs and
+             thus not listed. AF_XDP queues will have more information set in
+             the xsk attribute.
         type: u32
         enum: queue-type
       -
@@ -309,7 +315,11 @@ attribute-sets:
         doc: io_uring memory provider information.
         type: nest
         nested-attributes: io-uring-provider-info
-
+      -
+        name: xsk
+        doc: XSK information for this queue, if any.
+        type: nest
+        nested-attributes: xsk-info
   -
     name: qstats
     doc: |
@@ -652,6 +662,7 @@ operations:
             - ifindex
             - dmabuf
             - io-uring
+            - xsk
       dump:
         request:
           attributes:
index 6c6ee183802d335c03bcf3a0daad71909026c721..4e82f3871473b24393b7325d8b4ffcfba4cff263 100644 (file)
@@ -136,6 +136,11 @@ enum {
        NETDEV_A_NAPI_MAX = (__NETDEV_A_NAPI_MAX - 1)
 };
 
+enum {
+       __NETDEV_A_XSK_INFO_MAX,
+       NETDEV_A_XSK_INFO_MAX = (__NETDEV_A_XSK_INFO_MAX - 1)
+};
+
 enum {
        NETDEV_A_QUEUE_ID = 1,
        NETDEV_A_QUEUE_IFINDEX,
@@ -143,6 +148,7 @@ enum {
        NETDEV_A_QUEUE_NAPI_ID,
        NETDEV_A_QUEUE_DMABUF,
        NETDEV_A_QUEUE_IO_URING,
+       NETDEV_A_QUEUE_XSK,
 
        __NETDEV_A_QUEUE_MAX,
        NETDEV_A_QUEUE_MAX = (__NETDEV_A_QUEUE_MAX - 1)
index 22ac51356d9f6d83a682bd013fd21ede48ca0c26..c92fba65b20d18b1590cd55b8d796676eef72064 100644 (file)
@@ -400,11 +400,23 @@ netdev_nl_queue_fill_one(struct sk_buff *rsp, struct net_device *netdev,
                if (params->mp_ops &&
                    params->mp_ops->nl_fill(params->mp_priv, rsp, rxq))
                        goto nla_put_failure;
+#ifdef CONFIG_XDP_SOCKETS
+               if (rxq->pool)
+                       if (nla_put_empty_nest(rsp, NETDEV_A_QUEUE_XSK))
+                               goto nla_put_failure;
+#endif
+
                break;
        case NETDEV_QUEUE_TYPE_TX:
                txq = netdev_get_tx_queue(netdev, q_idx);
                if (nla_put_napi_id(rsp, txq->napi))
                        goto nla_put_failure;
+#ifdef CONFIG_XDP_SOCKETS
+               if (txq->pool)
+                       if (nla_put_empty_nest(rsp, NETDEV_A_QUEUE_XSK))
+                               goto nla_put_failure;
+#endif
+               break;
        }
 
        genlmsg_end(rsp, hdr);
index 6c6ee183802d335c03bcf3a0daad71909026c721..4e82f3871473b24393b7325d8b4ffcfba4cff263 100644 (file)
@@ -136,6 +136,11 @@ enum {
        NETDEV_A_NAPI_MAX = (__NETDEV_A_NAPI_MAX - 1)
 };
 
+enum {
+       __NETDEV_A_XSK_INFO_MAX,
+       NETDEV_A_XSK_INFO_MAX = (__NETDEV_A_XSK_INFO_MAX - 1)
+};
+
 enum {
        NETDEV_A_QUEUE_ID = 1,
        NETDEV_A_QUEUE_IFINDEX,
@@ -143,6 +148,7 @@ enum {
        NETDEV_A_QUEUE_NAPI_ID,
        NETDEV_A_QUEUE_DMABUF,
        NETDEV_A_QUEUE_IO_URING,
+       NETDEV_A_QUEUE_XSK,
 
        __NETDEV_A_QUEUE_MAX,
        NETDEV_A_QUEUE_MAX = (__NETDEV_A_QUEUE_MAX - 1)