2010-11-16 19:27:16 -08:00
/*******************************************************************************
Intel 10 Gigabit PCI Express Linux driver
2014-07-22 06:50:42 +00:00
Copyright ( c ) 1999 - 2014 Intel Corporation .
2010-11-16 19:27:16 -08:00
This program is free software ; you can redistribute it and / or modify it
under the terms and conditions of the GNU General Public License ,
version 2 , as published by the Free Software Foundation .
This program is distributed in the hope it will be useful , but WITHOUT
ANY WARRANTY ; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE . See the GNU General Public License for
more details .
You should have received a copy of the GNU General Public License along with
this program ; if not , write to the Free Software Foundation , Inc . ,
51 Franklin St - Fifth Floor , Boston , MA 02110 - 1301 USA .
The full GNU General Public License is included in this distribution in
the file called " COPYING " .
Contact Information :
2014-02-22 01:23:50 +00:00
Linux NICS < linux . nics @ intel . com >
2010-11-16 19:27:16 -08:00
e1000 - devel Mailing List < e1000 - devel @ lists . sourceforge . net >
Intel Corporation , 5200 N . E . Elam Young Parkway , Hillsboro , OR 97124 - 6497
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# include <linux/pci.h>
# include <linux/delay.h>
# include <linux/sched.h>
# include "ixgbe.h"
# include "ixgbe_phy.h"
2014-12-05 03:59:50 +00:00
# include "ixgbe_x540.h"
2010-11-16 19:27:16 -08:00
2013-10-01 04:33:53 -07:00
# define IXGBE_X540_MAX_TX_QUEUES 128
# define IXGBE_X540_MAX_RX_QUEUES 128
# define IXGBE_X540_RAR_ENTRIES 128
# define IXGBE_X540_MC_TBL_SIZE 128
# define IXGBE_X540_VFT_TBL_SIZE 128
# define IXGBE_X540_RX_PB_SIZE 384
2010-11-16 19:27:16 -08:00
static s32 ixgbe_update_flash_X540 ( struct ixgbe_hw * hw ) ;
static s32 ixgbe_poll_flash_update_done_X540 ( struct ixgbe_hw * hw ) ;
static s32 ixgbe_get_swfw_sync_semaphore ( struct ixgbe_hw * hw ) ;
static void ixgbe_release_swfw_sync_semaphore ( struct ixgbe_hw * hw ) ;
2014-12-05 03:59:50 +00:00
enum ixgbe_media_type ixgbe_get_media_type_X540 ( struct ixgbe_hw * hw )
2010-11-16 19:27:16 -08:00
{
return ixgbe_media_type_copper ;
}
2014-12-05 03:59:50 +00:00
s32 ixgbe_get_invariants_X540 ( struct ixgbe_hw * hw )
2010-11-16 19:27:16 -08:00
{
struct ixgbe_mac_info * mac = & hw - > mac ;
2015-06-10 20:42:30 -04:00
struct ixgbe_phy_info * phy = & hw - > phy ;
/* set_phy_power was set by default to NULL */
2015-11-05 11:02:14 -08:00
phy - > ops . set_phy_power = ixgbe_set_copper_phy_power ;
2010-11-16 19:27:16 -08:00
mac - > mcft_size = IXGBE_X540_MC_TBL_SIZE ;
mac - > vft_size = IXGBE_X540_VFT_TBL_SIZE ;
mac - > num_rar_entries = IXGBE_X540_RAR_ENTRIES ;
2014-02-22 01:23:49 +00:00
mac - > rx_pb_size = IXGBE_X540_RX_PB_SIZE ;
2010-11-16 19:27:16 -08:00
mac - > max_rx_queues = IXGBE_X540_MAX_RX_QUEUES ;
mac - > max_tx_queues = IXGBE_X540_MAX_TX_QUEUES ;
mac - > max_msix_vectors = ixgbe_get_pcie_msix_count_generic ( hw ) ;
return 0 ;
}
/**
* ixgbe_setup_mac_link_X540 - Set the auto advertised capabilitires
* @ hw : pointer to hardware structure
* @ speed : new link speed
* @ autoneg_wait_to_complete : true when waiting for completion is needed
* */
2014-12-05 03:59:50 +00:00
s32 ixgbe_setup_mac_link_X540 ( struct ixgbe_hw * hw , ixgbe_link_speed speed ,
bool autoneg_wait_to_complete )
2010-11-16 19:27:16 -08:00
{
2012-12-15 03:28:24 +00:00
return hw - > phy . ops . setup_link_speed ( hw , speed ,
2014-04-09 06:03:10 +00:00
autoneg_wait_to_complete ) ;
2010-11-16 19:27:16 -08:00
}
/**
* ixgbe_reset_hw_X540 - Perform hardware reset
* @ hw : pointer to hardware structure
*
* Resets the hardware by resetting the transmit and receive units , masks
* and clears all interrupts , perform a PHY reset , and perform a link ( MAC )
* reset .
* */
2014-12-05 03:59:50 +00:00
s32 ixgbe_reset_hw_X540 ( struct ixgbe_hw * hw )
2010-11-16 19:27:16 -08:00
{
2011-07-15 07:29:44 +00:00
s32 status ;
u32 ctrl , i ;
2010-11-16 19:27:16 -08:00
/* Call adapter stop to disable tx/rx and clear interrupts */
2011-08-16 04:35:11 +00:00
status = hw - > mac . ops . stop_adapter ( hw ) ;
2014-07-22 06:51:08 +00:00
if ( status )
return status ;
2010-11-16 19:27:16 -08:00
2011-08-16 04:35:11 +00:00
/* flush pending Tx transactions */
ixgbe_clear_tx_pending ( hw ) ;
2010-11-16 19:27:16 -08:00
2011-02-14 08:45:13 +00:00
mac_reset_top :
2011-08-16 08:04:11 +00:00
ctrl = IXGBE_CTRL_RST ;
2011-07-15 07:29:44 +00:00
ctrl | = IXGBE_READ_REG ( hw , IXGBE_CTRL ) ;
IXGBE_WRITE_REG ( hw , IXGBE_CTRL , ctrl ) ;
2010-11-16 19:27:16 -08:00
IXGBE_WRITE_FLUSH ( hw ) ;
2015-10-27 13:23:14 -07:00
usleep_range ( 1000 , 1200 ) ;
2010-11-16 19:27:16 -08:00
/* Poll for reset bit to self-clear indicating reset is complete */
for ( i = 0 ; i < 10 ; i + + ) {
ctrl = IXGBE_READ_REG ( hw , IXGBE_CTRL ) ;
2011-07-15 07:29:44 +00:00
if ( ! ( ctrl & IXGBE_CTRL_RST_MASK ) )
2010-11-16 19:27:16 -08:00
break ;
2015-10-27 13:23:14 -07:00
udelay ( 1 ) ;
2010-11-16 19:27:16 -08:00
}
2011-07-15 07:29:44 +00:00
if ( ctrl & IXGBE_CTRL_RST_MASK ) {
2010-11-16 19:27:16 -08:00
status = IXGBE_ERR_RESET_FAILED ;
hw_dbg ( hw , " Reset polling failed to complete. \n " ) ;
}
2011-08-16 08:04:11 +00:00
msleep ( 100 ) ;
2011-07-15 07:29:44 +00:00
2011-02-14 08:45:13 +00:00
/*
* Double resets are required for recovery from certain error
* conditions . Between resets , it is necessary to stall to allow time
2011-07-15 07:29:44 +00:00
* for any pending HW events to complete .
2011-02-14 08:45:13 +00:00
*/
if ( hw - > mac . flags & IXGBE_FLAGS_DOUBLE_RESET_REQUIRED ) {
hw - > mac . flags & = ~ IXGBE_FLAGS_DOUBLE_RESET_REQUIRED ;
goto mac_reset_top ;
}
2010-11-16 19:27:16 -08:00
/* Set the Rx packet buffer size. */
IXGBE_WRITE_REG ( hw , IXGBE_RXPBSIZE ( 0 ) , 384 < < IXGBE_RXPBSIZE_SHIFT ) ;
/* Store the permanent mac address */
hw - > mac . ops . get_mac_addr ( hw , hw - > mac . perm_addr ) ;
/*
* Store MAC address from RAR0 , clear receive address registers , and
* clear the multicast table . Also reset num_rar_entries to 128 ,
* since we modify this value when programming the SAN MAC address .
*/
2011-03-01 04:37:15 +00:00
hw - > mac . num_rar_entries = IXGBE_X540_MAX_TX_QUEUES ;
2010-11-16 19:27:16 -08:00
hw - > mac . ops . init_rx_addrs ( hw ) ;
/* Store the permanent SAN mac address */
hw - > mac . ops . get_san_mac_addr ( hw , hw - > mac . san_addr ) ;
/* Add the SAN MAC address to the RAR only if it's a valid address */
2012-10-24 17:19:02 +00:00
if ( is_valid_ether_addr ( hw - > mac . san_addr ) ) {
2012-05-05 05:32:52 +00:00
/* Save the SAN MAC RAR index */
hw - > mac . san_mac_rar_index = hw - > mac . num_rar_entries - 1 ;
2015-11-02 17:10:26 -08:00
hw - > mac . ops . set_rar ( hw , hw - > mac . san_mac_rar_index ,
hw - > mac . san_addr , 0 , IXGBE_RAH_AV ) ;
/* clear VMDq pool/queue selection for this RAR */
hw - > mac . ops . clear_vmdq ( hw , hw - > mac . san_mac_rar_index ,
IXGBE_CLEAR_VMDQ_ALL ) ;
2010-11-16 19:27:16 -08:00
/* Reserve the last RAR for the SAN MAC address */
hw - > mac . num_rar_entries - - ;
}
/* Store the alternative WWNN/WWPN prefix */
hw - > mac . ops . get_wwn_prefix ( hw , & hw - > mac . wwnn_prefix ,
2014-04-09 06:03:10 +00:00
& hw - > mac . wwpn_prefix ) ;
2010-11-16 19:27:16 -08:00
return status ;
}
2011-03-18 08:18:22 +00:00
/**
* ixgbe_start_hw_X540 - Prepare hardware for Tx / Rx
* @ hw : pointer to hardware structure
*
* Starts the hardware using the generic start_hw function
* and the generation start_hw function .
* Then performs revision - specific operations , if any .
* */
2014-12-05 03:59:50 +00:00
s32 ixgbe_start_hw_X540 ( struct ixgbe_hw * hw )
2011-03-18 08:18:22 +00:00
{
2014-07-22 06:51:08 +00:00
s32 ret_val ;
2011-03-18 08:18:22 +00:00
ret_val = ixgbe_start_hw_generic ( hw ) ;
2014-07-22 06:51:08 +00:00
if ( ret_val )
return ret_val ;
2011-03-18 08:18:22 +00:00
2014-07-22 06:51:08 +00:00
return ixgbe_start_hw_gen2 ( hw ) ;
2011-03-18 08:18:22 +00:00
}
2010-11-16 19:27:16 -08:00
/**
2011-03-03 09:24:56 +00:00
* ixgbe_init_eeprom_params_X540 - Initialize EEPROM params
* @ hw : pointer to hardware structure
*
* Initializes the EEPROM parameters ixgbe_eeprom_info within the
* ixgbe_hw struct in order to set up EEPROM access .
2010-11-16 19:27:16 -08:00
* */
2014-12-05 03:59:50 +00:00
s32 ixgbe_init_eeprom_params_X540 ( struct ixgbe_hw * hw )
2010-11-16 19:27:16 -08:00
{
struct ixgbe_eeprom_info * eeprom = & hw - > eeprom ;
u32 eec ;
u16 eeprom_size ;
if ( eeprom - > type = = ixgbe_eeprom_uninitialized ) {
eeprom - > semaphore_delay = 10 ;
eeprom - > type = ixgbe_flash ;
2015-06-09 17:15:01 -07:00
eec = IXGBE_READ_REG ( hw , IXGBE_EEC ( hw ) ) ;
2010-11-16 19:27:16 -08:00
eeprom_size = ( u16 ) ( ( eec & IXGBE_EEC_SIZE ) > >
2014-04-09 06:03:10 +00:00
IXGBE_EEC_SIZE_SHIFT ) ;
2010-11-16 19:27:16 -08:00
eeprom - > word_size = 1 < < ( eeprom_size +
2014-04-09 06:03:10 +00:00
IXGBE_EEPROM_WORD_SIZE_SHIFT ) ;
2010-11-16 19:27:16 -08:00
hw_dbg ( hw , " Eeprom params: type = %d, size = %d \n " ,
2011-03-03 09:24:56 +00:00
eeprom - > type , eeprom - > word_size ) ;
2010-11-16 19:27:16 -08:00
}
return 0 ;
}
/**
2011-04-20 08:49:06 +00:00
* ixgbe_read_eerd_X540 - Read EEPROM word using EERD
* @ hw : pointer to hardware structure
* @ offset : offset of word in the EEPROM to read
* @ data : word read from the EEPROM
*
* Reads a 16 bit word from the EEPROM using the EERD register .
2010-11-16 19:27:16 -08:00
* */
2010-11-16 19:27:17 -08:00
static s32 ixgbe_read_eerd_X540 ( struct ixgbe_hw * hw , u16 offset , u16 * data )
2010-11-16 19:27:16 -08:00
{
2014-07-22 06:50:42 +00:00
s32 status ;
if ( hw - > mac . ops . acquire_swfw_sync ( hw , IXGBE_GSSR_EEP_SM ) )
return IXGBE_ERR_SWFW_SYNC ;
2010-11-16 19:27:16 -08:00
2014-07-22 06:50:42 +00:00
status = ixgbe_read_eerd_generic ( hw , offset , data ) ;
2010-11-16 19:27:16 -08:00
2011-04-13 04:56:15 +00:00
hw - > mac . ops . release_swfw_sync ( hw , IXGBE_GSSR_EEP_SM ) ;
2010-11-16 19:27:16 -08:00
return status ;
}
2011-04-20 08:49:06 +00:00
/**
* ixgbe_read_eerd_buffer_X540 - Read EEPROM word ( s ) using EERD
* @ hw : pointer to hardware structure
* @ offset : offset of word in the EEPROM to read
* @ words : number of words
* @ data : word ( s ) read from the EEPROM
*
* Reads a 16 bit word ( s ) from the EEPROM using the EERD register .
* */
static s32 ixgbe_read_eerd_buffer_X540 ( struct ixgbe_hw * hw ,
u16 offset , u16 words , u16 * data )
{
2014-07-22 06:50:42 +00:00
s32 status ;
if ( hw - > mac . ops . acquire_swfw_sync ( hw , IXGBE_GSSR_EEP_SM ) )
return IXGBE_ERR_SWFW_SYNC ;
2011-04-20 08:49:06 +00:00
2014-07-22 06:50:42 +00:00
status = ixgbe_read_eerd_buffer_generic ( hw , offset , words , data ) ;
2011-04-20 08:49:06 +00:00
hw - > mac . ops . release_swfw_sync ( hw , IXGBE_GSSR_EEP_SM ) ;
return status ;
}
2010-11-16 19:27:16 -08:00
/**
2011-03-24 00:57:50 +00:00
* ixgbe_write_eewr_X540 - Write EEPROM word using EEWR
* @ hw : pointer to hardware structure
* @ offset : offset of word in the EEPROM to write
* @ data : word write to the EEPROM
2010-11-16 19:27:16 -08:00
*
2011-03-24 00:57:50 +00:00
* Write a 16 bit word to the EEPROM using the EEWR register .
2010-11-16 19:27:16 -08:00
* */
2010-11-16 19:27:17 -08:00
static s32 ixgbe_write_eewr_X540 ( struct ixgbe_hw * hw , u16 offset , u16 data )
2010-11-16 19:27:16 -08:00
{
2014-07-22 06:50:42 +00:00
s32 status ;
if ( hw - > mac . ops . acquire_swfw_sync ( hw , IXGBE_GSSR_EEP_SM ) )
return IXGBE_ERR_SWFW_SYNC ;
2010-11-16 19:27:16 -08:00
2014-07-22 06:50:42 +00:00
status = ixgbe_write_eewr_generic ( hw , offset , data ) ;
2010-11-16 19:27:16 -08:00
2011-03-24 00:57:50 +00:00
hw - > mac . ops . release_swfw_sync ( hw , IXGBE_GSSR_EEP_SM ) ;
2010-11-16 19:27:16 -08:00
return status ;
}
2011-04-20 08:49:06 +00:00
/**
* ixgbe_write_eewr_buffer_X540 - Write EEPROM word ( s ) using EEWR
* @ hw : pointer to hardware structure
* @ offset : offset of word in the EEPROM to write
* @ words : number of words
* @ data : word ( s ) write to the EEPROM
*
* Write a 16 bit word ( s ) to the EEPROM using the EEWR register .
* */
static s32 ixgbe_write_eewr_buffer_X540 ( struct ixgbe_hw * hw ,
u16 offset , u16 words , u16 * data )
{
2014-07-22 06:50:42 +00:00
s32 status ;
2011-04-20 08:49:06 +00:00
2014-07-22 06:50:42 +00:00
if ( hw - > mac . ops . acquire_swfw_sync ( hw , IXGBE_GSSR_EEP_SM ) )
return IXGBE_ERR_SWFW_SYNC ;
status = ixgbe_write_eewr_buffer_generic ( hw , offset , words , data ) ;
2011-04-20 08:49:06 +00:00
hw - > mac . ops . release_swfw_sync ( hw , IXGBE_GSSR_EEP_SM ) ;
return status ;
}
2010-11-16 19:27:16 -08:00
/**
2011-03-24 00:57:50 +00:00
* ixgbe_calc_eeprom_checksum_X540 - Calculates and returns the checksum
*
* This function does not use synchronization for EERD and EEWR . It can
* be used internally by function which utilize ixgbe_acquire_swfw_sync_X540 .
*
* @ hw : pointer to hardware structure
2010-11-16 19:27:16 -08:00
* */
2014-11-29 05:22:48 +00:00
static s32 ixgbe_calc_eeprom_checksum_X540 ( struct ixgbe_hw * hw )
2010-11-16 19:27:16 -08:00
{
u16 i ;
u16 j ;
u16 checksum = 0 ;
u16 length = 0 ;
u16 pointer = 0 ;
u16 word = 0 ;
2014-11-29 05:22:48 +00:00
u16 checksum_last_word = IXGBE_EEPROM_CHECKSUM ;
u16 ptr_start = IXGBE_PCIE_ANALOG_PTR ;
2010-11-16 19:27:16 -08:00
2011-03-24 00:57:50 +00:00
/*
* Do not use hw - > eeprom . ops . read because we do not want to take
* the synchronization semaphores here . Instead use
* ixgbe_read_eerd_generic
*/
2010-11-16 19:27:16 -08:00
/* Include 0x0-0x3F in the checksum */
2014-11-29 05:22:48 +00:00
for ( i = 0 ; i < checksum_last_word ; i + + ) {
if ( ixgbe_read_eerd_generic ( hw , i , & word ) ) {
2010-11-16 19:27:16 -08:00
hw_dbg ( hw , " EEPROM read failed \n " ) ;
2014-11-29 05:22:48 +00:00
return IXGBE_ERR_EEPROM ;
2010-11-16 19:27:16 -08:00
}
checksum + = word ;
}
/*
* Include all data from pointers 0x3 , 0x6 - 0xE . This excludes the
* FW , PHY module , and PCIe Expansion / Option ROM pointers .
*/
2014-11-29 05:22:48 +00:00
for ( i = ptr_start ; i < IXGBE_FW_PTR ; i + + ) {
2010-11-16 19:27:16 -08:00
if ( i = = IXGBE_PHY_PTR | | i = = IXGBE_OPTION_ROM_PTR )
continue ;
2014-11-29 05:22:48 +00:00
if ( ixgbe_read_eerd_generic ( hw , i , & pointer ) ) {
2010-11-16 19:27:16 -08:00
hw_dbg ( hw , " EEPROM read failed \n " ) ;
break ;
}
/* Skip pointer section if the pointer is invalid. */
if ( pointer = = 0xFFFF | | pointer = = 0 | |
pointer > = hw - > eeprom . word_size )
continue ;
2014-11-29 05:22:48 +00:00
if ( ixgbe_read_eerd_generic ( hw , pointer , & length ) ) {
2010-11-16 19:27:16 -08:00
hw_dbg ( hw , " EEPROM read failed \n " ) ;
2014-11-29 05:22:48 +00:00
return IXGBE_ERR_EEPROM ;
2010-11-16 19:27:16 -08:00
break ;
}
/* Skip pointer section if length is invalid. */
if ( length = = 0xFFFF | | length = = 0 | |
( pointer + length ) > = hw - > eeprom . word_size )
continue ;
2014-11-29 05:22:48 +00:00
for ( j = pointer + 1 ; j < = pointer + length ; j + + ) {
if ( ixgbe_read_eerd_generic ( hw , j , & word ) ) {
2010-11-16 19:27:16 -08:00
hw_dbg ( hw , " EEPROM read failed \n " ) ;
2014-11-29 05:22:48 +00:00
return IXGBE_ERR_EEPROM ;
2010-11-16 19:27:16 -08:00
}
checksum + = word ;
}
}
checksum = ( u16 ) IXGBE_EEPROM_SUM - checksum ;
2014-11-29 05:22:48 +00:00
return ( s32 ) checksum ;
2010-11-16 19:27:16 -08:00
}
2011-03-24 00:57:50 +00:00
/**
* ixgbe_validate_eeprom_checksum_X540 - Validate EEPROM checksum
* @ hw : pointer to hardware structure
* @ checksum_val : calculated checksum
*
* Performs checksum calculation and validates the EEPROM checksum . If the
* caller does not need checksum_val , the value can be NULL .
* */
static s32 ixgbe_validate_eeprom_checksum_X540 ( struct ixgbe_hw * hw ,
u16 * checksum_val )
{
s32 status ;
u16 checksum ;
u16 read_checksum = 0 ;
2014-07-22 06:50:42 +00:00
/* Read the first word from the EEPROM. If this times out or fails, do
2011-03-24 00:57:50 +00:00
* not continue or we could be in for a very long wait while every
* EEPROM read fails
*/
status = hw - > eeprom . ops . read ( hw , 0 , & checksum ) ;
2014-07-22 06:50:42 +00:00
if ( status ) {
2011-03-24 00:57:50 +00:00
hw_dbg ( hw , " EEPROM read failed \n " ) ;
2014-07-22 06:50:42 +00:00
return status ;
2011-03-24 00:57:50 +00:00
}
2014-07-22 06:50:42 +00:00
if ( hw - > mac . ops . acquire_swfw_sync ( hw , IXGBE_GSSR_EEP_SM ) )
return IXGBE_ERR_SWFW_SYNC ;
2014-11-29 05:22:48 +00:00
status = hw - > eeprom . ops . calc_checksum ( hw ) ;
if ( status < 0 )
goto out ;
checksum = ( u16 ) ( status & 0xffff ) ;
2014-07-22 06:50:42 +00:00
/* Do not use hw->eeprom.ops.read because we do not want to take
* the synchronization semaphores twice here .
*/
status = ixgbe_read_eerd_generic ( hw , IXGBE_EEPROM_CHECKSUM ,
& read_checksum ) ;
2014-11-29 05:22:48 +00:00
if ( status )
goto out ;
2011-03-24 00:57:50 +00:00
2014-11-29 05:22:48 +00:00
/* Verify read checksum from EEPROM is the same as
* calculated checksum
*/
if ( read_checksum ! = checksum ) {
hw_dbg ( hw , " Invalid EEPROM checksum " ) ;
status = IXGBE_ERR_EEPROM_CHECKSUM ;
}
2014-07-22 06:50:42 +00:00
/* If the user cares, return the calculated checksum */
if ( checksum_val )
* checksum_val = checksum ;
2014-11-29 05:22:48 +00:00
out :
hw - > mac . ops . release_swfw_sync ( hw , IXGBE_GSSR_EEP_SM ) ;
2014-07-22 06:50:42 +00:00
2011-03-24 00:57:50 +00:00
return status ;
}
2010-11-16 19:27:16 -08:00
/**
* ixgbe_update_eeprom_checksum_X540 - Updates the EEPROM checksum and flash
* @ hw : pointer to hardware structure
*
* After writing EEPROM to shadow RAM using EEWR register , software calculates
* checksum and updates the EEPROM and instructs the hardware to update
* the flash .
* */
2010-11-16 19:27:17 -08:00
static s32 ixgbe_update_eeprom_checksum_X540 ( struct ixgbe_hw * hw )
2010-11-16 19:27:16 -08:00
{
s32 status ;
2011-03-24 00:57:50 +00:00
u16 checksum ;
2010-11-16 19:27:16 -08:00
2014-07-22 06:50:42 +00:00
/* Read the first word from the EEPROM. If this times out or fails, do
2011-03-24 00:57:50 +00:00
* not continue or we could be in for a very long wait while every
* EEPROM read fails
*/
status = hw - > eeprom . ops . read ( hw , 0 , & checksum ) ;
2014-07-22 06:50:42 +00:00
if ( status ) {
2011-03-24 00:57:50 +00:00
hw_dbg ( hw , " EEPROM read failed \n " ) ;
2014-07-22 06:50:42 +00:00
return status ;
}
2011-03-24 00:57:50 +00:00
2014-07-22 06:50:42 +00:00
if ( hw - > mac . ops . acquire_swfw_sync ( hw , IXGBE_GSSR_EEP_SM ) )
return IXGBE_ERR_SWFW_SYNC ;
2010-11-16 19:27:16 -08:00
2014-11-29 05:22:48 +00:00
status = hw - > eeprom . ops . calc_checksum ( hw ) ;
if ( status < 0 )
goto out ;
checksum = ( u16 ) ( status & 0xffff ) ;
2011-03-24 00:57:50 +00:00
2014-07-22 06:50:42 +00:00
/* Do not use hw->eeprom.ops.write because we do not want to
* take the synchronization semaphores twice here .
*/
status = ixgbe_write_eewr_generic ( hw , IXGBE_EEPROM_CHECKSUM , checksum ) ;
2014-11-29 05:22:48 +00:00
if ( status )
goto out ;
status = ixgbe_update_flash_X540 ( hw ) ;
2011-03-24 00:57:50 +00:00
2014-11-29 05:22:48 +00:00
out :
2011-03-24 00:57:50 +00:00
hw - > mac . ops . release_swfw_sync ( hw , IXGBE_GSSR_EEP_SM ) ;
2010-11-16 19:27:16 -08:00
return status ;
}
/**
* ixgbe_update_flash_X540 - Instruct HW to copy EEPROM to Flash device
* @ hw : pointer to hardware structure
*
* Set FLUP ( bit 23 ) of the EEC register to instruct Hardware to copy
* EEPROM from shadow RAM to the flash device .
* */
static s32 ixgbe_update_flash_X540 ( struct ixgbe_hw * hw )
{
u32 flup ;
2014-07-22 06:51:08 +00:00
s32 status ;
2010-11-16 19:27:16 -08:00
status = ixgbe_poll_flash_update_done_X540 ( hw ) ;
if ( status = = IXGBE_ERR_EEPROM ) {
hw_dbg ( hw , " Flash update time out \n " ) ;
2014-07-22 06:51:08 +00:00
return status ;
2010-11-16 19:27:16 -08:00
}
2015-06-09 17:15:01 -07:00
flup = IXGBE_READ_REG ( hw , IXGBE_EEC ( hw ) ) | IXGBE_EEC_FLUP ;
IXGBE_WRITE_REG ( hw , IXGBE_EEC ( hw ) , flup ) ;
2010-11-16 19:27:16 -08:00
status = ixgbe_poll_flash_update_done_X540 ( hw ) ;
2011-03-12 08:56:38 +00:00
if ( status = = 0 )
2010-11-16 19:27:16 -08:00
hw_dbg ( hw , " Flash update complete \n " ) ;
else
hw_dbg ( hw , " Flash update time out \n " ) ;
if ( hw - > revision_id = = 0 ) {
2015-06-09 17:15:01 -07:00
flup = IXGBE_READ_REG ( hw , IXGBE_EEC ( hw ) ) ;
2010-11-16 19:27:16 -08:00
if ( flup & IXGBE_EEC_SEC1VAL ) {
flup | = IXGBE_EEC_FLUP ;
2015-06-09 17:15:01 -07:00
IXGBE_WRITE_REG ( hw , IXGBE_EEC ( hw ) , flup ) ;
2010-11-16 19:27:16 -08:00
}
status = ixgbe_poll_flash_update_done_X540 ( hw ) ;
2011-03-12 08:56:38 +00:00
if ( status = = 0 )
2010-11-16 19:27:16 -08:00
hw_dbg ( hw , " Flash update complete \n " ) ;
else
hw_dbg ( hw , " Flash update time out \n " ) ;
}
2014-07-22 06:51:08 +00:00
2010-11-16 19:27:16 -08:00
return status ;
}
/**
* ixgbe_poll_flash_update_done_X540 - Poll flash update status
* @ hw : pointer to hardware structure
*
* Polls the FLUDONE ( bit 26 ) of the EEC Register to determine when the
* flash update is done .
* */
static s32 ixgbe_poll_flash_update_done_X540 ( struct ixgbe_hw * hw )
{
u32 i ;
u32 reg ;
for ( i = 0 ; i < IXGBE_FLUDONE_ATTEMPTS ; i + + ) {
2015-06-09 17:15:01 -07:00
reg = IXGBE_READ_REG ( hw , IXGBE_EEC ( hw ) ) ;
2014-07-22 06:51:08 +00:00
if ( reg & IXGBE_EEC_FLUDONE )
return 0 ;
2010-11-16 19:27:16 -08:00
udelay ( 5 ) ;
}
2014-07-22 06:51:08 +00:00
return IXGBE_ERR_EEPROM ;
2010-11-16 19:27:16 -08:00
}
/**
* ixgbe_acquire_swfw_sync_X540 - Acquire SWFW semaphore
* @ hw : pointer to hardware structure
* @ mask : Mask to specify which semaphore to acquire
*
* Acquires the SWFW semaphore thought the SW_FW_SYNC register for
* the specified function ( CSR , PHY0 , PHY1 , NVM , Flash )
* */
2014-12-05 03:59:50 +00:00
s32 ixgbe_acquire_swfw_sync_X540 ( struct ixgbe_hw * hw , u32 mask )
2010-11-16 19:27:16 -08:00
{
2015-08-08 16:18:53 -07:00
u32 swmask = mask & IXGBE_GSSR_NVM_PHY_MASK ;
u32 swi2c_mask = mask & IXGBE_GSSR_I2C_MASK ;
u32 fwmask = swmask < < 5 ;
2010-11-16 19:27:16 -08:00
u32 timeout = 200 ;
2015-08-08 16:18:53 -07:00
u32 hwmask = 0 ;
u32 swfw_sync ;
2010-11-16 19:27:16 -08:00
u32 i ;
2015-08-08 16:18:53 -07:00
if ( swmask & IXGBE_GSSR_EEP_SM )
2010-11-16 19:27:16 -08:00
hwmask = IXGBE_GSSR_FLASH_SM ;
2015-08-08 16:18:53 -07:00
/* SW only mask does not have FW bit pair */
if ( mask & IXGBE_GSSR_SW_MNG_SM )
swmask | = IXGBE_GSSR_SW_MNG_SM ;
swmask | = swi2c_mask ;
fwmask | = swi2c_mask < < 2 ;
2010-11-16 19:27:16 -08:00
for ( i = 0 ; i < timeout ; i + + ) {
2015-08-08 16:18:53 -07:00
/* SW NVM semaphore bit is used for access to all
2010-11-16 19:27:16 -08:00
* SW_FW_SYNC bits ( not just NVM )
*/
if ( ixgbe_get_swfw_sync_semaphore ( hw ) )
return IXGBE_ERR_SWFW_SYNC ;
2015-06-09 17:15:01 -07:00
swfw_sync = IXGBE_READ_REG ( hw , IXGBE_SWFW_SYNC ( hw ) ) ;
2010-11-16 19:27:16 -08:00
if ( ! ( swfw_sync & ( fwmask | swmask | hwmask ) ) ) {
swfw_sync | = swmask ;
2015-06-09 17:15:01 -07:00
IXGBE_WRITE_REG ( hw , IXGBE_SWFW_SYNC ( hw ) , swfw_sync ) ;
2010-11-16 19:27:16 -08:00
ixgbe_release_swfw_sync_semaphore ( hw ) ;
2015-08-08 16:18:53 -07:00
usleep_range ( 5000 , 6000 ) ;
return 0 ;
2010-11-16 19:27:16 -08:00
}
2015-08-08 16:18:53 -07:00
/* Firmware currently using resource (fwmask), hardware
* currently using resource ( hwmask ) , or other software
* thread currently using resource ( swmask )
*/
ixgbe_release_swfw_sync_semaphore ( hw ) ;
usleep_range ( 5000 , 10000 ) ;
2010-11-16 19:27:16 -08:00
}
2015-08-08 16:18:53 -07:00
/* Failed to get SW only semaphore */
if ( swmask = = IXGBE_GSSR_SW_MNG_SM ) {
hw_dbg ( hw , " Failed to get SW only semaphore \n " ) ;
return IXGBE_ERR_SWFW_SYNC ;
}
2010-11-16 19:27:16 -08:00
2015-08-08 16:18:53 -07:00
/* If the resource is not released by the FW/HW the SW can assume that
* the FW / HW malfunctions . In that case the SW should set the SW bit ( s )
* of the requested resource ( s ) while ignoring the corresponding FW / HW
* bits in the SW_FW_SYNC register .
*/
if ( ixgbe_get_swfw_sync_semaphore ( hw ) )
return IXGBE_ERR_SWFW_SYNC ;
swfw_sync = IXGBE_READ_REG ( hw , IXGBE_SWFW_SYNC ( hw ) ) ;
if ( swfw_sync & ( fwmask | hwmask ) ) {
swfw_sync | = swmask ;
IXGBE_WRITE_REG ( hw , IXGBE_SWFW_SYNC ( hw ) , swfw_sync ) ;
ixgbe_release_swfw_sync_semaphore ( hw ) ;
usleep_range ( 5000 , 6000 ) ;
return 0 ;
}
/* If the resource is not released by other SW the SW can assume that
* the other SW malfunctions . In that case the SW should clear all SW
* flags that it does not own and then repeat the whole process once
* again .
*/
if ( swfw_sync & swmask ) {
u32 rmask = IXGBE_GSSR_EEP_SM | IXGBE_GSSR_PHY0_SM |
IXGBE_GSSR_PHY1_SM | IXGBE_GSSR_MAC_CSR_SM ;
if ( swi2c_mask )
rmask | = IXGBE_GSSR_I2C_MASK ;
ixgbe_release_swfw_sync_X540 ( hw , rmask ) ;
ixgbe_release_swfw_sync_semaphore ( hw ) ;
return IXGBE_ERR_SWFW_SYNC ;
2010-11-16 19:27:16 -08:00
}
2015-08-08 16:18:53 -07:00
ixgbe_release_swfw_sync_semaphore ( hw ) ;
2010-11-16 19:27:16 -08:00
2015-08-08 16:18:53 -07:00
return IXGBE_ERR_SWFW_SYNC ;
2010-11-16 19:27:16 -08:00
}
/**
* ixgbe_release_swfw_sync_X540 - Release SWFW semaphore
* @ hw : pointer to hardware structure
* @ mask : Mask to specify which semaphore to release
*
2011-03-30 22:57:33 -03:00
* Releases the SWFW semaphore through the SW_FW_SYNC register
2010-11-16 19:27:16 -08:00
* for the specified function ( CSR , PHY0 , PHY1 , EVM , Flash )
* */
2014-12-05 03:59:50 +00:00
void ixgbe_release_swfw_sync_X540 ( struct ixgbe_hw * hw , u32 mask )
2010-11-16 19:27:16 -08:00
{
2015-08-08 16:18:53 -07:00
u32 swmask = mask & ( IXGBE_GSSR_NVM_PHY_MASK | IXGBE_GSSR_SW_MNG_SM ) ;
2010-11-16 19:27:16 -08:00
u32 swfw_sync ;
2015-08-08 16:18:53 -07:00
if ( mask & IXGBE_GSSR_I2C_MASK )
swmask | = mask & IXGBE_GSSR_I2C_MASK ;
2010-11-16 19:27:16 -08:00
ixgbe_get_swfw_sync_semaphore ( hw ) ;
2015-06-09 17:15:01 -07:00
swfw_sync = IXGBE_READ_REG ( hw , IXGBE_SWFW_SYNC ( hw ) ) ;
2010-11-16 19:27:16 -08:00
swfw_sync & = ~ swmask ;
2015-06-09 17:15:01 -07:00
IXGBE_WRITE_REG ( hw , IXGBE_SWFW_SYNC ( hw ) , swfw_sync ) ;
2010-11-16 19:27:16 -08:00
ixgbe_release_swfw_sync_semaphore ( hw ) ;
2015-08-08 16:18:53 -07:00
usleep_range ( 5000 , 6000 ) ;
2010-11-16 19:27:16 -08:00
}
/**
2014-07-22 06:50:47 +00:00
* ixgbe_get_swfw_sync_semaphore - Get hardware semaphore
2010-11-16 19:27:16 -08:00
* @ hw : pointer to hardware structure
*
* Sets the hardware semaphores so SW / FW can gain control of shared resources
2014-07-22 06:50:47 +00:00
*/
2010-11-16 19:27:16 -08:00
static s32 ixgbe_get_swfw_sync_semaphore ( struct ixgbe_hw * hw )
{
u32 timeout = 2000 ;
u32 i ;
u32 swsm ;
/* Get SMBI software semaphore between device drivers first */
for ( i = 0 ; i < timeout ; i + + ) {
2014-07-22 06:50:47 +00:00
/* If the SMBI bit is 0 when we read it, then the bit will be
2010-11-16 19:27:16 -08:00
* set and we have the semaphore
*/
2015-06-09 17:15:01 -07:00
swsm = IXGBE_READ_REG ( hw , IXGBE_SWSM ( hw ) ) ;
2014-07-22 06:50:47 +00:00
if ( ! ( swsm & IXGBE_SWSM_SMBI ) )
2010-11-16 19:27:16 -08:00
break ;
2014-07-22 06:50:36 +00:00
usleep_range ( 50 , 100 ) ;
2010-11-16 19:27:16 -08:00
}
2014-07-22 06:50:47 +00:00
if ( i = = timeout ) {
hw_dbg ( hw ,
" Software semaphore SMBI between device drivers not granted. \n " ) ;
return IXGBE_ERR_EEPROM ;
}
2010-11-16 19:27:16 -08:00
/* Now get the semaphore between SW/FW through the REGSMP bit */
2014-07-22 06:50:47 +00:00
for ( i = 0 ; i < timeout ; i + + ) {
2015-06-09 17:15:01 -07:00
swsm = IXGBE_READ_REG ( hw , IXGBE_SWFW_SYNC ( hw ) ) ;
2014-07-22 06:50:47 +00:00
if ( ! ( swsm & IXGBE_SWFW_REGSMP ) )
return 0 ;
2010-11-16 19:27:16 -08:00
2014-07-22 06:50:47 +00:00
usleep_range ( 50 , 100 ) ;
2010-11-16 19:27:16 -08:00
}
2015-08-08 16:18:59 -07:00
/* Release semaphores and return error if SW NVM semaphore
* was not granted because we do not have access to the EEPROM
*/
hw_dbg ( hw , " REGSMP Software NVM semaphore not granted \n " ) ;
ixgbe_release_swfw_sync_semaphore ( hw ) ;
2014-07-22 06:50:47 +00:00
return IXGBE_ERR_EEPROM ;
2010-11-16 19:27:16 -08:00
}
/**
* ixgbe_release_nvm_semaphore - Release hardware semaphore
* @ hw : pointer to hardware structure
*
* This function clears hardware semaphore bits .
* */
static void ixgbe_release_swfw_sync_semaphore ( struct ixgbe_hw * hw )
{
u32 swsm ;
/* Release both semaphores by writing 0 to the bits REGSMP and SMBI */
2015-06-09 17:15:01 -07:00
swsm = IXGBE_READ_REG ( hw , IXGBE_SWFW_SYNC ( hw ) ) ;
2010-11-16 19:27:16 -08:00
swsm & = ~ IXGBE_SWFW_REGSMP ;
2015-06-09 17:15:01 -07:00
IXGBE_WRITE_REG ( hw , IXGBE_SWFW_SYNC ( hw ) , swsm ) ;
2010-11-16 19:27:16 -08:00
2015-06-09 17:15:01 -07:00
swsm = IXGBE_READ_REG ( hw , IXGBE_SWSM ( hw ) ) ;
2015-04-10 10:36:31 -07:00
swsm & = ~ IXGBE_SWSM_SMBI ;
2015-06-09 17:15:01 -07:00
IXGBE_WRITE_REG ( hw , IXGBE_SWSM ( hw ) , swsm ) ;
2015-04-10 10:36:31 -07:00
2010-11-16 19:27:16 -08:00
IXGBE_WRITE_FLUSH ( hw ) ;
}
2011-04-08 01:24:05 +00:00
/**
* ixgbe_blink_led_start_X540 - Blink LED based on index .
* @ hw : pointer to hardware structure
* @ index : led number to blink
*
* Devices that implement the version 2 interface :
* X540
* */
2014-12-05 03:59:50 +00:00
s32 ixgbe_blink_led_start_X540 ( struct ixgbe_hw * hw , u32 index )
2011-04-08 01:24:05 +00:00
{
u32 macc_reg ;
u32 ledctl_reg ;
2011-10-29 06:54:55 +00:00
ixgbe_link_speed speed ;
bool link_up ;
2011-04-08 01:24:05 +00:00
/*
2011-10-29 06:54:55 +00:00
* Link should be up in order for the blink bit in the LED control
* register to work . Force link and speed in the MAC if link is down .
* This will be reversed when we stop the blinking .
2011-04-08 01:24:05 +00:00
*/
2011-10-29 06:54:55 +00:00
hw - > mac . ops . check_link ( hw , & speed , & link_up , false ) ;
2012-02-09 11:17:23 +00:00
if ( ! link_up ) {
2011-10-29 06:54:55 +00:00
macc_reg = IXGBE_READ_REG ( hw , IXGBE_MACC ) ;
macc_reg | = IXGBE_MACC_FLU | IXGBE_MACC_FSV_10G | IXGBE_MACC_FS ;
IXGBE_WRITE_REG ( hw , IXGBE_MACC , macc_reg ) ;
}
2011-04-08 01:24:05 +00:00
/* Set the LED to LINK_UP + BLINK. */
ledctl_reg = IXGBE_READ_REG ( hw , IXGBE_LEDCTL ) ;
ledctl_reg & = ~ IXGBE_LED_MODE_MASK ( index ) ;
ledctl_reg | = IXGBE_LED_BLINK ( index ) ;
IXGBE_WRITE_REG ( hw , IXGBE_LEDCTL , ledctl_reg ) ;
IXGBE_WRITE_FLUSH ( hw ) ;
return 0 ;
}
/**
* ixgbe_blink_led_stop_X540 - Stop blinking LED based on index .
* @ hw : pointer to hardware structure
* @ index : led number to stop blinking
*
* Devices that implement the version 2 interface :
* X540
* */
2014-12-05 03:59:50 +00:00
s32 ixgbe_blink_led_stop_X540 ( struct ixgbe_hw * hw , u32 index )
2011-04-08 01:24:05 +00:00
{
u32 macc_reg ;
u32 ledctl_reg ;
/* Restore the LED to its default value. */
ledctl_reg = IXGBE_READ_REG ( hw , IXGBE_LEDCTL ) ;
ledctl_reg & = ~ IXGBE_LED_MODE_MASK ( index ) ;
ledctl_reg | = IXGBE_LED_LINK_ACTIVE < < IXGBE_LED_MODE_SHIFT ( index ) ;
ledctl_reg & = ~ IXGBE_LED_BLINK ( index ) ;
IXGBE_WRITE_REG ( hw , IXGBE_LEDCTL , ledctl_reg ) ;
/* Unforce link and speed in the MAC. */
macc_reg = IXGBE_READ_REG ( hw , IXGBE_MACC ) ;
macc_reg & = ~ ( IXGBE_MACC_FLU | IXGBE_MACC_FSV_10G | IXGBE_MACC_FS ) ;
IXGBE_WRITE_REG ( hw , IXGBE_MACC , macc_reg ) ;
IXGBE_WRITE_FLUSH ( hw ) ;
return 0 ;
}
2010-11-16 19:27:16 -08:00
static struct ixgbe_mac_operations mac_ops_X540 = {
. init_hw = & ixgbe_init_hw_generic ,
. reset_hw = & ixgbe_reset_hw_X540 ,
2011-03-18 08:18:22 +00:00
. start_hw = & ixgbe_start_hw_X540 ,
2010-11-16 19:27:16 -08:00
. clear_hw_cntrs = & ixgbe_clear_hw_cntrs_generic ,
. get_media_type = & ixgbe_get_media_type_X540 ,
. enable_rx_dma = & ixgbe_enable_rx_dma_generic ,
. get_mac_addr = & ixgbe_get_mac_addr_generic ,
. get_san_mac_addr = & ixgbe_get_san_mac_addr_generic ,
2011-03-31 09:36:18 +00:00
. get_device_caps = & ixgbe_get_device_caps_generic ,
2010-11-16 19:27:16 -08:00
. get_wwn_prefix = & ixgbe_get_wwn_prefix_generic ,
. stop_adapter = & ixgbe_stop_adapter_generic ,
. get_bus_info = & ixgbe_get_bus_info_generic ,
. set_lan_id = & ixgbe_set_lan_id_multi_port_pcie ,
. read_analog_reg8 = NULL ,
. write_analog_reg8 = NULL ,
. setup_link = & ixgbe_setup_mac_link_X540 ,
2011-05-02 12:34:10 +00:00
. set_rxpba = & ixgbe_set_rxpba_generic ,
2010-11-16 19:27:16 -08:00
. check_link = & ixgbe_check_mac_link_generic ,
. get_link_capabilities = & ixgbe_get_copper_link_capabilities_generic ,
. led_on = & ixgbe_led_on_generic ,
. led_off = & ixgbe_led_off_generic ,
2011-04-08 01:24:05 +00:00
. blink_led_start = & ixgbe_blink_led_start_X540 ,
. blink_led_stop = & ixgbe_blink_led_stop_X540 ,
2010-11-16 19:27:16 -08:00
. set_rar = & ixgbe_set_rar_generic ,
. clear_rar = & ixgbe_clear_rar_generic ,
. set_vmdq = & ixgbe_set_vmdq_generic ,
2012-05-05 05:32:52 +00:00
. set_vmdq_san_mac = & ixgbe_set_vmdq_san_mac_generic ,
2010-11-16 19:27:16 -08:00
. clear_vmdq = & ixgbe_clear_vmdq_generic ,
. init_rx_addrs = & ixgbe_init_rx_addrs_generic ,
. update_mc_addr_list = & ixgbe_update_mc_addr_list_generic ,
. enable_mc = & ixgbe_enable_mc_generic ,
. disable_mc = & ixgbe_disable_mc_generic ,
. clear_vfta = & ixgbe_clear_vfta_generic ,
. set_vfta = & ixgbe_set_vfta_generic ,
. fc_enable = & ixgbe_fc_enable_generic ,
2011-05-07 07:40:20 +00:00
. set_fw_drv_ver = & ixgbe_set_fw_drv_ver_generic ,
2010-11-16 19:27:16 -08:00
. init_uta_tables = & ixgbe_init_uta_tables_generic ,
. setup_sfp = NULL ,
2010-12-07 08:16:45 +00:00
. set_mac_anti_spoofing = & ixgbe_set_mac_anti_spoofing ,
. set_vlan_anti_spoofing = & ixgbe_set_vlan_anti_spoofing ,
2011-02-25 01:58:04 +00:00
. acquire_swfw_sync = & ixgbe_acquire_swfw_sync_X540 ,
. release_swfw_sync = & ixgbe_release_swfw_sync_X540 ,
2012-02-18 02:58:58 +00:00
. disable_rx_buff = & ixgbe_disable_rx_buff_generic ,
. enable_rx_buff = & ixgbe_enable_rx_buff_generic ,
2012-04-12 00:33:31 +00:00
. get_thermal_sensor_data = NULL ,
. init_thermal_sensor_thresh = NULL ,
2014-02-27 20:32:41 -08:00
. prot_autoc_read = & prot_autoc_read_generic ,
. prot_autoc_write = & prot_autoc_write_generic ,
2015-03-13 13:54:30 -07:00
. enable_rx = & ixgbe_enable_rx_generic ,
. disable_rx = & ixgbe_disable_rx_generic ,
2010-11-16 19:27:16 -08:00
} ;
static struct ixgbe_eeprom_operations eeprom_ops_X540 = {
. init_params = & ixgbe_init_eeprom_params_X540 ,
. read = & ixgbe_read_eerd_X540 ,
2011-04-20 08:49:06 +00:00
. read_buffer = & ixgbe_read_eerd_buffer_X540 ,
2010-11-16 19:27:16 -08:00
. write = & ixgbe_write_eewr_X540 ,
2011-04-20 08:49:06 +00:00
. write_buffer = & ixgbe_write_eewr_buffer_X540 ,
2010-11-16 19:27:16 -08:00
. calc_checksum = & ixgbe_calc_eeprom_checksum_X540 ,
2011-03-24 00:57:50 +00:00
. validate_checksum = & ixgbe_validate_eeprom_checksum_X540 ,
2010-11-16 19:27:16 -08:00
. update_checksum = & ixgbe_update_eeprom_checksum_X540 ,
} ;
static struct ixgbe_phy_operations phy_ops_X540 = {
. identify = & ixgbe_identify_phy_generic ,
. identify_sfp = & ixgbe_identify_sfp_module_generic ,
. init = NULL ,
2011-02-18 19:29:46 +00:00
. reset = NULL ,
2010-11-16 19:27:16 -08:00
. read_reg = & ixgbe_read_phy_reg_generic ,
. write_reg = & ixgbe_write_phy_reg_generic ,
. setup_link = & ixgbe_setup_phy_link_generic ,
. setup_link_speed = & ixgbe_setup_phy_link_speed_generic ,
. read_i2c_byte = & ixgbe_read_i2c_byte_generic ,
. write_i2c_byte = & ixgbe_write_i2c_byte_generic ,
2012-12-19 07:14:17 +00:00
. read_i2c_sff8472 = & ixgbe_read_i2c_sff8472_generic ,
2010-11-16 19:27:16 -08:00
. read_i2c_eeprom = & ixgbe_read_i2c_eeprom_generic ,
. write_i2c_eeprom = & ixgbe_write_i2c_eeprom_generic ,
. check_overtemp = & ixgbe_tn_check_overtemp ,
2015-06-09 16:09:47 -07:00
. set_phy_power = & ixgbe_set_copper_phy_power ,
2011-09-21 09:02:50 +00:00
. get_firmware_version = & ixgbe_get_phy_firmware_version_generic ,
2010-11-16 19:27:16 -08:00
} ;
2015-06-09 17:15:01 -07:00
static const u32 ixgbe_mvals_X540 [ IXGBE_MVALS_IDX_LIMIT ] = {
IXGBE_MVALS_INIT ( X540 )
} ;
2010-11-16 19:27:16 -08:00
struct ixgbe_info ixgbe_X540_info = {
. mac = ixgbe_mac_X540 ,
. get_invariants = & ixgbe_get_invariants_X540 ,
. mac_ops = & mac_ops_X540 ,
. eeprom_ops = & eeprom_ops_X540 ,
. phy_ops = & phy_ops_X540 ,
. mbx_ops = & mbx_ops_generic ,
2015-06-09 17:15:01 -07:00
. mvals = ixgbe_mvals_X540 ,
2010-11-16 19:27:16 -08:00
} ;