Commit e443d15b authored by Markus Schneider-Pargmann's avatar Markus Schneider-Pargmann Committed by Marc Kleine-Budde

can: m_can: Limit coalescing to peripheral instances

The use of coalescing for non-peripheral chips in the current
implementation is limited to non-existing. Disable the possibility to
set coalescing through ethtool.
Signed-off-by: default avatarMarkus Schneider-Pargmann <msp@baylibre.com>
Link: https://lore.kernel.org/all/20240805183047.305630-8-msp@baylibre.comSigned-off-by: default avatarMarc Kleine-Budde <mkl@pengutronix.de>
parent 733dbf55
...@@ -2184,7 +2184,7 @@ static int m_can_set_coalesce(struct net_device *dev, ...@@ -2184,7 +2184,7 @@ static int m_can_set_coalesce(struct net_device *dev,
return 0; return 0;
} }
static const struct ethtool_ops m_can_ethtool_ops = { static const struct ethtool_ops m_can_ethtool_ops_coalescing = {
.supported_coalesce_params = ETHTOOL_COALESCE_RX_USECS_IRQ | .supported_coalesce_params = ETHTOOL_COALESCE_RX_USECS_IRQ |
ETHTOOL_COALESCE_RX_MAX_FRAMES_IRQ | ETHTOOL_COALESCE_RX_MAX_FRAMES_IRQ |
ETHTOOL_COALESCE_TX_USECS_IRQ | ETHTOOL_COALESCE_TX_USECS_IRQ |
...@@ -2195,18 +2195,20 @@ static const struct ethtool_ops m_can_ethtool_ops = { ...@@ -2195,18 +2195,20 @@ static const struct ethtool_ops m_can_ethtool_ops = {
.set_coalesce = m_can_set_coalesce, .set_coalesce = m_can_set_coalesce,
}; };
static const struct ethtool_ops m_can_ethtool_ops_polling = { static const struct ethtool_ops m_can_ethtool_ops = {
.get_ts_info = ethtool_op_get_ts_info, .get_ts_info = ethtool_op_get_ts_info,
}; };
static int register_m_can_dev(struct net_device *dev) static int register_m_can_dev(struct m_can_classdev *cdev)
{ {
struct net_device *dev = cdev->net;
dev->flags |= IFF_ECHO; /* we support local echo */ dev->flags |= IFF_ECHO; /* we support local echo */
dev->netdev_ops = &m_can_netdev_ops; dev->netdev_ops = &m_can_netdev_ops;
if (dev->irq) if (dev->irq && cdev->is_peripheral)
dev->ethtool_ops = &m_can_ethtool_ops; dev->ethtool_ops = &m_can_ethtool_ops_coalescing;
else else
dev->ethtool_ops = &m_can_ethtool_ops_polling; dev->ethtool_ops = &m_can_ethtool_ops;
return register_candev(dev); return register_candev(dev);
} }
...@@ -2392,7 +2394,7 @@ int m_can_class_register(struct m_can_classdev *cdev) ...@@ -2392,7 +2394,7 @@ int m_can_class_register(struct m_can_classdev *cdev)
if (ret) if (ret)
goto rx_offload_del; goto rx_offload_del;
ret = register_m_can_dev(cdev->net); ret = register_m_can_dev(cdev);
if (ret) { if (ret) {
dev_err(cdev->dev, "registering %s failed (err=%d)\n", dev_err(cdev->dev, "registering %s failed (err=%d)\n",
cdev->net->name, ret); cdev->net->name, ret);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment