提交 d270f76c 编写于 作者: P Philippe Reynes 提交者: David S. Miller

net: ethernet: hisilicon: hns: use new api ethtool_{get|set}_link_ksettings

The ethtool api {get|set}_settings is deprecated.
We move this driver to new api {get|set}_link_ksettings.
Signed-off-by: NPhilippe Reynes <tremyfr@gmail.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 262b38cd
...@@ -64,14 +64,14 @@ static u32 hns_nic_get_link(struct net_device *net_dev) ...@@ -64,14 +64,14 @@ static u32 hns_nic_get_link(struct net_device *net_dev)
} }
static void hns_get_mdix_mode(struct net_device *net_dev, static void hns_get_mdix_mode(struct net_device *net_dev,
struct ethtool_cmd *cmd) struct ethtool_link_ksettings *cmd)
{ {
int mdix_ctrl, mdix, retval, is_resolved; int mdix_ctrl, mdix, retval, is_resolved;
struct phy_device *phy_dev = net_dev->phydev; struct phy_device *phy_dev = net_dev->phydev;
if (!phy_dev || !phy_dev->mdio.bus) { if (!phy_dev || !phy_dev->mdio.bus) {
cmd->eth_tp_mdix_ctrl = ETH_TP_MDI_INVALID; cmd->base.eth_tp_mdix_ctrl = ETH_TP_MDI_INVALID;
cmd->eth_tp_mdix = ETH_TP_MDI_INVALID; cmd->base.eth_tp_mdix = ETH_TP_MDI_INVALID;
return; return;
} }
...@@ -88,35 +88,35 @@ static void hns_get_mdix_mode(struct net_device *net_dev, ...@@ -88,35 +88,35 @@ static void hns_get_mdix_mode(struct net_device *net_dev,
switch (mdix_ctrl) { switch (mdix_ctrl) {
case 0x0: case 0x0:
cmd->eth_tp_mdix_ctrl = ETH_TP_MDI; cmd->base.eth_tp_mdix_ctrl = ETH_TP_MDI;
break; break;
case 0x1: case 0x1:
cmd->eth_tp_mdix_ctrl = ETH_TP_MDI_X; cmd->base.eth_tp_mdix_ctrl = ETH_TP_MDI_X;
break; break;
case 0x3: case 0x3:
cmd->eth_tp_mdix_ctrl = ETH_TP_MDI_AUTO; cmd->base.eth_tp_mdix_ctrl = ETH_TP_MDI_AUTO;
break; break;
default: default:
cmd->eth_tp_mdix_ctrl = ETH_TP_MDI_INVALID; cmd->base.eth_tp_mdix_ctrl = ETH_TP_MDI_INVALID;
break; break;
} }
if (!is_resolved) if (!is_resolved)
cmd->eth_tp_mdix = ETH_TP_MDI_INVALID; cmd->base.eth_tp_mdix = ETH_TP_MDI_INVALID;
else if (mdix) else if (mdix)
cmd->eth_tp_mdix = ETH_TP_MDI_X; cmd->base.eth_tp_mdix = ETH_TP_MDI_X;
else else
cmd->eth_tp_mdix = ETH_TP_MDI; cmd->base.eth_tp_mdix = ETH_TP_MDI;
} }
/** /**
*hns_nic_get_settings - implement ethtool get settings *hns_nic_get_link_ksettings - implement ethtool get link ksettings
*@net_dev: net_device *@net_dev: net_device
*@cmd: ethtool_cmd *@cmd: ethtool_link_ksettings
*retuen 0 - success , negative --fail *retuen 0 - success , negative --fail
*/ */
static int hns_nic_get_settings(struct net_device *net_dev, static int hns_nic_get_link_ksettings(struct net_device *net_dev,
struct ethtool_cmd *cmd) struct ethtool_link_ksettings *cmd)
{ {
struct hns_nic_priv *priv = netdev_priv(net_dev); struct hns_nic_priv *priv = netdev_priv(net_dev);
struct hnae_handle *h; struct hnae_handle *h;
...@@ -124,6 +124,7 @@ static int hns_nic_get_settings(struct net_device *net_dev, ...@@ -124,6 +124,7 @@ static int hns_nic_get_settings(struct net_device *net_dev,
int ret; int ret;
u8 duplex; u8 duplex;
u16 speed; u16 speed;
u32 supported, advertising;
if (!priv || !priv->ae_handle) if (!priv || !priv->ae_handle)
return -ESRCH; return -ESRCH;
...@@ -138,38 +139,43 @@ static int hns_nic_get_settings(struct net_device *net_dev, ...@@ -138,38 +139,43 @@ static int hns_nic_get_settings(struct net_device *net_dev,
return -EINVAL; return -EINVAL;
} }
ethtool_convert_link_mode_to_legacy_u32(&supported,
cmd->link_modes.supported);
ethtool_convert_link_mode_to_legacy_u32(&advertising,
cmd->link_modes.advertising);
/* When there is no phy, autoneg is off. */ /* When there is no phy, autoneg is off. */
cmd->autoneg = false; cmd->base.autoneg = false;
ethtool_cmd_speed_set(cmd, speed); cmd->base.cmd = speed;
cmd->duplex = duplex; cmd->base.duplex = duplex;
if (net_dev->phydev) if (net_dev->phydev)
(void)phy_ethtool_gset(net_dev->phydev, cmd); (void)phy_ethtool_ksettings_get(net_dev->phydev, cmd);
link_stat = hns_nic_get_link(net_dev); link_stat = hns_nic_get_link(net_dev);
if (!link_stat) { if (!link_stat) {
ethtool_cmd_speed_set(cmd, (u32)SPEED_UNKNOWN); cmd->base.speed = (u32)SPEED_UNKNOWN;
cmd->duplex = DUPLEX_UNKNOWN; cmd->base.duplex = DUPLEX_UNKNOWN;
} }
if (cmd->autoneg) if (cmd->base.autoneg)
cmd->advertising |= ADVERTISED_Autoneg; advertising |= ADVERTISED_Autoneg;
cmd->supported |= h->if_support; supported |= h->if_support;
if (h->phy_if == PHY_INTERFACE_MODE_SGMII) { if (h->phy_if == PHY_INTERFACE_MODE_SGMII) {
cmd->supported |= SUPPORTED_TP; supported |= SUPPORTED_TP;
cmd->advertising |= ADVERTISED_1000baseT_Full; advertising |= ADVERTISED_1000baseT_Full;
} else if (h->phy_if == PHY_INTERFACE_MODE_XGMII) { } else if (h->phy_if == PHY_INTERFACE_MODE_XGMII) {
cmd->supported |= SUPPORTED_FIBRE; supported |= SUPPORTED_FIBRE;
cmd->advertising |= ADVERTISED_10000baseKR_Full; advertising |= ADVERTISED_10000baseKR_Full;
} }
switch (h->media_type) { switch (h->media_type) {
case HNAE_MEDIA_TYPE_FIBER: case HNAE_MEDIA_TYPE_FIBER:
cmd->port = PORT_FIBRE; cmd->base.port = PORT_FIBRE;
break; break;
case HNAE_MEDIA_TYPE_COPPER: case HNAE_MEDIA_TYPE_COPPER:
cmd->port = PORT_TP; cmd->base.port = PORT_TP;
break; break;
case HNAE_MEDIA_TYPE_UNKNOWN: case HNAE_MEDIA_TYPE_UNKNOWN:
default: default:
...@@ -177,23 +183,27 @@ static int hns_nic_get_settings(struct net_device *net_dev, ...@@ -177,23 +183,27 @@ static int hns_nic_get_settings(struct net_device *net_dev,
} }
if (!(AE_IS_VER1(priv->enet_ver) && h->port_type == HNAE_PORT_DEBUG)) if (!(AE_IS_VER1(priv->enet_ver) && h->port_type == HNAE_PORT_DEBUG))
cmd->supported |= SUPPORTED_Pause; supported |= SUPPORTED_Pause;
ethtool_convert_legacy_u32_to_link_mode(cmd->link_modes.supported,
supported);
ethtool_convert_legacy_u32_to_link_mode(cmd->link_modes.advertising,
advertising);
cmd->transceiver = XCVR_EXTERNAL; cmd->base.mdio_support = ETH_MDIO_SUPPORTS_C45 | ETH_MDIO_SUPPORTS_C22;
cmd->mdio_support = (ETH_MDIO_SUPPORTS_C45 | ETH_MDIO_SUPPORTS_C22);
hns_get_mdix_mode(net_dev, cmd); hns_get_mdix_mode(net_dev, cmd);
return 0; return 0;
} }
/** /**
*hns_nic_set_settings - implement ethtool set settings *hns_nic_set_link_settings - implement ethtool set link ksettings
*@net_dev: net_device *@net_dev: net_device
*@cmd: ethtool_cmd *@cmd: ethtool_link_ksettings
*retuen 0 - success , negative --fail *retuen 0 - success , negative --fail
*/ */
static int hns_nic_set_settings(struct net_device *net_dev, static int hns_nic_set_link_ksettings(struct net_device *net_dev,
struct ethtool_cmd *cmd) const struct ethtool_link_ksettings *cmd)
{ {
struct hns_nic_priv *priv = netdev_priv(net_dev); struct hns_nic_priv *priv = netdev_priv(net_dev);
struct hnae_handle *h; struct hnae_handle *h;
...@@ -207,24 +217,25 @@ static int hns_nic_set_settings(struct net_device *net_dev, ...@@ -207,24 +217,25 @@ static int hns_nic_set_settings(struct net_device *net_dev,
return -ENODEV; return -ENODEV;
h = priv->ae_handle; h = priv->ae_handle;
speed = ethtool_cmd_speed(cmd); speed = cmd->base.speed;
if (h->phy_if == PHY_INTERFACE_MODE_XGMII) { if (h->phy_if == PHY_INTERFACE_MODE_XGMII) {
if (cmd->autoneg == AUTONEG_ENABLE || speed != SPEED_10000 || if (cmd->base.autoneg == AUTONEG_ENABLE ||
cmd->duplex != DUPLEX_FULL) speed != SPEED_10000 ||
cmd->base.duplex != DUPLEX_FULL)
return -EINVAL; return -EINVAL;
} else if (h->phy_if == PHY_INTERFACE_MODE_SGMII) { } else if (h->phy_if == PHY_INTERFACE_MODE_SGMII) {
if (!net_dev->phydev && cmd->autoneg == AUTONEG_ENABLE) if (!net_dev->phydev && cmd->base.autoneg == AUTONEG_ENABLE)
return -EINVAL; return -EINVAL;
if (speed == SPEED_1000 && cmd->duplex == DUPLEX_HALF) if (speed == SPEED_1000 && cmd->base.duplex == DUPLEX_HALF)
return -EINVAL; return -EINVAL;
if (net_dev->phydev) if (net_dev->phydev)
return phy_ethtool_sset(net_dev->phydev, cmd); return phy_ethtool_ksettings_set(net_dev->phydev, cmd);
if ((speed != SPEED_10 && speed != SPEED_100 && if ((speed != SPEED_10 && speed != SPEED_100 &&
speed != SPEED_1000) || (cmd->duplex != DUPLEX_HALF && speed != SPEED_1000) || (cmd->base.duplex != DUPLEX_HALF &&
cmd->duplex != DUPLEX_FULL)) cmd->base.duplex != DUPLEX_FULL))
return -EINVAL; return -EINVAL;
} else { } else {
netdev_err(net_dev, "Not supported!"); netdev_err(net_dev, "Not supported!");
...@@ -232,7 +243,7 @@ static int hns_nic_set_settings(struct net_device *net_dev, ...@@ -232,7 +243,7 @@ static int hns_nic_set_settings(struct net_device *net_dev,
} }
if (h->dev->ops->adjust_link) { if (h->dev->ops->adjust_link) {
h->dev->ops->adjust_link(h, (int)speed, cmd->duplex); h->dev->ops->adjust_link(h, (int)speed, cmd->base.duplex);
return 0; return 0;
} }
...@@ -1264,8 +1275,6 @@ static int hns_get_rxnfc(struct net_device *netdev, ...@@ -1264,8 +1275,6 @@ static int hns_get_rxnfc(struct net_device *netdev,
static const struct ethtool_ops hns_ethtool_ops = { static const struct ethtool_ops hns_ethtool_ops = {
.get_drvinfo = hns_nic_get_drvinfo, .get_drvinfo = hns_nic_get_drvinfo,
.get_link = hns_nic_get_link, .get_link = hns_nic_get_link,
.get_settings = hns_nic_get_settings,
.set_settings = hns_nic_set_settings,
.get_ringparam = hns_get_ringparam, .get_ringparam = hns_get_ringparam,
.get_pauseparam = hns_get_pauseparam, .get_pauseparam = hns_get_pauseparam,
.set_pauseparam = hns_set_pauseparam, .set_pauseparam = hns_set_pauseparam,
...@@ -1285,6 +1294,8 @@ static const struct ethtool_ops hns_ethtool_ops = { ...@@ -1285,6 +1294,8 @@ static const struct ethtool_ops hns_ethtool_ops = {
.get_rxfh = hns_get_rss, .get_rxfh = hns_get_rss,
.set_rxfh = hns_set_rss, .set_rxfh = hns_set_rss,
.get_rxnfc = hns_get_rxnfc, .get_rxnfc = hns_get_rxnfc,
.get_link_ksettings = hns_nic_get_link_ksettings,
.set_link_ksettings = hns_nic_set_link_ksettings,
}; };
void hns_ethtool_set_ops(struct net_device *ndev) void hns_ethtool_set_ops(struct net_device *ndev)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册