mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 02:30:34 +02:00 
			
		
		
		
	ntuple filters can specify an rss context to use for packet hashing and queue selection. When a filter is referencing an rss context, it should be invalid for that context to be deleted. A list of active ntuple filters and their associated rss contexts can be compiled by querying a device's ethtool_ops.get_rxnfc. This patch checks to see if any ntuple filters are referencing an rss context during context deletion, and prevents the deletion if the requested context is still in use. Signed-off-by: Daniel Zahka <daniel.zahka@gmail.com> Signed-off-by: Paolo Abeni <pabeni@redhat.com>
		
			
				
	
	
		
			63 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* SPDX-License-Identifier: GPL-2.0-only */
 | 
						|
 | 
						|
#ifndef _ETHTOOL_COMMON_H
 | 
						|
#define _ETHTOOL_COMMON_H
 | 
						|
 | 
						|
#include <linux/netdevice.h>
 | 
						|
#include <linux/ethtool.h>
 | 
						|
 | 
						|
#define ETHTOOL_DEV_FEATURE_WORDS	DIV_ROUND_UP(NETDEV_FEATURE_COUNT, 32)
 | 
						|
 | 
						|
/* compose link mode index from speed, type and duplex */
 | 
						|
#define ETHTOOL_LINK_MODE(speed, type, duplex) \
 | 
						|
	ETHTOOL_LINK_MODE_ ## speed ## base ## type ## _ ## duplex ## _BIT
 | 
						|
 | 
						|
#define __SOF_TIMESTAMPING_CNT (const_ilog2(SOF_TIMESTAMPING_LAST) + 1)
 | 
						|
 | 
						|
struct link_mode_info {
 | 
						|
	int				speed;
 | 
						|
	u8				lanes;
 | 
						|
	u8				duplex;
 | 
						|
};
 | 
						|
 | 
						|
struct genl_info;
 | 
						|
 | 
						|
extern const char
 | 
						|
netdev_features_strings[NETDEV_FEATURE_COUNT][ETH_GSTRING_LEN];
 | 
						|
extern const char
 | 
						|
rss_hash_func_strings[ETH_RSS_HASH_FUNCS_COUNT][ETH_GSTRING_LEN];
 | 
						|
extern const char
 | 
						|
tunable_strings[__ETHTOOL_TUNABLE_COUNT][ETH_GSTRING_LEN];
 | 
						|
extern const char
 | 
						|
phy_tunable_strings[__ETHTOOL_PHY_TUNABLE_COUNT][ETH_GSTRING_LEN];
 | 
						|
extern const char link_mode_names[][ETH_GSTRING_LEN];
 | 
						|
extern const struct link_mode_info link_mode_params[];
 | 
						|
extern const char netif_msg_class_names[][ETH_GSTRING_LEN];
 | 
						|
extern const char wol_mode_names[][ETH_GSTRING_LEN];
 | 
						|
extern const char sof_timestamping_names[][ETH_GSTRING_LEN];
 | 
						|
extern const char ts_tx_type_names[][ETH_GSTRING_LEN];
 | 
						|
extern const char ts_rx_filter_names[][ETH_GSTRING_LEN];
 | 
						|
extern const char udp_tunnel_type_names[][ETH_GSTRING_LEN];
 | 
						|
 | 
						|
int __ethtool_get_link(struct net_device *dev);
 | 
						|
 | 
						|
bool convert_legacy_settings_to_link_ksettings(
 | 
						|
	struct ethtool_link_ksettings *link_ksettings,
 | 
						|
	const struct ethtool_cmd *legacy_settings);
 | 
						|
int ethtool_check_max_channel(struct net_device *dev,
 | 
						|
			      struct ethtool_channels channels,
 | 
						|
			      struct genl_info *info);
 | 
						|
int ethtool_check_rss_ctx_busy(struct net_device *dev, u32 rss_context);
 | 
						|
int __ethtool_get_ts_info(struct net_device *dev, struct kernel_ethtool_ts_info *info);
 | 
						|
 | 
						|
extern const struct ethtool_phy_ops *ethtool_phy_ops;
 | 
						|
extern const struct ethtool_pse_ops *ethtool_pse_ops;
 | 
						|
 | 
						|
int ethtool_get_module_info_call(struct net_device *dev,
 | 
						|
				 struct ethtool_modinfo *modinfo);
 | 
						|
int ethtool_get_module_eeprom_call(struct net_device *dev,
 | 
						|
				   struct ethtool_eeprom *ee, u8 *data);
 | 
						|
 | 
						|
bool __ethtool_dev_mm_supported(struct net_device *dev);
 | 
						|
 | 
						|
#endif /* _ETHTOOL_COMMON_H */
 |