]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
can: m_can: Release irq on error in m_can_open
authorSimon Horman <horms@kernel.org>
Mon, 5 Aug 2024 14:01:58 +0000 (15:01 +0100)
committerMarc Kleine-Budde <mkl@pengutronix.de>
Tue, 6 Aug 2024 07:25:12 +0000 (09:25 +0200)
It appears that the irq requested in m_can_open() may be leaked
if an error subsequently occurs: if m_can_start() fails.

Address this by calling free_irq in the unwind path for
such cases.

Flagged by Smatch.
Compile tested only.

Fixes: eaacfeaca7ad ("can: m_can: Call the RAM init directly from m_can_chip_config")
Acked-by: Marc Kleine-Budde <mkl@pengutronix.de>
Signed-off-by: Simon Horman <horms@kernel.org>
Link: https://lore.kernel.org/all/20240805-mcan-irq-v2-1-7154c0484819@kernel.org
Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
drivers/net/can/m_can/m_can.c

index 7f63f866083e0511397398b3eb700f833a54effb..cd83c8b5d4b15b37ba467348fc5ea4fcf68e9755 100644 (file)
@@ -2052,7 +2052,7 @@ static int m_can_open(struct net_device *dev)
        /* start the m_can controller */
        err = m_can_start(dev);
        if (err)
-               goto exit_irq_fail;
+               goto exit_start_fail;
 
        if (!cdev->is_peripheral)
                napi_enable(&cdev->napi);
@@ -2061,6 +2061,9 @@ static int m_can_open(struct net_device *dev)
 
        return 0;
 
+exit_start_fail:
+       if (cdev->is_peripheral || dev->irq)
+               free_irq(dev->irq, dev);
 exit_irq_fail:
        if (cdev->is_peripheral)
                destroy_workqueue(cdev->tx_wq);