net/ixgbe/base: fix PHY identification for x550a
[dpdk.git] / drivers / net / ixgbe / base / ixgbe_phy.h
index 21d88f7..816de36 100644 (file)
@@ -1,6 +1,6 @@
 /*******************************************************************************
 
-Copyright (c) 2001-2014, Intel Corporation
+Copyright (c) 2001-2015, Intel Corporation
 All rights reserved.
 
 Redistribution and use in source and binary forms, with or without
@@ -51,6 +51,8 @@ POSSIBILITY OF SUCH DAMAGE.
 #define IXGBE_SFF_CABLE_SPEC_COMP      0x3C
 #define IXGBE_SFF_SFF_8472_SWAP                0x5C
 #define IXGBE_SFF_SFF_8472_COMP                0x5E
+#define IXGBE_SFF_SFF_8472_OSCB                0x6E
+#define IXGBE_SFF_SFF_8472_ESCB                0x76
 #define IXGBE_SFF_IDENTIFIER_QSFP_PLUS 0xD
 #define IXGBE_SFF_QSFP_VENDOR_OUI_BYTE0        0xA5
 #define IXGBE_SFF_QSFP_VENDOR_OUI_BYTE1        0xA6
@@ -70,6 +72,9 @@ POSSIBILITY OF SUCH DAMAGE.
 #define IXGBE_SFF_1GBASET_CAPABLE      0x8
 #define IXGBE_SFF_10GBASESR_CAPABLE    0x10
 #define IXGBE_SFF_10GBASELR_CAPABLE    0x20
+#define IXGBE_SFF_SOFT_RS_SELECT_MASK  0x8
+#define IXGBE_SFF_SOFT_RS_SELECT_10G   0x8
+#define IXGBE_SFF_SOFT_RS_SELECT_1G    0x0
 #define IXGBE_SFF_ADDRESSING_MODE      0x4
 #define IXGBE_SFF_QSFP_DA_ACTIVE_CABLE 0x1
 #define IXGBE_SFF_QSFP_DA_PASSIVE_CABLE        0x8
@@ -83,9 +88,35 @@ POSSIBILITY OF SUCH DAMAGE.
 #define IXGBE_I2C_EEPROM_STATUS_IN_PROGRESS    0x3
 
 #define IXGBE_CS4227                   0xBE    /* CS4227 address */
-#define IXGBE_CS4227_SPARE24_LSB       0x12B0  /* Reg to program EDC */
+#define IXGBE_CS4227_GLOBAL_ID_LSB     0
+#define IXGBE_CS4227_GLOBAL_ID_MSB     1
+#define IXGBE_CS4227_SCRATCH           2
+#define IXGBE_CS4227_GLOBAL_ID_VALUE   0x03E5
+#define IXGBE_CS4227_EFUSE_PDF_SKU     0x19F
+#define IXGBE_CS4223_SKU_ID            0x0010  /* Quad port */
+#define IXGBE_CS4227_SKU_ID            0x0014  /* Dual port */
+#define IXGBE_CS4227_RESET_PENDING     0x1357
+#define IXGBE_CS4227_RESET_COMPLETE    0x5AA5
+#define IXGBE_CS4227_RETRIES           15
+#define IXGBE_CS4227_EFUSE_STATUS      0x0181
+#define IXGBE_CS4227_LINE_SPARE22_MSB  0x12AD  /* Reg to program speed */
+#define IXGBE_CS4227_LINE_SPARE24_LSB  0x12B0  /* Reg to program EDC */
+#define IXGBE_CS4227_HOST_SPARE22_MSB  0x1AAD  /* Reg to program speed */
+#define IXGBE_CS4227_HOST_SPARE24_LSB  0x1AB0  /* Reg to program EDC */
+#define IXGBE_CS4227_EEPROM_STATUS     0x5001
+#define IXGBE_CS4227_EEPROM_LOAD_OK    0x0001
+#define IXGBE_CS4227_SPEED_1G          0x8000
+#define IXGBE_CS4227_SPEED_10G         0
 #define IXGBE_CS4227_EDC_MODE_CX1      0x0002
 #define IXGBE_CS4227_EDC_MODE_SR       0x0004
+#define IXGBE_CS4227_EDC_MODE_DIAG     0x0008
+#define IXGBE_CS4227_RESET_HOLD                500     /* microseconds */
+#define IXGBE_CS4227_RESET_DELAY       450     /* milliseconds */
+#define IXGBE_CS4227_CHECK_DELAY       30      /* milliseconds */
+#define IXGBE_PE                       0xE0    /* Port expander address */
+#define IXGBE_PE_OUTPUT                        1       /* Output register offset */
+#define IXGBE_PE_CONFIG                        3       /* Config register offset */
+#define IXGBE_PE_BIT1                  (1 << 1)
 
 /* Flow control defines */
 #define IXGBE_TAF_SYM_PAUSE            0x400
