From: Stanislav Fomichev <sdf.kernel@gmail.com>
To: Michael Chan <michael.chan@broadcom.com>
Cc: netdev@vger.kernel.org, davem@davemloft.net, edumazet@google.com,
kuba@kernel.org, pabeni@redhat.com,
Pavan Chebbi <pavan.chebbi@broadcom.com>
Subject: Re: [PATCH net-next 3/3] bnxt: convert to core rx_mode retry mechanism
Date: Thu, 28 May 2026 14:30:26 -0700 [thread overview]
Message-ID: <ahizyCDm5Co5SlZI@devvm7509.cco0.facebook.com> (raw)
In-Reply-To: <CACKFLimk4fauCzfnPDZYjLPqYfo0bYTbCxoCsK3GHBSJ-9vmkQ@mail.gmail.com>
On 05/27, Michael Chan wrote:
> On Tue, May 26, 2026 at 6:41 PM Stanislav Fomichev <sdf.kernel@gmail.com> wrote:
> >
> > Remove the driver-specific BNXT_STATE_L2_FILTER_RETRY + timer + sp_task
> > retry mechanism and rely on the core stack's ndo_set_rx_mode_async retry
> > instead.
> >
> > bnxt_cfg_rx_mode() now returns errors (including -ENODEV when the VF
> > cannot reach the PF), allowing the core stack to schedule retries with
> > exponential backoff.
> >
> > Call core's netif_rx_mode_schedule_retry during reset to handle
> > VF reopen.
> >
> > Cc: Michael Chan <michael.chan@broadcom.com>
> > Cc: Pavan Chebbi <pavan.chebbi@broadcom.com>
> > Signed-off-by: Stanislav Fomichev <sdf@fomichev.me>
> > ---
> > drivers/net/ethernet/broadcom/bnxt/bnxt.c | 36 ++++++++---------------
> > drivers/net/ethernet/broadcom/bnxt/bnxt.h | 2 --
> > 2 files changed, 12 insertions(+), 26 deletions(-)
> >
> > diff --git a/drivers/net/ethernet/broadcom/bnxt/bnxt.c b/drivers/net/ethernet/broadcom/bnxt/bnxt.c
>
> > @@ -13757,21 +13763,14 @@ static int bnxt_cfg_rx_mode(struct bnxt *bp, struct netdev_hw_addr_list *uc,
> > for (i = 1, off = 0; i < vnic->uc_filter_count; i++, off += ETH_ALEN) {
> > rc = bnxt_hwrm_set_vnic_filter(bp, 0, i, vnic->uc_list + off);
> > if (rc) {
> > - if (BNXT_VF(bp) && rc == -ENODEV) {
> > - if (!test_and_set_bit(BNXT_STATE_L2_FILTER_RETRY, &bp->state))
> > - netdev_warn(bp->dev, "Cannot configure L2 filters while PF is unavailable, will retry\n");
> > - else
> > - netdev_dbg(bp->dev, "PF still unavailable while configuring L2 filters.\n");
> > - rc = 0;
> > - } else {
> > + if (BNXT_VF(bp) && rc == -ENODEV)
> > + netdev_warn(bp->dev, "Cannot configure L2 filters while PF is unavailable, will retry\n");
>
> Maybe we can set rc to -EAGAIN here so it's easier for the caller to
> check for retry.
Yeah, that makes sense, will do, thanks!
prev parent reply other threads:[~2026-05-28 21:30 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-05-27 1:41 [PATCH net-next 0/3] net: add retry mechanism to ndo_set_rx_mode_async Stanislav Fomichev
2026-05-27 1:41 ` [PATCH net-next 1/3] net: change ndo_set_rx_mode_async return type to int Stanislav Fomichev
2026-05-27 1:41 ` [PATCH net-next 2/3] net: add retry mechanism to ndo_set_rx_mode_async Stanislav Fomichev
2026-05-29 0:29 ` Jakub Kicinski
2026-06-01 15:05 ` Stanislav Fomichev
2026-05-27 1:41 ` [PATCH net-next 3/3] bnxt: convert to core rx_mode retry mechanism Stanislav Fomichev
2026-05-27 17:48 ` Michael Chan
2026-05-28 21:30 ` Stanislav Fomichev [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=ahizyCDm5Co5SlZI@devvm7509.cco0.facebook.com \
--to=sdf.kernel@gmail.com \
--cc=davem@davemloft.net \
--cc=edumazet@google.com \
--cc=kuba@kernel.org \
--cc=michael.chan@broadcom.com \
--cc=netdev@vger.kernel.org \
--cc=pabeni@redhat.com \
--cc=pavan.chebbi@broadcom.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.