Skip to content

Commit 9ebf862

Browse files
geertugregkh
authored andcommitted
can: rcar_can: rcar_can_resume(): fix s2ram with PSCI
[ Upstream commit 5c793af ] On R-Car Gen3 using PSCI, s2ram powers down the SoC. After resume, the CAN interface no longer works, until it is brought down and up again. Fix this by calling rcar_can_start() from the PM resume callback, to fully initialize the controller instead of just restarting it. Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be> Link: https://patch.msgid.link/699b2f7fcb60b31b6f976a37f08ce99c5ffccb31.1755165227.git.geert+renesas@glider.be Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de> Signed-off-by: Sasha Levin <sashal@kernel.org>
1 parent b32c64d commit 9ebf862

1 file changed

Lines changed: 1 addition & 7 deletions

File tree

drivers/net/can/rcar/rcar_can.c

Lines changed: 1 addition & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -863,7 +863,6 @@ static int __maybe_unused rcar_can_resume(struct device *dev)
863863
{
864864
struct net_device *ndev = dev_get_drvdata(dev);
865865
struct rcar_can_priv *priv = netdev_priv(ndev);
866-
u16 ctlr;
867866
int err;
868867

869868
if (!netif_running(ndev))
@@ -875,12 +874,7 @@ static int __maybe_unused rcar_can_resume(struct device *dev)
875874
return err;
876875
}
877876

878-
ctlr = readw(&priv->regs->ctlr);
879-
ctlr &= ~RCAR_CAN_CTLR_SLPM;
880-
writew(ctlr, &priv->regs->ctlr);
881-
ctlr &= ~RCAR_CAN_CTLR_CANM;
882-
writew(ctlr, &priv->regs->ctlr);
883-
priv->can.state = CAN_STATE_ERROR_ACTIVE;
877+
rcar_can_start(ndev);
884878

885879
netif_device_attach(ndev);
886880
netif_start_queue(ndev);

0 commit comments

Comments
 (0)