Commit 86e3a040 authored by Philippe Reynes's avatar Philippe Reynes Committed by David S. Miller

net: ti: netcp_ethss: 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: default avatarPhilippe Reynes <tremyfr@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 2479876d
...@@ -1840,8 +1840,8 @@ static void keystone_get_ethtool_stats(struct net_device *ndev, ...@@ -1840,8 +1840,8 @@ static void keystone_get_ethtool_stats(struct net_device *ndev,
spin_unlock_bh(&gbe_dev->hw_stats_lock); spin_unlock_bh(&gbe_dev->hw_stats_lock);
} }
static int keystone_get_settings(struct net_device *ndev, static int keystone_get_link_ksettings(struct net_device *ndev,
struct ethtool_cmd *cmd) struct ethtool_link_ksettings *cmd)
{ {
struct netcp_intf *netcp = netdev_priv(ndev); struct netcp_intf *netcp = netdev_priv(ndev);
struct phy_device *phy = ndev->phydev; struct phy_device *phy = ndev->phydev;
...@@ -1858,20 +1858,28 @@ static int keystone_get_settings(struct net_device *ndev, ...@@ -1858,20 +1858,28 @@ static int keystone_get_settings(struct net_device *ndev,
if (!gbe_intf->slave) if (!gbe_intf->slave)
return -EINVAL; return -EINVAL;
ret = phy_ethtool_gset(phy, cmd); ret = phy_ethtool_ksettings_get(phy, cmd);
if (!ret) if (!ret)
cmd->port = gbe_intf->slave->phy_port_t; cmd->base.port = gbe_intf->slave->phy_port_t;
return ret; return ret;
} }
static int keystone_set_settings(struct net_device *ndev, static int keystone_set_link_ksettings(struct net_device *ndev,
struct ethtool_cmd *cmd) const struct ethtool_link_ksettings *cmd)
{ {
struct netcp_intf *netcp = netdev_priv(ndev); struct netcp_intf *netcp = netdev_priv(ndev);
struct phy_device *phy = ndev->phydev; struct phy_device *phy = ndev->phydev;
struct gbe_intf *gbe_intf; struct gbe_intf *gbe_intf;
u32 features = cmd->advertising & cmd->supported; u8 port = cmd->base.port;
u32 advertising, supported;
u32 features;
ethtool_convert_link_mode_to_legacy_u32(&advertising,
cmd->link_modes.advertising);
ethtool_convert_link_mode_to_legacy_u32(&supported,
cmd->link_modes.supported);
features = advertising & supported;
if (!phy) if (!phy)
return -EINVAL; return -EINVAL;
...@@ -1883,25 +1891,25 @@ static int keystone_set_settings(struct net_device *ndev, ...@@ -1883,25 +1891,25 @@ static int keystone_set_settings(struct net_device *ndev,
if (!gbe_intf->slave) if (!gbe_intf->slave)
return -EINVAL; return -EINVAL;
if (cmd->port != gbe_intf->slave->phy_port_t) { if (port != gbe_intf->slave->phy_port_t) {
if ((cmd->port == PORT_TP) && !(features & ADVERTISED_TP)) if ((port == PORT_TP) && !(features & ADVERTISED_TP))
return -EINVAL; return -EINVAL;
if ((cmd->port == PORT_AUI) && !(features & ADVERTISED_AUI)) if ((port == PORT_AUI) && !(features & ADVERTISED_AUI))
return -EINVAL; return -EINVAL;
if ((cmd->port == PORT_BNC) && !(features & ADVERTISED_BNC)) if ((port == PORT_BNC) && !(features & ADVERTISED_BNC))
return -EINVAL; return -EINVAL;
if ((cmd->port == PORT_MII) && !(features & ADVERTISED_MII)) if ((port == PORT_MII) && !(features & ADVERTISED_MII))
return -EINVAL; return -EINVAL;
if ((cmd->port == PORT_FIBRE) && !(features & ADVERTISED_FIBRE)) if ((port == PORT_FIBRE) && !(features & ADVERTISED_FIBRE))
return -EINVAL; return -EINVAL;
} }
gbe_intf->slave->phy_port_t = cmd->port; gbe_intf->slave->phy_port_t = port;
return phy_ethtool_sset(phy, cmd); return phy_ethtool_ksettings_set(phy, cmd);
} }
static const struct ethtool_ops keystone_ethtool_ops = { static const struct ethtool_ops keystone_ethtool_ops = {
...@@ -1912,8 +1920,8 @@ static const struct ethtool_ops keystone_ethtool_ops = { ...@@ -1912,8 +1920,8 @@ static const struct ethtool_ops keystone_ethtool_ops = {
.get_strings = keystone_get_stat_strings, .get_strings = keystone_get_stat_strings,
.get_sset_count = keystone_get_sset_count, .get_sset_count = keystone_get_sset_count,
.get_ethtool_stats = keystone_get_ethtool_stats, .get_ethtool_stats = keystone_get_ethtool_stats,
.get_settings = keystone_get_settings, .get_link_ksettings = keystone_get_link_ksettings,
.set_settings = keystone_set_settings, .set_link_ksettings = keystone_set_link_ksettings,
}; };
#define mac_hi(mac) (((mac)[0] << 0) | ((mac)[1] << 8) | \ #define mac_hi(mac) (((mac)[0] << 0) | ((mac)[1] << 8) | \
......
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