mdio_10g.h 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. /****************************************************************************
  2. * Driver for Solarflare Solarstorm network controllers and boards
  3. * Copyright 2006-2008 Solarflare Communications Inc.
  4. *
  5. * This program is free software; you can redistribute it and/or modify it
  6. * under the terms of the GNU General Public License version 2 as published
  7. * by the Free Software Foundation, incorporated herein by reference.
  8. */
  9. #ifndef EFX_MDIO_10G_H
  10. #define EFX_MDIO_10G_H
  11. /*
  12. * Definitions needed for doing 10G MDIO as specified in clause 45
  13. * MDIO, which do not appear in Linux yet. Also some helper functions.
  14. */
  15. #include "efx.h"
  16. #include "boards.h"
  17. /* Numbering of the MDIO Manageable Devices (MMDs) */
  18. /* Physical Medium Attachment/ Physical Medium Dependent sublayer */
  19. #define MDIO_MMD_PMAPMD (1)
  20. /* WAN Interface Sublayer */
  21. #define MDIO_MMD_WIS (2)
  22. /* Physical Coding Sublayer */
  23. #define MDIO_MMD_PCS (3)
  24. /* PHY Extender Sublayer */
  25. #define MDIO_MMD_PHYXS (4)
  26. /* Extender Sublayer */
  27. #define MDIO_MMD_DTEXS (5)
  28. /* Transmission convergence */
  29. #define MDIO_MMD_TC (6)
  30. /* Auto negotiation */
  31. #define MDIO_MMD_AN (7)
  32. /* Generic register locations */
  33. #define MDIO_MMDREG_CTRL1 (0)
  34. #define MDIO_MMDREG_STAT1 (1)
  35. #define MDIO_MMDREG_IDHI (2)
  36. #define MDIO_MMDREG_IDLOW (3)
  37. #define MDIO_MMDREG_SPEED (4)
  38. #define MDIO_MMDREG_DEVS0 (5)
  39. #define MDIO_MMDREG_DEVS1 (6)
  40. #define MDIO_MMDREG_CTRL2 (7)
  41. #define MDIO_MMDREG_STAT2 (8)
  42. /* Bits in MMDREG_CTRL1 */
  43. /* Reset */
  44. #define MDIO_MMDREG_CTRL1_RESET_LBN (15)
  45. #define MDIO_MMDREG_CTRL1_RESET_WIDTH (1)
  46. /* Bits in MMDREG_STAT1 */
  47. #define MDIO_MMDREG_STAT1_FAULT_LBN (7)
  48. #define MDIO_MMDREG_STAT1_FAULT_WIDTH (1)
  49. /* Link state */
  50. #define MDIO_MMDREG_STAT1_LINK_LBN (2)
  51. #define MDIO_MMDREG_STAT1_LINK_WIDTH (1)
  52. /* Bits in ID reg */
  53. #define MDIO_ID_REV(_id32) (_id32 & 0xf)
  54. #define MDIO_ID_MODEL(_id32) ((_id32 >> 4) & 0x3f)
  55. #define MDIO_ID_OUI(_id32) (_id32 >> 10)
  56. /* Bits in MMDREG_DEVS0. Someone thoughtfully layed things out
  57. * so the 'bit present' bit number of an MMD is the number of
  58. * that MMD */
  59. #define DEV_PRESENT_BIT(_b) (1 << _b)
  60. #define MDIO_MMDREG_DEVS0_PHYXS DEV_PRESENT_BIT(MDIO_MMD_PHYXS)
  61. #define MDIO_MMDREG_DEVS0_PCS DEV_PRESENT_BIT(MDIO_MMD_PCS)
  62. #define MDIO_MMDREG_DEVS0_PMAPMD DEV_PRESENT_BIT(MDIO_MMD_PMAPMD)
  63. /* Bits in MMDREG_STAT2 */
  64. #define MDIO_MMDREG_STAT2_PRESENT_VAL (2)
  65. #define MDIO_MMDREG_STAT2_PRESENT_LBN (14)
  66. #define MDIO_MMDREG_STAT2_PRESENT_WIDTH (2)
  67. /* PMA type (4 bits) */
  68. #define MDIO_PMAPMD_CTRL2_10G_CX4 (0x0)
  69. #define MDIO_PMAPMD_CTRL2_10G_EW (0x1)
  70. #define MDIO_PMAPMD_CTRL2_10G_LW (0x2)
  71. #define MDIO_PMAPMD_CTRL2_10G_SW (0x3)
  72. #define MDIO_PMAPMD_CTRL2_10G_LX4 (0x4)
  73. #define MDIO_PMAPMD_CTRL2_10G_ER (0x5)
  74. #define MDIO_PMAPMD_CTRL2_10G_LR (0x6)
  75. #define MDIO_PMAPMD_CTRL2_10G_SR (0x7)
  76. /* Reserved */
  77. #define MDIO_PMAPMD_CTRL2_10G_BT (0x9)
  78. /* Reserved */
  79. /* Reserved */
  80. #define MDIO_PMAPMD_CTRL2_1G_BT (0xc)
  81. /* Reserved */
  82. #define MDIO_PMAPMD_CTRL2_100_BT (0xe)
  83. #define MDIO_PMAPMD_CTRL2_10_BT (0xf)
  84. #define MDIO_PMAPMD_CTRL2_TYPE_MASK (0xf)
  85. /* /\* PHY XGXS lane state *\/ */
  86. #define MDIO_PHYXS_LANE_STATE (0x18)
  87. #define MDIO_PHYXS_LANE_ALIGNED_LBN (12)
  88. /* AN registers */
  89. #define MDIO_AN_STATUS (1)
  90. #define MDIO_AN_STATUS_XNP_LBN (7)
  91. #define MDIO_AN_STATUS_PAGE_LBN (6)
  92. #define MDIO_AN_STATUS_AN_DONE_LBN (5)
  93. #define MDIO_AN_STATUS_LP_AN_CAP_LBN (0)
  94. #define MDIO_AN_10GBT_STATUS (33)
  95. #define MDIO_AN_10GBT_STATUS_MS_FLT_LBN (15) /* MASTER/SLAVE config fault */
  96. #define MDIO_AN_10GBT_STATUS_MS_LBN (14) /* MASTER/SLAVE config */
  97. #define MDIO_AN_10GBT_STATUS_LOC_OK_LBN (13) /* Local OK */
  98. #define MDIO_AN_10GBT_STATUS_REM_OK_LBN (12) /* Remote OK */
  99. #define MDIO_AN_10GBT_STATUS_LP_10G_LBN (11) /* Link partner is 10GBT capable */
  100. #define MDIO_AN_10GBT_STATUS_LP_LTA_LBN (10) /* LP loop timing ability */
  101. #define MDIO_AN_10GBT_STATUS_LP_TRR_LBN (9) /* LP Training Reset Request */
  102. /* Packing of the prt and dev arguments of clause 45 style MDIO into a
  103. * single int so they can be passed into the mdio_read/write functions
  104. * that currently exist. Note that as Falcon is the only current user,
  105. * the packed form is chosen to match what Falcon needs to write into
  106. * a register. This is checked at compile-time so do not change it. If
  107. * your target chip needs things layed out differently you will need
  108. * to unpack the arguments in your chip-specific mdio functions.
  109. */
  110. /* These are defined by the standard. */
  111. #define MDIO45_PRT_ID_WIDTH (5)
  112. #define MDIO45_DEV_ID_WIDTH (5)
  113. /* The prt ID is just packed in immediately to the left of the dev ID */
  114. #define MDIO45_PRT_DEV_WIDTH (MDIO45_PRT_ID_WIDTH + MDIO45_DEV_ID_WIDTH)
  115. #define MDIO45_PRT_ID_MASK ((1 << MDIO45_PRT_DEV_WIDTH) - 1)
  116. /* This is the prt + dev extended by 1 bit to hold the 'is clause 45' flag. */
  117. #define MDIO45_XPRT_ID_WIDTH (MDIO45_PRT_DEV_WIDTH + 1)
  118. #define MDIO45_XPRT_ID_MASK ((1 << MDIO45_XPRT_ID_WIDTH) - 1)
  119. #define MDIO45_XPRT_ID_IS10G (1 << (MDIO45_XPRT_ID_WIDTH - 1))
  120. #define MDIO45_PRT_ID_COMP_LBN MDIO45_DEV_ID_WIDTH
  121. #define MDIO45_PRT_ID_COMP_WIDTH MDIO45_PRT_ID_WIDTH
  122. #define MDIO45_DEV_ID_COMP_LBN 0
  123. #define MDIO45_DEV_ID_COMP_WIDTH MDIO45_DEV_ID_WIDTH
  124. /* Compose port and device into a phy_id */
  125. static inline int mdio_clause45_pack(u8 prt, u8 dev)
  126. {
  127. efx_dword_t phy_id;
  128. EFX_POPULATE_DWORD_2(phy_id, MDIO45_PRT_ID_COMP, prt,
  129. MDIO45_DEV_ID_COMP, dev);
  130. return MDIO45_XPRT_ID_IS10G | EFX_DWORD_VAL(phy_id);
  131. }
  132. static inline void mdio_clause45_unpack(u32 val, u8 *prt, u8 *dev)
  133. {
  134. efx_dword_t phy_id;
  135. EFX_POPULATE_DWORD_1(phy_id, EFX_DWORD_0, val);
  136. *prt = EFX_DWORD_FIELD(phy_id, MDIO45_PRT_ID_COMP);
  137. *dev = EFX_DWORD_FIELD(phy_id, MDIO45_DEV_ID_COMP);
  138. }
  139. static inline int mdio_clause45_read(struct efx_nic *efx,
  140. u8 prt, u8 dev, u16 addr)
  141. {
  142. return efx->mii.mdio_read(efx->net_dev,
  143. mdio_clause45_pack(prt, dev), addr);
  144. }
  145. static inline void mdio_clause45_write(struct efx_nic *efx,
  146. u8 prt, u8 dev, u16 addr, int value)
  147. {
  148. efx->mii.mdio_write(efx->net_dev,
  149. mdio_clause45_pack(prt, dev), addr, value);
  150. }
  151. static inline u32 mdio_clause45_read_id(struct efx_nic *efx, int mmd)
  152. {
  153. int phy_id = efx->mii.phy_id;
  154. u16 id_low = mdio_clause45_read(efx, phy_id, mmd, MDIO_MMDREG_IDLOW);
  155. u16 id_hi = mdio_clause45_read(efx, phy_id, mmd, MDIO_MMDREG_IDHI);
  156. return (id_hi << 16) | (id_low);
  157. }
  158. static inline int mdio_clause45_phyxgxs_lane_sync(struct efx_nic *efx)
  159. {
  160. int i, sync, lane_status;
  161. for (i = 0; i < 2; ++i)
  162. lane_status = mdio_clause45_read(efx, efx->mii.phy_id,
  163. MDIO_MMD_PHYXS,
  164. MDIO_PHYXS_LANE_STATE);
  165. sync = (lane_status & (1 << MDIO_PHYXS_LANE_ALIGNED_LBN)) != 0;
  166. if (!sync)
  167. EFX_INFO(efx, "XGXS lane status: %x\n", lane_status);
  168. return sync;
  169. }
  170. extern const char *mdio_clause45_mmd_name(int mmd);
  171. /*
  172. * Reset a specific MMD and wait for reset to clear.
  173. * Return number of spins left (>0) on success, -%ETIMEDOUT on failure.
  174. *
  175. * This function will sleep
  176. */
  177. extern int mdio_clause45_reset_mmd(struct efx_nic *efx, int mmd,
  178. int spins, int spintime);
  179. /* As mdio_clause45_check_mmd but for multiple MMDs */
  180. int mdio_clause45_check_mmds(struct efx_nic *efx,
  181. unsigned int mmd_mask, unsigned int fatal_mask);
  182. /* Check the link status of specified mmds in bit mask */
  183. extern int mdio_clause45_links_ok(struct efx_nic *efx,
  184. unsigned int mmd_mask);
  185. /* Read (some of) the PHY settings over MDIO */
  186. extern void mdio_clause45_get_settings(struct efx_nic *efx,
  187. struct ethtool_cmd *ecmd);
  188. /* Set (some of) the PHY settings over MDIO */
  189. extern int mdio_clause45_set_settings(struct efx_nic *efx,
  190. struct ethtool_cmd *ecmd);
  191. /* Wait for specified MMDs to exit reset within a timeout */
  192. extern int mdio_clause45_wait_reset_mmds(struct efx_nic *efx,
  193. unsigned int mmd_mask);
  194. #endif /* EFX_MDIO_10G_H */