1/* SPDX-License-Identifier: GPL-2.0-only */
2
3#ifndef _ETHTOOL_COMMON_H
4#define _ETHTOOL_COMMON_H
5
6#include <linux/netdevice.h>
7#include <linux/ethtool.h>
8
9#define ETHTOOL_DEV_FEATURE_WORDS DIV_ROUND_UP(NETDEV_FEATURE_COUNT, 32)
10
11/* compose link mode index from speed, type and duplex */
12#define ETHTOOL_LINK_MODE(speed, type, duplex) \
13 ETHTOOL_LINK_MODE_ ## speed ## base ## type ## _ ## duplex ## _BIT
14
15#define __SOF_TIMESTAMPING_CNT (const_ilog2(SOF_TIMESTAMPING_LAST) + 1)
16#define __HWTSTAMP_FLAG_CNT (const_ilog2(HWTSTAMP_FLAG_LAST) + 1)
17
18struct genl_info;
19struct hwtstamp_provider_desc;
20
21extern const char
22netdev_features_strings[NETDEV_FEATURE_COUNT][ETH_GSTRING_LEN];
23extern const char
24rss_hash_func_strings[ETH_RSS_HASH_FUNCS_COUNT][ETH_GSTRING_LEN];
25extern const char
26tunable_strings[__ETHTOOL_TUNABLE_COUNT][ETH_GSTRING_LEN];
27extern const char
28phy_tunable_strings[__ETHTOOL_PHY_TUNABLE_COUNT][ETH_GSTRING_LEN];
29extern const char link_mode_names[][ETH_GSTRING_LEN];
30extern const char netif_msg_class_names[][ETH_GSTRING_LEN];
31extern const char wol_mode_names[][ETH_GSTRING_LEN];
32extern const char sof_timestamping_names[][ETH_GSTRING_LEN];
33extern const char ts_tx_type_names[][ETH_GSTRING_LEN];
34extern const char ts_rx_filter_names[][ETH_GSTRING_LEN];
35extern const char ts_flags_names[][ETH_GSTRING_LEN];
36extern const char udp_tunnel_type_names[][ETH_GSTRING_LEN];
37
38int __ethtool_get_link(struct net_device *dev);
39
40bool convert_legacy_settings_to_link_ksettings(
41 struct ethtool_link_ksettings *link_ksettings,
42 const struct ethtool_cmd *legacy_settings);
43int ethtool_check_max_channel(struct net_device *dev,
44 struct ethtool_channels channels,
45 struct genl_info *info);
46struct ethtool_rxfh_context *
47ethtool_rxfh_ctx_alloc(const struct ethtool_ops *ops,
48 u32 indir_size, u32 key_size);
49int ethtool_check_rss_ctx_busy(struct net_device *dev, u32 rss_context);
50int ethtool_rxfh_config_is_sym(u64 rxfh);
51
52void ethtool_ringparam_get_cfg(struct net_device *dev,
53 struct ethtool_ringparam *param,
54 struct kernel_ethtool_ringparam *kparam,
55 struct netlink_ext_ack *extack);
56
57int ethtool_get_rx_ring_count(struct net_device *dev);
58
59int __ethtool_get_ts_info(struct net_device *dev, struct kernel_ethtool_ts_info *info);
60int ethtool_get_ts_info_by_phc(struct net_device *dev,
61 struct kernel_ethtool_ts_info *info,
62 struct hwtstamp_provider_desc *hwprov_desc);
63int ethtool_net_get_ts_info_by_phc(struct net_device *dev,
64 struct kernel_ethtool_ts_info *info,
65 struct hwtstamp_provider_desc *hwprov_desc);
66struct phy_device *
67ethtool_phy_get_ts_info_by_phc(struct net_device *dev,
68 struct kernel_ethtool_ts_info *info,
69 struct hwtstamp_provider_desc *hwprov_desc);
70bool net_support_hwtstamp_qualifier(struct net_device *dev,
71 enum hwtstamp_provider_qualifier qualifier);
72
73extern const struct ethtool_phy_ops *ethtool_phy_ops;
74extern const struct ethtool_pse_ops *ethtool_pse_ops;
75
76int ethtool_get_module_info_call(struct net_device *dev,
77 struct ethtool_modinfo *modinfo);
78int ethtool_get_module_eeprom_call(struct net_device *dev,
79 struct ethtool_eeprom *ee, u8 *data);
80
81bool __ethtool_dev_mm_supported(struct net_device *dev);
82
83#if IS_ENABLED(CONFIG_ETHTOOL_NETLINK)
84void ethtool_rss_notify(struct net_device *dev, u32 type, u32 rss_context);
85#else
86static inline void
87ethtool_rss_notify(struct net_device *dev, u32 type, u32 rss_context)
88{
89}
90#endif
91
92#endif /* _ETHTOOL_COMMON_H */
93