提交 237f977a 编写于 作者: J Jakub Kicinski

Merge tag 'linux-can-fixes-for-5.10-20201130' of...

Merge tag 'linux-can-fixes-for-5.10-20201130' of git://git.kernel.org/pub/scm/linux/kernel/git/mkl/linux-can

Marc Kleine-Budde says:

====================
pull-request: can 2020-11-30

The first patch is by me an target the tcan4x5x bindings for the m_can driver.
It fixes the error path in the tcan4x5x_can_probe() function.

The next two patches are by Jeroen Hofstee and makes the lost of arbitration
error counters of sja1000 and the sun4i drivers consistent with the other
drivers.

Zhang Qilong contributes two patch that clean up the error path in the c_can
and kvaser_pciefd drivers.

* tag 'linux-can-fixes-for-5.10-20201130' of git://git.kernel.org/pub/scm/linux/kernel/git/mkl/linux-can:
  can: kvaser_pciefd: kvaser_pciefd_open(): fix error handling
  can: c_can: c_can_power_up(): fix error handling
  can: sun4i_can: sun4i_can_err(): don't count arbitration lose as an error
  can: sja1000: sja1000_err(): don't count arbitration lose as an error
  can: m_can: tcan4x5x_can_probe(): fix error path: remove erroneous clk_disable_unprepare()
====================

Link: https://lore.kernel.org/r/20201130125307.218258-1-mkl@pengutronix.deSigned-off-by: NJakub Kicinski <kuba@kernel.org>
...@@ -1295,12 +1295,22 @@ int c_can_power_up(struct net_device *dev) ...@@ -1295,12 +1295,22 @@ int c_can_power_up(struct net_device *dev)
time_after(time_out, jiffies)) time_after(time_out, jiffies))
cpu_relax(); cpu_relax();
if (time_after(jiffies, time_out)) if (time_after(jiffies, time_out)) {
return -ETIMEDOUT; ret = -ETIMEDOUT;
goto err_out;
}
ret = c_can_start(dev); ret = c_can_start(dev);
if (!ret) if (ret)
c_can_irq_control(priv, true); goto err_out;
c_can_irq_control(priv, true);
return 0;
err_out:
c_can_reset_ram(priv, false);
c_can_pm_runtime_put_sync(priv);
return ret; return ret;
} }
......
...@@ -692,8 +692,10 @@ static int kvaser_pciefd_open(struct net_device *netdev) ...@@ -692,8 +692,10 @@ static int kvaser_pciefd_open(struct net_device *netdev)
return err; return err;
err = kvaser_pciefd_bus_on(can); err = kvaser_pciefd_bus_on(can);
if (err) if (err) {
close_candev(netdev);
return err; return err;
}
return 0; return 0;
} }
......
...@@ -489,18 +489,18 @@ static int tcan4x5x_can_probe(struct spi_device *spi) ...@@ -489,18 +489,18 @@ static int tcan4x5x_can_probe(struct spi_device *spi)
spi->bits_per_word = 32; spi->bits_per_word = 32;
ret = spi_setup(spi); ret = spi_setup(spi);
if (ret) if (ret)
goto out_clk; goto out_m_can_class_free_dev;
priv->regmap = devm_regmap_init(&spi->dev, &tcan4x5x_bus, priv->regmap = devm_regmap_init(&spi->dev, &tcan4x5x_bus,
&spi->dev, &tcan4x5x_regmap); &spi->dev, &tcan4x5x_regmap);
if (IS_ERR(priv->regmap)) { if (IS_ERR(priv->regmap)) {
ret = PTR_ERR(priv->regmap); ret = PTR_ERR(priv->regmap);
goto out_clk; goto out_m_can_class_free_dev;
} }
ret = tcan4x5x_power_enable(priv->power, 1); ret = tcan4x5x_power_enable(priv->power, 1);
if (ret) if (ret)
goto out_clk; goto out_m_can_class_free_dev;
ret = tcan4x5x_parse_config(mcan_class); ret = tcan4x5x_parse_config(mcan_class);
if (ret) if (ret)
...@@ -519,11 +519,6 @@ static int tcan4x5x_can_probe(struct spi_device *spi) ...@@ -519,11 +519,6 @@ static int tcan4x5x_can_probe(struct spi_device *spi)
out_power: out_power:
tcan4x5x_power_enable(priv->power, 0); tcan4x5x_power_enable(priv->power, 0);
out_clk:
if (!IS_ERR(mcan_class->cclk)) {
clk_disable_unprepare(mcan_class->cclk);
clk_disable_unprepare(mcan_class->hclk);
}
out_m_can_class_free_dev: out_m_can_class_free_dev:
m_can_class_free_dev(mcan_class->net); m_can_class_free_dev(mcan_class->net);
dev_err(&spi->dev, "Probe failed, err=%d\n", ret); dev_err(&spi->dev, "Probe failed, err=%d\n", ret);
......
...@@ -474,7 +474,6 @@ static int sja1000_err(struct net_device *dev, uint8_t isrc, uint8_t status) ...@@ -474,7 +474,6 @@ static int sja1000_err(struct net_device *dev, uint8_t isrc, uint8_t status)
netdev_dbg(dev, "arbitration lost interrupt\n"); netdev_dbg(dev, "arbitration lost interrupt\n");
alc = priv->read_reg(priv, SJA1000_ALC); alc = priv->read_reg(priv, SJA1000_ALC);
priv->can.can_stats.arbitration_lost++; priv->can.can_stats.arbitration_lost++;
stats->tx_errors++;
cf->can_id |= CAN_ERR_LOSTARB; cf->can_id |= CAN_ERR_LOSTARB;
cf->data[0] = alc & 0x1f; cf->data[0] = alc & 0x1f;
} }
......
...@@ -604,7 +604,6 @@ static int sun4i_can_err(struct net_device *dev, u8 isrc, u8 status) ...@@ -604,7 +604,6 @@ static int sun4i_can_err(struct net_device *dev, u8 isrc, u8 status)
netdev_dbg(dev, "arbitration lost interrupt\n"); netdev_dbg(dev, "arbitration lost interrupt\n");
alc = readl(priv->base + SUN4I_REG_STA_ADDR); alc = readl(priv->base + SUN4I_REG_STA_ADDR);
priv->can.can_stats.arbitration_lost++; priv->can.can_stats.arbitration_lost++;
stats->tx_errors++;
if (likely(skb)) { if (likely(skb)) {
cf->can_id |= CAN_ERR_LOSTARB; cf->can_id |= CAN_ERR_LOSTARB;
cf->data[0] = (alc >> 8) & 0x1f; cf->data[0] = (alc >> 8) & 0x1f;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册