Commit fd477858 authored by Daniil Tatianin's avatar Daniil Tatianin Committed by David S. Miller

net/ethtool/ioctl: remove if n_stats checks from ethtool_get_phy_stats

Now that we always early return if we don't have any stats we can remove
these checks as they're no longer necessary.
Signed-off-by: default avatarDaniil Tatianin <d-tatianin@yandex-team.ru>
Reviewed-by: default avatarAndrew Lunn <andrew@lunn.ch>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 9deb1e9f
...@@ -2107,28 +2107,24 @@ static int ethtool_get_phy_stats(struct net_device *dev, void __user *useraddr) ...@@ -2107,28 +2107,24 @@ static int ethtool_get_phy_stats(struct net_device *dev, void __user *useraddr)
stats.n_stats = n_stats; stats.n_stats = n_stats;
if (n_stats) { data = vzalloc(array_size(n_stats, sizeof(u64)));
data = vzalloc(array_size(n_stats, sizeof(u64))); if (!data)
if (!data) return -ENOMEM;
return -ENOMEM;
if (phydev && !ops->get_ethtool_phy_stats && if (phydev && !ops->get_ethtool_phy_stats &&
phy_ops && phy_ops->get_stats) { phy_ops && phy_ops->get_stats) {
ret = phy_ops->get_stats(phydev, &stats, data); ret = phy_ops->get_stats(phydev, &stats, data);
if (ret < 0) if (ret < 0)
goto out; goto out;
} else {
ops->get_ethtool_phy_stats(dev, &stats, data);
}
} else { } else {
data = NULL; ops->get_ethtool_phy_stats(dev, &stats, data);
} }
ret = -EFAULT; ret = -EFAULT;
if (copy_to_user(useraddr, &stats, sizeof(stats))) if (copy_to_user(useraddr, &stats, sizeof(stats)))
goto out; goto out;
useraddr += sizeof(stats); useraddr += sizeof(stats);
if (n_stats && copy_to_user(useraddr, data, array_size(n_stats, sizeof(u64)))) if (copy_to_user(useraddr, data, array_size(n_stats, sizeof(u64))))
goto out; goto out;
ret = 0; ret = 0;
......
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