@@ -124,7 +155,72 @@ POSSIBILITY OF SUCH DAMAGE.
 /* SFP+ SFF-8472 Compliance */
 #define IXGBE_SFF_SFF_8472_UNSUP       0x00
 
-#ident "$Id: ixgbe_phy.h,v 1.56 2013/09/05 23:59:49 jtkirshe Exp $"
+/* More phy definitions */
+#define IXGBE_M88E1500_COPPER_CTRL             0       /* Page 0 reg */
+#define IXGBE_M88E1500_COPPER_CTRL_RESET       (1u << 15)
+#define IXGBE_M88E1500_COPPER_CTRL_AN_EN       (1u << 12)
+#define IXGBE_M88E1500_COPPER_CTRL_POWER_DOWN  (1u << 11)
+#define IXGBE_M88E1500_COPPER_CTRL_RESTART_AN  (1u << 9)
+#define IXGBE_M88E1500_COPPER_CTRL_FULL_DUPLEX (1u << 8)
+#define IXGBE_M88E1500_COPPER_CTRL_SPEED_MSB   (1u << 6)
+#define IXGBE_M88E1500_COPPER_STATUS           1       /* Page 0 reg */
+#define IXGBE_M88E1500_COPPER_STATUS_AN_DONE   (1u << 5)
+#define IXGBE_M88E1500_COPPER_AN               4       /* Page 0 reg */
+#define IXGBE_M88E1500_COPPER_AN_AS_PAUSE      (1u << 11)
+#define IXGBE_M88E1500_COPPER_AN_PAUSE         (1u << 10)
+#define IXGBE_M88E1500_COPPER_AN_T4            (1u << 9)
+#define IXGBE_M88E1500_COPPER_AN_100TX_FD      (1u << 8)
+#define IXGBE_M88E1500_COPPER_AN_100TX_HD      (1u << 7)
+#define IXGBE_M88E1500_COPPER_AN_10TX_FD       (1u << 6)
+#define IXGBE_M88E1500_COPPER_AN_10TX_HD       (1u << 5)
+#define IXGBE_M88E1500_COPPER_AN_LP_ABILITY    5       /* Page 0 reg */
+#define IXGBE_M88E1500_COPPER_AN_LP_AS_PAUSE   (1u << 11)
+#define IXGBE_M88E1500_COPPER_AN_LP_PAUSE      (1u << 10)
+#define IXGBE_M88E1500_1000T_CTRL              9       /* Page 0 reg */
+/* 1=Configure PHY as Master 0=Configure PHY as Slave */
+#define IXGBE_M88E1500_1000T_CTRL_MS_VALUE     (1u << 11)
+#define IXGBE_M88E1500_1000T_CTRL_1G_FD                (1u << 9)
+/* 1=Master/Slave manual config value 0=Automatic Master/Slave config */
+#define IXGBE_M88E1500_1000T_CTRL_MS_ENABLE    (1u << 12)
+#define IXGBE_M88E1500_1000T_CTRL_FULL_DUPLEX  (1u << 9)
+#define IXGBE_M88E1500_1000T_CTRL_HALF_DUPLEX  (1u << 8)
+#define IXGBE_M88E1500_1000T_STATUS            10      /* Page 0 reg */
+#define IXGBE_M88E1500_AUTO_COPPER_SGMII       0x2
+#define IXGBE_M88E1500_AUTO_COPPER_BASEX       0x3
+#define IXGBE_M88E1500_STATUS_LINK             (1u << 2) /* Interface Link Bit */
+#define IXGBE_M88E1500_MAC_CTRL_1              16      /* Page 0 reg */
+#define IXGBE_M88E1500_MAC_CTRL_1_MODE_MASK    0x0380 /* Mode Select */
+#define IXGBE_M88E1500_MAC_CTRL_1_DWN_SHIFT    12
+#define IXGBE_M88E1500_MAC_CTRL_1_DWN_4X       3u
+#define IXGBE_M88E1500_MAC_CTRL_1_ED_SHIFT     8
+#define IXGBE_M88E1500_MAC_CTRL_1_ED_TM                3u
+#define IXGBE_M88E1500_MAC_CTRL_1_MDIX_SHIFT   5
+#define IXGBE_M88E1500_MAC_CTRL_1_MDIX_AUTO    3u
+#define IXGBE_M88E1500_MAC_CTRL_1_POWER_DOWN   (1u << 2)
+#define IXGBE_M88E1500_PHY_SPEC_STATUS         17      /* Page 0 reg */
+#define IXGBE_M88E1500_PHY_SPEC_STATUS_SPEED_SHIFT     14
+#define IXGBE_M88E1500_PHY_SPEC_STATUS_SPEED_MASK      3u
+#define IXGBE_M88E1500_PHY_SPEC_STATUS_SPEED_10                0u
+#define IXGBE_M88E1500_PHY_SPEC_STATUS_SPEED_100       1u
+#define IXGBE_M88E1500_PHY_SPEC_STATUS_SPEED_1000      2u
+#define IXGBE_M88E1500_PHY_SPEC_STATUS_DUPLEX          (1u << 13)
+#define IXGBE_M88E1500_PHY_SPEC_STATUS_RESOLVED                (1u << 11)
+#define IXGBE_M88E1500_PHY_SPEC_STATUS_LINK            (1u << 10)
+#define IXGBE_M88E1500_PAGE_ADDR               22      /* All pages reg */
+#define IXGBE_M88E1500_FIBER_CTRL              0       /* Page 1 reg */
+#define IXGBE_M88E1500_FIBER_CTRL_RESET                (1u << 15)
+#define IXGBE_M88E1500_FIBER_CTRL_SPEED_LSB    (1u << 13)
+#define IXGBE_M88E1500_FIBER_CTRL_AN_EN                (1u << 12)
+#define IXGBE_M88E1500_FIBER_CTRL_POWER_DOWN   (1u << 11)
+#define IXGBE_M88E1500_FIBER_CTRL_DUPLEX_FULL  (1u << 8)
+#define IXGBE_M88E1500_FIBER_CTRL_SPEED_MSB    (1u << 6)
+#define IXGBE_M88E1500_MAC_SPEC_CTRL           16      /* Page 2 reg */
+#define IXGBE_M88E1500_MAC_SPEC_CTRL_POWER_DOWN        (1u << 3)
+#define IXGBE_M88E1500_EEE_CTRL_1              0       /* Page 18 reg */
+#define IXGBE_M88E1500_EEE_CTRL_1_MS           (1u << 0) /* EEE Master/Slave */
+#define IXGBE_M88E1500_GEN_CTRL                        20      /* Page 18 reg */
+#define IXGBE_M88E1500_GEN_CTRL_RESET          (1u << 15)
+#define IXGBE_M88E1500_GEN_CTRL_MODE_SGMII_COPPER      1u /* Mode bits 0-2 */
 
 s32 ixgbe_init_phy_ops_generic(struct ixgbe_hw *hw);
 bool ixgbe_validate_phy_addr(struct ixgbe_hw *hw, u32 phy_addr);
