Commit c03a14e8 authored by Jiri Pirko's avatar Jiri Pirko Committed by David S. Miller

ethtool: consolidate work with ethtool_ops

No need to check if ethtool_ops == NULL since it can't be.
Use local variable "ops" in functions where it is present
instead of dev->ethtool_ops
Introduce local variable "ops" in functions where dev->ethtool_ops is used
many times.
Signed-off-by: default avatarJiri Pirko <jiri@resnulli.us>
Reviewed-by: default avatarBen Hutchings <bhutchings@solarflare.com>
Reviewed-by: default avatarFlavio Leitner <fbl@redhat.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 6411280a
...@@ -175,7 +175,7 @@ static int __ethtool_get_sset_count(struct net_device *dev, int sset) ...@@ -175,7 +175,7 @@ static int __ethtool_get_sset_count(struct net_device *dev, int sset)
if (sset == ETH_SS_FEATURES) if (sset == ETH_SS_FEATURES)
return ARRAY_SIZE(netdev_features_strings); return ARRAY_SIZE(netdev_features_strings);
if (ops && ops->get_sset_count && ops->get_strings) if (ops->get_sset_count && ops->get_strings)
return ops->get_sset_count(dev, sset); return ops->get_sset_count(dev, sset);
else else
return -EOPNOTSUPP; return -EOPNOTSUPP;
...@@ -311,7 +311,7 @@ int __ethtool_get_settings(struct net_device *dev, struct ethtool_cmd *cmd) ...@@ -311,7 +311,7 @@ int __ethtool_get_settings(struct net_device *dev, struct ethtool_cmd *cmd)
{ {
ASSERT_RTNL(); ASSERT_RTNL();
if (!dev->ethtool_ops || !dev->ethtool_ops->get_settings) if (!dev->ethtool_ops->get_settings)
return -EOPNOTSUPP; return -EOPNOTSUPP;
memset(cmd, 0, sizeof(struct ethtool_cmd)); memset(cmd, 0, sizeof(struct ethtool_cmd));
...@@ -355,7 +355,7 @@ static noinline_for_stack int ethtool_get_drvinfo(struct net_device *dev, ...@@ -355,7 +355,7 @@ static noinline_for_stack int ethtool_get_drvinfo(struct net_device *dev,
memset(&info, 0, sizeof(info)); memset(&info, 0, sizeof(info));
info.cmd = ETHTOOL_GDRVINFO; info.cmd = ETHTOOL_GDRVINFO;
if (ops && ops->get_drvinfo) { if (ops->get_drvinfo) {
ops->get_drvinfo(dev, &info); ops->get_drvinfo(dev, &info);
} else if (dev->dev.parent && dev->dev.parent->driver) { } else if (dev->dev.parent && dev->dev.parent->driver) {
strlcpy(info.bus_info, dev_name(dev->dev.parent), strlcpy(info.bus_info, dev_name(dev->dev.parent),
...@@ -370,7 +370,7 @@ static noinline_for_stack int ethtool_get_drvinfo(struct net_device *dev, ...@@ -370,7 +370,7 @@ static noinline_for_stack int ethtool_get_drvinfo(struct net_device *dev,
* this method of obtaining string set info is deprecated; * this method of obtaining string set info is deprecated;
* Use ETHTOOL_GSSET_INFO instead. * Use ETHTOOL_GSSET_INFO instead.
*/ */
if (ops && ops->get_sset_count) { if (ops->get_sset_count) {
int rc; int rc;
rc = ops->get_sset_count(dev, ETH_SS_TEST); rc = ops->get_sset_count(dev, ETH_SS_TEST);
...@@ -383,9 +383,9 @@ static noinline_for_stack int ethtool_get_drvinfo(struct net_device *dev, ...@@ -383,9 +383,9 @@ static noinline_for_stack int ethtool_get_drvinfo(struct net_device *dev,
if (rc >= 0) if (rc >= 0)
info.n_priv_flags = rc; info.n_priv_flags = rc;
} }
if (ops && ops->get_regs_len) if (ops->get_regs_len)
info.regdump_len = ops->get_regs_len(dev); info.regdump_len = ops->get_regs_len(dev);
if (ops && ops->get_eeprom_len) if (ops->get_eeprom_len)
info.eedump_len = ops->get_eeprom_len(dev); info.eedump_len = ops->get_eeprom_len(dev);
if (copy_to_user(useraddr, &info, sizeof(info))) if (copy_to_user(useraddr, &info, sizeof(info)))
...@@ -590,13 +590,14 @@ static noinline_for_stack int ethtool_set_rxfh_indir(struct net_device *dev, ...@@ -590,13 +590,14 @@ static noinline_for_stack int ethtool_set_rxfh_indir(struct net_device *dev,
struct ethtool_rxnfc rx_rings; struct ethtool_rxnfc rx_rings;
u32 user_size, dev_size, i; u32 user_size, dev_size, i;
u32 *indir; u32 *indir;
const struct ethtool_ops *ops = dev->ethtool_ops;
int ret; int ret;
if (!dev->ethtool_ops->get_rxfh_indir_size || if (!ops->get_rxfh_indir_size || !ops->set_rxfh_indir ||
!dev->ethtool_ops->set_rxfh_indir || !ops->get_rxnfc)
!dev->ethtool_ops->get_rxnfc)
return -EOPNOTSUPP; return -EOPNOTSUPP;
dev_size = dev->ethtool_ops->get_rxfh_indir_size(dev);
dev_size = ops->get_rxfh_indir_size(dev);
if (dev_size == 0) if (dev_size == 0)
return -EOPNOTSUPP; return -EOPNOTSUPP;
...@@ -613,7 +614,7 @@ static noinline_for_stack int ethtool_set_rxfh_indir(struct net_device *dev, ...@@ -613,7 +614,7 @@ static noinline_for_stack int ethtool_set_rxfh_indir(struct net_device *dev,
return -ENOMEM; return -ENOMEM;
rx_rings.cmd = ETHTOOL_GRXRINGS; rx_rings.cmd = ETHTOOL_GRXRINGS;
ret = dev->ethtool_ops->get_rxnfc(dev, &rx_rings, NULL); ret = ops->get_rxnfc(dev, &rx_rings, NULL);
if (ret) if (ret)
goto out; goto out;
...@@ -639,7 +640,7 @@ static noinline_for_stack int ethtool_set_rxfh_indir(struct net_device *dev, ...@@ -639,7 +640,7 @@ static noinline_for_stack int ethtool_set_rxfh_indir(struct net_device *dev,
} }
} }
ret = dev->ethtool_ops->set_rxfh_indir(dev, indir); ret = ops->set_rxfh_indir(dev, indir);
out: out:
kfree(indir); kfree(indir);
...@@ -1082,9 +1083,10 @@ static int ethtool_phys_id(struct net_device *dev, void __user *useraddr) ...@@ -1082,9 +1083,10 @@ static int ethtool_phys_id(struct net_device *dev, void __user *useraddr)
{ {
struct ethtool_value id; struct ethtool_value id;
static bool busy; static bool busy;
const struct ethtool_ops *ops = dev->ethtool_ops;
int rc; int rc;
if (!dev->ethtool_ops->set_phys_id) if (!ops->set_phys_id)
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (busy) if (busy)
...@@ -1093,7 +1095,7 @@ static int ethtool_phys_id(struct net_device *dev, void __user *useraddr) ...@@ -1093,7 +1095,7 @@ static int ethtool_phys_id(struct net_device *dev, void __user *useraddr)
if (copy_from_user(&id, useraddr, sizeof(id))) if (copy_from_user(&id, useraddr, sizeof(id)))
return -EFAULT; return -EFAULT;
rc = dev->ethtool_ops->set_phys_id(dev, ETHTOOL_ID_ACTIVE); rc = ops->set_phys_id(dev, ETHTOOL_ID_ACTIVE);
if (rc < 0) if (rc < 0)
return rc; return rc;
...@@ -1118,7 +1120,7 @@ static int ethtool_phys_id(struct net_device *dev, void __user *useraddr) ...@@ -1118,7 +1120,7 @@ static int ethtool_phys_id(struct net_device *dev, void __user *useraddr)
i = n; i = n;
do { do {
rtnl_lock(); rtnl_lock();
rc = dev->ethtool_ops->set_phys_id(dev, rc = ops->set_phys_id(dev,
(i & 1) ? ETHTOOL_ID_OFF : ETHTOOL_ID_ON); (i & 1) ? ETHTOOL_ID_OFF : ETHTOOL_ID_ON);
rtnl_unlock(); rtnl_unlock();
if (rc) if (rc)
...@@ -1133,7 +1135,7 @@ static int ethtool_phys_id(struct net_device *dev, void __user *useraddr) ...@@ -1133,7 +1135,7 @@ static int ethtool_phys_id(struct net_device *dev, void __user *useraddr)
dev_put(dev); dev_put(dev);
busy = false; busy = false;
(void)dev->ethtool_ops->set_phys_id(dev, ETHTOOL_ID_INACTIVE); (void) ops->set_phys_id(dev, ETHTOOL_ID_INACTIVE);
return rc; return rc;
} }
...@@ -1275,7 +1277,7 @@ static int ethtool_get_dump_flag(struct net_device *dev, ...@@ -1275,7 +1277,7 @@ static int ethtool_get_dump_flag(struct net_device *dev,
struct ethtool_dump dump; struct ethtool_dump dump;
const struct ethtool_ops *ops = dev->ethtool_ops; const struct ethtool_ops *ops = dev->ethtool_ops;
if (!dev->ethtool_ops->get_dump_flag) if (!ops->get_dump_flag)
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (copy_from_user(&dump, useraddr, sizeof(dump))) if (copy_from_user(&dump, useraddr, sizeof(dump)))
...@@ -1299,8 +1301,7 @@ static int ethtool_get_dump_data(struct net_device *dev, ...@@ -1299,8 +1301,7 @@ static int ethtool_get_dump_data(struct net_device *dev,
const struct ethtool_ops *ops = dev->ethtool_ops; const struct ethtool_ops *ops = dev->ethtool_ops;
void *data = NULL; void *data = NULL;
if (!dev->ethtool_ops->get_dump_data || if (!ops->get_dump_data || !ops->get_dump_flag)
!dev->ethtool_ops->get_dump_flag)
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (copy_from_user(&dump, useraddr, sizeof(dump))) if (copy_from_user(&dump, useraddr, sizeof(dump)))
...@@ -1346,13 +1347,9 @@ static int ethtool_get_ts_info(struct net_device *dev, void __user *useraddr) ...@@ -1346,13 +1347,9 @@ static int ethtool_get_ts_info(struct net_device *dev, void __user *useraddr)
info.cmd = ETHTOOL_GET_TS_INFO; info.cmd = ETHTOOL_GET_TS_INFO;
if (phydev && phydev->drv && phydev->drv->ts_info) { if (phydev && phydev->drv && phydev->drv->ts_info) {
err = phydev->drv->ts_info(phydev, &info); err = phydev->drv->ts_info(phydev, &info);
} else if (ops->get_ts_info) {
} else if (dev->ethtool_ops && dev->ethtool_ops->get_ts_info) {
err = ops->get_ts_info(dev, &info); err = ops->get_ts_info(dev, &info);
} else { } else {
info.so_timestamping = info.so_timestamping =
SOF_TIMESTAMPING_RX_SOFTWARE | SOF_TIMESTAMPING_RX_SOFTWARE |
......
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