From: Vadim Fedorenko <vadim.fedorenko@linux.dev>
To: Shinas Rasheed <srasheed@marvell.com>,
netdev@vger.kernel.org, linux-kernel@vger.kernel.org
Cc: hgani@marvell.com, sedara@marvell.com, vimleshk@marvell.com,
thaller@redhat.com, wizhao@redhat.com, kheib@redhat.com,
egallen@redhat.com, konguyen@redhat.com, horms@kernel.org,
frank.feng@synaxg.com, Veerasenareddy Burru <vburru@marvell.com>,
Andrew Lunn <andrew+netdev@lunn.ch>,
"David S. Miller" <davem@davemloft.net>,
Eric Dumazet <edumazet@google.com>,
Jakub Kicinski <kuba@kernel.org>, Paolo Abeni <pabeni@redhat.com>
Subject: Re: [PATCH net v2 1/7] octeon_ep: Add checks to fix double free crashes.
Date: Fri, 8 Nov 2024 15:11:42 +0000 [thread overview]
Message-ID: <c3682951-e172-421f-945e-ffe08d67ab66@linux.dev> (raw)
In-Reply-To: <20241107132846.1118835-2-srasheed@marvell.com>
On 07/11/2024 13:28, Shinas Rasheed wrote:
> From: Vimlesh Kumar <vimleshk@marvell.com>
>
> Add required checks to avoid double free. Crashes were
> observed due to the same on reset scenarios
>
> Signed-off-by: Vimlesh Kumar <vimleshk@marvell.com>
> Signed-off-by: Shinas Rasheed <srasheed@marvell.com>
> ---
> V2:
> - No changes
>
> V1: https://lore.kernel.org/all/20241101103416.1064930-2-srasheed@marvell.com/
>
> .../ethernet/marvell/octeon_ep/octep_main.c | 39 +++++++++++--------
> .../net/ethernet/marvell/octeon_ep/octep_tx.c | 2 +
> 2 files changed, 25 insertions(+), 16 deletions(-)
>
> diff --git a/drivers/net/ethernet/marvell/octeon_ep/octep_main.c b/drivers/net/ethernet/marvell/octeon_ep/octep_main.c
> index 549436efc204..ff72b796bd25 100644
> --- a/drivers/net/ethernet/marvell/octeon_ep/octep_main.c
> +++ b/drivers/net/ethernet/marvell/octeon_ep/octep_main.c
> @@ -154,9 +154,11 @@ static int octep_enable_msix_range(struct octep_device *oct)
> */
> static void octep_disable_msix(struct octep_device *oct)
> {
> - pci_disable_msix(oct->pdev);
> - kfree(oct->msix_entries);
> - oct->msix_entries = NULL;
> + if (oct->msix_entries) {
> + pci_disable_msix(oct->pdev);
> + kfree(oct->msix_entries);
> + oct->msix_entries = NULL;
> + }
> dev_info(&oct->pdev->dev, "Disabled MSI-X\n");
How can this function crash? pci_disable_msix() will have checks for
already disabled msix, kfree can properly deal with NULL pointer.
Do you have stack trace of the crash here?
> }
>
> @@ -496,16 +498,18 @@ static void octep_free_irqs(struct octep_device *oct)
> {
> int i;
>
> - /* First few MSI-X interrupts are non queue interrupts; free them */
> - for (i = 0; i < CFG_GET_NON_IOQ_MSIX(oct->conf); i++)
> - free_irq(oct->msix_entries[i].vector, oct);
> - kfree(oct->non_ioq_irq_names);
> -
> - /* Free IRQs for Input/Output (Tx/Rx) queues */
> - for (i = CFG_GET_NON_IOQ_MSIX(oct->conf); i < oct->num_irqs; i++) {
> - irq_set_affinity_hint(oct->msix_entries[i].vector, NULL);
> - free_irq(oct->msix_entries[i].vector,
> - oct->ioq_vector[i - CFG_GET_NON_IOQ_MSIX(oct->conf)]);
> + if (oct->msix_entries) {
> + /* First few MSI-X interrupts are non queue interrupts; free them */
> + for (i = 0; i < CFG_GET_NON_IOQ_MSIX(oct->conf); i++)
> + free_irq(oct->msix_entries[i].vector, oct);
> + kfree(oct->non_ioq_irq_names);
> +
> + /* Free IRQs for Input/Output (Tx/Rx) queues */
> + for (i = CFG_GET_NON_IOQ_MSIX(oct->conf); i < oct->num_irqs; i++) {
> + irq_set_affinity_hint(oct->msix_entries[i].vector, NULL);
> + free_irq(oct->msix_entries[i].vector,
> + oct->ioq_vector[i - CFG_GET_NON_IOQ_MSIX(oct->conf)]);
> + }
> }
> netdev_info(oct->netdev, "IRQs freed\n");
> }
Have you considered fast return option? like
if (!octep_disable_msix)
return;
It will make less intendation and less changes in LoC but will presume
the same behavior.
> @@ -635,8 +639,10 @@ static void octep_napi_delete(struct octep_device *oct)
>
> for (i = 0; i < oct->num_oqs; i++) {
> netdev_dbg(oct->netdev, "Deleting NAPI on Q-%d\n", i);
> - netif_napi_del(&oct->ioq_vector[i]->napi);
> - oct->oq[i]->napi = NULL;
> + if (oct->oq[i]->napi) {
> + netif_napi_del(&oct->ioq_vector[i]->napi);
> + oct->oq[i]->napi = NULL;
> + }
> }
> }
>
[ .. snip ..]
next prev parent reply other threads:[~2024-11-08 15:11 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-11-07 13:28 [PATCH net v2 0/7] Double free fixes and NULL pointer checks Shinas Rasheed
2024-11-07 13:28 ` [PATCH net v2 1/7] octeon_ep: Add checks to fix double free crashes Shinas Rasheed
2024-11-08 15:11 ` Vadim Fedorenko [this message]
2024-11-07 13:28 ` [PATCH net v2 2/7] octeon_ep: Fix null dereferences to IQ/OQ pointers Shinas Rasheed
2024-11-07 13:28 ` [PATCH net v2 3/7] octeon_ep: add protective null checks in napi callbacks for cn9k cards Shinas Rasheed
2024-11-07 13:28 ` [PATCH net v2 4/7] octeon_ep: add protective null checks in napi callbacks for cnxk cards Shinas Rasheed
2024-11-07 13:28 ` [PATCH net v2 5/7] octeon_ep_vf: Fix null dereferences to IQ/OQ pointers Shinas Rasheed
2024-11-07 13:28 ` [PATCH net v2 6/7] octeon_ep_vf: add protective null checks in napi callbacks for cn9k cards Shinas Rasheed
2024-11-07 13:28 ` [PATCH net v2 7/7] octeon_ep_vf: add protective null checks in napi callbacks for cnxk cards Shinas Rasheed
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=c3682951-e172-421f-945e-ffe08d67ab66@linux.dev \
--to=vadim.fedorenko@linux.dev \
--cc=andrew+netdev@lunn.ch \
--cc=davem@davemloft.net \
--cc=edumazet@google.com \
--cc=egallen@redhat.com \
--cc=frank.feng@synaxg.com \
--cc=hgani@marvell.com \
--cc=horms@kernel.org \
--cc=kheib@redhat.com \
--cc=konguyen@redhat.com \
--cc=kuba@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=netdev@vger.kernel.org \
--cc=pabeni@redhat.com \
--cc=sedara@marvell.com \
--cc=srasheed@marvell.com \
--cc=thaller@redhat.com \
--cc=vburru@marvell.com \
--cc=vimleshk@marvell.com \
--cc=wizhao@redhat.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.