forked from mirrors/linux
		
	The core is now responsible for allocating IDs and a memory region for us to store our state (struct efx_rss_context_priv), so we no longer need efx_alloc_rss_context_entry() and friends. Since the contexts are now maintained by the core, use the core's lock (net_dev->ethtool->rss_lock), rather than our own mutex (efx->rss_lock), to serialise access against changes; and remove the now-unused efx->rss_lock from struct efx_nic. Signed-off-by: Edward Cree <ecree.xilinx@gmail.com> Reviewed-by: Przemek Kitszel <przemyslaw.kitszel@intel.com> Link: https://patch.msgid.link/150274740ea8cc137fef5502541ce573d32fb319.1719502240.git.ecree.xilinx@gmail.com Signed-off-by: Jakub Kicinski <kuba@kernel.org>
		
			
				
	
	
		
			70 lines
		
	
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* SPDX-License-Identifier: GPL-2.0-only */
 | 
						|
/****************************************************************************
 | 
						|
 * Driver for Solarflare network controllers and boards
 | 
						|
 * Copyright 2019 Solarflare Communications Inc.
 | 
						|
 *
 | 
						|
 * This program is free software; you can redistribute it and/or modify it
 | 
						|
 * under the terms of the GNU General Public License version 2 as published
 | 
						|
 * by the Free Software Foundation, incorporated herein by reference.
 | 
						|
 */
 | 
						|
 | 
						|
#ifndef EFX_ETHTOOL_COMMON_H
 | 
						|
#define EFX_ETHTOOL_COMMON_H
 | 
						|
 | 
						|
void efx_ethtool_get_drvinfo(struct net_device *net_dev,
 | 
						|
			     struct ethtool_drvinfo *info);
 | 
						|
u32 efx_ethtool_get_msglevel(struct net_device *net_dev);
 | 
						|
void efx_ethtool_set_msglevel(struct net_device *net_dev, u32 msg_enable);
 | 
						|
void efx_ethtool_self_test(struct net_device *net_dev,
 | 
						|
			   struct ethtool_test *test, u64 *data);
 | 
						|
void efx_ethtool_get_pauseparam(struct net_device *net_dev,
 | 
						|
				struct ethtool_pauseparam *pause);
 | 
						|
int efx_ethtool_set_pauseparam(struct net_device *net_dev,
 | 
						|
			       struct ethtool_pauseparam *pause);
 | 
						|
int efx_ethtool_fill_self_tests(struct efx_nic *efx,
 | 
						|
				struct efx_self_tests *tests,
 | 
						|
				u8 *strings, u64 *data);
 | 
						|
int efx_ethtool_get_sset_count(struct net_device *net_dev, int string_set);
 | 
						|
void efx_ethtool_get_strings(struct net_device *net_dev, u32 string_set,
 | 
						|
			     u8 *strings);
 | 
						|
void efx_ethtool_get_stats(struct net_device *net_dev,
 | 
						|
			   struct ethtool_stats *stats __attribute__ ((unused)),
 | 
						|
			   u64 *data);
 | 
						|
int efx_ethtool_get_link_ksettings(struct net_device *net_dev,
 | 
						|
				   struct ethtool_link_ksettings *out);
 | 
						|
int efx_ethtool_set_link_ksettings(struct net_device *net_dev,
 | 
						|
				   const struct ethtool_link_ksettings *settings);
 | 
						|
int efx_ethtool_get_fecparam(struct net_device *net_dev,
 | 
						|
			     struct ethtool_fecparam *fecparam);
 | 
						|
int efx_ethtool_set_fecparam(struct net_device *net_dev,
 | 
						|
			     struct ethtool_fecparam *fecparam);
 | 
						|
int efx_ethtool_get_rxnfc(struct net_device *net_dev,
 | 
						|
			  struct ethtool_rxnfc *info, u32 *rule_locs);
 | 
						|
int efx_ethtool_set_rxnfc(struct net_device *net_dev,
 | 
						|
			  struct ethtool_rxnfc *info);
 | 
						|
u32 efx_ethtool_get_rxfh_indir_size(struct net_device *net_dev);
 | 
						|
u32 efx_ethtool_get_rxfh_key_size(struct net_device *net_dev);
 | 
						|
int efx_ethtool_get_rxfh(struct net_device *net_dev,
 | 
						|
			 struct ethtool_rxfh_param *rxfh);
 | 
						|
int efx_ethtool_set_rxfh(struct net_device *net_dev,
 | 
						|
			 struct ethtool_rxfh_param *rxfh,
 | 
						|
			 struct netlink_ext_ack *extack);
 | 
						|
int efx_ethtool_create_rxfh_context(struct net_device *net_dev,
 | 
						|
				    struct ethtool_rxfh_context *ctx,
 | 
						|
				    const struct ethtool_rxfh_param *rxfh,
 | 
						|
				    struct netlink_ext_ack *extack);
 | 
						|
int efx_ethtool_modify_rxfh_context(struct net_device *net_dev,
 | 
						|
				    struct ethtool_rxfh_context *ctx,
 | 
						|
				    const struct ethtool_rxfh_param *rxfh,
 | 
						|
				    struct netlink_ext_ack *extack);
 | 
						|
int efx_ethtool_remove_rxfh_context(struct net_device *net_dev,
 | 
						|
				    struct ethtool_rxfh_context *ctx,
 | 
						|
				    u32 rss_context,
 | 
						|
				    struct netlink_ext_ack *extack);
 | 
						|
int efx_ethtool_reset(struct net_device *net_dev, u32 *flags);
 | 
						|
int efx_ethtool_get_module_eeprom(struct net_device *net_dev,
 | 
						|
				  struct ethtool_eeprom *ee,
 | 
						|
				  u8 *data);
 | 
						|
int efx_ethtool_get_module_info(struct net_device *net_dev,
 | 
						|
				struct ethtool_modinfo *modinfo);
 | 
						|
#endif
 |