From: Jakub Kicinski <kuba@kernel.org>
To: Daniel Borkmann <daniel@iogearbox.net>
Cc: netdev@vger.kernel.org, bpf@vger.kernel.org, davem@davemloft.net,
razor@blackwall.org, pabeni@redhat.com, willemb@google.com,
sdf@fomichev.me, john.fastabend@gmail.com, martin.lau@kernel.org,
jordan@jrife.io, maciej.fijalkowski@intel.com,
magnus.karlsson@intel.com, dw@davidwei.uk, toke@redhat.com,
yangzhenze@bytedance.com, wangdongdong.6@bytedance.com
Subject: Re: [PATCH net-next v7 05/16] net: Proxy net_mp_{open,close}_rxq for leased queues
Date: Tue, 20 Jan 2026 18:04:02 -0800 [thread overview]
Message-ID: <20260120180402.2b9ab13a@kernel.org> (raw)
In-Reply-To: <20260115082603.219152-6-daniel@iogearbox.net>
On Thu, 15 Jan 2026 09:25:52 +0100 Daniel Borkmann wrote:
> if (!netdev_need_ops_lock(dev))
> return -EOPNOTSUPP;
> -
> if (rxq_idx >= dev->real_num_rx_queues) {
> NL_SET_ERR_MSG(extack, "rx queue index out of range");
> return -ERANGE;
> }
> - rxq_idx = array_index_nospec(rxq_idx, dev->real_num_rx_queues);
>
> + rxq_idx = array_index_nospec(rxq_idx, dev->real_num_rx_queues);
The white space changes here look haphazard.
> + rxq = netif_get_rx_queue_lease_locked(&dev, &rxq_idx);
I really hate this function but I don't have any great suggestion on
how to make it better. I'd prefer if there was a clear separation
between the case where we call directly, vs where swapped the queue.
Instead of replacing pointers passed in by reference :| And that'd
remove the conditional locking too.
> + if (!rxq) {
> + NL_SET_ERR_MSG(extack, "rx queue peered to a virtual netdev");
The fact the !rxq means the queue was leased is also fairly random
vs all the subsequent checks.
> + return -EBUSY;
> + }
> + if (!dev->dev.parent) {
> + NL_SET_ERR_MSG(extack, "rx queue is mapped to a virtual netdev");
mapped? Or belongs?
> + ret = -EBUSY;
> + goto out;
> + }
> if (dev->cfg->hds_config != ETHTOOL_TCP_DATA_SPLIT_ENABLED) {
> NL_SET_ERR_MSG(extack, "tcp-data-split is disabled");
> - return -EINVAL;
> + ret = -EINVAL;
> + goto out;
> }
> if (dev->cfg->hds_thresh) {
> NL_SET_ERR_MSG(extack, "hds-thresh is not zero");
> - return -EINVAL;
> + ret = -EINVAL;
> + goto out;
> }
> if (dev_xdp_prog_count(dev)) {
> NL_SET_ERR_MSG(extack, "unable to custom memory provider to device with XDP program attached");
> - return -EEXIST;
> + ret = -EEXIST;
> + goto out;
> }
> -
> - rxq = __netif_get_rx_queue(dev, rxq_idx);
> if (rxq->mp_params.mp_ops) {
> NL_SET_ERR_MSG(extack, "designated queue already memory provider bound");
> - return -EEXIST;
> + ret = -EEXIST;
> + goto out;
> }
> #ifdef CONFIG_XDP_SOCKETS
> if (rxq->pool) {
> NL_SET_ERR_MSG(extack, "designated queue already in use by AF_XDP");
> - return -EBUSY;
> + ret = -EBUSY;
> + goto out;
All these checks can be factored out to avoid making this function long
and having 5 gotos.
> }
> #endif
> -
Please lease my whitespace be.
> rxq->mp_params = *p;
> ret = netdev_rx_queue_restart(dev, rxq_idx);
> if (ret) {
> rxq->mp_params.mp_ops = NULL;
> rxq->mp_params.mp_priv = NULL;
> }
next prev parent reply other threads:[~2026-01-21 2:04 UTC|newest]
Thread overview: 46+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-01-15 8:25 [PATCH net-next v7 00/16] netkit: Support for io_uring zero-copy and AF_XDP Daniel Borkmann
2026-01-15 8:25 ` [PATCH net-next v7 01/16] net: Add queue-create operation Daniel Borkmann
2026-01-19 1:43 ` Stanislav Fomichev
2026-01-19 14:20 ` Nikolay Aleksandrov
2026-01-15 8:25 ` [PATCH net-next v7 02/16] net: Implement netdev_nl_queue_create_doit Daniel Borkmann
2026-01-19 1:44 ` Stanislav Fomichev
2026-01-19 14:20 ` Nikolay Aleksandrov
2026-01-15 8:25 ` [PATCH net-next v7 03/16] net: Add lease info to queue-get response Daniel Borkmann
2026-01-19 1:44 ` Stanislav Fomichev
2026-01-15 8:25 ` [PATCH net-next v7 04/16] net, ethtool: Disallow leased real rxqs to be resized Daniel Borkmann
2026-01-19 1:44 ` Stanislav Fomichev
2026-01-15 8:25 ` [PATCH net-next v7 05/16] net: Proxy net_mp_{open,close}_rxq for leased queues Daniel Borkmann
2026-01-19 1:44 ` Stanislav Fomichev
2026-01-21 2:04 ` Jakub Kicinski [this message]
2026-01-21 3:44 ` David Wei
2026-01-15 8:25 ` [PATCH net-next v7 06/16] net: Proxy netdev_queue_get_dma_dev " Daniel Borkmann
2026-01-19 1:45 ` Stanislav Fomichev
2026-01-19 14:21 ` Nikolay Aleksandrov
2026-01-15 8:25 ` [PATCH net-next v7 07/16] xsk: Extend xsk_rcv_check validation Daniel Borkmann
2026-01-19 1:45 ` Stanislav Fomichev
2026-01-19 14:21 ` Nikolay Aleksandrov
2026-01-15 8:25 ` [PATCH net-next v7 08/16] xsk: Proxy pool management for leased queues Daniel Borkmann
2026-01-19 1:45 ` Stanislav Fomichev
2026-01-19 14:22 ` Nikolay Aleksandrov
2026-01-15 8:25 ` [PATCH net-next v7 09/16] netkit: Add single device mode for netkit Daniel Borkmann
2026-01-15 8:25 ` [PATCH net-next v7 10/16] netkit: Implement rtnl_link_ops->alloc and ndo_queue_create Daniel Borkmann
2026-01-15 8:25 ` [PATCH net-next v7 11/16] netkit: Add netkit notifier to check for unregistering devices Daniel Borkmann
2026-01-19 14:22 ` Nikolay Aleksandrov
2026-01-15 8:25 ` [PATCH net-next v7 12/16] netkit: Add xsk support for af_xdp applications Daniel Borkmann
2026-01-15 8:26 ` [PATCH net-next v7 13/16] selftests/net: Add bpf skb forwarding program Daniel Borkmann
2026-01-19 1:45 ` Stanislav Fomichev
2026-01-19 14:23 ` Nikolay Aleksandrov
2026-01-15 8:26 ` [PATCH net-next v7 14/16] selftests/net: Add env for container based tests Daniel Borkmann
2026-01-19 1:46 ` Stanislav Fomichev
2026-01-19 14:23 ` Nikolay Aleksandrov
2026-01-15 8:26 ` [PATCH net-next v7 15/16] selftests/net: Make NetDrvContEnv support queue leasing Daniel Borkmann
2026-01-19 1:46 ` Stanislav Fomichev
2026-01-19 14:23 ` Nikolay Aleksandrov
2026-01-21 1:51 ` Jakub Kicinski
2026-01-21 1:57 ` David Wei
2026-01-15 8:26 ` [PATCH net-next v7 16/16] selftests/net: Add netkit container tests Daniel Borkmann
2026-01-19 1:46 ` Stanislav Fomichev
2026-01-19 14:25 ` Nikolay Aleksandrov
2026-01-20 11:50 ` [PATCH net-next v7 00/16] netkit: Support for io_uring zero-copy and AF_XDP patchwork-bot+netdevbpf
2026-01-21 2:08 ` Jakub Kicinski
2026-01-21 3:46 ` David Wei
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=20260120180402.2b9ab13a@kernel.org \
--to=kuba@kernel.org \
--cc=bpf@vger.kernel.org \
--cc=daniel@iogearbox.net \
--cc=davem@davemloft.net \
--cc=dw@davidwei.uk \
--cc=john.fastabend@gmail.com \
--cc=jordan@jrife.io \
--cc=maciej.fijalkowski@intel.com \
--cc=magnus.karlsson@intel.com \
--cc=martin.lau@kernel.org \
--cc=netdev@vger.kernel.org \
--cc=pabeni@redhat.com \
--cc=razor@blackwall.org \
--cc=sdf@fomichev.me \
--cc=toke@redhat.com \
--cc=wangdongdong.6@bytedance.com \
--cc=willemb@google.com \
--cc=yangzhenze@bytedance.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.