]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
can: m_can: m_can_get_berr_counter(): don't wake up controller if interface is down
authorMarc Kleine-Budde <mkl@pengutronix.de>
Wed, 6 Aug 2025 10:20:44 +0000 (12:20 +0200)
committerMarc Kleine-Budde <mkl@pengutronix.de>
Fri, 17 Oct 2025 13:17:19 +0000 (15:17 +0200)
If the interface is down, the CAN controller might be powered down, the
clock disabled, and/or it's external reset asserted.

Don't wake up the controller to read the CAN bus error counters, if the
interface is down.

Reviewed-by: Markus Schneider-Pargmann <msp@baylibre.com>
Link: https://patch.msgid.link/20251008-m_can-cleanups-v1-7-1784a18eaa84@pengutronix.de
Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
drivers/net/can/m_can/m_can.c

index 713d3df296df52f5ca02313cf1679dd50a7cac57..eb856547ae7df27a844b236a0c1d4498cbb8b60f 100644 (file)
@@ -791,6 +791,10 @@ static int m_can_get_berr_counter(const struct net_device *dev,
        struct m_can_classdev *cdev = netdev_priv(dev);
        int err;
 
+       /* Avoid waking up the controller if the interface is down */
+       if (!(dev->flags & IFF_UP))
+               return 0;
+
        err = m_can_clk_start(cdev);
        if (err)
                return err;