@@ -171,11 +267,19 @@ s32 ixgbe_get_sfp_init_sequence_offsets(struct ixgbe_hw *hw,
 s32 ixgbe_tn_check_overtemp(struct ixgbe_hw *hw);
 s32 ixgbe_read_i2c_byte_generic(struct ixgbe_hw *hw, u8 byte_offset,
                                u8 dev_addr, u8 *data);
+s32 ixgbe_read_i2c_byte_generic_unlocked(struct ixgbe_hw *hw, u8 byte_offset,
+                                        u8 dev_addr, u8 *data);
 s32 ixgbe_write_i2c_byte_generic(struct ixgbe_hw *hw, u8 byte_offset,
                                 u8 dev_addr, u8 data);
+s32 ixgbe_write_i2c_byte_generic_unlocked(struct ixgbe_hw *hw, u8 byte_offset,
+                                         u8 dev_addr, u8 data);
 s32 ixgbe_read_i2c_eeprom_generic(struct ixgbe_hw *hw, u8 byte_offset,
                                  u8 *eeprom_data);
 s32 ixgbe_write_i2c_eeprom_generic(struct ixgbe_hw *hw, u8 byte_offset,
                                   u8 eeprom_data);
 void ixgbe_i2c_bus_clear(struct ixgbe_hw *hw);
+s32 ixgbe_read_i2c_combined_generic_int(struct ixgbe_hw *, u8 addr, u16 reg,
+                                       u16 *val, bool lock);
+s32 ixgbe_write_i2c_combined_generic_int(struct ixgbe_hw *, u8 addr, u16 reg,
+                                        u16 val, bool lock);
 #endif /* _IXGBE_PHY_H_ */