2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								/*******************************************************************************
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  Intel  10  Gigabit  PCI  Express  Linux  driver 
							 
						 
					
						
							
								
									
										
										
										
											2014-02-27 20:32:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  Copyright ( c )  1999  -  2014  Intel  Corporation . 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07: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 > 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07: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> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-01-14 18:53:16 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  "ixgbe.h" 
  
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# include  "ixgbe_phy.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  void  ixgbe_i2c_start ( struct  ixgbe_hw  * hw ) ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  void  ixgbe_i2c_stop ( struct  ixgbe_hw  * hw ) ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  s32  ixgbe_clock_in_i2c_byte ( struct  ixgbe_hw  * hw ,  u8  * data ) ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  s32  ixgbe_clock_out_i2c_byte ( struct  ixgbe_hw  * hw ,  u8  data ) ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  s32  ixgbe_get_i2c_ack ( struct  ixgbe_hw  * hw ) ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  s32  ixgbe_clock_in_i2c_bit ( struct  ixgbe_hw  * hw ,  bool  * data ) ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  s32  ixgbe_clock_out_i2c_bit ( struct  ixgbe_hw  * hw ,  bool  data ) ;  
						 
					
						
							
								
									
										
										
										
											2011-08-27 07:18:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  void  ixgbe_raise_i2c_clk ( struct  ixgbe_hw  * hw ,  u32  * i2cctl ) ;  
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  void  ixgbe_lower_i2c_clk ( struct  ixgbe_hw  * hw ,  u32  * i2cctl ) ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  s32  ixgbe_set_i2c_data ( struct  ixgbe_hw  * hw ,  u32  * i2cctl ,  bool  data ) ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  bool  ixgbe_get_i2c_data ( u32  * i2cctl ) ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  void  ixgbe_i2c_bus_clear ( struct  ixgbe_hw  * hw ) ;  
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								static  enum  ixgbe_phy_type  ixgbe_get_phy_type_from_id ( u32  phy_id ) ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  s32  ixgbe_get_phy_id ( struct  ixgbe_hw  * hw ) ;  
						 
					
						
							
								
									
										
										
										
											2013-11-23 03:19:19 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  s32  ixgbe_identify_qsfp_module_generic ( struct  ixgbe_hw  * hw ) ;  
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   ixgbe_identify_phy_generic  -  Get  physical  layer  module 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Determines  the  physical  layer  module  found  on  the  current  adapter . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								s32  ixgbe_identify_phy_generic ( struct  ixgbe_hw  * hw )  
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  phy_addr ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-25 07:49:39 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u16  ext_ability  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( hw - > phy . type  = =  ixgbe_phy_unknown )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										for  ( phy_addr  =  0 ;  phy_addr  <  IXGBE_MAX_PHY_ADDR ;  phy_addr + + )  { 
							 
						 
					
						
							
								
									
										
										
										
											2009-07-02 12:50:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											hw - > phy . mdio . prtad  =  phy_addr ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-04-29 08:08:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											if  ( mdio45_probe ( & hw - > phy . mdio ,  phy_addr )  = =  0 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												ixgbe_get_phy_id ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . type  = 
							 
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													ixgbe_get_phy_type_from_id ( hw - > phy . id ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-25 07:49:39 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if  ( hw - > phy . type  = =  ixgbe_phy_unknown )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													hw - > phy . ops . read_reg ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															     MDIO_PMA_EXTABLE , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															     MDIO_MMD_PMAPMD , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															     & ext_ability ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													if  ( ext_ability  & 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													    ( MDIO_PMA_EXTABLE_10GBT  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													     MDIO_PMA_EXTABLE_1000BT ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														hw - > phy . type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															 ixgbe_phy_cu_unknown ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														hw - > phy . type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															 ixgbe_phy_generic ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2009-07-02 12:50:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										/* clear value if nothing found */ 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										hw - > phy . mdio . prtad  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  IXGBE_ERR_PHY_ADDR_INVALID ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-02-27 20:32:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  ixgbe_check_reset_blocked  -  check  status  of  MNG  FW  veto  bit 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  @ hw :  pointer  to  the  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  This  function  checks  the  MMNGC . MNG_VETO  bit  to  see  if  there  are 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  any  constraints  on  link  from  manageability .   For  MAC ' s  that  don ' t 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  have  this  bit  just  return  false  since  the  link  can  not  be  blocked 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  via  this  method . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
									
										
										
										
											2014-03-11 05:57:56 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								bool  ixgbe_check_reset_blocked ( struct  ixgbe_hw  * hw )  
						 
					
						
							
								
									
										
										
										
											2014-02-27 20:32:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  mmngc ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* If we don't have this bit, it can't be blocking */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( hw - > mac . type  = =  ixgbe_mac_82598EB ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  false ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									mmngc  =  IXGBE_READ_REG ( hw ,  IXGBE_MMNGC ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( mmngc  &  IXGBE_MMNGC_MNG_VETO )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw_dbg ( hw ,  " MNG_VETO bit detected. \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  false ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_get_phy_id  -  Get  the  phy  type 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  s32  ixgbe_get_phy_id ( struct  ixgbe_hw  * hw )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  status ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u16  phy_id_high  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u16  phy_id_low  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-04-29 08:08:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									status  =  hw - > phy . ops . read_reg ( hw ,  MDIO_DEVID1 ,  MDIO_MMD_PMAPMD , 
							 
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												      & phy_id_high ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( status  = =  0 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . id  =  ( u32 ) ( phy_id_high  < <  16 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-04-29 08:08:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										status  =  hw - > phy . ops . read_reg ( hw ,  MDIO_DEVID2 ,  MDIO_MMD_PMAPMD , 
							 
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													      & phy_id_low ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										hw - > phy . id  | =  ( u32 ) ( phy_id_low  &  IXGBE_PHY_REVISION_MASK ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . revision  =  ( u32 ) ( phy_id_low  &  ~ IXGBE_PHY_REVISION_MASK ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  status ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_get_phy_type_from_id  -  Get  the  phy  type 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  enum  ixgbe_phy_type  ixgbe_get_phy_type_from_id ( u32  phy_id )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									enum  ixgbe_phy_type  phy_type ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									switch  ( phy_id )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-10-31 00:46:40 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									case  TN1010_PHY_ID : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										phy_type  =  ixgbe_phy_tn ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break ; 
							 
						 
					
						
							
								
									
										
										
										
											2010-12-09 06:55:14 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									case  X540_PHY_ID : 
							 
						 
					
						
							
								
									
										
										
										
											2010-11-16 19:27:16 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										phy_type  =  ixgbe_phy_aq ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									case  QT2022_PHY_ID : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										phy_type  =  ixgbe_phy_qt ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									case  ATH_PHY_ID : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										phy_type  =  ixgbe_phy_nl ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									default : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										phy_type  =  ixgbe_phy_unknown ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  phy_type ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   ixgbe_reset_phy_generic  -  Performs  a  PHY  reset 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								s32  ixgbe_reset_phy_generic ( struct  ixgbe_hw  * hw )  
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2011-02-16 01:38:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u32  i ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u16  ctrl  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									s32  status  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( hw - > phy . type  = =  ixgbe_phy_unknown ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_identify_phy_generic ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( status  ! =  0  | |  hw - > phy . type  = =  ixgbe_phy_none ) 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  status ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-16 01:38:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-05-20 23:07:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/* Don't reset PHY if it's shut down due to overtemp. */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( ! hw - > phy . reset_if_overtemp  & & 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    ( IXGBE_ERR_OVERTEMP  = =  hw - > phy . ops . check_overtemp ( hw ) ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2010-05-20 23:07:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-02-27 20:32:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/* Blocked by MNG FW so bail */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( ixgbe_check_reset_blocked ( hw ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-02-27 20:32:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									/*
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  Perform  soft  PHY  reset  to  the  PHY_XS . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  This  will  cause  a  soft  reset  to  the  PHY 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 */ 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-16 01:38:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									hw - > phy . ops . write_reg ( hw ,  MDIO_CTRL1 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											      MDIO_MMD_PHYXS , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											      MDIO_CTRL1_RESET ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/*
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  Poll  for  reset  bit  to  self - clear  indicating  reset  is  complete . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  Some  PHYs  could  take  up  to  3  seconds  to  complete  and  need  about 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  1.7  usec  delay  after  the  reset  is  complete . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( i  =  0 ;  i  <  30 ;  i + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										msleep ( 100 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . ops . read_reg ( hw ,  MDIO_CTRL1 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     MDIO_MMD_PHYXS ,  & ctrl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ! ( ctrl  &  MDIO_CTRL1_RESET ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											udelay ( 2 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( ctrl  &  MDIO_CTRL1_RESET )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw_dbg ( hw ,  " PHY reset polling failed to complete. \n " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  IXGBE_ERR_RESET_FAILED ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-16 01:38:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_read_phy_mdi  -  Reads  a  value  from  a  specified  PHY  register  without 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   the  SWFW  lock 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ reg_addr :  32  bit  address  of  PHY  register  to  read 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ phy_data :  Pointer  to  read  data  from  PHY  register 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_read_phy_reg_mdi ( struct  ixgbe_hw  * hw ,  u32  reg_addr ,  u32  device_type ,  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										       u16  * phy_data ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  i ,  data ,  command ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Setup and write the address cycle command */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									command  =  ( ( reg_addr  < <  IXGBE_MSCA_NP_ADDR_SHIFT )   | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   ( device_type  < <  IXGBE_MSCA_DEV_TYPE_SHIFT )  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   ( hw - > phy . mdio . prtad  < <  IXGBE_MSCA_PHY_ADDR_SHIFT )  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   ( IXGBE_MSCA_ADDR_CYCLE  |  IXGBE_MSCA_MDI_COMMAND ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									IXGBE_WRITE_REG ( hw ,  IXGBE_MSCA ,  command ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Check every 10 usec to see if the address cycle completed.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  The  MDI  Command  bit  will  clear  when  the  operation  is 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  complete 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( i  =  0 ;  i  <  IXGBE_MDIO_COMMAND_TIMEOUT ;  i + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										udelay ( 10 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										command  =  IXGBE_READ_REG ( hw ,  IXGBE_MSCA ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ( command  &  IXGBE_MSCA_MDI_COMMAND )  = =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( ( command  &  IXGBE_MSCA_MDI_COMMAND )  ! =  0 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw_dbg ( hw ,  " PHY address command did not complete. \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  IXGBE_ERR_PHY ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Address cycle complete, setup and write the read
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  command 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									command  =  ( ( reg_addr  < <  IXGBE_MSCA_NP_ADDR_SHIFT )   | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   ( device_type  < <  IXGBE_MSCA_DEV_TYPE_SHIFT )  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   ( hw - > phy . mdio . prtad  < <  IXGBE_MSCA_PHY_ADDR_SHIFT )  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   ( IXGBE_MSCA_READ  |  IXGBE_MSCA_MDI_COMMAND ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									IXGBE_WRITE_REG ( hw ,  IXGBE_MSCA ,  command ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Check every 10 usec to see if the address cycle
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  completed .  The  MDI  Command  bit  will  clear  when  the 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  operation  is  complete 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( i  =  0 ;  i  <  IXGBE_MDIO_COMMAND_TIMEOUT ;  i + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										udelay ( 10 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										command  =  IXGBE_READ_REG ( hw ,  IXGBE_MSCA ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ( command  &  IXGBE_MSCA_MDI_COMMAND )  = =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( ( command  &  IXGBE_MSCA_MDI_COMMAND )  ! =  0 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw_dbg ( hw ,  " PHY read command didn't complete \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  IXGBE_ERR_PHY ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Read operation is complete.  Get the data
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  from  MSRWD 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									data  =  IXGBE_READ_REG ( hw ,  IXGBE_MSRWD ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									data  > > =  IXGBE_MSRWD_READ_DATA_SHIFT ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									* phy_data  =  ( u16 ) ( data ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   ixgbe_read_phy_reg_generic  -  Reads  a  value  from  a  specified  PHY  register 
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   using  the  SWFW  lock  -  this  function  is  needed  in  most  cases 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ reg_addr :  32  bit  address  of  PHY  register  to  read 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ phy_data :  Pointer  to  read  data  from  PHY  register 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								s32  ixgbe_read_phy_reg_generic ( struct  ixgbe_hw  * hw ,  u32  reg_addr ,  
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											       u32  device_type ,  u16  * phy_data ) 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									s32  status ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									u16  gssr ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( IXGBE_READ_REG ( hw ,  IXGBE_STATUS )  &  IXGBE_STATUS_LAN_ID_1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										gssr  =  IXGBE_GSSR_PHY1_SM ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										gssr  =  IXGBE_GSSR_PHY0_SM ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( hw - > mac . ops . acquire_swfw_sync ( hw ,  gssr )  = =  0 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_read_phy_reg_mdi ( hw ,  reg_addr ,  device_type , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														phy_data ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > mac . ops . release_swfw_sync ( hw ,  gssr ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  IXGBE_ERR_SWFW_SYNC ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									return  status ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_write_phy_reg_mdi  -  Writes  a  value  to  specified  PHY  register 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   without  SWFW  lock 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ reg_addr :  32  bit  PHY  register  to  write 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ device_type :  5  bit  device  type 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ phy_data :  Data  to  write  to  the  PHY  register 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_write_phy_reg_mdi ( struct  ixgbe_hw  * hw ,  u32  reg_addr ,  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												u32  device_type ,  u16  phy_data ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  i ,  command ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/* Put the data in the MDI single read and write data register*/ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									IXGBE_WRITE_REG ( hw ,  IXGBE_MSRWD ,  ( u32 ) phy_data ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/* Setup and write the address cycle command */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									command  =  ( ( reg_addr  < <  IXGBE_MSCA_NP_ADDR_SHIFT )   | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   ( device_type  < <  IXGBE_MSCA_DEV_TYPE_SHIFT )  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   ( hw - > phy . mdio . prtad  < <  IXGBE_MSCA_PHY_ADDR_SHIFT )  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   ( IXGBE_MSCA_ADDR_CYCLE  |  IXGBE_MSCA_MDI_COMMAND ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									IXGBE_WRITE_REG ( hw ,  IXGBE_MSCA ,  command ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/*
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  Check  every  10  usec  to  see  if  the  address  cycle  completed . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  The  MDI  Command  bit  will  clear  when  the  operation  is 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  complete 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( i  =  0 ;  i  <  IXGBE_MDIO_COMMAND_TIMEOUT ;  i + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										udelay ( 10 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										command  =  IXGBE_READ_REG ( hw ,  IXGBE_MSCA ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ( command  &  IXGBE_MSCA_MDI_COMMAND )  = =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( ( command  &  IXGBE_MSCA_MDI_COMMAND )  ! =  0 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw_dbg ( hw ,  " PHY address cmd didn't complete \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  IXGBE_ERR_PHY ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/*
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  Address  cycle  complete ,  setup  and  write  the  write 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  command 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									command  =  ( ( reg_addr  < <  IXGBE_MSCA_NP_ADDR_SHIFT )   | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   ( device_type  < <  IXGBE_MSCA_DEV_TYPE_SHIFT )  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   ( hw - > phy . mdio . prtad  < <  IXGBE_MSCA_PHY_ADDR_SHIFT )  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   ( IXGBE_MSCA_WRITE  |  IXGBE_MSCA_MDI_COMMAND ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									IXGBE_WRITE_REG ( hw ,  IXGBE_MSCA ,  command ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Check every 10 usec to see if the address cycle
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  completed .  The  MDI  Command  bit  will  clear  when  the 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  operation  is  complete 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( i  =  0 ;  i  <  IXGBE_MDIO_COMMAND_TIMEOUT ;  i + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										udelay ( 10 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										command  =  IXGBE_READ_REG ( hw ,  IXGBE_MSCA ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ( command  &  IXGBE_MSCA_MDI_COMMAND )  = =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( ( command  &  IXGBE_MSCA_MDI_COMMAND )  ! =  0 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw_dbg ( hw ,  " PHY write cmd didn't complete \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  IXGBE_ERR_PHY ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   ixgbe_write_phy_reg_generic  -  Writes  a  value  to  specified  PHY  register 
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   using  SWFW  lock -  this  function  is  needed  in  most  cases 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ reg_addr :  32  bit  PHY  register  to  write 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ device_type :  5  bit  device  type 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ phy_data :  Data  to  write  to  the  PHY  register 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								s32  ixgbe_write_phy_reg_generic ( struct  ixgbe_hw  * hw ,  u32  reg_addr ,  
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												u32  device_type ,  u16  phy_data ) 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									s32  status ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									u16  gssr ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( IXGBE_READ_REG ( hw ,  IXGBE_STATUS )  &  IXGBE_STATUS_LAN_ID_1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										gssr  =  IXGBE_GSSR_PHY1_SM ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										gssr  =  IXGBE_GSSR_PHY0_SM ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( hw - > mac . ops . acquire_swfw_sync ( hw ,  gssr )  = =  0 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_write_phy_reg_mdi ( hw ,  reg_addr ,  device_type , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														 phy_data ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-25 01:58:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										hw - > mac . ops . release_swfw_sync ( hw ,  gssr ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-05-29 06:23:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  IXGBE_ERR_SWFW_SYNC ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  status ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   ixgbe_setup_phy_link_generic  -  Set  and  restart  autoneg 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Restart  autonegotiation  and  PHY  and  waits  for  completion . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								s32  ixgbe_setup_phy_link_generic ( struct  ixgbe_hw  * hw )  
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									s32  status  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									u32  time_out ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  max_time_out  =  10 ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u16  autoneg_reg  =  IXGBE_MII_AUTONEG_REG ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									bool  autoneg  =  false ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ixgbe_link_speed  speed ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ixgbe_get_copper_link_capabilities_generic ( hw ,  & speed ,  & autoneg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( speed  &  IXGBE_LINK_SPEED_10GB_FULL )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* Set or unset auto-negotiation 10G advertisement */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . ops . read_reg ( hw ,  MDIO_AN_10GBT_CTRL , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     MDIO_MMD_AN , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     & autoneg_reg ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-04-29 08:08:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										autoneg_reg  & =  ~ MDIO_AN_10GBT_CTRL_ADV10G ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( hw - > phy . autoneg_advertised  &  IXGBE_LINK_SPEED_10GB_FULL ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											autoneg_reg  | =  MDIO_AN_10GBT_CTRL_ADV10G ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										hw - > phy . ops . write_reg ( hw ,  MDIO_AN_10GBT_CTRL , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      MDIO_MMD_AN , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      autoneg_reg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( speed  &  IXGBE_LINK_SPEED_1GB_FULL )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* Set or unset auto-negotiation 1G advertisement */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . ops . read_reg ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     IXGBE_MII_AUTONEG_VENDOR_PROVISION_1_REG , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     MDIO_MMD_AN , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     & autoneg_reg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										autoneg_reg  & =  ~ IXGBE_MII_1GBASE_T_ADVERTISE ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( hw - > phy . autoneg_advertised  &  IXGBE_LINK_SPEED_1GB_FULL ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											autoneg_reg  | =  IXGBE_MII_1GBASE_T_ADVERTISE ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . ops . write_reg ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      IXGBE_MII_AUTONEG_VENDOR_PROVISION_1_REG , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      MDIO_MMD_AN , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      autoneg_reg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( speed  &  IXGBE_LINK_SPEED_100_FULL )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* Set or unset auto-negotiation 100M advertisement */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . ops . read_reg ( hw ,  MDIO_AN_ADVERTISE , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     MDIO_MMD_AN , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     & autoneg_reg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-03-31 09:36:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										autoneg_reg  & =  ~ ( ADVERTISE_100FULL  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												 ADVERTISE_100HALF ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( hw - > phy . autoneg_advertised  &  IXGBE_LINK_SPEED_100_FULL ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											autoneg_reg  | =  ADVERTISE_100FULL ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . ops . write_reg ( hw ,  MDIO_AN_ADVERTISE , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      MDIO_MMD_AN , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      autoneg_reg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-02-27 20:32:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/* Blocked by MNG FW so don't reset PHY */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( ixgbe_check_reset_blocked ( hw ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-02-27 20:32:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									/* Restart PHY autonegotiation and wait for completion */ 
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									hw - > phy . ops . read_reg ( hw ,  MDIO_CTRL1 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											     MDIO_MMD_AN ,  & autoneg_reg ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-04-29 08:08:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									autoneg_reg  | =  MDIO_AN_CTRL1_RESTART ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									hw - > phy . ops . write_reg ( hw ,  MDIO_CTRL1 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											      MDIO_MMD_AN ,  autoneg_reg ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Wait for autonegotiation to finish */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( time_out  =  0 ;  time_out  <  max_time_out ;  time_out + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										udelay ( 10 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* Restart PHY autonegotiation and wait for completion */ 
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										status  =  hw - > phy . ops . read_reg ( hw ,  MDIO_STAT1 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													      MDIO_MMD_AN , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													      & autoneg_reg ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-04-29 08:08:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										autoneg_reg  & =  MDIO_AN_STAT1_COMPLETE ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( autoneg_reg  = =  MDIO_AN_STAT1_COMPLETE )  { 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( time_out  = =  max_time_out )  { 
							 
						 
					
						
							
								
									
										
										
										
											2014-04-02 10:33:22 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										hw_dbg ( hw ,  " ixgbe_setup_phy_link_generic: time out \n " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  IXGBE_ERR_LINK_SETUP ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  status ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   ixgbe_setup_phy_link_speed_generic  -  Sets  the  auto  advertised  capabilities 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ speed :  new  link  speed 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								s32  ixgbe_setup_phy_link_speed_generic ( struct  ixgbe_hw  * hw ,  
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												       ixgbe_link_speed  speed , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												       bool  autoneg_wait_to_complete ) 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									/*
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  Clear  autoneg_advertised  and  set  new  values  based  on  input  link 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  speed . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									hw - > phy . autoneg_advertised  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( speed  &  IXGBE_LINK_SPEED_10GB_FULL ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . autoneg_advertised  | =  IXGBE_LINK_SPEED_10GB_FULL ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									if  ( speed  &  IXGBE_LINK_SPEED_1GB_FULL ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . autoneg_advertised  | =  IXGBE_LINK_SPEED_1GB_FULL ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( speed  &  IXGBE_LINK_SPEED_100_FULL ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . autoneg_advertised  | =  IXGBE_LINK_SPEED_100_FULL ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									/* Setup link based on the new speed settings */ 
							 
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									hw - > phy . ops . setup_link ( hw ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-15 14:07:45 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
									
										
										
										
											2008-09-11 19:59:59 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-11-16 19:27:15 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  ixgbe_get_copper_link_capabilities_generic  -  Determines  link  capabilities 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  @ speed :  pointer  to  link  speed 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  @ autoneg :  boolean  auto - negotiation  value 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  Determines  the  link  capabilities  by  reading  the  AUTOC  register . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_get_copper_link_capabilities_generic ( struct  ixgbe_hw  * hw ,  
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													       ixgbe_link_speed  * speed , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													       bool  * autoneg ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-11-16 19:27:15 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									s32  status ; 
							 
						 
					
						
							
								
									
										
										
										
											2010-11-16 19:27:15 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u16  speed_ability ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									* speed  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									* autoneg  =  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									status  =  hw - > phy . ops . read_reg ( hw ,  MDIO_SPEED ,  MDIO_MMD_PMAPMD , 
							 
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												      & speed_ability ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2010-11-16 19:27:15 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( status  = =  0 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( speed_ability  &  MDIO_SPEED_10G ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											* speed  | =  IXGBE_LINK_SPEED_10GB_FULL ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( speed_ability  &  MDIO_PMA_SPEED_1000 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											* speed  | =  IXGBE_LINK_SPEED_1GB_FULL ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( speed_ability  &  MDIO_PMA_SPEED_100 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											* speed  | =  IXGBE_LINK_SPEED_100_FULL ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  status ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_check_phy_link_tnx  -  Determine  link  and  speed  status 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Reads  the  VS1  register  to  determine  if  link  is  up  and  the  current  speed  for 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   the  PHY . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_check_phy_link_tnx ( struct  ixgbe_hw  * hw ,  ixgbe_link_speed  * speed ,  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											     bool  * link_up ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									s32  status ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u32  time_out ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  max_time_out  =  10 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u16  phy_link  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u16  phy_speed  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u16  phy_data  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Initialize speed and link to default case */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									* link_up  =  false ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									* speed  =  IXGBE_LINK_SPEED_10GB_FULL ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/*
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  Check  current  speed  and  link  status  of  the  PHY  register . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  This  is  a  vendor  specific  register  and  may  have  to 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  be  changed  for  other  copper  PHYs . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( time_out  =  0 ;  time_out  <  max_time_out ;  time_out + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										udelay ( 10 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  hw - > phy . ops . read_reg ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													      MDIO_STAT1 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													      MDIO_MMD_VEND1 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													      & phy_data ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										phy_link  =  phy_data  & 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											    IXGBE_MDIO_VENDOR_SPECIFIC_1_LINK_STATUS ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										phy_speed  =  phy_data  & 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											    IXGBE_MDIO_VENDOR_SPECIFIC_1_SPEED_STATUS ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( phy_link  = =  IXGBE_MDIO_VENDOR_SPECIFIC_1_LINK_STATUS )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											* link_up  =  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( phy_speed  = = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											    IXGBE_MDIO_VENDOR_SPECIFIC_1_SPEED_STATUS ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												* speed  =  IXGBE_LINK_SPEED_1GB_FULL ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  status ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 	ixgbe_setup_phy_link_tnx  -  Set  and  restart  autoneg 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 	@ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 	Restart  autonegotiation  and  PHY  and  waits  for  completion . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_setup_phy_link_tnx ( struct  ixgbe_hw  * hw )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									s32  status ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u32  time_out ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  max_time_out  =  10 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u16  autoneg_reg  =  IXGBE_MII_AUTONEG_REG ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									bool  autoneg  =  false ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ixgbe_link_speed  speed ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ixgbe_get_copper_link_capabilities_generic ( hw ,  & speed ,  & autoneg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( speed  &  IXGBE_LINK_SPEED_10GB_FULL )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* Set or unset auto-negotiation 10G advertisement */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . ops . read_reg ( hw ,  MDIO_AN_10GBT_CTRL , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     MDIO_MMD_AN , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     & autoneg_reg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										autoneg_reg  & =  ~ MDIO_AN_10GBT_CTRL_ADV10G ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( hw - > phy . autoneg_advertised  &  IXGBE_LINK_SPEED_10GB_FULL ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											autoneg_reg  | =  MDIO_AN_10GBT_CTRL_ADV10G ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . ops . write_reg ( hw ,  MDIO_AN_10GBT_CTRL , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      MDIO_MMD_AN , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      autoneg_reg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( speed  &  IXGBE_LINK_SPEED_1GB_FULL )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* Set or unset auto-negotiation 1G advertisement */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . ops . read_reg ( hw ,  IXGBE_MII_AUTONEG_XNP_TX_REG , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     MDIO_MMD_AN , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     & autoneg_reg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										autoneg_reg  & =  ~ IXGBE_MII_1GBASE_T_ADVERTISE_XNP_TX ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( hw - > phy . autoneg_advertised  &  IXGBE_LINK_SPEED_1GB_FULL ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											autoneg_reg  | =  IXGBE_MII_1GBASE_T_ADVERTISE_XNP_TX ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . ops . write_reg ( hw ,  IXGBE_MII_AUTONEG_XNP_TX_REG , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      MDIO_MMD_AN , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      autoneg_reg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( speed  &  IXGBE_LINK_SPEED_100_FULL )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* Set or unset auto-negotiation 100M advertisement */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . ops . read_reg ( hw ,  MDIO_AN_ADVERTISE , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     MDIO_MMD_AN , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     & autoneg_reg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-03-31 09:36:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										autoneg_reg  & =  ~ ( ADVERTISE_100FULL  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												 ADVERTISE_100HALF ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( hw - > phy . autoneg_advertised  &  IXGBE_LINK_SPEED_100_FULL ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											autoneg_reg  | =  ADVERTISE_100FULL ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . ops . write_reg ( hw ,  MDIO_AN_ADVERTISE , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      MDIO_MMD_AN , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      autoneg_reg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-02-27 20:32:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/* Blocked by MNG FW so don't reset PHY */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( ixgbe_check_reset_blocked ( hw ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-02-27 20:32:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/* Restart PHY autonegotiation and wait for completion */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									hw - > phy . ops . read_reg ( hw ,  MDIO_CTRL1 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											     MDIO_MMD_AN ,  & autoneg_reg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									autoneg_reg  | =  MDIO_AN_CTRL1_RESTART ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									hw - > phy . ops . write_reg ( hw ,  MDIO_CTRL1 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											      MDIO_MMD_AN ,  autoneg_reg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Wait for autonegotiation to finish */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( time_out  =  0 ;  time_out  <  max_time_out ;  time_out + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										udelay ( 10 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* Restart PHY autonegotiation and wait for completion */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  hw - > phy . ops . read_reg ( hw ,  MDIO_STAT1 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													      MDIO_MMD_AN , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													      & autoneg_reg ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										autoneg_reg  & =  MDIO_AN_STAT1_COMPLETE ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( autoneg_reg  = =  MDIO_AN_STAT1_COMPLETE ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( time_out  = =  max_time_out )  { 
							 
						 
					
						
							
								
									
										
										
										
											2014-04-02 10:33:22 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										hw_dbg ( hw ,  " ixgbe_setup_phy_link_tnx: time out \n " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  IXGBE_ERR_LINK_SETUP ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  status ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_get_phy_firmware_version_tnx  -  Gets  the  PHY  Firmware  Version 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ firmware_version :  pointer  to  the  PHY  Firmware  Version 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_get_phy_firmware_version_tnx ( struct  ixgbe_hw  * hw ,  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												       u16  * firmware_version ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									s32  status ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									status  =  hw - > phy . ops . read_reg ( hw ,  TNX_FW_REV , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      MDIO_MMD_VEND1 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      firmware_version ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  status ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_get_phy_firmware_version_generic  -  Gets  the  PHY  Firmware  Version 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ firmware_version :  pointer  to  the  PHY  Firmware  Version 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_get_phy_firmware_version_generic ( struct  ixgbe_hw  * hw ,  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													   u16  * firmware_version ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									s32  status ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-03-05 01:28:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									status  =  hw - > phy . ops . read_reg ( hw ,  AQ_FW_REV , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      MDIO_MMD_VEND1 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												      firmware_version ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  status ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_reset_phy_nl  -  Performs  a  PHY  reset 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_reset_phy_nl ( struct  ixgbe_hw  * hw )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u16  phy_offset ,  control ,  eword ,  edata ,  block_crc ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									bool  end_data  =  false ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u16  list_offset ,  data_offset ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u16  phy_data  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									s32  ret_val ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u32  i ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-02-27 20:32:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/* Blocked by MNG FW so bail */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( ixgbe_check_reset_blocked ( hw ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-02-27 20:32:43 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-04-29 08:08:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									hw - > phy . ops . read_reg ( hw ,  MDIO_CTRL1 ,  MDIO_MMD_PHYXS ,  & phy_data ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* reset the PHY and poll for completion */ 
							 
						 
					
						
							
								
									
										
										
										
											2009-04-29 08:08:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									hw - > phy . ops . write_reg ( hw ,  MDIO_CTRL1 ,  MDIO_MMD_PHYXS , 
							 
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											      ( phy_data  |  MDIO_CTRL1_RESET ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( i  =  0 ;  i  <  100 ;  i + + )  { 
							 
						 
					
						
							
								
									
										
										
										
											2009-04-29 08:08:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										hw - > phy . ops . read_reg ( hw ,  MDIO_CTRL1 ,  MDIO_MMD_PHYXS , 
							 
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												     & phy_data ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-04-29 08:08:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( ( phy_data  &  MDIO_CTRL1_RESET )  = =  0 ) 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-03-18 09:32:53 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										usleep_range ( 10000 ,  20000 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-04-29 08:08:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( ( phy_data  &  MDIO_CTRL1_RESET )  ! =  0 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										hw_dbg ( hw ,  " PHY reset did not complete. \n " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  IXGBE_ERR_PHY ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Get init offsets */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ret_val  =  ixgbe_get_sfp_init_sequence_offsets ( hw ,  & list_offset , 
							 
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														      & data_offset ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( ret_val ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  ret_val ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ret_val  =  hw - > eeprom . ops . read ( hw ,  data_offset ,  & block_crc ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									data_offset + + ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									while  ( ! end_data )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/*
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										 *  Read  control  word  from  PHY  init  contents  offset 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ret_val  =  hw - > eeprom . ops . read ( hw ,  data_offset ,  & eword ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-05-24 07:31:09 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( ret_val ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  err_eeprom ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										control  =  ( eword  &  IXGBE_CONTROL_MASK_NL )  > > 
							 
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											   IXGBE_CONTROL_SHIFT_NL ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										edata  =  eword  &  IXGBE_DATA_MASK_NL ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										switch  ( control )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										case  IXGBE_DELAY_NL : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											data_offset + + ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw_dbg ( hw ,  " DELAY: %d MS \n " ,  edata ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-03-18 09:32:53 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											usleep_range ( edata  *  1000 ,  edata  *  2000 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										case  IXGBE_DATA_NL : 
							 
						 
					
						
							
								
									
										
										
										
											2010-03-24 07:57:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											hw_dbg ( hw ,  " DATA: \n " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											data_offset + + ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-05-24 07:31:09 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											ret_val  =  hw - > eeprom . ops . read ( hw ,  data_offset + + , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														      & phy_offset ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( ret_val ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												goto  err_eeprom ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											for  ( i  =  0 ;  i  <  edata ;  i + + )  { 
							 
						 
					
						
							
								
									
										
										
										
											2013-05-24 07:31:09 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												ret_val  =  hw - > eeprom . ops . read ( hw ,  data_offset , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															      & eword ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if  ( ret_val ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													goto  err_eeprom ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												hw - > phy . ops . write_reg ( hw ,  phy_offset , 
							 
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														      MDIO_MMD_PMAPMD ,  eword ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												hw_dbg ( hw ,  " Wrote %4.4x to %4.4x \n " ,  eword , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												       phy_offset ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												data_offset + + ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												phy_offset + + ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										case  IXGBE_CONTROL_NL : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											data_offset + + ; 
							 
						 
					
						
							
								
									
										
										
										
											2010-03-24 07:57:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											hw_dbg ( hw ,  " CONTROL: \n " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											if  ( edata  = =  IXGBE_CONTROL_EOL_NL )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw_dbg ( hw ,  " EOL \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												end_data  =  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}  else  if  ( edata  = =  IXGBE_CONTROL_SOL_NL )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw_dbg ( hw ,  " SOL \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw_dbg ( hw ,  " Bad control value \n " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												return  IXGBE_ERR_PHY ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										default : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw_dbg ( hw ,  " Bad control type \n " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											return  IXGBE_ERR_PHY ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  ret_val ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-05-24 07:31:09 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								err_eeprom :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									hw_err ( hw ,  " eeprom read at offset %d failed \n " ,  data_offset ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  IXGBE_ERR_PHY ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   ixgbe_identify_module_generic  -  Identifies  module  type 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   Determines  HW  type  and  calls  appropriate  function . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_identify_module_generic ( struct  ixgbe_hw  * hw )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									switch  ( hw - > mac . ops . get_media_type ( hw ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									case  ixgbe_media_type_fiber : 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  ixgbe_identify_sfp_module_generic ( hw ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									case  ixgbe_media_type_fiber_qsfp : 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  ixgbe_identify_qsfp_module_generic ( hw ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									default : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . sfp_type  =  ixgbe_sfp_type_not_present ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  IXGBE_ERR_SFP_NOT_PRESENT ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									return  IXGBE_ERR_SFP_NOT_PRESENT ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_identify_sfp_module_generic  -  Identifies  SFP  modules 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-16 10:14:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   Searches  for  and  identifies  the  SFP  module  and  assigns  appropriate  PHY  type . 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_identify_sfp_module_generic ( struct  ixgbe_hw  * hw )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2012-02-01 09:19:21 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									struct  ixgbe_adapter  * adapter  =  hw - > back ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									s32  status ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u32  vendor_oui  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-04-09 22:28:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									enum  ixgbe_sfp_type  stored_sfp_type  =  hw - > phy . sfp_type ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u8  identifier  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u8  comp_codes_1g  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u8  comp_codes_10g  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u8  oui_bytes [ 3 ]  =  { 0 ,  0 ,  0 } ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-05-19 09:18:51 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u8  cable_tech  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2010-05-18 16:00:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u8  cable_spec  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u16  enforce_sfp  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-05-26 20:40:47 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( hw - > mac . ops . get_media_type ( hw )  ! =  ixgbe_media_type_fiber )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . sfp_type  =  ixgbe_sfp_type_not_present ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  IXGBE_ERR_SFP_NOT_PRESENT ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-05-26 20:40:47 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-16 10:14:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									status  =  hw - > phy . ops . read_i2c_eeprom ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													     IXGBE_SFF_IDENTIFIER , 
							 
						 
					
						
							
								
									
										
										
										
											2013-01-18 02:17:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													     & identifier ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( status ) 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-16 10:14:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										goto  err_read_i2c_eeprom ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-16 10:14:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/* LAN ID is needed for sfp_type determination */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									hw - > mac . ops . set_lan_id ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( identifier  ! =  IXGBE_SFF_IDENTIFIER_SFP )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . type  =  ixgbe_phy_sfp_unsupported ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  IXGBE_ERR_SFP_NOT_SUPPORTED ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									status  =  hw - > phy . ops . read_i2c_eeprom ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													     IXGBE_SFF_1GBE_COMP_CODES , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													     & comp_codes_1g ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-16 10:14:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( status ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										goto  err_read_i2c_eeprom ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-16 10:14:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									status  =  hw - > phy . ops . read_i2c_eeprom ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													     IXGBE_SFF_10GBE_COMP_CODES , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													     & comp_codes_10g ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-16 10:14:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( status ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										goto  err_read_i2c_eeprom ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									status  =  hw - > phy . ops . read_i2c_eeprom ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													     IXGBE_SFF_CABLE_TECHNOLOGY , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													     & cable_tech ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-16 10:14:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( status ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										goto  err_read_i2c_eeprom ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-16 10:14:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									 /* ID Module
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  *  = = = = = = = = = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  *  0    SFP_DA_CU 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  *  1    SFP_SR 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  *  2    SFP_LR 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  *  3    SFP_DA_CORE0  -  82599 - specific 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  *  4    SFP_DA_CORE1  -  82599 - specific 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  *  5    SFP_SR / LR_CORE0  -  82599 - specific 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  *  6    SFP_SR / LR_CORE1  -  82599 - specific 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  *  7    SFP_act_lmt_DA_CORE0  -  82599 - specific 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  *  8    SFP_act_lmt_DA_CORE1  -  82599 - specific 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  *  9    SFP_1g_cu_CORE0  -  82599 - specific 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  *  10   SFP_1g_cu_CORE1  -  82599 - specific 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  *  11   SFP_1g_sx_CORE0  -  82599 - specific 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  *  12   SFP_1g_sx_CORE1  -  82599 - specific 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									  */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( hw - > mac . type  = =  ixgbe_mac_82598EB )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( cable_tech  &  IXGBE_SFF_DA_PASSIVE_CABLE ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . sfp_type  =  ixgbe_sfp_type_da_cu ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										else  if  ( comp_codes_10g  &  IXGBE_SFF_10GBASESR_CAPABLE ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . sfp_type  =  ixgbe_sfp_type_sr ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										else  if  ( comp_codes_10g  &  IXGBE_SFF_10GBASELR_CAPABLE ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . sfp_type  =  ixgbe_sfp_type_lr ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . sfp_type  =  ixgbe_sfp_type_unknown ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									}  else  if  ( hw - > mac . type  = =  ixgbe_mac_82599EB )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( cable_tech  &  IXGBE_SFF_DA_PASSIVE_CABLE )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( hw - > bus . lan_id  = =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . sfp_type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													     ixgbe_sfp_type_da_cu_core0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											else 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												hw - > phy . sfp_type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													     ixgbe_sfp_type_da_cu_core1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}  else  if  ( cable_tech  &  IXGBE_SFF_DA_ACTIVE_CABLE )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . ops . read_i2c_eeprom ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													hw ,  IXGBE_SFF_CABLE_SPEC_COMP , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													& cable_spec ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( cable_spec  & 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											    IXGBE_SFF_DA_SPEC_ACTIVE_LIMITING )  { 
							 
						 
					
						
							
								
									
										
										
										
											2013-04-11 06:23:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												if  ( hw - > bus . lan_id  = =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													hw - > phy . sfp_type  = 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													ixgbe_sfp_type_da_act_lmt_core0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-04-11 06:23:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													hw - > phy . sfp_type  = 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													ixgbe_sfp_type_da_act_lmt_core1 ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-16 10:14:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												hw - > phy . sfp_type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														ixgbe_sfp_type_unknown ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-16 10:14:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										}  else  if  ( comp_codes_10g  & 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											   ( IXGBE_SFF_10GBASESR_CAPABLE  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											    IXGBE_SFF_10GBASELR_CAPABLE ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( hw - > bus . lan_id  = =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . sfp_type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													      ixgbe_sfp_type_srlr_core0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . sfp_type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													      ixgbe_sfp_type_srlr_core1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}  else  if  ( comp_codes_1g  &  IXGBE_SFF_1GBASET_CAPABLE )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( hw - > bus . lan_id  = =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . sfp_type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													ixgbe_sfp_type_1g_cu_core0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . sfp_type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													ixgbe_sfp_type_1g_cu_core1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}  else  if  ( comp_codes_1g  &  IXGBE_SFF_1GBASESX_CAPABLE )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( hw - > bus . lan_id  = =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . sfp_type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													ixgbe_sfp_type_1g_sx_core0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . sfp_type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													ixgbe_sfp_type_1g_sx_core1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}  else  if  ( comp_codes_1g  &  IXGBE_SFF_1GBASELX_CAPABLE )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( hw - > bus . lan_id  = =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . sfp_type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													ixgbe_sfp_type_1g_lx_core0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . sfp_type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													ixgbe_sfp_type_1g_lx_core1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . sfp_type  =  ixgbe_sfp_type_unknown ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( hw - > phy . sfp_type  ! =  stored_sfp_type ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . sfp_setup_needed  =  true ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-04-23 11:31:37 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/* Determine if the SFP+ PHY is dual speed or not. */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									hw - > phy . multispeed_fiber  =  false ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( ( ( comp_codes_1g  &  IXGBE_SFF_1GBASESX_CAPABLE )  & & 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									     ( comp_codes_10g  &  IXGBE_SFF_10GBASESR_CAPABLE ) )  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    ( ( comp_codes_1g  &  IXGBE_SFF_1GBASELX_CAPABLE )  & & 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									     ( comp_codes_10g  &  IXGBE_SFF_10GBASELR_CAPABLE ) ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . multispeed_fiber  =  true ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-04-23 11:31:37 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/* Determine PHY vendor */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( hw - > phy . type  ! =  ixgbe_phy_nl )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . id  =  identifier ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  hw - > phy . ops . read_i2c_eeprom ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													    IXGBE_SFF_VENDOR_OUI_BYTE0 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													    & oui_bytes [ 0 ] ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-04-23 11:31:37 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  err_read_i2c_eeprom ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										status  =  hw - > phy . ops . read_i2c_eeprom ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													    IXGBE_SFF_VENDOR_OUI_BYTE1 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													    & oui_bytes [ 1 ] ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  err_read_i2c_eeprom ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  hw - > phy . ops . read_i2c_eeprom ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													    IXGBE_SFF_VENDOR_OUI_BYTE2 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													    & oui_bytes [ 2 ] ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  err_read_i2c_eeprom ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										vendor_oui  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										  ( ( oui_bytes [ 0 ]  < <  IXGBE_SFF_VENDOR_OUI_BYTE0_SHIFT )  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   ( oui_bytes [ 1 ]  < <  IXGBE_SFF_VENDOR_OUI_BYTE1_SHIFT )  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   ( oui_bytes [ 2 ]  < <  IXGBE_SFF_VENDOR_OUI_BYTE2_SHIFT ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										switch  ( vendor_oui )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										case  IXGBE_SFF_VENDOR_OUI_TYCO : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( cable_tech  &  IXGBE_SFF_DA_PASSIVE_CABLE ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													    ixgbe_phy_sfp_passive_tyco ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										case  IXGBE_SFF_VENDOR_OUI_FTL : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( cable_tech  &  IXGBE_SFF_DA_ACTIVE_CABLE ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . type  =  ixgbe_phy_sfp_ftl_active ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . type  =  ixgbe_phy_sfp_ftl ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										case  IXGBE_SFF_VENDOR_OUI_AVAGO : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . type  =  ixgbe_phy_sfp_avago ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										case  IXGBE_SFF_VENDOR_OUI_INTEL : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . type  =  ixgbe_phy_sfp_intel ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										default : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( cable_tech  &  IXGBE_SFF_DA_PASSIVE_CABLE ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													 ixgbe_phy_sfp_passive_unknown ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											else  if  ( cable_tech  &  IXGBE_SFF_DA_ACTIVE_CABLE ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													ixgbe_phy_sfp_active_unknown ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . type  =  ixgbe_phy_sfp_unknown ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/* Allow any DA cable vendor */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( cable_tech  &  ( IXGBE_SFF_DA_PASSIVE_CABLE  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    IXGBE_SFF_DA_ACTIVE_CABLE ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Verify supported 1G SFP modules */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( comp_codes_10g  = =  0  & & 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    ! ( hw - > phy . sfp_type  = =  ixgbe_sfp_type_1g_cu_core1  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									      hw - > phy . sfp_type  = =  ixgbe_sfp_type_1g_cu_core0  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									      hw - > phy . sfp_type  = =  ixgbe_sfp_type_1g_lx_core0  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									      hw - > phy . sfp_type  = =  ixgbe_sfp_type_1g_lx_core1  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									      hw - > phy . sfp_type  = =  ixgbe_sfp_type_1g_sx_core0  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									      hw - > phy . sfp_type  = =  ixgbe_sfp_type_1g_sx_core1 ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . type  =  ixgbe_phy_sfp_unsupported ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  IXGBE_ERR_SFP_NOT_SUPPORTED ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Anything else 82598-based is supported */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( hw - > mac . type  = =  ixgbe_mac_82598EB ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									hw - > mac . ops . get_device_caps ( hw ,  & enforce_sfp ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( ! ( enforce_sfp  &  IXGBE_DEVICE_CAPS_ALLOW_ANY_SFP )  & & 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    ! ( hw - > phy . sfp_type  = =  ixgbe_sfp_type_1g_cu_core0  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									      hw - > phy . sfp_type  = =  ixgbe_sfp_type_1g_cu_core1  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									      hw - > phy . sfp_type  = =  ixgbe_sfp_type_1g_lx_core0  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									      hw - > phy . sfp_type  = =  ixgbe_sfp_type_1g_lx_core1  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									      hw - > phy . sfp_type  = =  ixgbe_sfp_type_1g_sx_core0  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									      hw - > phy . sfp_type  = =  ixgbe_sfp_type_1g_sx_core1 ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* Make sure we're a supported PHY type */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( hw - > phy . type  = =  ixgbe_phy_sfp_intel ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( hw - > allow_unsupported_sfp )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											e_warn ( drv ,  " WARNING: Intel (R) Network Connections are quality tested using Intel (R) Ethernet Optics.  Using untested modules is not supported and may cause unstable operation or damage to the module or the adapter.  Intel Corporation is not responsible for any harm caused by using untested modules. \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw_dbg ( hw ,  " SFP+ module not supported \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . type  =  ixgbe_phy_sfp_unsupported ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  IXGBE_ERR_SFP_NOT_SUPPORTED ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-16 10:14:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								err_read_i2c_eeprom :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									hw - > phy . sfp_type  =  ixgbe_sfp_type_not_present ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( hw - > phy . type  ! =  ixgbe_phy_nl )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . id  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . type  =  ixgbe_phy_unknown ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  IXGBE_ERR_SFP_NOT_PRESENT ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  ixgbe_identify_qsfp_module_generic  -  Identifies  QSFP  modules 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  Searches  for  and  identifies  the  QSFP  module  and  assigns  appropriate  PHY  type 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
									
										
										
										
											2013-11-23 03:19:19 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  s32  ixgbe_identify_qsfp_module_generic ( struct  ixgbe_hw  * hw )  
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									struct  ixgbe_adapter  * adapter  =  hw - > back ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									s32  status ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u32  vendor_oui  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									enum  ixgbe_sfp_type  stored_sfp_type  =  hw - > phy . sfp_type ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u8  identifier  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u8  comp_codes_1g  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u8  comp_codes_10g  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u8  oui_bytes [ 3 ]  =  { 0 ,  0 ,  0 } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u16  enforce_sfp  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-08-16 23:11:14 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u8  connector  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u8  cable_length  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u8  device_tech  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									bool  active_cable  =  false ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( hw - > mac . ops . get_media_type ( hw )  ! =  ixgbe_media_type_fiber_qsfp )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . sfp_type  =  ixgbe_sfp_type_not_present ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  IXGBE_ERR_SFP_NOT_PRESENT ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									status  =  hw - > phy . ops . read_i2c_eeprom ( hw ,  IXGBE_SFF_IDENTIFIER , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													     & identifier ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										goto  err_read_i2c_eeprom ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( identifier  ! =  IXGBE_SFF_IDENTIFIER_QSFP_PLUS )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . type  =  ixgbe_phy_sfp_unsupported ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  IXGBE_ERR_SFP_NOT_SUPPORTED ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									hw - > phy . id  =  identifier ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* LAN ID is needed for sfp_type determination */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									hw - > mac . ops . set_lan_id ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									status  =  hw - > phy . ops . read_i2c_eeprom ( hw ,  IXGBE_SFF_QSFP_10GBE_COMP , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													     & comp_codes_10g ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										goto  err_read_i2c_eeprom ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2013-08-13 07:22:16 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									status  =  hw - > phy . ops . read_i2c_eeprom ( hw ,  IXGBE_SFF_QSFP_1GBE_COMP , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													     & comp_codes_1g ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										goto  err_read_i2c_eeprom ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( comp_codes_10g  &  IXGBE_SFF_QSFP_DA_PASSIVE_CABLE )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . type  =  ixgbe_phy_qsfp_passive_unknown ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( hw - > bus . lan_id  = =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . sfp_type  =  ixgbe_sfp_type_da_cu_core0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . sfp_type  =  ixgbe_sfp_type_da_cu_core1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									}  else  if  ( comp_codes_10g  &  ( IXGBE_SFF_10GBASESR_CAPABLE  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     IXGBE_SFF_10GBASELR_CAPABLE ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( hw - > bus . lan_id  = =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . sfp_type  =  ixgbe_sfp_type_srlr_core0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . sfp_type  =  ixgbe_sfp_type_srlr_core1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2013-08-16 23:11:14 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( comp_codes_10g  &  IXGBE_SFF_QSFP_DA_ACTIVE_CABLE ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											active_cable  =  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ! active_cable )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											/* check for active DA cables that pre-date
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											 *  SFF - 8436  v3 .6 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . ops . read_i2c_eeprom ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													IXGBE_SFF_QSFP_CONNECTOR , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													& connector ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . ops . read_i2c_eeprom ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													IXGBE_SFF_QSFP_CABLE_LENGTH , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													& cable_length ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . ops . read_i2c_eeprom ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													IXGBE_SFF_QSFP_DEVICE_TECH , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													& device_tech ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( ( connector  = = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     IXGBE_SFF_QSFP_CONNECTOR_NOT_SEPARABLE )  & & 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											    ( cable_length  >  0 )  & & 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											    ( ( device_tech  > >  4 )  = = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												     IXGBE_SFF_QSFP_TRANSMITER_850NM_VCSEL ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												active_cable  =  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( active_cable )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . type  =  ixgbe_phy_qsfp_active_unknown ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( hw - > bus . lan_id  = =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . sfp_type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														ixgbe_sfp_type_da_act_lmt_core0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw - > phy . sfp_type  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														ixgbe_sfp_type_da_act_lmt_core1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											/* unsupported module type */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . type  =  ixgbe_phy_sfp_unsupported ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											return  IXGBE_ERR_SFP_NOT_SUPPORTED ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-08-16 23:11:14 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( hw - > phy . sfp_type  ! =  stored_sfp_type ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . sfp_setup_needed  =  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Determine if the QSFP+ PHY is dual speed or not. */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									hw - > phy . multispeed_fiber  =  false ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( ( ( comp_codes_1g  &  IXGBE_SFF_1GBASESX_CAPABLE )  & & 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									     ( comp_codes_10g  &  IXGBE_SFF_10GBASESR_CAPABLE ) )  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    ( ( comp_codes_1g  &  IXGBE_SFF_1GBASELX_CAPABLE )  & & 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									     ( comp_codes_10g  &  IXGBE_SFF_10GBASELR_CAPABLE ) ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > phy . multispeed_fiber  =  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Determine PHY vendor for optical modules */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( comp_codes_10g  &  ( IXGBE_SFF_10GBASESR_CAPABLE  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											      IXGBE_SFF_10GBASELR_CAPABLE ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  hw - > phy . ops . read_i2c_eeprom ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													IXGBE_SFF_QSFP_VENDOR_OUI_BYTE0 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													& oui_bytes [ 0 ] ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  err_read_i2c_eeprom ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  hw - > phy . ops . read_i2c_eeprom ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													IXGBE_SFF_QSFP_VENDOR_OUI_BYTE1 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													& oui_bytes [ 1 ] ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  err_read_i2c_eeprom ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  hw - > phy . ops . read_i2c_eeprom ( hw , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													IXGBE_SFF_QSFP_VENDOR_OUI_BYTE2 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													& oui_bytes [ 2 ] ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  err_read_i2c_eeprom ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										vendor_oui  = 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											( ( oui_bytes [ 0 ]  < <  IXGBE_SFF_VENDOR_OUI_BYTE0_SHIFT )  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											 ( oui_bytes [ 1 ]  < <  IXGBE_SFF_VENDOR_OUI_BYTE1_SHIFT )  | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											 ( oui_bytes [ 2 ]  < <  IXGBE_SFF_VENDOR_OUI_BYTE2_SHIFT ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( vendor_oui  = =  IXGBE_SFF_VENDOR_OUI_INTEL ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . type  =  ixgbe_phy_qsfp_intel ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . type  =  ixgbe_phy_qsfp_unknown ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw - > mac . ops . get_device_caps ( hw ,  & enforce_sfp ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ! ( enforce_sfp  &  IXGBE_DEVICE_CAPS_ALLOW_ANY_SFP ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											/* Make sure we're a supported PHY type */ 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											if  ( hw - > phy . type  = =  ixgbe_phy_qsfp_intel ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												return  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( hw - > allow_unsupported_sfp )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												e_warn ( drv ,  " WARNING: Intel (R) Network Connections are quality tested using Intel (R) Ethernet Optics. Using untested modules is not supported and may cause unstable operation or damage to the module or the adapter. Intel Corporation is not responsible for any harm caused by using untested modules. \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											hw_dbg ( hw ,  " QSFP module not supported \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw - > phy . type  =  ixgbe_phy_sfp_unsupported ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  IXGBE_ERR_SFP_NOT_SUPPORTED ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-07-27 06:25:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								err_read_i2c_eeprom :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									hw - > phy . sfp_type  =  ixgbe_sfp_type_not_present ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									hw - > phy . id  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									hw - > phy . type  =  ixgbe_phy_unknown ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  IXGBE_ERR_SFP_NOT_PRESENT ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
									
										
										
										
											2011-02-16 10:14:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   ixgbe_get_sfp_init_sequence_offsets  -  Provides  offset  of  PHY  init  sequence 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ list_offset :  offset  to  the  SFP  ID  list 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ data_offset :  offset  to  the  SFP  data  block 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-19 08:43:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Checks  the  MAC ' s  EEPROM  to  see  if  it  supports  a  given  SFP +  module  type ,  if 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   so  it  returns  the  offsets  to  the  phy  init  sequence  block . 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_get_sfp_init_sequence_offsets ( struct  ixgbe_hw  * hw ,  
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													u16  * list_offset , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													u16  * data_offset ) 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u16  sfp_id ; 
							 
						 
					
						
							
								
									
										
										
										
											2010-06-29 18:30:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u16  sfp_type  =  hw - > phy . sfp_type ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( hw - > phy . sfp_type  = =  ixgbe_sfp_type_unknown ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  IXGBE_ERR_SFP_NOT_SUPPORTED ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( hw - > phy . sfp_type  = =  ixgbe_sfp_type_not_present ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  IXGBE_ERR_SFP_NOT_PRESENT ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( ( hw - > device_id  = =  IXGBE_DEV_ID_82598_SR_DUAL_PORT_EM )  & & 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    ( hw - > phy . sfp_type  = =  ixgbe_sfp_type_da_cu ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  IXGBE_ERR_SFP_NOT_SUPPORTED ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-06-29 18:30:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/*
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  Limiting  active  cables  and  1 G  Phys  must  be  initialized  as 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  SR  modules 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( sfp_type  = =  ixgbe_sfp_type_da_act_lmt_core0  | | 
							 
						 
					
						
							
								
									
										
										
										
											2013-04-11 06:23:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									    sfp_type  = =  ixgbe_sfp_type_1g_lx_core0  | | 
							 
						 
					
						
							
								
									
										
										
										
											2012-06-08 06:59:09 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									    sfp_type  = =  ixgbe_sfp_type_1g_cu_core0  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									    sfp_type  = =  ixgbe_sfp_type_1g_sx_core0 ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-06-29 18:30:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										sfp_type  =  ixgbe_sfp_type_srlr_core0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									else  if  ( sfp_type  = =  ixgbe_sfp_type_da_act_lmt_core1  | | 
							 
						 
					
						
							
								
									
										
										
										
											2013-04-11 06:23:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										 sfp_type  = =  ixgbe_sfp_type_1g_lx_core1  | | 
							 
						 
					
						
							
								
									
										
										
										
											2012-06-08 06:59:09 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										 sfp_type  = =  ixgbe_sfp_type_1g_cu_core1  | | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										 sfp_type  = =  ixgbe_sfp_type_1g_sx_core1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-06-29 18:30:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										sfp_type  =  ixgbe_sfp_type_srlr_core1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/* Read offset to PHY init contents */ 
							 
						 
					
						
							
								
									
										
										
										
											2013-05-24 07:31:09 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( hw - > eeprom . ops . read ( hw ,  IXGBE_PHY_INIT_OFFSET_NL ,  list_offset ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw_err ( hw ,  " eeprom read at %d failed \n " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										       IXGBE_PHY_INIT_OFFSET_NL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  IXGBE_ERR_SFP_NO_INIT_SEQ_PRESENT ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( ( ! * list_offset )  | |  ( * list_offset  = =  0xFFFF ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  IXGBE_ERR_SFP_NO_INIT_SEQ_PRESENT ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Shift offset to first ID word */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									( * list_offset ) + + ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/*
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  Find  the  matching  SFP  ID  in  the  EEPROM 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  and  program  the  init  sequence 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 */ 
							 
						 
					
						
							
								
									
										
										
										
											2013-05-24 07:31:09 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( hw - > eeprom . ops . read ( hw ,  * list_offset ,  & sfp_id ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										goto  err_phy ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									while  ( sfp_id  ! =  IXGBE_PHY_INIT_END_NL )  { 
							 
						 
					
						
							
								
									
										
										
										
											2010-06-29 18:30:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( sfp_id  = =  sfp_type )  { 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											( * list_offset ) + + ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-05-24 07:31:09 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											if  ( hw - > eeprom . ops . read ( hw ,  * list_offset ,  data_offset ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												goto  err_phy ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											if  ( ( ! * data_offset )  | |  ( * data_offset  = =  0xFFFF ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												hw_dbg ( hw ,  " SFP+ module not supported \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												return  IXGBE_ERR_SFP_NOT_SUPPORTED ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											( * list_offset )  + =  2 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( hw - > eeprom . ops . read ( hw ,  * list_offset ,  & sfp_id ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2013-05-24 07:31:09 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												goto  err_phy ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( sfp_id  = =  IXGBE_PHY_INIT_END_NL )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw_dbg ( hw ,  " No matching SFP+ module found \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  IXGBE_ERR_SFP_NOT_SUPPORTED ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2013-05-24 07:31:09 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								err_phy :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									hw_err ( hw ,  " eeprom read at offset %d failed \n " ,  * list_offset ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  IXGBE_ERR_PHY ; 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-20 21:11:42 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_read_i2c_eeprom_generic  -  Reads  8  bit  EEPROM  word  over  I2C  interface 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ byte_offset :  EEPROM  byte  offset  to  read 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ eeprom_data :  value  read 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Performs  byte  read  operation  to  SFP  module ' s  EEPROM  over  I2C  interface . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_read_i2c_eeprom_generic ( struct  ixgbe_hw  * hw ,  u8  byte_offset ,  
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												  u8  * eeprom_data ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  hw - > phy . ops . read_i2c_byte ( hw ,  byte_offset , 
							 
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													 IXGBE_I2C_EEPROM_DEV_ADDR , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													 eeprom_data ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2012-12-19 07:14:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_read_i2c_sff8472_generic  -  Reads  8  bit  word  over  I2C  interface 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ byte_offset :  byte  offset  at  address  0xA2 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ eeprom_data :  value  read 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Performs  byte  read  operation  to  SFP  module ' s  SFF - 8472  data  over  I2C 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_read_i2c_sff8472_generic ( struct  ixgbe_hw  * hw ,  u8  byte_offset ,  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												   u8  * sff8472_data ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  hw - > phy . ops . read_i2c_byte ( hw ,  byte_offset , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													 IXGBE_I2C_EEPROM_DEV_ADDR2 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													 sff8472_data ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_write_i2c_eeprom_generic  -  Writes  8  bit  EEPROM  word  over  I2C  interface 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ byte_offset :  EEPROM  byte  offset  to  write 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ eeprom_data :  value  to  write 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Performs  byte  write  operation  to  SFP  module ' s  EEPROM  over  I2C  interface . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_write_i2c_eeprom_generic ( struct  ixgbe_hw  * hw ,  u8  byte_offset ,  
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												   u8  eeprom_data ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  hw - > phy . ops . write_i2c_byte ( hw ,  byte_offset , 
							 
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													  IXGBE_I2C_EEPROM_DEV_ADDR , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													  eeprom_data ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_read_i2c_byte_generic  -  Reads  8  bit  word  over  I2C 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ byte_offset :  byte  offset  to  read 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ data :  value  read 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Performs  byte  read  operation  to  SFP  module ' s  EEPROM  over  I2C  interface  at 
							 
						 
					
						
							
								
									
										
										
										
											2011-08-30 13:33:51 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   a  specified  device  address . 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_read_i2c_byte_generic ( struct  ixgbe_hw  * hw ,  u8  byte_offset ,  
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												u8  dev_addr ,  u8  * data ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									s32  status ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-19 08:43:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u32  max_retry  =  10 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u32  retry  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-19 08:43:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u16  swfw_mask  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-19 13:56:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									bool  nack  =  true ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-08-30 13:33:51 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									* data  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-19 08:43:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( IXGBE_READ_REG ( hw ,  IXGBE_STATUS )  &  IXGBE_STATUS_LAN_ID_1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										swfw_mask  =  IXGBE_GSSR_PHY1_SM ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										swfw_mask  =  IXGBE_GSSR_PHY0_SM ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									do  { 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( hw - > mac . ops . acquire_swfw_sync ( hw ,  swfw_mask ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  IXGBE_ERR_SWFW_SYNC ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-19 08:43:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										ixgbe_i2c_start ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* Device Address and write indication */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_clock_out_i2c_byte ( hw ,  dev_addr ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  fail ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_get_i2c_ack ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  fail ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_clock_out_i2c_byte ( hw ,  byte_offset ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  fail ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_get_i2c_ack ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  fail ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ixgbe_i2c_start ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* Device Address and read indication */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_clock_out_i2c_byte ( hw ,  ( dev_addr  |  0x1 ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  fail ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_get_i2c_ack ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  fail ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_clock_in_i2c_byte ( hw ,  data ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  fail ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_clock_out_i2c_bit ( hw ,  nack ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  fail ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ixgbe_i2c_stop ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								fail :  
						 
					
						
							
								
									
										
										
										
											2013-01-18 02:16:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										ixgbe_i2c_bus_clear ( hw ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-04-13 04:56:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										hw - > mac . ops . release_swfw_sync ( hw ,  swfw_mask ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-19 08:43:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										msleep ( 100 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										retry + + ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( retry  <  max_retry ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw_dbg ( hw ,  " I2C byte read error - Retrying. \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw_dbg ( hw ,  " I2C byte read error. \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									}  while  ( retry  <  max_retry ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-04-13 04:56:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									hw - > mac . ops . release_swfw_sync ( hw ,  swfw_mask ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-19 08:43:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									return  status ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_write_i2c_byte_generic  -  Writes  8  bit  word  over  I2C 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ byte_offset :  byte  offset  to  write 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ data :  value  to  write 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Performs  byte  write  operation  to  SFP  module ' s  EEPROM  over  I2C  interface  at 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   a  specified  device  address . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_write_i2c_byte_generic ( struct  ixgbe_hw  * hw ,  u8  byte_offset ,  
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												 u8  dev_addr ,  u8  data ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									s32  status ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u32  max_retry  =  1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  retry  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-19 08:43:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u16  swfw_mask  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( IXGBE_READ_REG ( hw ,  IXGBE_STATUS )  &  IXGBE_STATUS_LAN_ID_1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										swfw_mask  =  IXGBE_GSSR_PHY1_SM ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										swfw_mask  =  IXGBE_GSSR_PHY0_SM ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( hw - > mac . ops . acquire_swfw_sync ( hw ,  swfw_mask ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  IXGBE_ERR_SWFW_SYNC ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									do  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ixgbe_i2c_start ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_clock_out_i2c_byte ( hw ,  dev_addr ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  fail ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_get_i2c_ack ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  fail ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_clock_out_i2c_byte ( hw ,  byte_offset ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  fail ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_get_i2c_ack ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  fail ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_clock_out_i2c_byte ( hw ,  data ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  fail ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_get_i2c_ack ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											goto  fail ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ixgbe_i2c_stop ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								fail :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ixgbe_i2c_bus_clear ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										retry + + ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( retry  <  max_retry ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw_dbg ( hw ,  " I2C byte write error - Retrying. \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											hw_dbg ( hw ,  " I2C byte write error. \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									}  while  ( retry  <  max_retry ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-04-13 04:56:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									hw - > mac . ops . release_swfw_sync ( hw ,  swfw_mask ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-19 08:43:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									return  status ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_i2c_start  -  Sets  I2C  start  condition 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Sets  I2C  start  condition  ( High  - >  Low  on  SDA  while  SCL  is  High ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  void  ixgbe_i2c_start ( struct  ixgbe_hw  * hw )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  i2cctl  =  IXGBE_READ_REG ( hw ,  IXGBE_I2CCTL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Start condition must begin with data and clock high */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ixgbe_set_i2c_data ( hw ,  & i2cctl ,  1 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ixgbe_raise_i2c_clk ( hw ,  & i2cctl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Setup time for start condition (4.7us) */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									udelay ( IXGBE_I2C_T_SU_STA ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ixgbe_set_i2c_data ( hw ,  & i2cctl ,  0 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Hold time for start condition (4us) */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									udelay ( IXGBE_I2C_T_HD_STA ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ixgbe_lower_i2c_clk ( hw ,  & i2cctl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Minimum low period of clock is 4.7 us */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									udelay ( IXGBE_I2C_T_LOW ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_i2c_stop  -  Sets  I2C  stop  condition 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Sets  I2C  stop  condition  ( Low  - >  High  on  SDA  while  SCL  is  High ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  void  ixgbe_i2c_stop ( struct  ixgbe_hw  * hw )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  i2cctl  =  IXGBE_READ_REG ( hw ,  IXGBE_I2CCTL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Stop condition must begin with data low and clock high */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ixgbe_set_i2c_data ( hw ,  & i2cctl ,  0 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ixgbe_raise_i2c_clk ( hw ,  & i2cctl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Setup time for stop condition (4us) */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									udelay ( IXGBE_I2C_T_SU_STO ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ixgbe_set_i2c_data ( hw ,  & i2cctl ,  1 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* bus free time between stop and start (4.7us)*/ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									udelay ( IXGBE_I2C_T_BUF ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_clock_in_i2c_byte  -  Clocks  in  one  byte  via  I2C 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ data :  data  byte  to  clock  in 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Clocks  in  one  byte  data  via  I2C  data / clock 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  s32  ixgbe_clock_in_i2c_byte ( struct  ixgbe_hw  * hw ,  u8  * data )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									s32  i ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-19 13:56:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									bool  bit  =  false ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( i  =  7 ;  i  > =  0 ;  i - - )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 07:18:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										ixgbe_clock_in_i2c_bit ( hw ,  & bit ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										* data  | =  bit  < <  i ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 07:18:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_clock_out_i2c_byte  -  Clocks  out  one  byte  via  I2C 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ data :  data  byte  clocked  out 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Clocks  out  one  byte  data  via  I2C  data / clock 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  s32  ixgbe_clock_out_i2c_byte ( struct  ixgbe_hw  * hw ,  u8  data )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									s32  status ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									s32  i ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  i2cctl ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-19 13:56:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									bool  bit  =  false ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( i  =  7 ;  i  > =  0 ;  i - - )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										bit  =  ( data  > >  i )  &  0x1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  ixgbe_clock_out_i2c_bit ( hw ,  bit ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( status  ! =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Release SDA line (set high) */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									i2cctl  =  IXGBE_READ_REG ( hw ,  IXGBE_I2CCTL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									i2cctl  | =  IXGBE_I2C_DATA_OUT ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									IXGBE_WRITE_REG ( hw ,  IXGBE_I2CCTL ,  i2cctl ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-11-04 06:43:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									IXGBE_WRITE_FLUSH ( hw ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  status ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_get_i2c_ack  -  Polls  for  I2C  ACK 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Clocks  in / out  one  bit  via  I2C  data / clock 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  s32  ixgbe_get_i2c_ack ( struct  ixgbe_hw  * hw )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2011-08-27 07:18:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									s32  status  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u32  i  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  i2cctl  =  IXGBE_READ_REG ( hw ,  IXGBE_I2CCTL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  timeout  =  10 ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-19 13:56:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									bool  ack  =  true ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 07:18:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ixgbe_raise_i2c_clk ( hw ,  & i2cctl ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Minimum high period of clock is 4us */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									udelay ( IXGBE_I2C_T_HIGH ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Poll for ACK.  Note that ACK in I2C spec is
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									 *  transition  from  1  to  0  */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( i  =  0 ;  i  <  timeout ;  i + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										i2cctl  =  IXGBE_READ_REG ( hw ,  IXGBE_I2CCTL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ack  =  ixgbe_get_i2c_data ( & i2cctl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										udelay ( 1 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ack  = =  0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( ack  = =  1 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw_dbg ( hw ,  " I2C ack was not received. \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										status  =  IXGBE_ERR_I2C ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ixgbe_lower_i2c_clk ( hw ,  & i2cctl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Minimum low period of clock is 4.7 us */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									udelay ( IXGBE_I2C_T_LOW ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  status ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_clock_in_i2c_bit  -  Clocks  in  one  bit  via  I2C  data / clock 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ data :  read  data  value 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Clocks  in  one  bit  via  I2C  data / clock 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  s32  ixgbe_clock_in_i2c_bit ( struct  ixgbe_hw  * hw ,  bool  * data )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  i2cctl  =  IXGBE_READ_REG ( hw ,  IXGBE_I2CCTL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 07:18:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ixgbe_raise_i2c_clk ( hw ,  & i2cctl ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Minimum high period of clock is 4us */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									udelay ( IXGBE_I2C_T_HIGH ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									i2cctl  =  IXGBE_READ_REG ( hw ,  IXGBE_I2CCTL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									* data  =  ixgbe_get_i2c_data ( & i2cctl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ixgbe_lower_i2c_clk ( hw ,  & i2cctl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Minimum low period of clock is 4.7 us */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									udelay ( IXGBE_I2C_T_LOW ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 07:18:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_clock_out_i2c_bit  -  Clocks  in / out  one  bit  via  I2C  data / clock 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ data :  data  value  to  write 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Clocks  out  one  bit  via  I2C  data / clock 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  s32  ixgbe_clock_out_i2c_bit ( struct  ixgbe_hw  * hw ,  bool  data )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									s32  status ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  i2cctl  =  IXGBE_READ_REG ( hw ,  IXGBE_I2CCTL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									status  =  ixgbe_set_i2c_data ( hw ,  & i2cctl ,  data ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( status  = =  0 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 07:18:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										ixgbe_raise_i2c_clk ( hw ,  & i2cctl ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* Minimum high period of clock is 4us */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										udelay ( IXGBE_I2C_T_HIGH ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ixgbe_lower_i2c_clk ( hw ,  & i2cctl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* Minimum low period of clock is 4.7 us.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										 *  This  also  takes  care  of  the  data  hold  time . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										udelay ( IXGBE_I2C_T_LOW ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									}  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw_dbg ( hw ,  " I2C data was not set to %X \n " ,  data ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  IXGBE_ERR_I2C ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_raise_i2c_clk  -  Raises  the  I2C  SCL  clock 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ i2cctl :  Current  value  of  I2CCTL  register 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Raises  the  I2C  clock  line  ' 0 ' - > ' 1 ' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 07:18:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  void  ixgbe_raise_i2c_clk ( struct  ixgbe_hw  * hw ,  u32  * i2cctl )  
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2012-03-15 07:36:37 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									u32  i  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  timeout  =  IXGBE_I2C_CLOCK_STRETCHING_TIMEOUT ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  i2cctl_r  =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2012-03-15 07:36:37 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									for  ( i  =  0 ;  i  <  timeout ;  i + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										* i2cctl  | =  IXGBE_I2C_CLK_OUT ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										IXGBE_WRITE_REG ( hw ,  IXGBE_I2CCTL ,  * i2cctl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										IXGBE_WRITE_FLUSH ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* SCL rise time (1000ns) */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										udelay ( IXGBE_I2C_T_RISE ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										i2cctl_r  =  IXGBE_READ_REG ( hw ,  IXGBE_I2CCTL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( i2cctl_r  &  IXGBE_I2C_CLK_IN ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_lower_i2c_clk  -  Lowers  the  I2C  SCL  clock 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ i2cctl :  Current  value  of  I2CCTL  register 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Lowers  the  I2C  clock  line  ' 1 ' - > ' 0 ' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  void  ixgbe_lower_i2c_clk ( struct  ixgbe_hw  * hw ,  u32  * i2cctl )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									* i2cctl  & =  ~ IXGBE_I2C_CLK_OUT ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									IXGBE_WRITE_REG ( hw ,  IXGBE_I2CCTL ,  * i2cctl ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-07-20 00:56:21 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									IXGBE_WRITE_FLUSH ( hw ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* SCL fall time (300ns) */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									udelay ( IXGBE_I2C_T_FALL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_set_i2c_data  -  Sets  the  I2C  data  bit 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ i2cctl :  Current  value  of  I2CCTL  register 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ data :  I2C  data  value  ( 0  or  1 )  to  set 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Sets  the  I2C  data  bit 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  s32  ixgbe_set_i2c_data ( struct  ixgbe_hw  * hw ,  u32  * i2cctl ,  bool  data )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( data ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										* i2cctl  | =  IXGBE_I2C_DATA_OUT ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										* i2cctl  & =  ~ IXGBE_I2C_DATA_OUT ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									IXGBE_WRITE_REG ( hw ,  IXGBE_I2CCTL ,  * i2cctl ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-07-20 00:56:21 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									IXGBE_WRITE_FLUSH ( hw ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Data rise/fall (1000ns/300ns) and set-up time (250ns) */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									udelay ( IXGBE_I2C_T_RISE  +  IXGBE_I2C_T_FALL  +  IXGBE_I2C_T_SU_DATA ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Verify data was set correctly */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									* i2cctl  =  IXGBE_READ_REG ( hw ,  IXGBE_I2CCTL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( data  ! =  ixgbe_get_i2c_data ( i2cctl ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										hw_dbg ( hw ,  " Error - I2C data was not set to %X. \n " ,  data ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  IXGBE_ERR_I2C ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_get_i2c_data  -  Reads  the  I2C  SDA  data  bit 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ i2cctl :  Current  value  of  I2CCTL  register 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Returns  the  I2C  data  bit  value 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  bool  ixgbe_get_i2c_data ( u32  * i2cctl )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( * i2cctl  &  IXGBE_I2C_DATA_IN ) 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  false ; 
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   ixgbe_i2c_bus_clear  -  Clears  the  I2C  bus 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Clears  the  I2C  bus  by  sending  nine  clock  pulses . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Used  when  data  line  is  stuck  low . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  void  ixgbe_i2c_bus_clear ( struct  ixgbe_hw  * hw )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  i2cctl  =  IXGBE_READ_REG ( hw ,  IXGBE_I2CCTL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u32  i ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-19 08:43:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ixgbe_i2c_start ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ixgbe_set_i2c_data ( hw ,  & i2cctl ,  1 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( i  =  0 ;  i  <  9 ;  i + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ixgbe_raise_i2c_clk ( hw ,  & i2cctl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* Min high period of clock is 4us */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										udelay ( IXGBE_I2C_T_HIGH ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ixgbe_lower_i2c_clk ( hw ,  & i2cctl ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* Min low period of clock is 4.7us*/ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										udelay ( IXGBE_I2C_T_LOW ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-19 08:43:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ixgbe_i2c_start ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-02-27 15:44:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/* Put the i2c bus back to default state */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ixgbe_i2c_stop ( hw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-05-20 23:07:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/**
  
						 
					
						
							
								
									
										
										
										
											2011-03-30 22:57:33 -03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   ixgbe_tn_check_overtemp  -  Checks  if  an  overtemp  occurred . 
							 
						 
					
						
							
								
									
										
										
										
											2010-05-20 23:07:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *   @ hw :  pointer  to  hardware  structure 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   Checks  if  the  LASI  temp  alarm  status  was  triggered  due  to  overtemp 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								s32  ixgbe_tn_check_overtemp ( struct  ixgbe_hw  * hw )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									u16  phy_data  =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( hw - > device_id  ! =  IXGBE_DEV_ID_82599_T3_LOM ) 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2010-05-20 23:07:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* Check that the LASI temp alarm status was triggered */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									hw - > phy . ops . read_reg ( hw ,  IXGBE_TN_LASI_STATUS_REG , 
							 
						 
					
						
							
								
									
										
										
										
											2014-04-09 06:03:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											     MDIO_MMD_PMAPMD ,  & phy_data ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2010-05-20 23:07:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( ! ( phy_data  &  IXGBE_TN_LASI_STATUS_TEMP_ALARM ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2010-05-20 23:07:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-07-22 06:51:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									return  IXGBE_ERR_OVERTEMP ; 
							 
						 
					
						
							
								
									
										
										
										
											2010-05-20 23:07:06 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}