regs.h 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468
  1. /*****************************************************************************
  2. * *
  3. * File: regs.h *
  4. * $Revision: 1.8 $ *
  5. * $Date: 2005/06/21 18:29:48 $ *
  6. * Description: *
  7. * part of the Chelsio 10Gb Ethernet Driver. *
  8. * *
  9. * This program is free software; you can redistribute it and/or modify *
  10. * it under the terms of the GNU General Public License, version 2, as *
  11. * published by the Free Software Foundation. *
  12. * *
  13. * You should have received a copy of the GNU General Public License along *
  14. * with this program; if not, write to the Free Software Foundation, Inc., *
  15. * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
  16. * *
  17. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED *
  18. * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF *
  19. * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. *
  20. * *
  21. * http://www.chelsio.com *
  22. * *
  23. * Copyright (c) 2003 - 2005 Chelsio Communications, Inc. *
  24. * All rights reserved. *
  25. * *
  26. * Maintainers: maintainers@chelsio.com *
  27. * *
  28. * Authors: Dimitrios Michailidis <dm@chelsio.com> *
  29. * Tina Yang <tainay@chelsio.com> *
  30. * Felix Marti <felix@chelsio.com> *
  31. * Scott Bardone <sbardone@chelsio.com> *
  32. * Kurt Ottaway <kottaway@chelsio.com> *
  33. * Frank DiMambro <frank@chelsio.com> *
  34. * *
  35. * History: *
  36. * *
  37. ****************************************************************************/
  38. #ifndef _CXGB_REGS_H_
  39. #define _CXGB_REGS_H_
  40. /* SGE registers */
  41. #define A_SG_CONTROL 0x0
  42. #define S_CMDQ0_ENABLE 0
  43. #define V_CMDQ0_ENABLE(x) ((x) << S_CMDQ0_ENABLE)
  44. #define F_CMDQ0_ENABLE V_CMDQ0_ENABLE(1U)
  45. #define S_CMDQ1_ENABLE 1
  46. #define V_CMDQ1_ENABLE(x) ((x) << S_CMDQ1_ENABLE)
  47. #define F_CMDQ1_ENABLE V_CMDQ1_ENABLE(1U)
  48. #define S_FL0_ENABLE 2
  49. #define V_FL0_ENABLE(x) ((x) << S_FL0_ENABLE)
  50. #define F_FL0_ENABLE V_FL0_ENABLE(1U)
  51. #define S_FL1_ENABLE 3
  52. #define V_FL1_ENABLE(x) ((x) << S_FL1_ENABLE)
  53. #define F_FL1_ENABLE V_FL1_ENABLE(1U)
  54. #define S_CPL_ENABLE 4
  55. #define V_CPL_ENABLE(x) ((x) << S_CPL_ENABLE)
  56. #define F_CPL_ENABLE V_CPL_ENABLE(1U)
  57. #define S_RESPONSE_QUEUE_ENABLE 5
  58. #define V_RESPONSE_QUEUE_ENABLE(x) ((x) << S_RESPONSE_QUEUE_ENABLE)
  59. #define F_RESPONSE_QUEUE_ENABLE V_RESPONSE_QUEUE_ENABLE(1U)
  60. #define S_CMDQ_PRIORITY 6
  61. #define M_CMDQ_PRIORITY 0x3
  62. #define V_CMDQ_PRIORITY(x) ((x) << S_CMDQ_PRIORITY)
  63. #define G_CMDQ_PRIORITY(x) (((x) >> S_CMDQ_PRIORITY) & M_CMDQ_PRIORITY)
  64. #define S_DISABLE_CMDQ1_GTS 9
  65. #define V_DISABLE_CMDQ1_GTS(x) ((x) << S_DISABLE_CMDQ1_GTS)
  66. #define F_DISABLE_CMDQ1_GTS V_DISABLE_CMDQ1_GTS(1U)
  67. #define S_DISABLE_FL0_GTS 10
  68. #define V_DISABLE_FL0_GTS(x) ((x) << S_DISABLE_FL0_GTS)
  69. #define F_DISABLE_FL0_GTS V_DISABLE_FL0_GTS(1U)
  70. #define S_DISABLE_FL1_GTS 11
  71. #define V_DISABLE_FL1_GTS(x) ((x) << S_DISABLE_FL1_GTS)
  72. #define F_DISABLE_FL1_GTS V_DISABLE_FL1_GTS(1U)
  73. #define S_ENABLE_BIG_ENDIAN 12
  74. #define V_ENABLE_BIG_ENDIAN(x) ((x) << S_ENABLE_BIG_ENDIAN)
  75. #define F_ENABLE_BIG_ENDIAN V_ENABLE_BIG_ENDIAN(1U)
  76. #define S_ISCSI_COALESCE 14
  77. #define V_ISCSI_COALESCE(x) ((x) << S_ISCSI_COALESCE)
  78. #define F_ISCSI_COALESCE V_ISCSI_COALESCE(1U)
  79. #define S_RX_PKT_OFFSET 15
  80. #define V_RX_PKT_OFFSET(x) ((x) << S_RX_PKT_OFFSET)
  81. #define S_VLAN_XTRACT 18
  82. #define V_VLAN_XTRACT(x) ((x) << S_VLAN_XTRACT)
  83. #define F_VLAN_XTRACT V_VLAN_XTRACT(1U)
  84. #define A_SG_DOORBELL 0x4
  85. #define A_SG_CMD0BASELWR 0x8
  86. #define A_SG_CMD0BASEUPR 0xc
  87. #define A_SG_CMD1BASELWR 0x10
  88. #define A_SG_CMD1BASEUPR 0x14
  89. #define A_SG_FL0BASELWR 0x18
  90. #define A_SG_FL0BASEUPR 0x1c
  91. #define A_SG_FL1BASELWR 0x20
  92. #define A_SG_FL1BASEUPR 0x24
  93. #define A_SG_CMD0SIZE 0x28
  94. #define A_SG_FL0SIZE 0x2c
  95. #define A_SG_RSPSIZE 0x30
  96. #define A_SG_RSPBASELWR 0x34
  97. #define A_SG_RSPBASEUPR 0x38
  98. #define A_SG_FLTHRESHOLD 0x3c
  99. #define A_SG_RSPQUEUECREDIT 0x40
  100. #define A_SG_SLEEPING 0x48
  101. #define A_SG_INTRTIMER 0x4c
  102. #define A_SG_CMD1SIZE 0xb0
  103. #define A_SG_FL1SIZE 0xb4
  104. #define A_SG_INT_ENABLE 0xb8
  105. #define S_RESPQ_EXHAUSTED 0
  106. #define V_RESPQ_EXHAUSTED(x) ((x) << S_RESPQ_EXHAUSTED)
  107. #define F_RESPQ_EXHAUSTED V_RESPQ_EXHAUSTED(1U)
  108. #define S_RESPQ_OVERFLOW 1
  109. #define V_RESPQ_OVERFLOW(x) ((x) << S_RESPQ_OVERFLOW)
  110. #define F_RESPQ_OVERFLOW V_RESPQ_OVERFLOW(1U)
  111. #define S_FL_EXHAUSTED 2
  112. #define V_FL_EXHAUSTED(x) ((x) << S_FL_EXHAUSTED)
  113. #define F_FL_EXHAUSTED V_FL_EXHAUSTED(1U)
  114. #define S_PACKET_TOO_BIG 3
  115. #define V_PACKET_TOO_BIG(x) ((x) << S_PACKET_TOO_BIG)
  116. #define F_PACKET_TOO_BIG V_PACKET_TOO_BIG(1U)
  117. #define S_PACKET_MISMATCH 4
  118. #define V_PACKET_MISMATCH(x) ((x) << S_PACKET_MISMATCH)
  119. #define F_PACKET_MISMATCH V_PACKET_MISMATCH(1U)
  120. #define A_SG_INT_CAUSE 0xbc
  121. #define A_SG_RESPACCUTIMER 0xc0
  122. /* MC3 registers */
  123. #define S_READY 1
  124. #define V_READY(x) ((x) << S_READY)
  125. #define F_READY V_READY(1U)
  126. /* MC4 registers */
  127. #define A_MC4_CFG 0x180
  128. #define S_MC4_SLOW 25
  129. #define V_MC4_SLOW(x) ((x) << S_MC4_SLOW)
  130. #define F_MC4_SLOW V_MC4_SLOW(1U)
  131. /* TPI registers */
  132. #define A_TPI_ADDR 0x280
  133. #define A_TPI_WR_DATA 0x284
  134. #define A_TPI_RD_DATA 0x288
  135. #define A_TPI_CSR 0x28c
  136. #define S_TPIWR 0
  137. #define V_TPIWR(x) ((x) << S_TPIWR)
  138. #define F_TPIWR V_TPIWR(1U)
  139. #define S_TPIRDY 1
  140. #define V_TPIRDY(x) ((x) << S_TPIRDY)
  141. #define F_TPIRDY V_TPIRDY(1U)
  142. #define A_TPI_PAR 0x29c
  143. #define S_TPIPAR 0
  144. #define M_TPIPAR 0x7f
  145. #define V_TPIPAR(x) ((x) << S_TPIPAR)
  146. #define G_TPIPAR(x) (((x) >> S_TPIPAR) & M_TPIPAR)
  147. /* TP registers */
  148. #define A_TP_IN_CONFIG 0x300
  149. #define S_TP_IN_CSPI_CPL 3
  150. #define V_TP_IN_CSPI_CPL(x) ((x) << S_TP_IN_CSPI_CPL)
  151. #define F_TP_IN_CSPI_CPL V_TP_IN_CSPI_CPL(1U)
  152. #define S_TP_IN_CSPI_CHECK_IP_CSUM 5
  153. #define V_TP_IN_CSPI_CHECK_IP_CSUM(x) ((x) << S_TP_IN_CSPI_CHECK_IP_CSUM)
  154. #define F_TP_IN_CSPI_CHECK_IP_CSUM V_TP_IN_CSPI_CHECK_IP_CSUM(1U)
  155. #define S_TP_IN_CSPI_CHECK_TCP_CSUM 6
  156. #define V_TP_IN_CSPI_CHECK_TCP_CSUM(x) ((x) << S_TP_IN_CSPI_CHECK_TCP_CSUM)
  157. #define F_TP_IN_CSPI_CHECK_TCP_CSUM V_TP_IN_CSPI_CHECK_TCP_CSUM(1U)
  158. #define S_TP_IN_ESPI_ETHERNET 8
  159. #define V_TP_IN_ESPI_ETHERNET(x) ((x) << S_TP_IN_ESPI_ETHERNET)
  160. #define F_TP_IN_ESPI_ETHERNET V_TP_IN_ESPI_ETHERNET(1U)
  161. #define S_TP_IN_ESPI_CHECK_IP_CSUM 12
  162. #define V_TP_IN_ESPI_CHECK_IP_CSUM(x) ((x) << S_TP_IN_ESPI_CHECK_IP_CSUM)
  163. #define F_TP_IN_ESPI_CHECK_IP_CSUM V_TP_IN_ESPI_CHECK_IP_CSUM(1U)
  164. #define S_TP_IN_ESPI_CHECK_TCP_CSUM 13
  165. #define V_TP_IN_ESPI_CHECK_TCP_CSUM(x) ((x) << S_TP_IN_ESPI_CHECK_TCP_CSUM)
  166. #define F_TP_IN_ESPI_CHECK_TCP_CSUM V_TP_IN_ESPI_CHECK_TCP_CSUM(1U)
  167. #define S_OFFLOAD_DISABLE 14
  168. #define V_OFFLOAD_DISABLE(x) ((x) << S_OFFLOAD_DISABLE)
  169. #define F_OFFLOAD_DISABLE V_OFFLOAD_DISABLE(1U)
  170. #define A_TP_OUT_CONFIG 0x304
  171. #define S_TP_OUT_CSPI_CPL 2
  172. #define V_TP_OUT_CSPI_CPL(x) ((x) << S_TP_OUT_CSPI_CPL)
  173. #define F_TP_OUT_CSPI_CPL V_TP_OUT_CSPI_CPL(1U)
  174. #define S_TP_OUT_ESPI_ETHERNET 6
  175. #define V_TP_OUT_ESPI_ETHERNET(x) ((x) << S_TP_OUT_ESPI_ETHERNET)
  176. #define F_TP_OUT_ESPI_ETHERNET V_TP_OUT_ESPI_ETHERNET(1U)
  177. #define S_TP_OUT_ESPI_GENERATE_IP_CSUM 10
  178. #define V_TP_OUT_ESPI_GENERATE_IP_CSUM(x) ((x) << S_TP_OUT_ESPI_GENERATE_IP_CSUM)
  179. #define F_TP_OUT_ESPI_GENERATE_IP_CSUM V_TP_OUT_ESPI_GENERATE_IP_CSUM(1U)
  180. #define S_TP_OUT_ESPI_GENERATE_TCP_CSUM 11
  181. #define V_TP_OUT_ESPI_GENERATE_TCP_CSUM(x) ((x) << S_TP_OUT_ESPI_GENERATE_TCP_CSUM)
  182. #define F_TP_OUT_ESPI_GENERATE_TCP_CSUM V_TP_OUT_ESPI_GENERATE_TCP_CSUM(1U)
  183. #define A_TP_GLOBAL_CONFIG 0x308
  184. #define S_IP_TTL 0
  185. #define M_IP_TTL 0xff
  186. #define V_IP_TTL(x) ((x) << S_IP_TTL)
  187. #define S_TCP_CSUM 11
  188. #define V_TCP_CSUM(x) ((x) << S_TCP_CSUM)
  189. #define F_TCP_CSUM V_TCP_CSUM(1U)
  190. #define S_UDP_CSUM 12
  191. #define V_UDP_CSUM(x) ((x) << S_UDP_CSUM)
  192. #define F_UDP_CSUM V_UDP_CSUM(1U)
  193. #define S_IP_CSUM 13
  194. #define V_IP_CSUM(x) ((x) << S_IP_CSUM)
  195. #define F_IP_CSUM V_IP_CSUM(1U)
  196. #define S_PATH_MTU 15
  197. #define V_PATH_MTU(x) ((x) << S_PATH_MTU)
  198. #define F_PATH_MTU V_PATH_MTU(1U)
  199. #define S_5TUPLE_LOOKUP 17
  200. #define V_5TUPLE_LOOKUP(x) ((x) << S_5TUPLE_LOOKUP)
  201. #define S_SYN_COOKIE_PARAMETER 26
  202. #define V_SYN_COOKIE_PARAMETER(x) ((x) << S_SYN_COOKIE_PARAMETER)
  203. #define A_TP_PC_CONFIG 0x348
  204. #define S_DIS_TX_FILL_WIN_PUSH 12
  205. #define V_DIS_TX_FILL_WIN_PUSH(x) ((x) << S_DIS_TX_FILL_WIN_PUSH)
  206. #define F_DIS_TX_FILL_WIN_PUSH V_DIS_TX_FILL_WIN_PUSH(1U)
  207. #define S_TP_PC_REV 30
  208. #define M_TP_PC_REV 0x3
  209. #define G_TP_PC_REV(x) (((x) >> S_TP_PC_REV) & M_TP_PC_REV)
  210. #define A_TP_RESET 0x44c
  211. #define S_TP_RESET 0
  212. #define V_TP_RESET(x) ((x) << S_TP_RESET)
  213. #define F_TP_RESET V_TP_RESET(1U)
  214. #define A_TP_INT_ENABLE 0x470
  215. #define A_TP_INT_CAUSE 0x474
  216. #define A_TP_TX_DROP_CONFIG 0x4b8
  217. #define S_ENABLE_TX_DROP 31
  218. #define V_ENABLE_TX_DROP(x) ((x) << S_ENABLE_TX_DROP)
  219. #define F_ENABLE_TX_DROP V_ENABLE_TX_DROP(1U)
  220. #define S_ENABLE_TX_ERROR 30
  221. #define V_ENABLE_TX_ERROR(x) ((x) << S_ENABLE_TX_ERROR)
  222. #define F_ENABLE_TX_ERROR V_ENABLE_TX_ERROR(1U)
  223. #define S_DROP_TICKS_CNT 4
  224. #define V_DROP_TICKS_CNT(x) ((x) << S_DROP_TICKS_CNT)
  225. #define S_NUM_PKTS_DROPPED 0
  226. #define V_NUM_PKTS_DROPPED(x) ((x) << S_NUM_PKTS_DROPPED)
  227. /* CSPI registers */
  228. #define S_DIP4ERR 0
  229. #define V_DIP4ERR(x) ((x) << S_DIP4ERR)
  230. #define F_DIP4ERR V_DIP4ERR(1U)
  231. #define S_RXDROP 1
  232. #define V_RXDROP(x) ((x) << S_RXDROP)
  233. #define F_RXDROP V_RXDROP(1U)
  234. #define S_TXDROP 2
  235. #define V_TXDROP(x) ((x) << S_TXDROP)
  236. #define F_TXDROP V_TXDROP(1U)
  237. #define S_RXOVERFLOW 3
  238. #define V_RXOVERFLOW(x) ((x) << S_RXOVERFLOW)
  239. #define F_RXOVERFLOW V_RXOVERFLOW(1U)
  240. #define S_RAMPARITYERR 4
  241. #define V_RAMPARITYERR(x) ((x) << S_RAMPARITYERR)
  242. #define F_RAMPARITYERR V_RAMPARITYERR(1U)
  243. /* ESPI registers */
  244. #define A_ESPI_SCH_TOKEN0 0x880
  245. #define A_ESPI_SCH_TOKEN1 0x884
  246. #define A_ESPI_SCH_TOKEN2 0x888
  247. #define A_ESPI_SCH_TOKEN3 0x88c
  248. #define A_ESPI_RX_FIFO_ALMOST_EMPTY_WATERMARK 0x890
  249. #define A_ESPI_RX_FIFO_ALMOST_FULL_WATERMARK 0x894
  250. #define A_ESPI_CALENDAR_LENGTH 0x898
  251. #define A_PORT_CONFIG 0x89c
  252. #define S_RX_NPORTS 0
  253. #define V_RX_NPORTS(x) ((x) << S_RX_NPORTS)
  254. #define S_TX_NPORTS 8
  255. #define V_TX_NPORTS(x) ((x) << S_TX_NPORTS)
  256. #define A_ESPI_FIFO_STATUS_ENABLE 0x8a0
  257. #define S_RXSTATUSENABLE 0
  258. #define V_RXSTATUSENABLE(x) ((x) << S_RXSTATUSENABLE)
  259. #define F_RXSTATUSENABLE V_RXSTATUSENABLE(1U)
  260. #define S_INTEL1010MODE 4
  261. #define V_INTEL1010MODE(x) ((x) << S_INTEL1010MODE)
  262. #define F_INTEL1010MODE V_INTEL1010MODE(1U)
  263. #define A_ESPI_MAXBURST1_MAXBURST2 0x8a8
  264. #define A_ESPI_TRAIN 0x8ac
  265. #define A_ESPI_INTR_STATUS 0x8c8
  266. #define S_DIP2PARITYERR 5
  267. #define V_DIP2PARITYERR(x) ((x) << S_DIP2PARITYERR)
  268. #define F_DIP2PARITYERR V_DIP2PARITYERR(1U)
  269. #define A_ESPI_INTR_ENABLE 0x8cc
  270. #define A_RX_DROP_THRESHOLD 0x8d0
  271. #define A_ESPI_RX_RESET 0x8ec
  272. #define A_ESPI_MISC_CONTROL 0x8f0
  273. #define S_OUT_OF_SYNC_COUNT 0
  274. #define V_OUT_OF_SYNC_COUNT(x) ((x) << S_OUT_OF_SYNC_COUNT)
  275. #define S_DIP2_PARITY_ERR_THRES 5
  276. #define V_DIP2_PARITY_ERR_THRES(x) ((x) << S_DIP2_PARITY_ERR_THRES)
  277. #define S_DIP4_THRES 9
  278. #define V_DIP4_THRES(x) ((x) << S_DIP4_THRES)
  279. #define S_MONITORED_PORT_NUM 25
  280. #define V_MONITORED_PORT_NUM(x) ((x) << S_MONITORED_PORT_NUM)
  281. #define S_MONITORED_DIRECTION 27
  282. #define V_MONITORED_DIRECTION(x) ((x) << S_MONITORED_DIRECTION)
  283. #define F_MONITORED_DIRECTION V_MONITORED_DIRECTION(1U)
  284. #define S_MONITORED_INTERFACE 28
  285. #define V_MONITORED_INTERFACE(x) ((x) << S_MONITORED_INTERFACE)
  286. #define F_MONITORED_INTERFACE V_MONITORED_INTERFACE(1U)
  287. #define A_ESPI_DIP2_ERR_COUNT 0x8f4
  288. #define A_ESPI_CMD_ADDR 0x8f8
  289. #define S_WRITE_DATA 0
  290. #define V_WRITE_DATA(x) ((x) << S_WRITE_DATA)
  291. #define S_REGISTER_OFFSET 8
  292. #define V_REGISTER_OFFSET(x) ((x) << S_REGISTER_OFFSET)
  293. #define S_CHANNEL_ADDR 12
  294. #define V_CHANNEL_ADDR(x) ((x) << S_CHANNEL_ADDR)
  295. #define S_MODULE_ADDR 16
  296. #define V_MODULE_ADDR(x) ((x) << S_MODULE_ADDR)
  297. #define S_BUNDLE_ADDR 20
  298. #define V_BUNDLE_ADDR(x) ((x) << S_BUNDLE_ADDR)
  299. #define S_SPI4_COMMAND 24
  300. #define V_SPI4_COMMAND(x) ((x) << S_SPI4_COMMAND)
  301. #define A_ESPI_GOSTAT 0x8fc
  302. #define S_ESPI_CMD_BUSY 8
  303. #define V_ESPI_CMD_BUSY(x) ((x) << S_ESPI_CMD_BUSY)
  304. #define F_ESPI_CMD_BUSY V_ESPI_CMD_BUSY(1U)
  305. /* PL registers */
  306. #define A_PL_ENABLE 0xa00
  307. #define S_PL_INTR_SGE_ERR 0
  308. #define V_PL_INTR_SGE_ERR(x) ((x) << S_PL_INTR_SGE_ERR)
  309. #define F_PL_INTR_SGE_ERR V_PL_INTR_SGE_ERR(1U)
  310. #define S_PL_INTR_SGE_DATA 1
  311. #define V_PL_INTR_SGE_DATA(x) ((x) << S_PL_INTR_SGE_DATA)
  312. #define F_PL_INTR_SGE_DATA V_PL_INTR_SGE_DATA(1U)
  313. #define S_PL_INTR_TP 6
  314. #define V_PL_INTR_TP(x) ((x) << S_PL_INTR_TP)
  315. #define F_PL_INTR_TP V_PL_INTR_TP(1U)
  316. #define S_PL_INTR_ESPI 8
  317. #define V_PL_INTR_ESPI(x) ((x) << S_PL_INTR_ESPI)
  318. #define F_PL_INTR_ESPI V_PL_INTR_ESPI(1U)
  319. #define S_PL_INTR_PCIX 10
  320. #define V_PL_INTR_PCIX(x) ((x) << S_PL_INTR_PCIX)
  321. #define F_PL_INTR_PCIX V_PL_INTR_PCIX(1U)
  322. #define S_PL_INTR_EXT 11
  323. #define V_PL_INTR_EXT(x) ((x) << S_PL_INTR_EXT)
  324. #define F_PL_INTR_EXT V_PL_INTR_EXT(1U)
  325. #define A_PL_CAUSE 0xa04
  326. /* MC5 registers */
  327. #define A_MC5_CONFIG 0xc04
  328. #define S_TCAM_RESET 1
  329. #define V_TCAM_RESET(x) ((x) << S_TCAM_RESET)
  330. #define F_TCAM_RESET V_TCAM_RESET(1U)
  331. #define S_M_BUS_ENABLE 5
  332. #define V_M_BUS_ENABLE(x) ((x) << S_M_BUS_ENABLE)
  333. #define F_M_BUS_ENABLE V_M_BUS_ENABLE(1U)
  334. /* PCICFG registers */
  335. #define A_PCICFG_PM_CSR 0x44
  336. #define A_PCICFG_VPD_ADDR 0x4a
  337. #define S_VPD_OP_FLAG 15
  338. #define V_VPD_OP_FLAG(x) ((x) << S_VPD_OP_FLAG)
  339. #define F_VPD_OP_FLAG V_VPD_OP_FLAG(1U)
  340. #define A_PCICFG_VPD_DATA 0x4c
  341. #define A_PCICFG_INTR_ENABLE 0xf4
  342. #define A_PCICFG_INTR_CAUSE 0xf8
  343. #define A_PCICFG_MODE 0xfc
  344. #define S_PCI_MODE_64BIT 0
  345. #define V_PCI_MODE_64BIT(x) ((x) << S_PCI_MODE_64BIT)
  346. #define F_PCI_MODE_64BIT V_PCI_MODE_64BIT(1U)
  347. #define S_PCI_MODE_PCIX 5
  348. #define V_PCI_MODE_PCIX(x) ((x) << S_PCI_MODE_PCIX)
  349. #define F_PCI_MODE_PCIX V_PCI_MODE_PCIX(1U)
  350. #define S_PCI_MODE_CLK 6
  351. #define M_PCI_MODE_CLK 0x3
  352. #define G_PCI_MODE_CLK(x) (((x) >> S_PCI_MODE_CLK) & M_PCI_MODE_CLK)
  353. #endif /* _CXGB_REGS_H_ */