2008-04-27 15:55:59 +04:00
/****************************************************************************
* Driver for Solarflare Solarstorm network controllers and boards
* Copyright 2005 - 2006 Fen Systems Ltd .
* Copyright 2006 - 2008 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_EFX_H
# define EFX_EFX_H
# include "net_driver.h"
/* PCI IDs */
# define EFX_VENDID_SFC 0x1924
# define FALCON_A_P_DEVID 0x0703
# define FALCON_A_S_DEVID 0x6703
# define FALCON_B_P_DEVID 0x0710
2009-10-23 12:32:33 +04:00
/* Solarstorm controllers use BAR 0 for I/O space and BAR 2(&3) for memory */
# define EFX_MEM_BAR 2
2008-04-27 15:55:59 +04:00
/* TX */
2009-11-23 19:07:30 +03:00
extern int efx_probe_tx_queue ( struct efx_tx_queue * tx_queue ) ;
extern void efx_remove_tx_queue ( struct efx_tx_queue * tx_queue ) ;
extern void efx_init_tx_queue ( struct efx_tx_queue * tx_queue ) ;
extern void efx_fini_tx_queue ( struct efx_tx_queue * tx_queue ) ;
extern void efx_release_tx_buffers ( struct efx_tx_queue * tx_queue ) ;
extern netdev_tx_t
efx_hard_start_xmit ( struct sk_buff * skb , struct net_device * net_dev ) ;
extern netdev_tx_t
efx_enqueue_skb ( struct efx_tx_queue * tx_queue , struct sk_buff * skb ) ;
2009-10-23 12:31:54 +04:00
extern void efx_xmit_done ( struct efx_tx_queue * tx_queue , unsigned int index ) ;
2008-04-27 15:55:59 +04:00
extern void efx_stop_queue ( struct efx_nic * efx ) ;
extern void efx_wake_queue ( struct efx_nic * efx ) ;
2009-10-23 12:30:58 +04:00
# define EFX_TXQ_SIZE 1024
# define EFX_TXQ_MASK (EFX_TXQ_SIZE - 1)
2008-04-27 15:55:59 +04:00
/* RX */
2009-11-23 19:07:30 +03:00
extern int efx_probe_rx_queue ( struct efx_rx_queue * rx_queue ) ;
extern void efx_remove_rx_queue ( struct efx_rx_queue * rx_queue ) ;
extern void efx_init_rx_queue ( struct efx_rx_queue * rx_queue ) ;
extern void efx_fini_rx_queue ( struct efx_rx_queue * rx_queue ) ;
extern void efx_rx_strategy ( struct efx_channel * channel ) ;
extern void efx_fast_push_rx_descriptors ( struct efx_rx_queue * rx_queue ) ;
extern void efx_rx_work ( struct work_struct * data ) ;
extern void __efx_rx_packet ( struct efx_channel * channel ,
struct efx_rx_buffer * rx_buf , bool checksummed ) ;
2008-04-27 15:55:59 +04:00
extern void efx_rx_packet ( struct efx_rx_queue * rx_queue , unsigned int index ,
2008-09-01 15:46:50 +04:00
unsigned int len , bool checksummed , bool discard ) ;
2008-04-27 15:55:59 +04:00
extern void efx_schedule_slow_fill ( struct efx_rx_queue * rx_queue , int delay ) ;
2009-10-23 12:30:58 +04:00
# define EFX_RXQ_SIZE 1024
# define EFX_RXQ_MASK (EFX_RXQ_SIZE - 1)
2008-04-27 15:55:59 +04:00
/* Channels */
extern void efx_process_channel_now ( struct efx_channel * channel ) ;
2009-10-23 12:30:58 +04:00
# define EFX_EVQ_SIZE 4096
# define EFX_EVQ_MASK (EFX_EVQ_SIZE - 1)
2008-04-27 15:55:59 +04:00
/* Ports */
2009-11-29 06:42:41 +03:00
extern int efx_reconfigure_port ( struct efx_nic * efx ) ;
extern int __efx_reconfigure_port ( struct efx_nic * efx ) ;
2008-09-01 15:49:02 +04:00
2009-11-23 19:07:30 +03:00
/* Ethtool support */
extern int efx_ethtool_get_settings ( struct net_device * net_dev ,
struct ethtool_cmd * ecmd ) ;
extern int efx_ethtool_set_settings ( struct net_device * net_dev ,
struct ethtool_cmd * ecmd ) ;
extern const struct ethtool_ops efx_ethtool_ops ;
2008-09-01 15:49:02 +04:00
/* Reset handling */
2009-11-29 06:43:15 +03:00
extern int efx_reset ( struct efx_nic * efx , enum reset_type method ) ;
2009-11-29 06:42:41 +03:00
extern void efx_reset_down ( struct efx_nic * efx , enum reset_type method ) ;
extern int efx_reset_up ( struct efx_nic * efx , enum reset_type method , bool ok ) ;
2008-04-27 15:55:59 +04:00
/* Global */
extern void efx_schedule_reset ( struct efx_nic * efx , enum reset_type type ) ;
extern void efx_suspend ( struct efx_nic * efx ) ;
extern void efx_resume ( struct efx_nic * efx ) ;
extern void efx_init_irq_moderation ( struct efx_nic * efx , int tx_usecs ,
2009-03-20 16:30:37 +03:00
int rx_usecs , bool rx_adaptive ) ;
2008-04-27 15:55:59 +04:00
extern int efx_request_power ( struct efx_nic * efx , int mw , const char * name ) ;
extern void efx_hex_dump ( const u8 * , unsigned int , const char * ) ;
/* Dummy PHY ops for PHY drivers */
extern int efx_port_dummy_op_int ( struct efx_nic * efx ) ;
extern void efx_port_dummy_op_void ( struct efx_nic * efx ) ;
2009-11-23 19:03:45 +03:00
extern void
efx_port_dummy_op_set_id_led ( struct efx_nic * efx , enum efx_led_mode mode ) ;
2009-11-28 08:34:05 +03:00
extern bool efx_port_dummy_op_poll ( struct efx_nic * efx ) ;
2008-04-27 15:55:59 +04:00
2008-11-04 23:34:28 +03:00
/* MTD */
# ifdef CONFIG_SFC_MTD
extern int efx_mtd_probe ( struct efx_nic * efx ) ;
extern void efx_mtd_rename ( struct efx_nic * efx ) ;
extern void efx_mtd_remove ( struct efx_nic * efx ) ;
# else
static inline int efx_mtd_probe ( struct efx_nic * efx ) { return 0 ; }
static inline void efx_mtd_rename ( struct efx_nic * efx ) { }
static inline void efx_mtd_remove ( struct efx_nic * efx ) { }
# endif
2008-04-27 15:55:59 +04:00
extern unsigned int efx_monitor_interval ;
static inline void efx_schedule_channel ( struct efx_channel * channel )
{
EFX_TRACE ( channel - > efx , " channel %d scheduling NAPI poll on CPU%d \n " ,
channel - > channel , raw_smp_processor_id ( ) ) ;
2008-09-01 15:46:50 +04:00
channel - > work_pending = true ;
2008-04-27 15:55:59 +04:00
2009-01-20 03:43:59 +03:00
napi_schedule ( & channel - > napi_str ) ;
2008-04-27 15:55:59 +04:00
}
2009-11-28 08:34:05 +03:00
extern void efx_link_status_changed ( struct efx_nic * efx ) ;
2009-11-29 06:42:41 +03:00
extern void efx_link_set_advertising ( struct efx_nic * efx , u32 ) ;
extern void efx_link_set_wanted_fc ( struct efx_nic * efx , enum efx_fc_type ) ;
2009-11-28 08:34:05 +03:00
2008-04-27 15:55:59 +04:00
# endif /* EFX_EFX_H */