lxt971a.h 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. /***********************************************************************
  2. *
  3. * Copyright (C) 2004 by FS Forth-Systeme GmbH.
  4. * All rights reserved.
  5. *
  6. * $Id: ns9750_eth.h,v 1.2 2004/02/24 13:25:39 mpietrek Exp $
  7. * @Author: Markus Pietrek
  8. * @References: [1] NS9750 Hardware Reference, December 2003
  9. * [2] Intel LXT971 Datasheet #249414 Rev. 02
  10. * [3] NS7520 Linux Ethernet Driver
  11. *
  12. * SPDX-License-Identifier: GPL-2.0+
  13. */
  14. #ifndef __LXT971A_H__
  15. #define __LXT971A_H__
  16. /* PHY definitions (LXT971A) [2] */
  17. #define PHY_LXT971_PORT_CFG (0x10)
  18. #define PHY_LXT971_STAT2 (0x11)
  19. #define PHY_LXT971_INT_ENABLE (0x12)
  20. #define PHY_LXT971_INT_STATUS (0x13)
  21. #define PHY_LXT971_LED_CFG (0x14)
  22. #define PHY_LXT971_DIG_CFG (0x1A)
  23. #define PHY_LXT971_TX_CTRL (0x1E)
  24. /* PORT_CFG Port Configuration Register Bit Fields */
  25. #define PHY_LXT971_PORT_CFG_RES1 (0x8000)
  26. #define PHY_LXT971_PORT_CFG_FORCE_LNK (0x4000)
  27. #define PHY_LXT971_PORT_CFG_TX_DISABLE (0x2000)
  28. #define PHY_LXT971_PORT_CFG_BYPASS_SCR (0x1000)
  29. #define PHY_LXT971_PORT_CFG_RES2 (0x0800)
  30. #define PHY_LXT971_PORT_CFG_JABBER (0x0400)
  31. #define PHY_LXT971_PORT_CFG_SQE (0x0200)
  32. #define PHY_LXT971_PORT_CFG_TP_LOOPBACK (0x0100)
  33. #define PHY_LXT971_PORT_CFG_CRS_SEL (0x0080)
  34. #define PHY_LXT971_PORT_CFG_SLEEP_MODE (0x0040)
  35. #define PHY_LXT971_PORT_CFG_PRE_EN (0x0020)
  36. #define PHY_LXT971_PORT_CFG_SLEEP_T_MA (0x0018)
  37. #define PHY_LXT971_PORT_CFG_SLEEP_T_104 (0x0010)
  38. #define PHY_LXT971_PORT_CFG_SLEEP_T_200 (0x0001)
  39. #define PHY_LXT971_PORT_CFG_SLEEP_T_304 (0x0000)
  40. #define PHY_LXT971_PORT_CFG_FLT_CODE_EN (0x0004)
  41. #define PHY_LXT971_PORT_CFG_ALT_NP (0x0002)
  42. #define PHY_LXT971_PORT_CFG_FIBER_SEL (0x0001)
  43. /* STAT2 Status Register #2 Bit Fields */
  44. #define PHY_LXT971_STAT2_RES1 (0x8000)
  45. #define PHY_LXT971_STAT2_100BTX (0x4000)
  46. #define PHY_LXT971_STAT2_TX_STATUS (0x2000)
  47. #define PHY_LXT971_STAT2_RX_STATUS (0x1000)
  48. #define PHY_LXT971_STAT2_COL_STATUS (0x0800)
  49. #define PHY_LXT971_STAT2_LINK (0x0400)
  50. #define PHY_LXT971_STAT2_DUPLEX_MODE (0x0200)
  51. #define PHY_LXT971_STAT2_AUTO_NEG (0x0100)
  52. #define PHY_LXT971_STAT2_AUTO_NEG_COMP (0x0080)
  53. #define PHY_LXT971_STAT2_RES2 (0x0040)
  54. #define PHY_LXT971_STAT2_POLARITY (0x0020)
  55. #define PHY_LXT971_STAT2_PAUSE (0x0010)
  56. #define PHY_LXT971_STAT2_ERROR (0x0008)
  57. #define PHY_LXT971_STAT2_RES3 (0x0007)
  58. /* INT_ENABLE Interrupt Enable Register Bit Fields */
  59. #define PHY_LXT971_INT_ENABLE_RES1 (0xFF00)
  60. #define PHY_LXT971_INT_ENABLE_ANMSK (0x0080)
  61. #define PHY_LXT971_INT_ENABLE_SPEEDMSK (0x0040)
  62. #define PHY_LXT971_INT_ENABLE_DUPLEXMSK (0x0020)
  63. #define PHY_LXT971_INT_ENABLE_LINKMSK (0x0010)
  64. #define PHY_LXT971_INT_ENABLE_RES2 (0x000C)
  65. #define PHY_LXT971_INT_ENABLE_INTEN (0x0002)
  66. #define PHY_LXT971_INT_ENABLE_TINT (0x0001)
  67. /* INT_STATUS Interrupt Status Register Bit Fields */
  68. #define PHY_LXT971_INT_STATUS_RES1 (0xFF00)
  69. #define PHY_LXT971_INT_STATUS_ANDONE (0x0080)
  70. #define PHY_LXT971_INT_STATUS_SPEEDCHG (0x0040)
  71. #define PHY_LXT971_INT_STATUS_DUPLEXCHG (0x0020)
  72. #define PHY_LXT971_INT_STATUS_LINKCHG (0x0010)
  73. #define PHY_LXT971_INT_STATUS_RES2 (0x0008)
  74. #define PHY_LXT971_INT_STATUS_MDINT (0x0004)
  75. #define PHY_LXT971_INT_STATUS_RES3 (0x0003)
  76. /* LED_CFG Interrupt LED Configuration Register Bit Fields */
  77. #define PHY_LXT971_LED_CFG_SHIFT_LED1 (0x000C)
  78. #define PHY_LXT971_LED_CFG_SHIFT_LED2 (0x0008)
  79. #define PHY_LXT971_LED_CFG_SHIFT_LED3 (0x0004)
  80. #define PHY_LXT971_LED_CFG_LEDFREQ_MA (0x000C)
  81. #define PHY_LXT971_LED_CFG_LEDFREQ_RES (0x000C)
  82. #define PHY_LXT971_LED_CFG_LEDFREQ_100 (0x0008)
  83. #define PHY_LXT971_LED_CFG_LEDFREQ_60 (0x0004)
  84. #define PHY_LXT971_LED_CFG_LEDFREQ_30 (0x0000)
  85. #define PHY_LXT971_LED_CFG_PULSE_STR (0x0002)
  86. #define PHY_LXT971_LED_CFG_RES1 (0x0001)
  87. /* only one of these values must be shifted for each SHIFT_LED? */
  88. #define PHY_LXT971_LED_CFG_UNUSED1 (0x000F)
  89. #define PHY_LXT971_LED_CFG_DUPLEX_COL (0x000E)
  90. #define PHY_LXT971_LED_CFG_LINK_ACT (0x000D)
  91. #define PHY_LXT971_LED_CFG_LINK_RX (0x000C)
  92. #define PHY_LXT971_LED_CFG_TEST_BLK_SLW (0x000B)
  93. #define PHY_LXT971_LED_CFG_TEST_BLK_FST (0x000A)
  94. #define PHY_LXT971_LED_CFG_TEST_OFF (0x0009)
  95. #define PHY_LXT971_LED_CFG_TEST_ON (0x0008)
  96. #define PHY_LXT971_LED_CFG_RX_OR_TX (0x0007)
  97. #define PHY_LXT971_LED_CFG_UNUSED2 (0x0006)
  98. #define PHY_LXT971_LED_CFG_DUPLEX (0x0005)
  99. #define PHY_LXT971_LED_CFG_LINK (0x0004)
  100. #define PHY_LXT971_LED_CFG_COLLISION (0x0003)
  101. #define PHY_LXT971_LED_CFG_RECEIVE (0x0002)
  102. #define PHY_LXT971_LED_CFG_TRANSMIT (0x0001)
  103. #define PHY_LXT971_LED_CFG_SPEED (0x0000)
  104. /* DIG_CFG Digitial Configuration Register Bit Fields */
  105. #define PHY_LXT971_DIG_CFG_RES1 (0xF000)
  106. #define PHY_LXT971_DIG_CFG_MII_DRIVE (0x0800)
  107. #define PHY_LXT971_DIG_CFG_RES2 (0x0400)
  108. #define PHY_LXT971_DIG_CFG_SHOW_SYMBOL (0x0200)
  109. #define PHY_LXT971_DIG_CFG_RES3 (0x01FF)
  110. #define PHY_LXT971_MDIO_MAX_CLK (8000000)
  111. #define PHY_MDIO_MAX_CLK (2500000)
  112. /* TX_CTRL Transmit Control Register Bit Fields
  113. documentation is buggy for this register, therefore setting not included */
  114. typedef enum
  115. {
  116. PHY_NONE = 0x0000, /* no PHY detected yet */
  117. PHY_LXT971A = 0x0013
  118. } PhyType;
  119. #endif /* __LXT971A_H__ */