diff options
author | Russell King <rmk+kernel@armlinux.org.uk> | 2020-07-30 22:50:04 +0100 |
---|---|---|
committer | Russell King (Oracle) <rmk+kernel@armlinux.org.uk> | 2024-04-16 16:52:32 +0100 |
commit | 301d655ffc17c70814280563aaabeab10cf40a1b (patch) | |
tree | d191325f84e98a2b9768d93e26c2806153e6daa4 | |
parent | 6a31fa06f44b89c0004afaa3682f34d3c5a1d837 (diff) |
net: ethtool: allow MAC drivers to override ethtool get_ts_info
Check whether the MAC driver has implemented the get_ts_info()
method first, and call it if present. If this method returns
-EOPNOTSUPP, defer to the phylib or default implementation.
XXX: review any drivers that use phylib and provide get_ts_info().
Signed-off-by: Russell King <rmk+kernel@armlinux.org.uk>
-rw-r--r-- | net/ethtool/common.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/net/ethtool/common.c b/net/ethtool/common.c index 6b2a360dcdf0..3e97d1a0beea 100644 --- a/net/ethtool/common.c +++ b/net/ethtool/common.c @@ -633,14 +633,18 @@ int __ethtool_get_ts_info(struct net_device *dev, struct ethtool_ts_info *info) { const struct ethtool_ops *ops = dev->ethtool_ops; struct phy_device *phydev = dev->phydev; + int ret; memset(info, 0, sizeof(*info)); info->cmd = ETHTOOL_GET_TS_INFO; + if (ops->get_ts_info) { + ret = ops->get_ts_info(dev, info); + if (ret != -EOPNOTSUPP) + return ret; + } if (phy_has_tsinfo(phydev)) return phy_ts_info(phydev, info); - if (ops->get_ts_info) - return ops->get_ts_info(dev, info); info->so_timestamping = SOF_TIMESTAMPING_RX_SOFTWARE | SOF_TIMESTAMPING_SOFTWARE; |