regs.h 73 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169
  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_CMDQ0_GTS 8
  65. #define V_DISABLE_CMDQ0_GTS(x) ((x) << S_DISABLE_CMDQ0_GTS)
  66. #define F_DISABLE_CMDQ0_GTS V_DISABLE_CMDQ0_GTS(1U)
  67. #define S_DISABLE_CMDQ1_GTS 9
  68. #define V_DISABLE_CMDQ1_GTS(x) ((x) << S_DISABLE_CMDQ1_GTS)
  69. #define F_DISABLE_CMDQ1_GTS V_DISABLE_CMDQ1_GTS(1U)
  70. #define S_DISABLE_FL0_GTS 10
  71. #define V_DISABLE_FL0_GTS(x) ((x) << S_DISABLE_FL0_GTS)
  72. #define F_DISABLE_FL0_GTS V_DISABLE_FL0_GTS(1U)
  73. #define S_DISABLE_FL1_GTS 11
  74. #define V_DISABLE_FL1_GTS(x) ((x) << S_DISABLE_FL1_GTS)
  75. #define F_DISABLE_FL1_GTS V_DISABLE_FL1_GTS(1U)
  76. #define S_ENABLE_BIG_ENDIAN 12
  77. #define V_ENABLE_BIG_ENDIAN(x) ((x) << S_ENABLE_BIG_ENDIAN)
  78. #define F_ENABLE_BIG_ENDIAN V_ENABLE_BIG_ENDIAN(1U)
  79. #define S_FL_SELECTION_CRITERIA 13
  80. #define V_FL_SELECTION_CRITERIA(x) ((x) << S_FL_SELECTION_CRITERIA)
  81. #define F_FL_SELECTION_CRITERIA V_FL_SELECTION_CRITERIA(1U)
  82. #define S_ISCSI_COALESCE 14
  83. #define V_ISCSI_COALESCE(x) ((x) << S_ISCSI_COALESCE)
  84. #define F_ISCSI_COALESCE V_ISCSI_COALESCE(1U)
  85. #define S_RX_PKT_OFFSET 15
  86. #define M_RX_PKT_OFFSET 0x7
  87. #define V_RX_PKT_OFFSET(x) ((x) << S_RX_PKT_OFFSET)
  88. #define G_RX_PKT_OFFSET(x) (((x) >> S_RX_PKT_OFFSET) & M_RX_PKT_OFFSET)
  89. #define S_VLAN_XTRACT 18
  90. #define V_VLAN_XTRACT(x) ((x) << S_VLAN_XTRACT)
  91. #define F_VLAN_XTRACT V_VLAN_XTRACT(1U)
  92. #define A_SG_DOORBELL 0x4
  93. #define A_SG_CMD0BASELWR 0x8
  94. #define A_SG_CMD0BASEUPR 0xc
  95. #define A_SG_CMD1BASELWR 0x10
  96. #define A_SG_CMD1BASEUPR 0x14
  97. #define A_SG_FL0BASELWR 0x18
  98. #define A_SG_FL0BASEUPR 0x1c
  99. #define A_SG_FL1BASELWR 0x20
  100. #define A_SG_FL1BASEUPR 0x24
  101. #define A_SG_CMD0SIZE 0x28
  102. #define S_CMDQ0_SIZE 0
  103. #define M_CMDQ0_SIZE 0x1ffff
  104. #define V_CMDQ0_SIZE(x) ((x) << S_CMDQ0_SIZE)
  105. #define G_CMDQ0_SIZE(x) (((x) >> S_CMDQ0_SIZE) & M_CMDQ0_SIZE)
  106. #define A_SG_FL0SIZE 0x2c
  107. #define S_FL0_SIZE 0
  108. #define M_FL0_SIZE 0x1ffff
  109. #define V_FL0_SIZE(x) ((x) << S_FL0_SIZE)
  110. #define G_FL0_SIZE(x) (((x) >> S_FL0_SIZE) & M_FL0_SIZE)
  111. #define A_SG_RSPSIZE 0x30
  112. #define S_RESPQ_SIZE 0
  113. #define M_RESPQ_SIZE 0x1ffff
  114. #define V_RESPQ_SIZE(x) ((x) << S_RESPQ_SIZE)
  115. #define G_RESPQ_SIZE(x) (((x) >> S_RESPQ_SIZE) & M_RESPQ_SIZE)
  116. #define A_SG_RSPBASELWR 0x34
  117. #define A_SG_RSPBASEUPR 0x38
  118. #define A_SG_FLTHRESHOLD 0x3c
  119. #define S_FL_THRESHOLD 0
  120. #define M_FL_THRESHOLD 0xffff
  121. #define V_FL_THRESHOLD(x) ((x) << S_FL_THRESHOLD)
  122. #define G_FL_THRESHOLD(x) (((x) >> S_FL_THRESHOLD) & M_FL_THRESHOLD)
  123. #define A_SG_RSPQUEUECREDIT 0x40
  124. #define S_RESPQ_CREDIT 0
  125. #define M_RESPQ_CREDIT 0x1ffff
  126. #define V_RESPQ_CREDIT(x) ((x) << S_RESPQ_CREDIT)
  127. #define G_RESPQ_CREDIT(x) (((x) >> S_RESPQ_CREDIT) & M_RESPQ_CREDIT)
  128. #define A_SG_SLEEPING 0x48
  129. #define S_SLEEPING 0
  130. #define M_SLEEPING 0xffff
  131. #define V_SLEEPING(x) ((x) << S_SLEEPING)
  132. #define G_SLEEPING(x) (((x) >> S_SLEEPING) & M_SLEEPING)
  133. #define A_SG_INTRTIMER 0x4c
  134. #define S_INTERRUPT_TIMER_COUNT 0
  135. #define M_INTERRUPT_TIMER_COUNT 0xffffff
  136. #define V_INTERRUPT_TIMER_COUNT(x) ((x) << S_INTERRUPT_TIMER_COUNT)
  137. #define G_INTERRUPT_TIMER_COUNT(x) (((x) >> S_INTERRUPT_TIMER_COUNT) & M_INTERRUPT_TIMER_COUNT)
  138. #define A_SG_CMD0PTR 0x50
  139. #define S_CMDQ0_POINTER 0
  140. #define M_CMDQ0_POINTER 0xffff
  141. #define V_CMDQ0_POINTER(x) ((x) << S_CMDQ0_POINTER)
  142. #define G_CMDQ0_POINTER(x) (((x) >> S_CMDQ0_POINTER) & M_CMDQ0_POINTER)
  143. #define S_CURRENT_GENERATION_BIT 16
  144. #define V_CURRENT_GENERATION_BIT(x) ((x) << S_CURRENT_GENERATION_BIT)
  145. #define F_CURRENT_GENERATION_BIT V_CURRENT_GENERATION_BIT(1U)
  146. #define A_SG_CMD1PTR 0x54
  147. #define S_CMDQ1_POINTER 0
  148. #define M_CMDQ1_POINTER 0xffff
  149. #define V_CMDQ1_POINTER(x) ((x) << S_CMDQ1_POINTER)
  150. #define G_CMDQ1_POINTER(x) (((x) >> S_CMDQ1_POINTER) & M_CMDQ1_POINTER)
  151. #define A_SG_FL0PTR 0x58
  152. #define S_FL0_POINTER 0
  153. #define M_FL0_POINTER 0xffff
  154. #define V_FL0_POINTER(x) ((x) << S_FL0_POINTER)
  155. #define G_FL0_POINTER(x) (((x) >> S_FL0_POINTER) & M_FL0_POINTER)
  156. #define A_SG_FL1PTR 0x5c
  157. #define S_FL1_POINTER 0
  158. #define M_FL1_POINTER 0xffff
  159. #define V_FL1_POINTER(x) ((x) << S_FL1_POINTER)
  160. #define G_FL1_POINTER(x) (((x) >> S_FL1_POINTER) & M_FL1_POINTER)
  161. #define A_SG_VERSION 0x6c
  162. #define S_DAY 0
  163. #define M_DAY 0x1f
  164. #define V_DAY(x) ((x) << S_DAY)
  165. #define G_DAY(x) (((x) >> S_DAY) & M_DAY)
  166. #define S_MONTH 5
  167. #define M_MONTH 0xf
  168. #define V_MONTH(x) ((x) << S_MONTH)
  169. #define G_MONTH(x) (((x) >> S_MONTH) & M_MONTH)
  170. #define A_SG_CMD1SIZE 0xb0
  171. #define S_CMDQ1_SIZE 0
  172. #define M_CMDQ1_SIZE 0x1ffff
  173. #define V_CMDQ1_SIZE(x) ((x) << S_CMDQ1_SIZE)
  174. #define G_CMDQ1_SIZE(x) (((x) >> S_CMDQ1_SIZE) & M_CMDQ1_SIZE)
  175. #define A_SG_FL1SIZE 0xb4
  176. #define S_FL1_SIZE 0
  177. #define M_FL1_SIZE 0x1ffff
  178. #define V_FL1_SIZE(x) ((x) << S_FL1_SIZE)
  179. #define G_FL1_SIZE(x) (((x) >> S_FL1_SIZE) & M_FL1_SIZE)
  180. #define A_SG_INT_ENABLE 0xb8
  181. #define S_RESPQ_EXHAUSTED 0
  182. #define V_RESPQ_EXHAUSTED(x) ((x) << S_RESPQ_EXHAUSTED)
  183. #define F_RESPQ_EXHAUSTED V_RESPQ_EXHAUSTED(1U)
  184. #define S_RESPQ_OVERFLOW 1
  185. #define V_RESPQ_OVERFLOW(x) ((x) << S_RESPQ_OVERFLOW)
  186. #define F_RESPQ_OVERFLOW V_RESPQ_OVERFLOW(1U)
  187. #define S_FL_EXHAUSTED 2
  188. #define V_FL_EXHAUSTED(x) ((x) << S_FL_EXHAUSTED)
  189. #define F_FL_EXHAUSTED V_FL_EXHAUSTED(1U)
  190. #define S_PACKET_TOO_BIG 3
  191. #define V_PACKET_TOO_BIG(x) ((x) << S_PACKET_TOO_BIG)
  192. #define F_PACKET_TOO_BIG V_PACKET_TOO_BIG(1U)
  193. #define S_PACKET_MISMATCH 4
  194. #define V_PACKET_MISMATCH(x) ((x) << S_PACKET_MISMATCH)
  195. #define F_PACKET_MISMATCH V_PACKET_MISMATCH(1U)
  196. #define A_SG_INT_CAUSE 0xbc
  197. #define A_SG_RESPACCUTIMER 0xc0
  198. /* MC3 registers */
  199. #define A_MC3_CFG 0x100
  200. #define S_CLK_ENABLE 0
  201. #define V_CLK_ENABLE(x) ((x) << S_CLK_ENABLE)
  202. #define F_CLK_ENABLE V_CLK_ENABLE(1U)
  203. #define S_READY 1
  204. #define V_READY(x) ((x) << S_READY)
  205. #define F_READY V_READY(1U)
  206. #define S_READ_TO_WRITE_DELAY 2
  207. #define M_READ_TO_WRITE_DELAY 0x7
  208. #define V_READ_TO_WRITE_DELAY(x) ((x) << S_READ_TO_WRITE_DELAY)
  209. #define G_READ_TO_WRITE_DELAY(x) (((x) >> S_READ_TO_WRITE_DELAY) & M_READ_TO_WRITE_DELAY)
  210. #define S_WRITE_TO_READ_DELAY 5
  211. #define M_WRITE_TO_READ_DELAY 0x7
  212. #define V_WRITE_TO_READ_DELAY(x) ((x) << S_WRITE_TO_READ_DELAY)
  213. #define G_WRITE_TO_READ_DELAY(x) (((x) >> S_WRITE_TO_READ_DELAY) & M_WRITE_TO_READ_DELAY)
  214. #define S_MC3_BANK_CYCLE 8
  215. #define M_MC3_BANK_CYCLE 0xf
  216. #define V_MC3_BANK_CYCLE(x) ((x) << S_MC3_BANK_CYCLE)
  217. #define G_MC3_BANK_CYCLE(x) (((x) >> S_MC3_BANK_CYCLE) & M_MC3_BANK_CYCLE)
  218. #define S_REFRESH_CYCLE 12
  219. #define M_REFRESH_CYCLE 0xf
  220. #define V_REFRESH_CYCLE(x) ((x) << S_REFRESH_CYCLE)
  221. #define G_REFRESH_CYCLE(x) (((x) >> S_REFRESH_CYCLE) & M_REFRESH_CYCLE)
  222. #define S_PRECHARGE_CYCLE 16
  223. #define M_PRECHARGE_CYCLE 0x3
  224. #define V_PRECHARGE_CYCLE(x) ((x) << S_PRECHARGE_CYCLE)
  225. #define G_PRECHARGE_CYCLE(x) (((x) >> S_PRECHARGE_CYCLE) & M_PRECHARGE_CYCLE)
  226. #define S_ACTIVE_TO_READ_WRITE_DELAY 18
  227. #define V_ACTIVE_TO_READ_WRITE_DELAY(x) ((x) << S_ACTIVE_TO_READ_WRITE_DELAY)
  228. #define F_ACTIVE_TO_READ_WRITE_DELAY V_ACTIVE_TO_READ_WRITE_DELAY(1U)
  229. #define S_ACTIVE_TO_PRECHARGE_DELAY 19
  230. #define M_ACTIVE_TO_PRECHARGE_DELAY 0x7
  231. #define V_ACTIVE_TO_PRECHARGE_DELAY(x) ((x) << S_ACTIVE_TO_PRECHARGE_DELAY)
  232. #define G_ACTIVE_TO_PRECHARGE_DELAY(x) (((x) >> S_ACTIVE_TO_PRECHARGE_DELAY) & M_ACTIVE_TO_PRECHARGE_DELAY)
  233. #define S_WRITE_RECOVERY_DELAY 22
  234. #define M_WRITE_RECOVERY_DELAY 0x3
  235. #define V_WRITE_RECOVERY_DELAY(x) ((x) << S_WRITE_RECOVERY_DELAY)
  236. #define G_WRITE_RECOVERY_DELAY(x) (((x) >> S_WRITE_RECOVERY_DELAY) & M_WRITE_RECOVERY_DELAY)
  237. #define S_DENSITY 24
  238. #define M_DENSITY 0x3
  239. #define V_DENSITY(x) ((x) << S_DENSITY)
  240. #define G_DENSITY(x) (((x) >> S_DENSITY) & M_DENSITY)
  241. #define S_ORGANIZATION 26
  242. #define V_ORGANIZATION(x) ((x) << S_ORGANIZATION)
  243. #define F_ORGANIZATION V_ORGANIZATION(1U)
  244. #define S_BANKS 27
  245. #define V_BANKS(x) ((x) << S_BANKS)
  246. #define F_BANKS V_BANKS(1U)
  247. #define S_UNREGISTERED 28
  248. #define V_UNREGISTERED(x) ((x) << S_UNREGISTERED)
  249. #define F_UNREGISTERED V_UNREGISTERED(1U)
  250. #define S_MC3_WIDTH 29
  251. #define M_MC3_WIDTH 0x3
  252. #define V_MC3_WIDTH(x) ((x) << S_MC3_WIDTH)
  253. #define G_MC3_WIDTH(x) (((x) >> S_MC3_WIDTH) & M_MC3_WIDTH)
  254. #define S_MC3_SLOW 31
  255. #define V_MC3_SLOW(x) ((x) << S_MC3_SLOW)
  256. #define F_MC3_SLOW V_MC3_SLOW(1U)
  257. #define A_MC3_MODE 0x104
  258. #define S_MC3_MODE 0
  259. #define M_MC3_MODE 0x3fff
  260. #define V_MC3_MODE(x) ((x) << S_MC3_MODE)
  261. #define G_MC3_MODE(x) (((x) >> S_MC3_MODE) & M_MC3_MODE)
  262. #define S_BUSY 31
  263. #define V_BUSY(x) ((x) << S_BUSY)
  264. #define F_BUSY V_BUSY(1U)
  265. #define A_MC3_EXT_MODE 0x108
  266. #define S_MC3_EXTENDED_MODE 0
  267. #define M_MC3_EXTENDED_MODE 0x3fff
  268. #define V_MC3_EXTENDED_MODE(x) ((x) << S_MC3_EXTENDED_MODE)
  269. #define G_MC3_EXTENDED_MODE(x) (((x) >> S_MC3_EXTENDED_MODE) & M_MC3_EXTENDED_MODE)
  270. #define A_MC3_PRECHARG 0x10c
  271. #define A_MC3_REFRESH 0x110
  272. #define S_REFRESH_ENABLE 0
  273. #define V_REFRESH_ENABLE(x) ((x) << S_REFRESH_ENABLE)
  274. #define F_REFRESH_ENABLE V_REFRESH_ENABLE(1U)
  275. #define S_REFRESH_DIVISOR 1
  276. #define M_REFRESH_DIVISOR 0x3fff
  277. #define V_REFRESH_DIVISOR(x) ((x) << S_REFRESH_DIVISOR)
  278. #define G_REFRESH_DIVISOR(x) (((x) >> S_REFRESH_DIVISOR) & M_REFRESH_DIVISOR)
  279. #define A_MC3_STROBE 0x114
  280. #define S_MASTER_DLL_RESET 0
  281. #define V_MASTER_DLL_RESET(x) ((x) << S_MASTER_DLL_RESET)
  282. #define F_MASTER_DLL_RESET V_MASTER_DLL_RESET(1U)
  283. #define S_MASTER_DLL_TAP_COUNT 1
  284. #define M_MASTER_DLL_TAP_COUNT 0xff
  285. #define V_MASTER_DLL_TAP_COUNT(x) ((x) << S_MASTER_DLL_TAP_COUNT)
  286. #define G_MASTER_DLL_TAP_COUNT(x) (((x) >> S_MASTER_DLL_TAP_COUNT) & M_MASTER_DLL_TAP_COUNT)
  287. #define S_MASTER_DLL_LOCKED 9
  288. #define V_MASTER_DLL_LOCKED(x) ((x) << S_MASTER_DLL_LOCKED)
  289. #define F_MASTER_DLL_LOCKED V_MASTER_DLL_LOCKED(1U)
  290. #define S_MASTER_DLL_MAX_TAP_COUNT 10
  291. #define V_MASTER_DLL_MAX_TAP_COUNT(x) ((x) << S_MASTER_DLL_MAX_TAP_COUNT)
  292. #define F_MASTER_DLL_MAX_TAP_COUNT V_MASTER_DLL_MAX_TAP_COUNT(1U)
  293. #define S_MASTER_DLL_TAP_COUNT_OFFSET 11
  294. #define M_MASTER_DLL_TAP_COUNT_OFFSET 0x3f
  295. #define V_MASTER_DLL_TAP_COUNT_OFFSET(x) ((x) << S_MASTER_DLL_TAP_COUNT_OFFSET)
  296. #define G_MASTER_DLL_TAP_COUNT_OFFSET(x) (((x) >> S_MASTER_DLL_TAP_COUNT_OFFSET) & M_MASTER_DLL_TAP_COUNT_OFFSET)
  297. #define S_SLAVE_DLL_RESET 11
  298. #define V_SLAVE_DLL_RESET(x) ((x) << S_SLAVE_DLL_RESET)
  299. #define F_SLAVE_DLL_RESET V_SLAVE_DLL_RESET(1U)
  300. #define S_SLAVE_DLL_DELTA 12
  301. #define M_SLAVE_DLL_DELTA 0xf
  302. #define V_SLAVE_DLL_DELTA(x) ((x) << S_SLAVE_DLL_DELTA)
  303. #define G_SLAVE_DLL_DELTA(x) (((x) >> S_SLAVE_DLL_DELTA) & M_SLAVE_DLL_DELTA)
  304. #define S_SLAVE_DELAY_LINE_MANUAL_TAP_COUNT 17
  305. #define M_SLAVE_DELAY_LINE_MANUAL_TAP_COUNT 0x3f
  306. #define V_SLAVE_DELAY_LINE_MANUAL_TAP_COUNT(x) ((x) << S_SLAVE_DELAY_LINE_MANUAL_TAP_COUNT)
  307. #define G_SLAVE_DELAY_LINE_MANUAL_TAP_COUNT(x) (((x) >> S_SLAVE_DELAY_LINE_MANUAL_TAP_COUNT) & M_SLAVE_DELAY_LINE_MANUAL_TAP_COUNT)
  308. #define S_SLAVE_DELAY_LINE_MANUAL_TAP_COUNT_ENABLE 23
  309. #define V_SLAVE_DELAY_LINE_MANUAL_TAP_COUNT_ENABLE(x) ((x) << S_SLAVE_DELAY_LINE_MANUAL_TAP_COUNT_ENABLE)
  310. #define F_SLAVE_DELAY_LINE_MANUAL_TAP_COUNT_ENABLE V_SLAVE_DELAY_LINE_MANUAL_TAP_COUNT_ENABLE(1U)
  311. #define S_SLAVE_DELAY_LINE_TAP_COUNT 24
  312. #define M_SLAVE_DELAY_LINE_TAP_COUNT 0x3f
  313. #define V_SLAVE_DELAY_LINE_TAP_COUNT(x) ((x) << S_SLAVE_DELAY_LINE_TAP_COUNT)
  314. #define G_SLAVE_DELAY_LINE_TAP_COUNT(x) (((x) >> S_SLAVE_DELAY_LINE_TAP_COUNT) & M_SLAVE_DELAY_LINE_TAP_COUNT)
  315. #define A_MC3_ECC_CNTL 0x118
  316. #define S_ECC_GENERATION_ENABLE 0
  317. #define V_ECC_GENERATION_ENABLE(x) ((x) << S_ECC_GENERATION_ENABLE)
  318. #define F_ECC_GENERATION_ENABLE V_ECC_GENERATION_ENABLE(1U)
  319. #define S_ECC_CHECK_ENABLE 1
  320. #define V_ECC_CHECK_ENABLE(x) ((x) << S_ECC_CHECK_ENABLE)
  321. #define F_ECC_CHECK_ENABLE V_ECC_CHECK_ENABLE(1U)
  322. #define S_CORRECTABLE_ERROR_COUNT 2
  323. #define M_CORRECTABLE_ERROR_COUNT 0xff
  324. #define V_CORRECTABLE_ERROR_COUNT(x) ((x) << S_CORRECTABLE_ERROR_COUNT)
  325. #define G_CORRECTABLE_ERROR_COUNT(x) (((x) >> S_CORRECTABLE_ERROR_COUNT) & M_CORRECTABLE_ERROR_COUNT)
  326. #define S_UNCORRECTABLE_ERROR_COUNT 10
  327. #define M_UNCORRECTABLE_ERROR_COUNT 0xff
  328. #define V_UNCORRECTABLE_ERROR_COUNT(x) ((x) << S_UNCORRECTABLE_ERROR_COUNT)
  329. #define G_UNCORRECTABLE_ERROR_COUNT(x) (((x) >> S_UNCORRECTABLE_ERROR_COUNT) & M_UNCORRECTABLE_ERROR_COUNT)
  330. #define A_MC3_CE_ADDR 0x11c
  331. #define S_MC3_CE_ADDR 4
  332. #define M_MC3_CE_ADDR 0xfffffff
  333. #define V_MC3_CE_ADDR(x) ((x) << S_MC3_CE_ADDR)
  334. #define G_MC3_CE_ADDR(x) (((x) >> S_MC3_CE_ADDR) & M_MC3_CE_ADDR)
  335. #define A_MC3_CE_DATA0 0x120
  336. #define A_MC3_CE_DATA1 0x124
  337. #define A_MC3_CE_DATA2 0x128
  338. #define A_MC3_CE_DATA3 0x12c
  339. #define A_MC3_CE_DATA4 0x130
  340. #define A_MC3_UE_ADDR 0x134
  341. #define S_MC3_UE_ADDR 4
  342. #define M_MC3_UE_ADDR 0xfffffff
  343. #define V_MC3_UE_ADDR(x) ((x) << S_MC3_UE_ADDR)
  344. #define G_MC3_UE_ADDR(x) (((x) >> S_MC3_UE_ADDR) & M_MC3_UE_ADDR)
  345. #define A_MC3_UE_DATA0 0x138
  346. #define A_MC3_UE_DATA1 0x13c
  347. #define A_MC3_UE_DATA2 0x140
  348. #define A_MC3_UE_DATA3 0x144
  349. #define A_MC3_UE_DATA4 0x148
  350. #define A_MC3_BD_ADDR 0x14c
  351. #define A_MC3_BD_DATA0 0x150
  352. #define A_MC3_BD_DATA1 0x154
  353. #define A_MC3_BD_DATA2 0x158
  354. #define A_MC3_BD_DATA3 0x15c
  355. #define A_MC3_BD_DATA4 0x160
  356. #define A_MC3_BD_OP 0x164
  357. #define S_BACK_DOOR_OPERATION 0
  358. #define V_BACK_DOOR_OPERATION(x) ((x) << S_BACK_DOOR_OPERATION)
  359. #define F_BACK_DOOR_OPERATION V_BACK_DOOR_OPERATION(1U)
  360. #define A_MC3_BIST_ADDR_BEG 0x168
  361. #define A_MC3_BIST_ADDR_END 0x16c
  362. #define A_MC3_BIST_DATA 0x170
  363. #define A_MC3_BIST_OP 0x174
  364. #define S_OP 0
  365. #define V_OP(x) ((x) << S_OP)
  366. #define F_OP V_OP(1U)
  367. #define S_DATA_PATTERN 1
  368. #define M_DATA_PATTERN 0x3
  369. #define V_DATA_PATTERN(x) ((x) << S_DATA_PATTERN)
  370. #define G_DATA_PATTERN(x) (((x) >> S_DATA_PATTERN) & M_DATA_PATTERN)
  371. #define S_CONTINUOUS 3
  372. #define V_CONTINUOUS(x) ((x) << S_CONTINUOUS)
  373. #define F_CONTINUOUS V_CONTINUOUS(1U)
  374. #define A_MC3_INT_ENABLE 0x178
  375. #define S_MC3_CORR_ERR 0
  376. #define V_MC3_CORR_ERR(x) ((x) << S_MC3_CORR_ERR)
  377. #define F_MC3_CORR_ERR V_MC3_CORR_ERR(1U)
  378. #define S_MC3_UNCORR_ERR 1
  379. #define V_MC3_UNCORR_ERR(x) ((x) << S_MC3_UNCORR_ERR)
  380. #define F_MC3_UNCORR_ERR V_MC3_UNCORR_ERR(1U)
  381. #define S_MC3_PARITY_ERR 2
  382. #define M_MC3_PARITY_ERR 0xff
  383. #define V_MC3_PARITY_ERR(x) ((x) << S_MC3_PARITY_ERR)
  384. #define G_MC3_PARITY_ERR(x) (((x) >> S_MC3_PARITY_ERR) & M_MC3_PARITY_ERR)
  385. #define S_MC3_ADDR_ERR 10
  386. #define V_MC3_ADDR_ERR(x) ((x) << S_MC3_ADDR_ERR)
  387. #define F_MC3_ADDR_ERR V_MC3_ADDR_ERR(1U)
  388. #define A_MC3_INT_CAUSE 0x17c
  389. /* MC4 registers */
  390. #define A_MC4_CFG 0x180
  391. #define S_POWER_UP 0
  392. #define V_POWER_UP(x) ((x) << S_POWER_UP)
  393. #define F_POWER_UP V_POWER_UP(1U)
  394. #define S_MC4_BANK_CYCLE 8
  395. #define M_MC4_BANK_CYCLE 0x7
  396. #define V_MC4_BANK_CYCLE(x) ((x) << S_MC4_BANK_CYCLE)
  397. #define G_MC4_BANK_CYCLE(x) (((x) >> S_MC4_BANK_CYCLE) & M_MC4_BANK_CYCLE)
  398. #define S_MC4_NARROW 24
  399. #define V_MC4_NARROW(x) ((x) << S_MC4_NARROW)
  400. #define F_MC4_NARROW V_MC4_NARROW(1U)
  401. #define S_MC4_SLOW 25
  402. #define V_MC4_SLOW(x) ((x) << S_MC4_SLOW)
  403. #define F_MC4_SLOW V_MC4_SLOW(1U)
  404. #define S_MC4A_WIDTH 24
  405. #define M_MC4A_WIDTH 0x3
  406. #define V_MC4A_WIDTH(x) ((x) << S_MC4A_WIDTH)
  407. #define G_MC4A_WIDTH(x) (((x) >> S_MC4A_WIDTH) & M_MC4A_WIDTH)
  408. #define S_MC4A_SLOW 26
  409. #define V_MC4A_SLOW(x) ((x) << S_MC4A_SLOW)
  410. #define F_MC4A_SLOW V_MC4A_SLOW(1U)
  411. #define A_MC4_MODE 0x184
  412. #define S_MC4_MODE 0
  413. #define M_MC4_MODE 0x7fff
  414. #define V_MC4_MODE(x) ((x) << S_MC4_MODE)
  415. #define G_MC4_MODE(x) (((x) >> S_MC4_MODE) & M_MC4_MODE)
  416. #define A_MC4_EXT_MODE 0x188
  417. #define S_MC4_EXTENDED_MODE 0
  418. #define M_MC4_EXTENDED_MODE 0x7fff
  419. #define V_MC4_EXTENDED_MODE(x) ((x) << S_MC4_EXTENDED_MODE)
  420. #define G_MC4_EXTENDED_MODE(x) (((x) >> S_MC4_EXTENDED_MODE) & M_MC4_EXTENDED_MODE)
  421. #define A_MC4_REFRESH 0x190
  422. #define A_MC4_STROBE 0x194
  423. #define A_MC4_ECC_CNTL 0x198
  424. #define A_MC4_CE_ADDR 0x19c
  425. #define S_MC4_CE_ADDR 4
  426. #define M_MC4_CE_ADDR 0xffffff
  427. #define V_MC4_CE_ADDR(x) ((x) << S_MC4_CE_ADDR)
  428. #define G_MC4_CE_ADDR(x) (((x) >> S_MC4_CE_ADDR) & M_MC4_CE_ADDR)
  429. #define A_MC4_CE_DATA0 0x1a0
  430. #define A_MC4_CE_DATA1 0x1a4
  431. #define A_MC4_CE_DATA2 0x1a8
  432. #define A_MC4_CE_DATA3 0x1ac
  433. #define A_MC4_CE_DATA4 0x1b0
  434. #define A_MC4_UE_ADDR 0x1b4
  435. #define S_MC4_UE_ADDR 4
  436. #define M_MC4_UE_ADDR 0xffffff
  437. #define V_MC4_UE_ADDR(x) ((x) << S_MC4_UE_ADDR)
  438. #define G_MC4_UE_ADDR(x) (((x) >> S_MC4_UE_ADDR) & M_MC4_UE_ADDR)
  439. #define A_MC4_UE_DATA0 0x1b8
  440. #define A_MC4_UE_DATA1 0x1bc
  441. #define A_MC4_UE_DATA2 0x1c0
  442. #define A_MC4_UE_DATA3 0x1c4
  443. #define A_MC4_UE_DATA4 0x1c8
  444. #define A_MC4_BD_ADDR 0x1cc
  445. #define S_MC4_BACK_DOOR_ADDR 0
  446. #define M_MC4_BACK_DOOR_ADDR 0xfffffff
  447. #define V_MC4_BACK_DOOR_ADDR(x) ((x) << S_MC4_BACK_DOOR_ADDR)
  448. #define G_MC4_BACK_DOOR_ADDR(x) (((x) >> S_MC4_BACK_DOOR_ADDR) & M_MC4_BACK_DOOR_ADDR)
  449. #define A_MC4_BD_DATA0 0x1d0
  450. #define A_MC4_BD_DATA1 0x1d4
  451. #define A_MC4_BD_DATA2 0x1d8
  452. #define A_MC4_BD_DATA3 0x1dc
  453. #define A_MC4_BD_DATA4 0x1e0
  454. #define A_MC4_BD_OP 0x1e4
  455. #define S_OPERATION 0
  456. #define V_OPERATION(x) ((x) << S_OPERATION)
  457. #define F_OPERATION V_OPERATION(1U)
  458. #define A_MC4_BIST_ADDR_BEG 0x1e8
  459. #define A_MC4_BIST_ADDR_END 0x1ec
  460. #define A_MC4_BIST_DATA 0x1f0
  461. #define A_MC4_BIST_OP 0x1f4
  462. #define A_MC4_INT_ENABLE 0x1f8
  463. #define S_MC4_CORR_ERR 0
  464. #define V_MC4_CORR_ERR(x) ((x) << S_MC4_CORR_ERR)
  465. #define F_MC4_CORR_ERR V_MC4_CORR_ERR(1U)
  466. #define S_MC4_UNCORR_ERR 1
  467. #define V_MC4_UNCORR_ERR(x) ((x) << S_MC4_UNCORR_ERR)
  468. #define F_MC4_UNCORR_ERR V_MC4_UNCORR_ERR(1U)
  469. #define S_MC4_ADDR_ERR 2
  470. #define V_MC4_ADDR_ERR(x) ((x) << S_MC4_ADDR_ERR)
  471. #define F_MC4_ADDR_ERR V_MC4_ADDR_ERR(1U)
  472. #define A_MC4_INT_CAUSE 0x1fc
  473. /* TPI registers */
  474. #define A_TPI_ADDR 0x280
  475. #define S_TPI_ADDRESS 0
  476. #define M_TPI_ADDRESS 0xffffff
  477. #define V_TPI_ADDRESS(x) ((x) << S_TPI_ADDRESS)
  478. #define G_TPI_ADDRESS(x) (((x) >> S_TPI_ADDRESS) & M_TPI_ADDRESS)
  479. #define A_TPI_WR_DATA 0x284
  480. #define A_TPI_RD_DATA 0x288
  481. #define A_TPI_CSR 0x28c
  482. #define S_TPIWR 0
  483. #define V_TPIWR(x) ((x) << S_TPIWR)
  484. #define F_TPIWR V_TPIWR(1U)
  485. #define S_TPIRDY 1
  486. #define V_TPIRDY(x) ((x) << S_TPIRDY)
  487. #define F_TPIRDY V_TPIRDY(1U)
  488. #define S_INT_DIR 31
  489. #define V_INT_DIR(x) ((x) << S_INT_DIR)
  490. #define F_INT_DIR V_INT_DIR(1U)
  491. #define A_TPI_PAR 0x29c
  492. #define S_TPIPAR 0
  493. #define M_TPIPAR 0x7f
  494. #define V_TPIPAR(x) ((x) << S_TPIPAR)
  495. #define G_TPIPAR(x) (((x) >> S_TPIPAR) & M_TPIPAR)
  496. /* TP registers */
  497. #define A_TP_IN_CONFIG 0x300
  498. #define S_TP_IN_CSPI_TUNNEL 0
  499. #define V_TP_IN_CSPI_TUNNEL(x) ((x) << S_TP_IN_CSPI_TUNNEL)
  500. #define F_TP_IN_CSPI_TUNNEL V_TP_IN_CSPI_TUNNEL(1U)
  501. #define S_TP_IN_CSPI_ETHERNET 1
  502. #define V_TP_IN_CSPI_ETHERNET(x) ((x) << S_TP_IN_CSPI_ETHERNET)
  503. #define F_TP_IN_CSPI_ETHERNET V_TP_IN_CSPI_ETHERNET(1U)
  504. #define S_TP_IN_CSPI_CPL 3
  505. #define V_TP_IN_CSPI_CPL(x) ((x) << S_TP_IN_CSPI_CPL)
  506. #define F_TP_IN_CSPI_CPL V_TP_IN_CSPI_CPL(1U)
  507. #define S_TP_IN_CSPI_POS 4
  508. #define V_TP_IN_CSPI_POS(x) ((x) << S_TP_IN_CSPI_POS)
  509. #define F_TP_IN_CSPI_POS V_TP_IN_CSPI_POS(1U)
  510. #define S_TP_IN_CSPI_CHECK_IP_CSUM 5
  511. #define V_TP_IN_CSPI_CHECK_IP_CSUM(x) ((x) << S_TP_IN_CSPI_CHECK_IP_CSUM)
  512. #define F_TP_IN_CSPI_CHECK_IP_CSUM V_TP_IN_CSPI_CHECK_IP_CSUM(1U)
  513. #define S_TP_IN_CSPI_CHECK_TCP_CSUM 6
  514. #define V_TP_IN_CSPI_CHECK_TCP_CSUM(x) ((x) << S_TP_IN_CSPI_CHECK_TCP_CSUM)
  515. #define F_TP_IN_CSPI_CHECK_TCP_CSUM V_TP_IN_CSPI_CHECK_TCP_CSUM(1U)
  516. #define S_TP_IN_ESPI_TUNNEL 7
  517. #define V_TP_IN_ESPI_TUNNEL(x) ((x) << S_TP_IN_ESPI_TUNNEL)
  518. #define F_TP_IN_ESPI_TUNNEL V_TP_IN_ESPI_TUNNEL(1U)
  519. #define S_TP_IN_ESPI_ETHERNET 8
  520. #define V_TP_IN_ESPI_ETHERNET(x) ((x) << S_TP_IN_ESPI_ETHERNET)
  521. #define F_TP_IN_ESPI_ETHERNET V_TP_IN_ESPI_ETHERNET(1U)
  522. #define S_TP_IN_ESPI_CPL 10
  523. #define V_TP_IN_ESPI_CPL(x) ((x) << S_TP_IN_ESPI_CPL)
  524. #define F_TP_IN_ESPI_CPL V_TP_IN_ESPI_CPL(1U)
  525. #define S_TP_IN_ESPI_POS 11
  526. #define V_TP_IN_ESPI_POS(x) ((x) << S_TP_IN_ESPI_POS)
  527. #define F_TP_IN_ESPI_POS V_TP_IN_ESPI_POS(1U)
  528. #define S_TP_IN_ESPI_CHECK_IP_CSUM 12
  529. #define V_TP_IN_ESPI_CHECK_IP_CSUM(x) ((x) << S_TP_IN_ESPI_CHECK_IP_CSUM)
  530. #define F_TP_IN_ESPI_CHECK_IP_CSUM V_TP_IN_ESPI_CHECK_IP_CSUM(1U)
  531. #define S_TP_IN_ESPI_CHECK_TCP_CSUM 13
  532. #define V_TP_IN_ESPI_CHECK_TCP_CSUM(x) ((x) << S_TP_IN_ESPI_CHECK_TCP_CSUM)
  533. #define F_TP_IN_ESPI_CHECK_TCP_CSUM V_TP_IN_ESPI_CHECK_TCP_CSUM(1U)
  534. #define S_OFFLOAD_DISABLE 14
  535. #define V_OFFLOAD_DISABLE(x) ((x) << S_OFFLOAD_DISABLE)
  536. #define F_OFFLOAD_DISABLE V_OFFLOAD_DISABLE(1U)
  537. #define A_TP_OUT_CONFIG 0x304
  538. #define S_TP_OUT_C_ETH 0
  539. #define V_TP_OUT_C_ETH(x) ((x) << S_TP_OUT_C_ETH)
  540. #define F_TP_OUT_C_ETH V_TP_OUT_C_ETH(1U)
  541. #define S_TP_OUT_CSPI_CPL 2
  542. #define V_TP_OUT_CSPI_CPL(x) ((x) << S_TP_OUT_CSPI_CPL)
  543. #define F_TP_OUT_CSPI_CPL V_TP_OUT_CSPI_CPL(1U)
  544. #define S_TP_OUT_CSPI_POS 3
  545. #define V_TP_OUT_CSPI_POS(x) ((x) << S_TP_OUT_CSPI_POS)
  546. #define F_TP_OUT_CSPI_POS V_TP_OUT_CSPI_POS(1U)
  547. #define S_TP_OUT_CSPI_GENERATE_IP_CSUM 4
  548. #define V_TP_OUT_CSPI_GENERATE_IP_CSUM(x) ((x) << S_TP_OUT_CSPI_GENERATE_IP_CSUM)
  549. #define F_TP_OUT_CSPI_GENERATE_IP_CSUM V_TP_OUT_CSPI_GENERATE_IP_CSUM(1U)
  550. #define S_TP_OUT_CSPI_GENERATE_TCP_CSUM 5
  551. #define V_TP_OUT_CSPI_GENERATE_TCP_CSUM(x) ((x) << S_TP_OUT_CSPI_GENERATE_TCP_CSUM)
  552. #define F_TP_OUT_CSPI_GENERATE_TCP_CSUM V_TP_OUT_CSPI_GENERATE_TCP_CSUM(1U)
  553. #define S_TP_OUT_ESPI_ETHERNET 6
  554. #define V_TP_OUT_ESPI_ETHERNET(x) ((x) << S_TP_OUT_ESPI_ETHERNET)
  555. #define F_TP_OUT_ESPI_ETHERNET V_TP_OUT_ESPI_ETHERNET(1U)
  556. #define S_TP_OUT_ESPI_TAG_ETHERNET 7
  557. #define V_TP_OUT_ESPI_TAG_ETHERNET(x) ((x) << S_TP_OUT_ESPI_TAG_ETHERNET)
  558. #define F_TP_OUT_ESPI_TAG_ETHERNET V_TP_OUT_ESPI_TAG_ETHERNET(1U)
  559. #define S_TP_OUT_ESPI_CPL 8
  560. #define V_TP_OUT_ESPI_CPL(x) ((x) << S_TP_OUT_ESPI_CPL)
  561. #define F_TP_OUT_ESPI_CPL V_TP_OUT_ESPI_CPL(1U)
  562. #define S_TP_OUT_ESPI_POS 9
  563. #define V_TP_OUT_ESPI_POS(x) ((x) << S_TP_OUT_ESPI_POS)
  564. #define F_TP_OUT_ESPI_POS V_TP_OUT_ESPI_POS(1U)
  565. #define S_TP_OUT_ESPI_GENERATE_IP_CSUM 10
  566. #define V_TP_OUT_ESPI_GENERATE_IP_CSUM(x) ((x) << S_TP_OUT_ESPI_GENERATE_IP_CSUM)
  567. #define F_TP_OUT_ESPI_GENERATE_IP_CSUM V_TP_OUT_ESPI_GENERATE_IP_CSUM(1U)
  568. #define S_TP_OUT_ESPI_GENERATE_TCP_CSUM 11
  569. #define V_TP_OUT_ESPI_GENERATE_TCP_CSUM(x) ((x) << S_TP_OUT_ESPI_GENERATE_TCP_CSUM)
  570. #define F_TP_OUT_ESPI_GENERATE_TCP_CSUM V_TP_OUT_ESPI_GENERATE_TCP_CSUM(1U)
  571. #define A_TP_GLOBAL_CONFIG 0x308
  572. #define S_IP_TTL 0
  573. #define M_IP_TTL 0xff
  574. #define V_IP_TTL(x) ((x) << S_IP_TTL)
  575. #define G_IP_TTL(x) (((x) >> S_IP_TTL) & M_IP_TTL)
  576. #define S_TCAM_SERVER_REGION_USAGE 8
  577. #define M_TCAM_SERVER_REGION_USAGE 0x3
  578. #define V_TCAM_SERVER_REGION_USAGE(x) ((x) << S_TCAM_SERVER_REGION_USAGE)
  579. #define G_TCAM_SERVER_REGION_USAGE(x) (((x) >> S_TCAM_SERVER_REGION_USAGE) & M_TCAM_SERVER_REGION_USAGE)
  580. #define S_QOS_MAPPING 10
  581. #define V_QOS_MAPPING(x) ((x) << S_QOS_MAPPING)
  582. #define F_QOS_MAPPING V_QOS_MAPPING(1U)
  583. #define S_TCP_CSUM 11
  584. #define V_TCP_CSUM(x) ((x) << S_TCP_CSUM)
  585. #define F_TCP_CSUM V_TCP_CSUM(1U)
  586. #define S_UDP_CSUM 12
  587. #define V_UDP_CSUM(x) ((x) << S_UDP_CSUM)
  588. #define F_UDP_CSUM V_UDP_CSUM(1U)
  589. #define S_IP_CSUM 13
  590. #define V_IP_CSUM(x) ((x) << S_IP_CSUM)
  591. #define F_IP_CSUM V_IP_CSUM(1U)
  592. #define S_IP_ID_SPLIT 14
  593. #define V_IP_ID_SPLIT(x) ((x) << S_IP_ID_SPLIT)
  594. #define F_IP_ID_SPLIT V_IP_ID_SPLIT(1U)
  595. #define S_PATH_MTU 15
  596. #define V_PATH_MTU(x) ((x) << S_PATH_MTU)
  597. #define F_PATH_MTU V_PATH_MTU(1U)
  598. #define S_5TUPLE_LOOKUP 17
  599. #define M_5TUPLE_LOOKUP 0x3
  600. #define V_5TUPLE_LOOKUP(x) ((x) << S_5TUPLE_LOOKUP)
  601. #define G_5TUPLE_LOOKUP(x) (((x) >> S_5TUPLE_LOOKUP) & M_5TUPLE_LOOKUP)
  602. #define S_IP_FRAGMENT_DROP 19
  603. #define V_IP_FRAGMENT_DROP(x) ((x) << S_IP_FRAGMENT_DROP)
  604. #define F_IP_FRAGMENT_DROP V_IP_FRAGMENT_DROP(1U)
  605. #define S_PING_DROP 20
  606. #define V_PING_DROP(x) ((x) << S_PING_DROP)
  607. #define F_PING_DROP V_PING_DROP(1U)
  608. #define S_PROTECT_MODE 21
  609. #define V_PROTECT_MODE(x) ((x) << S_PROTECT_MODE)
  610. #define F_PROTECT_MODE V_PROTECT_MODE(1U)
  611. #define S_SYN_COOKIE_ALGORITHM 22
  612. #define V_SYN_COOKIE_ALGORITHM(x) ((x) << S_SYN_COOKIE_ALGORITHM)
  613. #define F_SYN_COOKIE_ALGORITHM V_SYN_COOKIE_ALGORITHM(1U)
  614. #define S_ATTACK_FILTER 23
  615. #define V_ATTACK_FILTER(x) ((x) << S_ATTACK_FILTER)
  616. #define F_ATTACK_FILTER V_ATTACK_FILTER(1U)
  617. #define S_INTERFACE_TYPE 24
  618. #define V_INTERFACE_TYPE(x) ((x) << S_INTERFACE_TYPE)
  619. #define F_INTERFACE_TYPE V_INTERFACE_TYPE(1U)
  620. #define S_DISABLE_RX_FLOW_CONTROL 25
  621. #define V_DISABLE_RX_FLOW_CONTROL(x) ((x) << S_DISABLE_RX_FLOW_CONTROL)
  622. #define F_DISABLE_RX_FLOW_CONTROL V_DISABLE_RX_FLOW_CONTROL(1U)
  623. #define S_SYN_COOKIE_PARAMETER 26
  624. #define M_SYN_COOKIE_PARAMETER 0x3f
  625. #define V_SYN_COOKIE_PARAMETER(x) ((x) << S_SYN_COOKIE_PARAMETER)
  626. #define G_SYN_COOKIE_PARAMETER(x) (((x) >> S_SYN_COOKIE_PARAMETER) & M_SYN_COOKIE_PARAMETER)
  627. #define A_TP_GLOBAL_RX_CREDITS 0x30c
  628. #define A_TP_CM_SIZE 0x310
  629. #define A_TP_CM_MM_BASE 0x314
  630. #define S_CM_MEMMGR_BASE 0
  631. #define M_CM_MEMMGR_BASE 0xfffffff
  632. #define V_CM_MEMMGR_BASE(x) ((x) << S_CM_MEMMGR_BASE)
  633. #define G_CM_MEMMGR_BASE(x) (((x) >> S_CM_MEMMGR_BASE) & M_CM_MEMMGR_BASE)
  634. #define A_TP_CM_TIMER_BASE 0x318
  635. #define S_CM_TIMER_BASE 0
  636. #define M_CM_TIMER_BASE 0xfffffff
  637. #define V_CM_TIMER_BASE(x) ((x) << S_CM_TIMER_BASE)
  638. #define G_CM_TIMER_BASE(x) (((x) >> S_CM_TIMER_BASE) & M_CM_TIMER_BASE)
  639. #define A_TP_PM_SIZE 0x31c
  640. #define A_TP_PM_TX_BASE 0x320
  641. #define A_TP_PM_DEFRAG_BASE 0x324
  642. #define A_TP_PM_RX_BASE 0x328
  643. #define A_TP_PM_RX_PG_SIZE 0x32c
  644. #define A_TP_PM_RX_MAX_PGS 0x330
  645. #define A_TP_PM_TX_PG_SIZE 0x334
  646. #define A_TP_PM_TX_MAX_PGS 0x338
  647. #define A_TP_TCP_OPTIONS 0x340
  648. #define S_TIMESTAMP 0
  649. #define M_TIMESTAMP 0x3
  650. #define V_TIMESTAMP(x) ((x) << S_TIMESTAMP)
  651. #define G_TIMESTAMP(x) (((x) >> S_TIMESTAMP) & M_TIMESTAMP)
  652. #define S_WINDOW_SCALE 2
  653. #define M_WINDOW_SCALE 0x3
  654. #define V_WINDOW_SCALE(x) ((x) << S_WINDOW_SCALE)
  655. #define G_WINDOW_SCALE(x) (((x) >> S_WINDOW_SCALE) & M_WINDOW_SCALE)
  656. #define S_SACK 4
  657. #define M_SACK 0x3
  658. #define V_SACK(x) ((x) << S_SACK)
  659. #define G_SACK(x) (((x) >> S_SACK) & M_SACK)
  660. #define S_ECN 6
  661. #define M_ECN 0x3
  662. #define V_ECN(x) ((x) << S_ECN)
  663. #define G_ECN(x) (((x) >> S_ECN) & M_ECN)
  664. #define S_SACK_ALGORITHM 8
  665. #define M_SACK_ALGORITHM 0x3
  666. #define V_SACK_ALGORITHM(x) ((x) << S_SACK_ALGORITHM)
  667. #define G_SACK_ALGORITHM(x) (((x) >> S_SACK_ALGORITHM) & M_SACK_ALGORITHM)
  668. #define S_MSS 10
  669. #define V_MSS(x) ((x) << S_MSS)
  670. #define F_MSS V_MSS(1U)
  671. #define S_DEFAULT_PEER_MSS 16
  672. #define M_DEFAULT_PEER_MSS 0xffff
  673. #define V_DEFAULT_PEER_MSS(x) ((x) << S_DEFAULT_PEER_MSS)
  674. #define G_DEFAULT_PEER_MSS(x) (((x) >> S_DEFAULT_PEER_MSS) & M_DEFAULT_PEER_MSS)
  675. #define A_TP_DACK_CONFIG 0x344
  676. #define S_DACK_MODE 0
  677. #define V_DACK_MODE(x) ((x) << S_DACK_MODE)
  678. #define F_DACK_MODE V_DACK_MODE(1U)
  679. #define S_DACK_AUTO_MGMT 1
  680. #define V_DACK_AUTO_MGMT(x) ((x) << S_DACK_AUTO_MGMT)
  681. #define F_DACK_AUTO_MGMT V_DACK_AUTO_MGMT(1U)
  682. #define S_DACK_AUTO_CAREFUL 2
  683. #define V_DACK_AUTO_CAREFUL(x) ((x) << S_DACK_AUTO_CAREFUL)
  684. #define F_DACK_AUTO_CAREFUL V_DACK_AUTO_CAREFUL(1U)
  685. #define S_DACK_MSS_SELECTOR 3
  686. #define M_DACK_MSS_SELECTOR 0x3
  687. #define V_DACK_MSS_SELECTOR(x) ((x) << S_DACK_MSS_SELECTOR)
  688. #define G_DACK_MSS_SELECTOR(x) (((x) >> S_DACK_MSS_SELECTOR) & M_DACK_MSS_SELECTOR)
  689. #define S_DACK_BYTE_THRESHOLD 5
  690. #define M_DACK_BYTE_THRESHOLD 0xfffff
  691. #define V_DACK_BYTE_THRESHOLD(x) ((x) << S_DACK_BYTE_THRESHOLD)
  692. #define G_DACK_BYTE_THRESHOLD(x) (((x) >> S_DACK_BYTE_THRESHOLD) & M_DACK_BYTE_THRESHOLD)
  693. #define A_TP_PC_CONFIG 0x348
  694. #define S_TP_ACCESS_LATENCY 0
  695. #define M_TP_ACCESS_LATENCY 0xf
  696. #define V_TP_ACCESS_LATENCY(x) ((x) << S_TP_ACCESS_LATENCY)
  697. #define G_TP_ACCESS_LATENCY(x) (((x) >> S_TP_ACCESS_LATENCY) & M_TP_ACCESS_LATENCY)
  698. #define S_HELD_FIN_DISABLE 4
  699. #define V_HELD_FIN_DISABLE(x) ((x) << S_HELD_FIN_DISABLE)
  700. #define F_HELD_FIN_DISABLE V_HELD_FIN_DISABLE(1U)
  701. #define S_DDP_FC_ENABLE 5
  702. #define V_DDP_FC_ENABLE(x) ((x) << S_DDP_FC_ENABLE)
  703. #define F_DDP_FC_ENABLE V_DDP_FC_ENABLE(1U)
  704. #define S_RDMA_ERR_ENABLE 6
  705. #define V_RDMA_ERR_ENABLE(x) ((x) << S_RDMA_ERR_ENABLE)
  706. #define F_RDMA_ERR_ENABLE V_RDMA_ERR_ENABLE(1U)
  707. #define S_FAST_PDU_DELIVERY 7
  708. #define V_FAST_PDU_DELIVERY(x) ((x) << S_FAST_PDU_DELIVERY)
  709. #define F_FAST_PDU_DELIVERY V_FAST_PDU_DELIVERY(1U)
  710. #define S_CLEAR_FIN 8
  711. #define V_CLEAR_FIN(x) ((x) << S_CLEAR_FIN)
  712. #define F_CLEAR_FIN V_CLEAR_FIN(1U)
  713. #define S_DIS_TX_FILL_WIN_PUSH 12
  714. #define V_DIS_TX_FILL_WIN_PUSH(x) ((x) << S_DIS_TX_FILL_WIN_PUSH)
  715. #define F_DIS_TX_FILL_WIN_PUSH V_DIS_TX_FILL_WIN_PUSH(1U)
  716. #define S_TP_PC_REV 30
  717. #define M_TP_PC_REV 0x3
  718. #define V_TP_PC_REV(x) ((x) << S_TP_PC_REV)
  719. #define G_TP_PC_REV(x) (((x) >> S_TP_PC_REV) & M_TP_PC_REV)
  720. #define A_TP_BACKOFF0 0x350
  721. #define S_ELEMENT0 0
  722. #define M_ELEMENT0 0xff
  723. #define V_ELEMENT0(x) ((x) << S_ELEMENT0)
  724. #define G_ELEMENT0(x) (((x) >> S_ELEMENT0) & M_ELEMENT0)
  725. #define S_ELEMENT1 8
  726. #define M_ELEMENT1 0xff
  727. #define V_ELEMENT1(x) ((x) << S_ELEMENT1)
  728. #define G_ELEMENT1(x) (((x) >> S_ELEMENT1) & M_ELEMENT1)
  729. #define S_ELEMENT2 16
  730. #define M_ELEMENT2 0xff
  731. #define V_ELEMENT2(x) ((x) << S_ELEMENT2)
  732. #define G_ELEMENT2(x) (((x) >> S_ELEMENT2) & M_ELEMENT2)
  733. #define S_ELEMENT3 24
  734. #define M_ELEMENT3 0xff
  735. #define V_ELEMENT3(x) ((x) << S_ELEMENT3)
  736. #define G_ELEMENT3(x) (((x) >> S_ELEMENT3) & M_ELEMENT3)
  737. #define A_TP_BACKOFF1 0x354
  738. #define A_TP_BACKOFF2 0x358
  739. #define A_TP_BACKOFF3 0x35c
  740. #define A_TP_PARA_REG0 0x360
  741. #define S_VAR_MULT 0
  742. #define M_VAR_MULT 0xf
  743. #define V_VAR_MULT(x) ((x) << S_VAR_MULT)
  744. #define G_VAR_MULT(x) (((x) >> S_VAR_MULT) & M_VAR_MULT)
  745. #define S_VAR_GAIN 4
  746. #define M_VAR_GAIN 0xf
  747. #define V_VAR_GAIN(x) ((x) << S_VAR_GAIN)
  748. #define G_VAR_GAIN(x) (((x) >> S_VAR_GAIN) & M_VAR_GAIN)
  749. #define S_SRTT_GAIN 8
  750. #define M_SRTT_GAIN 0xf
  751. #define V_SRTT_GAIN(x) ((x) << S_SRTT_GAIN)
  752. #define G_SRTT_GAIN(x) (((x) >> S_SRTT_GAIN) & M_SRTT_GAIN)
  753. #define S_RTTVAR_INIT 12
  754. #define M_RTTVAR_INIT 0xf
  755. #define V_RTTVAR_INIT(x) ((x) << S_RTTVAR_INIT)
  756. #define G_RTTVAR_INIT(x) (((x) >> S_RTTVAR_INIT) & M_RTTVAR_INIT)
  757. #define S_DUP_THRESH 20
  758. #define M_DUP_THRESH 0xf
  759. #define V_DUP_THRESH(x) ((x) << S_DUP_THRESH)
  760. #define G_DUP_THRESH(x) (((x) >> S_DUP_THRESH) & M_DUP_THRESH)
  761. #define S_INIT_CONG_WIN 24
  762. #define M_INIT_CONG_WIN 0x7
  763. #define V_INIT_CONG_WIN(x) ((x) << S_INIT_CONG_WIN)
  764. #define G_INIT_CONG_WIN(x) (((x) >> S_INIT_CONG_WIN) & M_INIT_CONG_WIN)
  765. #define A_TP_PARA_REG1 0x364
  766. #define S_INITIAL_SLOW_START_THRESHOLD 0
  767. #define M_INITIAL_SLOW_START_THRESHOLD 0xffff
  768. #define V_INITIAL_SLOW_START_THRESHOLD(x) ((x) << S_INITIAL_SLOW_START_THRESHOLD)
  769. #define G_INITIAL_SLOW_START_THRESHOLD(x) (((x) >> S_INITIAL_SLOW_START_THRESHOLD) & M_INITIAL_SLOW_START_THRESHOLD)
  770. #define S_RECEIVE_BUFFER_SIZE 16
  771. #define M_RECEIVE_BUFFER_SIZE 0xffff
  772. #define V_RECEIVE_BUFFER_SIZE(x) ((x) << S_RECEIVE_BUFFER_SIZE)
  773. #define G_RECEIVE_BUFFER_SIZE(x) (((x) >> S_RECEIVE_BUFFER_SIZE) & M_RECEIVE_BUFFER_SIZE)
  774. #define A_TP_PARA_REG2 0x368
  775. #define S_RX_COALESCE_SIZE 0
  776. #define M_RX_COALESCE_SIZE 0xffff
  777. #define V_RX_COALESCE_SIZE(x) ((x) << S_RX_COALESCE_SIZE)
  778. #define G_RX_COALESCE_SIZE(x) (((x) >> S_RX_COALESCE_SIZE) & M_RX_COALESCE_SIZE)
  779. #define S_MAX_RX_SIZE 16
  780. #define M_MAX_RX_SIZE 0xffff
  781. #define V_MAX_RX_SIZE(x) ((x) << S_MAX_RX_SIZE)
  782. #define G_MAX_RX_SIZE(x) (((x) >> S_MAX_RX_SIZE) & M_MAX_RX_SIZE)
  783. #define A_TP_PARA_REG3 0x36c
  784. #define S_RX_COALESCING_PSH_DELIVER 0
  785. #define V_RX_COALESCING_PSH_DELIVER(x) ((x) << S_RX_COALESCING_PSH_DELIVER)
  786. #define F_RX_COALESCING_PSH_DELIVER V_RX_COALESCING_PSH_DELIVER(1U)
  787. #define S_RX_COALESCING_ENABLE 1
  788. #define V_RX_COALESCING_ENABLE(x) ((x) << S_RX_COALESCING_ENABLE)
  789. #define F_RX_COALESCING_ENABLE V_RX_COALESCING_ENABLE(1U)
  790. #define S_TAHOE_ENABLE 2
  791. #define V_TAHOE_ENABLE(x) ((x) << S_TAHOE_ENABLE)
  792. #define F_TAHOE_ENABLE V_TAHOE_ENABLE(1U)
  793. #define S_MAX_REORDER_FRAGMENTS 12
  794. #define M_MAX_REORDER_FRAGMENTS 0x7
  795. #define V_MAX_REORDER_FRAGMENTS(x) ((x) << S_MAX_REORDER_FRAGMENTS)
  796. #define G_MAX_REORDER_FRAGMENTS(x) (((x) >> S_MAX_REORDER_FRAGMENTS) & M_MAX_REORDER_FRAGMENTS)
  797. #define A_TP_TIMER_RESOLUTION 0x390
  798. #define S_DELAYED_ACK_TIMER_RESOLUTION 0
  799. #define M_DELAYED_ACK_TIMER_RESOLUTION 0x3f
  800. #define V_DELAYED_ACK_TIMER_RESOLUTION(x) ((x) << S_DELAYED_ACK_TIMER_RESOLUTION)
  801. #define G_DELAYED_ACK_TIMER_RESOLUTION(x) (((x) >> S_DELAYED_ACK_TIMER_RESOLUTION) & M_DELAYED_ACK_TIMER_RESOLUTION)
  802. #define S_GENERIC_TIMER_RESOLUTION 16
  803. #define M_GENERIC_TIMER_RESOLUTION 0x3f
  804. #define V_GENERIC_TIMER_RESOLUTION(x) ((x) << S_GENERIC_TIMER_RESOLUTION)
  805. #define G_GENERIC_TIMER_RESOLUTION(x) (((x) >> S_GENERIC_TIMER_RESOLUTION) & M_GENERIC_TIMER_RESOLUTION)
  806. #define A_TP_2MSL 0x394
  807. #define S_2MSL 0
  808. #define M_2MSL 0x3fffffff
  809. #define V_2MSL(x) ((x) << S_2MSL)
  810. #define G_2MSL(x) (((x) >> S_2MSL) & M_2MSL)
  811. #define A_TP_RXT_MIN 0x398
  812. #define S_RETRANSMIT_TIMER_MIN 0
  813. #define M_RETRANSMIT_TIMER_MIN 0xffff
  814. #define V_RETRANSMIT_TIMER_MIN(x) ((x) << S_RETRANSMIT_TIMER_MIN)
  815. #define G_RETRANSMIT_TIMER_MIN(x) (((x) >> S_RETRANSMIT_TIMER_MIN) & M_RETRANSMIT_TIMER_MIN)
  816. #define A_TP_RXT_MAX 0x39c
  817. #define S_RETRANSMIT_TIMER_MAX 0
  818. #define M_RETRANSMIT_TIMER_MAX 0x3fffffff
  819. #define V_RETRANSMIT_TIMER_MAX(x) ((x) << S_RETRANSMIT_TIMER_MAX)
  820. #define G_RETRANSMIT_TIMER_MAX(x) (((x) >> S_RETRANSMIT_TIMER_MAX) & M_RETRANSMIT_TIMER_MAX)
  821. #define A_TP_PERS_MIN 0x3a0
  822. #define S_PERSIST_TIMER_MIN 0
  823. #define M_PERSIST_TIMER_MIN 0xffff
  824. #define V_PERSIST_TIMER_MIN(x) ((x) << S_PERSIST_TIMER_MIN)
  825. #define G_PERSIST_TIMER_MIN(x) (((x) >> S_PERSIST_TIMER_MIN) & M_PERSIST_TIMER_MIN)
  826. #define A_TP_PERS_MAX 0x3a4
  827. #define S_PERSIST_TIMER_MAX 0
  828. #define M_PERSIST_TIMER_MAX 0x3fffffff
  829. #define V_PERSIST_TIMER_MAX(x) ((x) << S_PERSIST_TIMER_MAX)
  830. #define G_PERSIST_TIMER_MAX(x) (((x) >> S_PERSIST_TIMER_MAX) & M_PERSIST_TIMER_MAX)
  831. #define A_TP_KEEP_IDLE 0x3ac
  832. #define S_KEEP_ALIVE_IDLE_TIME 0
  833. #define M_KEEP_ALIVE_IDLE_TIME 0x3fffffff
  834. #define V_KEEP_ALIVE_IDLE_TIME(x) ((x) << S_KEEP_ALIVE_IDLE_TIME)
  835. #define G_KEEP_ALIVE_IDLE_TIME(x) (((x) >> S_KEEP_ALIVE_IDLE_TIME) & M_KEEP_ALIVE_IDLE_TIME)
  836. #define A_TP_KEEP_INTVL 0x3b0
  837. #define S_KEEP_ALIVE_INTERVAL_TIME 0
  838. #define M_KEEP_ALIVE_INTERVAL_TIME 0x3fffffff
  839. #define V_KEEP_ALIVE_INTERVAL_TIME(x) ((x) << S_KEEP_ALIVE_INTERVAL_TIME)
  840. #define G_KEEP_ALIVE_INTERVAL_TIME(x) (((x) >> S_KEEP_ALIVE_INTERVAL_TIME) & M_KEEP_ALIVE_INTERVAL_TIME)
  841. #define A_TP_INIT_SRTT 0x3b4
  842. #define S_INITIAL_SRTT 0
  843. #define M_INITIAL_SRTT 0xffff
  844. #define V_INITIAL_SRTT(x) ((x) << S_INITIAL_SRTT)
  845. #define G_INITIAL_SRTT(x) (((x) >> S_INITIAL_SRTT) & M_INITIAL_SRTT)
  846. #define A_TP_DACK_TIME 0x3b8
  847. #define S_DELAYED_ACK_TIME 0
  848. #define M_DELAYED_ACK_TIME 0x7ff
  849. #define V_DELAYED_ACK_TIME(x) ((x) << S_DELAYED_ACK_TIME)
  850. #define G_DELAYED_ACK_TIME(x) (((x) >> S_DELAYED_ACK_TIME) & M_DELAYED_ACK_TIME)
  851. #define A_TP_FINWAIT2_TIME 0x3bc
  852. #define S_FINWAIT2_TIME 0
  853. #define M_FINWAIT2_TIME 0x3fffffff
  854. #define V_FINWAIT2_TIME(x) ((x) << S_FINWAIT2_TIME)
  855. #define G_FINWAIT2_TIME(x) (((x) >> S_FINWAIT2_TIME) & M_FINWAIT2_TIME)
  856. #define A_TP_FAST_FINWAIT2_TIME 0x3c0
  857. #define S_FAST_FINWAIT2_TIME 0
  858. #define M_FAST_FINWAIT2_TIME 0x3fffffff
  859. #define V_FAST_FINWAIT2_TIME(x) ((x) << S_FAST_FINWAIT2_TIME)
  860. #define G_FAST_FINWAIT2_TIME(x) (((x) >> S_FAST_FINWAIT2_TIME) & M_FAST_FINWAIT2_TIME)
  861. #define A_TP_SHIFT_CNT 0x3c4
  862. #define S_KEEPALIVE_MAX 0
  863. #define M_KEEPALIVE_MAX 0xff
  864. #define V_KEEPALIVE_MAX(x) ((x) << S_KEEPALIVE_MAX)
  865. #define G_KEEPALIVE_MAX(x) (((x) >> S_KEEPALIVE_MAX) & M_KEEPALIVE_MAX)
  866. #define S_WINDOWPROBE_MAX 8
  867. #define M_WINDOWPROBE_MAX 0xff
  868. #define V_WINDOWPROBE_MAX(x) ((x) << S_WINDOWPROBE_MAX)
  869. #define G_WINDOWPROBE_MAX(x) (((x) >> S_WINDOWPROBE_MAX) & M_WINDOWPROBE_MAX)
  870. #define S_RETRANSMISSION_MAX 16
  871. #define M_RETRANSMISSION_MAX 0xff
  872. #define V_RETRANSMISSION_MAX(x) ((x) << S_RETRANSMISSION_MAX)
  873. #define G_RETRANSMISSION_MAX(x) (((x) >> S_RETRANSMISSION_MAX) & M_RETRANSMISSION_MAX)
  874. #define S_SYN_MAX 24
  875. #define M_SYN_MAX 0xff
  876. #define V_SYN_MAX(x) ((x) << S_SYN_MAX)
  877. #define G_SYN_MAX(x) (((x) >> S_SYN_MAX) & M_SYN_MAX)
  878. #define A_TP_QOS_REG0 0x3e0
  879. #define S_L3_VALUE 0
  880. #define M_L3_VALUE 0x3f
  881. #define V_L3_VALUE(x) ((x) << S_L3_VALUE)
  882. #define G_L3_VALUE(x) (((x) >> S_L3_VALUE) & M_L3_VALUE)
  883. #define A_TP_QOS_REG1 0x3e4
  884. #define A_TP_QOS_REG2 0x3e8
  885. #define A_TP_QOS_REG3 0x3ec
  886. #define A_TP_QOS_REG4 0x3f0
  887. #define A_TP_QOS_REG5 0x3f4
  888. #define A_TP_QOS_REG6 0x3f8
  889. #define A_TP_QOS_REG7 0x3fc
  890. #define A_TP_MTU_REG0 0x404
  891. #define A_TP_MTU_REG1 0x408
  892. #define A_TP_MTU_REG2 0x40c
  893. #define A_TP_MTU_REG3 0x410
  894. #define A_TP_MTU_REG4 0x414
  895. #define A_TP_MTU_REG5 0x418
  896. #define A_TP_MTU_REG6 0x41c
  897. #define A_TP_MTU_REG7 0x420
  898. #define A_TP_RESET 0x44c
  899. #define S_TP_RESET 0
  900. #define V_TP_RESET(x) ((x) << S_TP_RESET)
  901. #define F_TP_RESET V_TP_RESET(1U)
  902. #define S_CM_MEMMGR_INIT 1
  903. #define V_CM_MEMMGR_INIT(x) ((x) << S_CM_MEMMGR_INIT)
  904. #define F_CM_MEMMGR_INIT V_CM_MEMMGR_INIT(1U)
  905. #define A_TP_MIB_INDEX 0x450
  906. #define A_TP_MIB_DATA 0x454
  907. #define A_TP_SYNC_TIME_HI 0x458
  908. #define A_TP_SYNC_TIME_LO 0x45c
  909. #define A_TP_CM_MM_RX_FLST_BASE 0x460
  910. #define S_CM_MEMMGR_RX_FREE_LIST_BASE 0
  911. #define M_CM_MEMMGR_RX_FREE_LIST_BASE 0xfffffff
  912. #define V_CM_MEMMGR_RX_FREE_LIST_BASE(x) ((x) << S_CM_MEMMGR_RX_FREE_LIST_BASE)
  913. #define G_CM_MEMMGR_RX_FREE_LIST_BASE(x) (((x) >> S_CM_MEMMGR_RX_FREE_LIST_BASE) & M_CM_MEMMGR_RX_FREE_LIST_BASE)
  914. #define A_TP_CM_MM_TX_FLST_BASE 0x464
  915. #define S_CM_MEMMGR_TX_FREE_LIST_BASE 0
  916. #define M_CM_MEMMGR_TX_FREE_LIST_BASE 0xfffffff
  917. #define V_CM_MEMMGR_TX_FREE_LIST_BASE(x) ((x) << S_CM_MEMMGR_TX_FREE_LIST_BASE)
  918. #define G_CM_MEMMGR_TX_FREE_LIST_BASE(x) (((x) >> S_CM_MEMMGR_TX_FREE_LIST_BASE) & M_CM_MEMMGR_TX_FREE_LIST_BASE)
  919. #define A_TP_CM_MM_P_FLST_BASE 0x468
  920. #define S_CM_MEMMGR_PSTRUCT_FREE_LIST_BASE 0
  921. #define M_CM_MEMMGR_PSTRUCT_FREE_LIST_BASE 0xfffffff
  922. #define V_CM_MEMMGR_PSTRUCT_FREE_LIST_BASE(x) ((x) << S_CM_MEMMGR_PSTRUCT_FREE_LIST_BASE)
  923. #define G_CM_MEMMGR_PSTRUCT_FREE_LIST_BASE(x) (((x) >> S_CM_MEMMGR_PSTRUCT_FREE_LIST_BASE) & M_CM_MEMMGR_PSTRUCT_FREE_LIST_BASE)
  924. #define A_TP_CM_MM_MAX_P 0x46c
  925. #define S_CM_MEMMGR_MAX_PSTRUCT 0
  926. #define M_CM_MEMMGR_MAX_PSTRUCT 0xfffffff
  927. #define V_CM_MEMMGR_MAX_PSTRUCT(x) ((x) << S_CM_MEMMGR_MAX_PSTRUCT)
  928. #define G_CM_MEMMGR_MAX_PSTRUCT(x) (((x) >> S_CM_MEMMGR_MAX_PSTRUCT) & M_CM_MEMMGR_MAX_PSTRUCT)
  929. #define A_TP_INT_ENABLE 0x470
  930. #define S_TX_FREE_LIST_EMPTY 0
  931. #define V_TX_FREE_LIST_EMPTY(x) ((x) << S_TX_FREE_LIST_EMPTY)
  932. #define F_TX_FREE_LIST_EMPTY V_TX_FREE_LIST_EMPTY(1U)
  933. #define S_RX_FREE_LIST_EMPTY 1
  934. #define V_RX_FREE_LIST_EMPTY(x) ((x) << S_RX_FREE_LIST_EMPTY)
  935. #define F_RX_FREE_LIST_EMPTY V_RX_FREE_LIST_EMPTY(1U)
  936. #define A_TP_INT_CAUSE 0x474
  937. #define A_TP_TIMER_SEPARATOR 0x4a4
  938. #define S_DISABLE_PAST_TIMER_INSERTION 0
  939. #define V_DISABLE_PAST_TIMER_INSERTION(x) ((x) << S_DISABLE_PAST_TIMER_INSERTION)
  940. #define F_DISABLE_PAST_TIMER_INSERTION V_DISABLE_PAST_TIMER_INSERTION(1U)
  941. #define S_MODULATION_TIMER_SEPARATOR 1
  942. #define M_MODULATION_TIMER_SEPARATOR 0x7fff
  943. #define V_MODULATION_TIMER_SEPARATOR(x) ((x) << S_MODULATION_TIMER_SEPARATOR)
  944. #define G_MODULATION_TIMER_SEPARATOR(x) (((x) >> S_MODULATION_TIMER_SEPARATOR) & M_MODULATION_TIMER_SEPARATOR)
  945. #define S_GLOBAL_TIMER_SEPARATOR 16
  946. #define M_GLOBAL_TIMER_SEPARATOR 0xffff
  947. #define V_GLOBAL_TIMER_SEPARATOR(x) ((x) << S_GLOBAL_TIMER_SEPARATOR)
  948. #define G_GLOBAL_TIMER_SEPARATOR(x) (((x) >> S_GLOBAL_TIMER_SEPARATOR) & M_GLOBAL_TIMER_SEPARATOR)
  949. #define A_TP_CM_FC_MODE 0x4b0
  950. #define A_TP_PC_CONGESTION_CNTL 0x4b4
  951. #define A_TP_TX_DROP_CONFIG 0x4b8
  952. #define S_ENABLE_TX_DROP 31
  953. #define V_ENABLE_TX_DROP(x) ((x) << S_ENABLE_TX_DROP)
  954. #define F_ENABLE_TX_DROP V_ENABLE_TX_DROP(1U)
  955. #define S_ENABLE_TX_ERROR 30
  956. #define V_ENABLE_TX_ERROR(x) ((x) << S_ENABLE_TX_ERROR)
  957. #define F_ENABLE_TX_ERROR V_ENABLE_TX_ERROR(1U)
  958. #define S_DROP_TICKS_CNT 4
  959. #define M_DROP_TICKS_CNT 0x3ffffff
  960. #define V_DROP_TICKS_CNT(x) ((x) << S_DROP_TICKS_CNT)
  961. #define G_DROP_TICKS_CNT(x) (((x) >> S_DROP_TICKS_CNT) & M_DROP_TICKS_CNT)
  962. #define S_NUM_PKTS_DROPPED 0
  963. #define M_NUM_PKTS_DROPPED 0xf
  964. #define V_NUM_PKTS_DROPPED(x) ((x) << S_NUM_PKTS_DROPPED)
  965. #define G_NUM_PKTS_DROPPED(x) (((x) >> S_NUM_PKTS_DROPPED) & M_NUM_PKTS_DROPPED)
  966. #define A_TP_TX_DROP_COUNT 0x4bc
  967. /* RAT registers */
  968. #define A_RAT_ROUTE_CONTROL 0x580
  969. #define S_USE_ROUTE_TABLE 0
  970. #define V_USE_ROUTE_TABLE(x) ((x) << S_USE_ROUTE_TABLE)
  971. #define F_USE_ROUTE_TABLE V_USE_ROUTE_TABLE(1U)
  972. #define S_ENABLE_CSPI 1
  973. #define V_ENABLE_CSPI(x) ((x) << S_ENABLE_CSPI)
  974. #define F_ENABLE_CSPI V_ENABLE_CSPI(1U)
  975. #define S_ENABLE_PCIX 2
  976. #define V_ENABLE_PCIX(x) ((x) << S_ENABLE_PCIX)
  977. #define F_ENABLE_PCIX V_ENABLE_PCIX(1U)
  978. #define A_RAT_ROUTE_TABLE_INDEX 0x584
  979. #define S_ROUTE_TABLE_INDEX 0
  980. #define M_ROUTE_TABLE_INDEX 0xf
  981. #define V_ROUTE_TABLE_INDEX(x) ((x) << S_ROUTE_TABLE_INDEX)
  982. #define G_ROUTE_TABLE_INDEX(x) (((x) >> S_ROUTE_TABLE_INDEX) & M_ROUTE_TABLE_INDEX)
  983. #define A_RAT_ROUTE_TABLE_DATA 0x588
  984. #define A_RAT_NO_ROUTE 0x58c
  985. #define S_CPL_OPCODE 0
  986. #define M_CPL_OPCODE 0xff
  987. #define V_CPL_OPCODE(x) ((x) << S_CPL_OPCODE)
  988. #define G_CPL_OPCODE(x) (((x) >> S_CPL_OPCODE) & M_CPL_OPCODE)
  989. #define A_RAT_INTR_ENABLE 0x590
  990. #define S_ZEROROUTEERROR 0
  991. #define V_ZEROROUTEERROR(x) ((x) << S_ZEROROUTEERROR)
  992. #define F_ZEROROUTEERROR V_ZEROROUTEERROR(1U)
  993. #define S_CSPIFRAMINGERROR 1
  994. #define V_CSPIFRAMINGERROR(x) ((x) << S_CSPIFRAMINGERROR)
  995. #define F_CSPIFRAMINGERROR V_CSPIFRAMINGERROR(1U)
  996. #define S_SGEFRAMINGERROR 2
  997. #define V_SGEFRAMINGERROR(x) ((x) << S_SGEFRAMINGERROR)
  998. #define F_SGEFRAMINGERROR V_SGEFRAMINGERROR(1U)
  999. #define S_TPFRAMINGERROR 3
  1000. #define V_TPFRAMINGERROR(x) ((x) << S_TPFRAMINGERROR)
  1001. #define F_TPFRAMINGERROR V_TPFRAMINGERROR(1U)
  1002. #define A_RAT_INTR_CAUSE 0x594
  1003. /* CSPI registers */
  1004. #define A_CSPI_RX_AE_WM 0x810
  1005. #define A_CSPI_RX_AF_WM 0x814
  1006. #define A_CSPI_CALENDAR_LEN 0x818
  1007. #define S_CALENDARLENGTH 0
  1008. #define M_CALENDARLENGTH 0xffff
  1009. #define V_CALENDARLENGTH(x) ((x) << S_CALENDARLENGTH)
  1010. #define G_CALENDARLENGTH(x) (((x) >> S_CALENDARLENGTH) & M_CALENDARLENGTH)
  1011. #define A_CSPI_FIFO_STATUS_ENABLE 0x820
  1012. #define S_FIFOSTATUSENABLE 0
  1013. #define V_FIFOSTATUSENABLE(x) ((x) << S_FIFOSTATUSENABLE)
  1014. #define F_FIFOSTATUSENABLE V_FIFOSTATUSENABLE(1U)
  1015. #define A_CSPI_MAXBURST1_MAXBURST2 0x828
  1016. #define S_MAXBURST1 0
  1017. #define M_MAXBURST1 0xffff
  1018. #define V_MAXBURST1(x) ((x) << S_MAXBURST1)
  1019. #define G_MAXBURST1(x) (((x) >> S_MAXBURST1) & M_MAXBURST1)
  1020. #define S_MAXBURST2 16
  1021. #define M_MAXBURST2 0xffff
  1022. #define V_MAXBURST2(x) ((x) << S_MAXBURST2)
  1023. #define G_MAXBURST2(x) (((x) >> S_MAXBURST2) & M_MAXBURST2)
  1024. #define A_CSPI_TRAIN 0x82c
  1025. #define S_CSPI_TRAIN_ALPHA 0
  1026. #define M_CSPI_TRAIN_ALPHA 0xffff
  1027. #define V_CSPI_TRAIN_ALPHA(x) ((x) << S_CSPI_TRAIN_ALPHA)
  1028. #define G_CSPI_TRAIN_ALPHA(x) (((x) >> S_CSPI_TRAIN_ALPHA) & M_CSPI_TRAIN_ALPHA)
  1029. #define S_CSPI_TRAIN_DATA_MAXT 16
  1030. #define M_CSPI_TRAIN_DATA_MAXT 0xffff
  1031. #define V_CSPI_TRAIN_DATA_MAXT(x) ((x) << S_CSPI_TRAIN_DATA_MAXT)
  1032. #define G_CSPI_TRAIN_DATA_MAXT(x) (((x) >> S_CSPI_TRAIN_DATA_MAXT) & M_CSPI_TRAIN_DATA_MAXT)
  1033. #define A_CSPI_INTR_STATUS 0x848
  1034. #define S_DIP4ERR 0
  1035. #define V_DIP4ERR(x) ((x) << S_DIP4ERR)
  1036. #define F_DIP4ERR V_DIP4ERR(1U)
  1037. #define S_RXDROP 1
  1038. #define V_RXDROP(x) ((x) << S_RXDROP)
  1039. #define F_RXDROP V_RXDROP(1U)
  1040. #define S_TXDROP 2
  1041. #define V_TXDROP(x) ((x) << S_TXDROP)
  1042. #define F_TXDROP V_TXDROP(1U)
  1043. #define S_RXOVERFLOW 3
  1044. #define V_RXOVERFLOW(x) ((x) << S_RXOVERFLOW)
  1045. #define F_RXOVERFLOW V_RXOVERFLOW(1U)
  1046. #define S_RAMPARITYERR 4
  1047. #define V_RAMPARITYERR(x) ((x) << S_RAMPARITYERR)
  1048. #define F_RAMPARITYERR V_RAMPARITYERR(1U)
  1049. #define A_CSPI_INTR_ENABLE 0x84c
  1050. /* ESPI registers */
  1051. #define A_ESPI_SCH_TOKEN0 0x880
  1052. #define S_SCHTOKEN0 0
  1053. #define M_SCHTOKEN0 0xffff
  1054. #define V_SCHTOKEN0(x) ((x) << S_SCHTOKEN0)
  1055. #define G_SCHTOKEN0(x) (((x) >> S_SCHTOKEN0) & M_SCHTOKEN0)
  1056. #define A_ESPI_SCH_TOKEN1 0x884
  1057. #define S_SCHTOKEN1 0
  1058. #define M_SCHTOKEN1 0xffff
  1059. #define V_SCHTOKEN1(x) ((x) << S_SCHTOKEN1)
  1060. #define G_SCHTOKEN1(x) (((x) >> S_SCHTOKEN1) & M_SCHTOKEN1)
  1061. #define A_ESPI_SCH_TOKEN2 0x888
  1062. #define S_SCHTOKEN2 0
  1063. #define M_SCHTOKEN2 0xffff
  1064. #define V_SCHTOKEN2(x) ((x) << S_SCHTOKEN2)
  1065. #define G_SCHTOKEN2(x) (((x) >> S_SCHTOKEN2) & M_SCHTOKEN2)
  1066. #define A_ESPI_SCH_TOKEN3 0x88c
  1067. #define S_SCHTOKEN3 0
  1068. #define M_SCHTOKEN3 0xffff
  1069. #define V_SCHTOKEN3(x) ((x) << S_SCHTOKEN3)
  1070. #define G_SCHTOKEN3(x) (((x) >> S_SCHTOKEN3) & M_SCHTOKEN3)
  1071. #define A_ESPI_RX_FIFO_ALMOST_EMPTY_WATERMARK 0x890
  1072. #define S_ALMOSTEMPTY 0
  1073. #define M_ALMOSTEMPTY 0xffff
  1074. #define V_ALMOSTEMPTY(x) ((x) << S_ALMOSTEMPTY)
  1075. #define G_ALMOSTEMPTY(x) (((x) >> S_ALMOSTEMPTY) & M_ALMOSTEMPTY)
  1076. #define A_ESPI_RX_FIFO_ALMOST_FULL_WATERMARK 0x894
  1077. #define S_ALMOSTFULL 0
  1078. #define M_ALMOSTFULL 0xffff
  1079. #define V_ALMOSTFULL(x) ((x) << S_ALMOSTFULL)
  1080. #define G_ALMOSTFULL(x) (((x) >> S_ALMOSTFULL) & M_ALMOSTFULL)
  1081. #define A_ESPI_CALENDAR_LENGTH 0x898
  1082. #define A_PORT_CONFIG 0x89c
  1083. #define S_RX_NPORTS 0
  1084. #define M_RX_NPORTS 0xff
  1085. #define V_RX_NPORTS(x) ((x) << S_RX_NPORTS)
  1086. #define G_RX_NPORTS(x) (((x) >> S_RX_NPORTS) & M_RX_NPORTS)
  1087. #define S_TX_NPORTS 8
  1088. #define M_TX_NPORTS 0xff
  1089. #define V_TX_NPORTS(x) ((x) << S_TX_NPORTS)
  1090. #define G_TX_NPORTS(x) (((x) >> S_TX_NPORTS) & M_TX_NPORTS)
  1091. #define A_ESPI_FIFO_STATUS_ENABLE 0x8a0
  1092. #define S_RXSTATUSENABLE 0
  1093. #define V_RXSTATUSENABLE(x) ((x) << S_RXSTATUSENABLE)
  1094. #define F_RXSTATUSENABLE V_RXSTATUSENABLE(1U)
  1095. #define S_TXDROPENABLE 1
  1096. #define V_TXDROPENABLE(x) ((x) << S_TXDROPENABLE)
  1097. #define F_TXDROPENABLE V_TXDROPENABLE(1U)
  1098. #define S_RXENDIANMODE 2
  1099. #define V_RXENDIANMODE(x) ((x) << S_RXENDIANMODE)
  1100. #define F_RXENDIANMODE V_RXENDIANMODE(1U)
  1101. #define S_TXENDIANMODE 3
  1102. #define V_TXENDIANMODE(x) ((x) << S_TXENDIANMODE)
  1103. #define F_TXENDIANMODE V_TXENDIANMODE(1U)
  1104. #define S_INTEL1010MODE 4
  1105. #define V_INTEL1010MODE(x) ((x) << S_INTEL1010MODE)
  1106. #define F_INTEL1010MODE V_INTEL1010MODE(1U)
  1107. #define A_ESPI_MAXBURST1_MAXBURST2 0x8a8
  1108. #define A_ESPI_TRAIN 0x8ac
  1109. #define S_MAXTRAINALPHA 0
  1110. #define M_MAXTRAINALPHA 0xffff
  1111. #define V_MAXTRAINALPHA(x) ((x) << S_MAXTRAINALPHA)
  1112. #define G_MAXTRAINALPHA(x) (((x) >> S_MAXTRAINALPHA) & M_MAXTRAINALPHA)
  1113. #define S_MAXTRAINDATA 16
  1114. #define M_MAXTRAINDATA 0xffff
  1115. #define V_MAXTRAINDATA(x) ((x) << S_MAXTRAINDATA)
  1116. #define G_MAXTRAINDATA(x) (((x) >> S_MAXTRAINDATA) & M_MAXTRAINDATA)
  1117. #define A_RAM_STATUS 0x8b0
  1118. #define S_RXFIFOPARITYERROR 0
  1119. #define M_RXFIFOPARITYERROR 0x3ff
  1120. #define V_RXFIFOPARITYERROR(x) ((x) << S_RXFIFOPARITYERROR)
  1121. #define G_RXFIFOPARITYERROR(x) (((x) >> S_RXFIFOPARITYERROR) & M_RXFIFOPARITYERROR)
  1122. #define S_TXFIFOPARITYERROR 10
  1123. #define M_TXFIFOPARITYERROR 0x3ff
  1124. #define V_TXFIFOPARITYERROR(x) ((x) << S_TXFIFOPARITYERROR)
  1125. #define G_TXFIFOPARITYERROR(x) (((x) >> S_TXFIFOPARITYERROR) & M_TXFIFOPARITYERROR)
  1126. #define S_RXFIFOOVERFLOW 20
  1127. #define M_RXFIFOOVERFLOW 0x3ff
  1128. #define V_RXFIFOOVERFLOW(x) ((x) << S_RXFIFOOVERFLOW)
  1129. #define G_RXFIFOOVERFLOW(x) (((x) >> S_RXFIFOOVERFLOW) & M_RXFIFOOVERFLOW)
  1130. #define A_TX_DROP_COUNT0 0x8b4
  1131. #define S_TXPORT0DROPCNT 0
  1132. #define M_TXPORT0DROPCNT 0xffff
  1133. #define V_TXPORT0DROPCNT(x) ((x) << S_TXPORT0DROPCNT)
  1134. #define G_TXPORT0DROPCNT(x) (((x) >> S_TXPORT0DROPCNT) & M_TXPORT0DROPCNT)
  1135. #define S_TXPORT1DROPCNT 16
  1136. #define M_TXPORT1DROPCNT 0xffff
  1137. #define V_TXPORT1DROPCNT(x) ((x) << S_TXPORT1DROPCNT)
  1138. #define G_TXPORT1DROPCNT(x) (((x) >> S_TXPORT1DROPCNT) & M_TXPORT1DROPCNT)
  1139. #define A_TX_DROP_COUNT1 0x8b8
  1140. #define S_TXPORT2DROPCNT 0
  1141. #define M_TXPORT2DROPCNT 0xffff
  1142. #define V_TXPORT2DROPCNT(x) ((x) << S_TXPORT2DROPCNT)
  1143. #define G_TXPORT2DROPCNT(x) (((x) >> S_TXPORT2DROPCNT) & M_TXPORT2DROPCNT)
  1144. #define S_TXPORT3DROPCNT 16
  1145. #define M_TXPORT3DROPCNT 0xffff
  1146. #define V_TXPORT3DROPCNT(x) ((x) << S_TXPORT3DROPCNT)
  1147. #define G_TXPORT3DROPCNT(x) (((x) >> S_TXPORT3DROPCNT) & M_TXPORT3DROPCNT)
  1148. #define A_RX_DROP_COUNT0 0x8bc
  1149. #define S_RXPORT0DROPCNT 0
  1150. #define M_RXPORT0DROPCNT 0xffff
  1151. #define V_RXPORT0DROPCNT(x) ((x) << S_RXPORT0DROPCNT)
  1152. #define G_RXPORT0DROPCNT(x) (((x) >> S_RXPORT0DROPCNT) & M_RXPORT0DROPCNT)
  1153. #define S_RXPORT1DROPCNT 16
  1154. #define M_RXPORT1DROPCNT 0xffff
  1155. #define V_RXPORT1DROPCNT(x) ((x) << S_RXPORT1DROPCNT)
  1156. #define G_RXPORT1DROPCNT(x) (((x) >> S_RXPORT1DROPCNT) & M_RXPORT1DROPCNT)
  1157. #define A_RX_DROP_COUNT1 0x8c0
  1158. #define S_RXPORT2DROPCNT 0
  1159. #define M_RXPORT2DROPCNT 0xffff
  1160. #define V_RXPORT2DROPCNT(x) ((x) << S_RXPORT2DROPCNT)
  1161. #define G_RXPORT2DROPCNT(x) (((x) >> S_RXPORT2DROPCNT) & M_RXPORT2DROPCNT)
  1162. #define S_RXPORT3DROPCNT 16
  1163. #define M_RXPORT3DROPCNT 0xffff
  1164. #define V_RXPORT3DROPCNT(x) ((x) << S_RXPORT3DROPCNT)
  1165. #define G_RXPORT3DROPCNT(x) (((x) >> S_RXPORT3DROPCNT) & M_RXPORT3DROPCNT)
  1166. #define A_DIP4_ERROR_COUNT 0x8c4
  1167. #define S_DIP4ERRORCNT 0
  1168. #define M_DIP4ERRORCNT 0xfff
  1169. #define V_DIP4ERRORCNT(x) ((x) << S_DIP4ERRORCNT)
  1170. #define G_DIP4ERRORCNT(x) (((x) >> S_DIP4ERRORCNT) & M_DIP4ERRORCNT)
  1171. #define S_DIP4ERRORCNTSHADOW 12
  1172. #define M_DIP4ERRORCNTSHADOW 0xfff
  1173. #define V_DIP4ERRORCNTSHADOW(x) ((x) << S_DIP4ERRORCNTSHADOW)
  1174. #define G_DIP4ERRORCNTSHADOW(x) (((x) >> S_DIP4ERRORCNTSHADOW) & M_DIP4ERRORCNTSHADOW)
  1175. #define S_TRICN_RX_TRAIN_ERR 24
  1176. #define V_TRICN_RX_TRAIN_ERR(x) ((x) << S_TRICN_RX_TRAIN_ERR)
  1177. #define F_TRICN_RX_TRAIN_ERR V_TRICN_RX_TRAIN_ERR(1U)
  1178. #define S_TRICN_RX_TRAINING 25
  1179. #define V_TRICN_RX_TRAINING(x) ((x) << S_TRICN_RX_TRAINING)
  1180. #define F_TRICN_RX_TRAINING V_TRICN_RX_TRAINING(1U)
  1181. #define S_TRICN_RX_TRAIN_OK 26
  1182. #define V_TRICN_RX_TRAIN_OK(x) ((x) << S_TRICN_RX_TRAIN_OK)
  1183. #define F_TRICN_RX_TRAIN_OK V_TRICN_RX_TRAIN_OK(1U)
  1184. #define A_ESPI_INTR_STATUS 0x8c8
  1185. #define S_DIP2PARITYERR 5
  1186. #define V_DIP2PARITYERR(x) ((x) << S_DIP2PARITYERR)
  1187. #define F_DIP2PARITYERR V_DIP2PARITYERR(1U)
  1188. #define A_ESPI_INTR_ENABLE 0x8cc
  1189. #define A_RX_DROP_THRESHOLD 0x8d0
  1190. #define A_ESPI_RX_RESET 0x8ec
  1191. #define S_ESPI_RX_LNK_RST 0
  1192. #define V_ESPI_RX_LNK_RST(x) ((x) << S_ESPI_RX_LNK_RST)
  1193. #define F_ESPI_RX_LNK_RST V_ESPI_RX_LNK_RST(1U)
  1194. #define S_ESPI_RX_CORE_RST 1
  1195. #define V_ESPI_RX_CORE_RST(x) ((x) << S_ESPI_RX_CORE_RST)
  1196. #define F_ESPI_RX_CORE_RST V_ESPI_RX_CORE_RST(1U)
  1197. #define S_RX_CLK_STATUS 2
  1198. #define V_RX_CLK_STATUS(x) ((x) << S_RX_CLK_STATUS)
  1199. #define F_RX_CLK_STATUS V_RX_CLK_STATUS(1U)
  1200. #define A_ESPI_MISC_CONTROL 0x8f0
  1201. #define S_OUT_OF_SYNC_COUNT 0
  1202. #define M_OUT_OF_SYNC_COUNT 0xf
  1203. #define V_OUT_OF_SYNC_COUNT(x) ((x) << S_OUT_OF_SYNC_COUNT)
  1204. #define G_OUT_OF_SYNC_COUNT(x) (((x) >> S_OUT_OF_SYNC_COUNT) & M_OUT_OF_SYNC_COUNT)
  1205. #define S_DIP2_COUNT_MODE_ENABLE 4
  1206. #define V_DIP2_COUNT_MODE_ENABLE(x) ((x) << S_DIP2_COUNT_MODE_ENABLE)
  1207. #define F_DIP2_COUNT_MODE_ENABLE V_DIP2_COUNT_MODE_ENABLE(1U)
  1208. #define S_DIP2_PARITY_ERR_THRES 5
  1209. #define M_DIP2_PARITY_ERR_THRES 0xf
  1210. #define V_DIP2_PARITY_ERR_THRES(x) ((x) << S_DIP2_PARITY_ERR_THRES)
  1211. #define G_DIP2_PARITY_ERR_THRES(x) (((x) >> S_DIP2_PARITY_ERR_THRES) & M_DIP2_PARITY_ERR_THRES)
  1212. #define S_DIP4_THRES 9
  1213. #define M_DIP4_THRES 0xfff
  1214. #define V_DIP4_THRES(x) ((x) << S_DIP4_THRES)
  1215. #define G_DIP4_THRES(x) (((x) >> S_DIP4_THRES) & M_DIP4_THRES)
  1216. #define S_DIP4_THRES_ENABLE 21
  1217. #define V_DIP4_THRES_ENABLE(x) ((x) << S_DIP4_THRES_ENABLE)
  1218. #define F_DIP4_THRES_ENABLE V_DIP4_THRES_ENABLE(1U)
  1219. #define S_FORCE_DISABLE_STATUS 22
  1220. #define V_FORCE_DISABLE_STATUS(x) ((x) << S_FORCE_DISABLE_STATUS)
  1221. #define F_FORCE_DISABLE_STATUS V_FORCE_DISABLE_STATUS(1U)
  1222. #define S_DYNAMIC_DESKEW 23
  1223. #define V_DYNAMIC_DESKEW(x) ((x) << S_DYNAMIC_DESKEW)
  1224. #define F_DYNAMIC_DESKEW V_DYNAMIC_DESKEW(1U)
  1225. #define S_MONITORED_PORT_NUM 25
  1226. #define M_MONITORED_PORT_NUM 0x3
  1227. #define V_MONITORED_PORT_NUM(x) ((x) << S_MONITORED_PORT_NUM)
  1228. #define G_MONITORED_PORT_NUM(x) (((x) >> S_MONITORED_PORT_NUM) & M_MONITORED_PORT_NUM)
  1229. #define S_MONITORED_DIRECTION 27
  1230. #define V_MONITORED_DIRECTION(x) ((x) << S_MONITORED_DIRECTION)
  1231. #define F_MONITORED_DIRECTION V_MONITORED_DIRECTION(1U)
  1232. #define S_MONITORED_INTERFACE 28
  1233. #define V_MONITORED_INTERFACE(x) ((x) << S_MONITORED_INTERFACE)
  1234. #define F_MONITORED_INTERFACE V_MONITORED_INTERFACE(1U)
  1235. #define A_ESPI_DIP2_ERR_COUNT 0x8f4
  1236. #define S_DIP2_ERR_CNT 0
  1237. #define M_DIP2_ERR_CNT 0xf
  1238. #define V_DIP2_ERR_CNT(x) ((x) << S_DIP2_ERR_CNT)
  1239. #define G_DIP2_ERR_CNT(x) (((x) >> S_DIP2_ERR_CNT) & M_DIP2_ERR_CNT)
  1240. #define A_ESPI_CMD_ADDR 0x8f8
  1241. #define S_WRITE_DATA 0
  1242. #define M_WRITE_DATA 0xff
  1243. #define V_WRITE_DATA(x) ((x) << S_WRITE_DATA)
  1244. #define G_WRITE_DATA(x) (((x) >> S_WRITE_DATA) & M_WRITE_DATA)
  1245. #define S_REGISTER_OFFSET 8
  1246. #define M_REGISTER_OFFSET 0xf
  1247. #define V_REGISTER_OFFSET(x) ((x) << S_REGISTER_OFFSET)
  1248. #define G_REGISTER_OFFSET(x) (((x) >> S_REGISTER_OFFSET) & M_REGISTER_OFFSET)
  1249. #define S_CHANNEL_ADDR 12
  1250. #define M_CHANNEL_ADDR 0xf
  1251. #define V_CHANNEL_ADDR(x) ((x) << S_CHANNEL_ADDR)
  1252. #define G_CHANNEL_ADDR(x) (((x) >> S_CHANNEL_ADDR) & M_CHANNEL_ADDR)
  1253. #define S_MODULE_ADDR 16
  1254. #define M_MODULE_ADDR 0x3
  1255. #define V_MODULE_ADDR(x) ((x) << S_MODULE_ADDR)
  1256. #define G_MODULE_ADDR(x) (((x) >> S_MODULE_ADDR) & M_MODULE_ADDR)
  1257. #define S_BUNDLE_ADDR 20
  1258. #define M_BUNDLE_ADDR 0x3
  1259. #define V_BUNDLE_ADDR(x) ((x) << S_BUNDLE_ADDR)
  1260. #define G_BUNDLE_ADDR(x) (((x) >> S_BUNDLE_ADDR) & M_BUNDLE_ADDR)
  1261. #define S_SPI4_COMMAND 24
  1262. #define M_SPI4_COMMAND 0xff
  1263. #define V_SPI4_COMMAND(x) ((x) << S_SPI4_COMMAND)
  1264. #define G_SPI4_COMMAND(x) (((x) >> S_SPI4_COMMAND) & M_SPI4_COMMAND)
  1265. #define A_ESPI_GOSTAT 0x8fc
  1266. #define S_READ_DATA 0
  1267. #define M_READ_DATA 0xff
  1268. #define V_READ_DATA(x) ((x) << S_READ_DATA)
  1269. #define G_READ_DATA(x) (((x) >> S_READ_DATA) & M_READ_DATA)
  1270. #define S_ESPI_CMD_BUSY 8
  1271. #define V_ESPI_CMD_BUSY(x) ((x) << S_ESPI_CMD_BUSY)
  1272. #define F_ESPI_CMD_BUSY V_ESPI_CMD_BUSY(1U)
  1273. #define S_ERROR_ACK 9
  1274. #define V_ERROR_ACK(x) ((x) << S_ERROR_ACK)
  1275. #define F_ERROR_ACK V_ERROR_ACK(1U)
  1276. #define S_UNMAPPED_ERR 10
  1277. #define V_UNMAPPED_ERR(x) ((x) << S_UNMAPPED_ERR)
  1278. #define F_UNMAPPED_ERR V_UNMAPPED_ERR(1U)
  1279. #define S_TRANSACTION_TIMER 16
  1280. #define M_TRANSACTION_TIMER 0xff
  1281. #define V_TRANSACTION_TIMER(x) ((x) << S_TRANSACTION_TIMER)
  1282. #define G_TRANSACTION_TIMER(x) (((x) >> S_TRANSACTION_TIMER) & M_TRANSACTION_TIMER)
  1283. /* ULP registers */
  1284. #define A_ULP_ULIMIT 0x980
  1285. #define A_ULP_TAGMASK 0x984
  1286. #define A_ULP_HREG_INDEX 0x988
  1287. #define A_ULP_HREG_DATA 0x98c
  1288. #define A_ULP_INT_ENABLE 0x990
  1289. #define A_ULP_INT_CAUSE 0x994
  1290. #define S_HREG_PAR_ERR 0
  1291. #define V_HREG_PAR_ERR(x) ((x) << S_HREG_PAR_ERR)
  1292. #define F_HREG_PAR_ERR V_HREG_PAR_ERR(1U)
  1293. #define S_EGRS_DATA_PAR_ERR 1
  1294. #define V_EGRS_DATA_PAR_ERR(x) ((x) << S_EGRS_DATA_PAR_ERR)
  1295. #define F_EGRS_DATA_PAR_ERR V_EGRS_DATA_PAR_ERR(1U)
  1296. #define S_INGRS_DATA_PAR_ERR 2
  1297. #define V_INGRS_DATA_PAR_ERR(x) ((x) << S_INGRS_DATA_PAR_ERR)
  1298. #define F_INGRS_DATA_PAR_ERR V_INGRS_DATA_PAR_ERR(1U)
  1299. #define S_PM_INTR 3
  1300. #define V_PM_INTR(x) ((x) << S_PM_INTR)
  1301. #define F_PM_INTR V_PM_INTR(1U)
  1302. #define S_PM_E2C_SYNC_ERR 4
  1303. #define V_PM_E2C_SYNC_ERR(x) ((x) << S_PM_E2C_SYNC_ERR)
  1304. #define F_PM_E2C_SYNC_ERR V_PM_E2C_SYNC_ERR(1U)
  1305. #define S_PM_C2E_SYNC_ERR 5
  1306. #define V_PM_C2E_SYNC_ERR(x) ((x) << S_PM_C2E_SYNC_ERR)
  1307. #define F_PM_C2E_SYNC_ERR V_PM_C2E_SYNC_ERR(1U)
  1308. #define S_PM_E2C_EMPTY_ERR 6
  1309. #define V_PM_E2C_EMPTY_ERR(x) ((x) << S_PM_E2C_EMPTY_ERR)
  1310. #define F_PM_E2C_EMPTY_ERR V_PM_E2C_EMPTY_ERR(1U)
  1311. #define S_PM_C2E_EMPTY_ERR 7
  1312. #define V_PM_C2E_EMPTY_ERR(x) ((x) << S_PM_C2E_EMPTY_ERR)
  1313. #define F_PM_C2E_EMPTY_ERR V_PM_C2E_EMPTY_ERR(1U)
  1314. #define S_PM_PAR_ERR 8
  1315. #define M_PM_PAR_ERR 0xffff
  1316. #define V_PM_PAR_ERR(x) ((x) << S_PM_PAR_ERR)
  1317. #define G_PM_PAR_ERR(x) (((x) >> S_PM_PAR_ERR) & M_PM_PAR_ERR)
  1318. #define S_PM_E2C_WRT_FULL 24
  1319. #define V_PM_E2C_WRT_FULL(x) ((x) << S_PM_E2C_WRT_FULL)
  1320. #define F_PM_E2C_WRT_FULL V_PM_E2C_WRT_FULL(1U)
  1321. #define S_PM_C2E_WRT_FULL 25
  1322. #define V_PM_C2E_WRT_FULL(x) ((x) << S_PM_C2E_WRT_FULL)
  1323. #define F_PM_C2E_WRT_FULL V_PM_C2E_WRT_FULL(1U)
  1324. #define A_ULP_PIO_CTRL 0x998
  1325. /* PL registers */
  1326. #define A_PL_ENABLE 0xa00
  1327. #define S_PL_INTR_SGE_ERR 0
  1328. #define V_PL_INTR_SGE_ERR(x) ((x) << S_PL_INTR_SGE_ERR)
  1329. #define F_PL_INTR_SGE_ERR V_PL_INTR_SGE_ERR(1U)
  1330. #define S_PL_INTR_SGE_DATA 1
  1331. #define V_PL_INTR_SGE_DATA(x) ((x) << S_PL_INTR_SGE_DATA)
  1332. #define F_PL_INTR_SGE_DATA V_PL_INTR_SGE_DATA(1U)
  1333. #define S_PL_INTR_MC3 2
  1334. #define V_PL_INTR_MC3(x) ((x) << S_PL_INTR_MC3)
  1335. #define F_PL_INTR_MC3 V_PL_INTR_MC3(1U)
  1336. #define S_PL_INTR_MC4 3
  1337. #define V_PL_INTR_MC4(x) ((x) << S_PL_INTR_MC4)
  1338. #define F_PL_INTR_MC4 V_PL_INTR_MC4(1U)
  1339. #define S_PL_INTR_MC5 4
  1340. #define V_PL_INTR_MC5(x) ((x) << S_PL_INTR_MC5)
  1341. #define F_PL_INTR_MC5 V_PL_INTR_MC5(1U)
  1342. #define S_PL_INTR_RAT 5
  1343. #define V_PL_INTR_RAT(x) ((x) << S_PL_INTR_RAT)
  1344. #define F_PL_INTR_RAT V_PL_INTR_RAT(1U)
  1345. #define S_PL_INTR_TP 6
  1346. #define V_PL_INTR_TP(x) ((x) << S_PL_INTR_TP)
  1347. #define F_PL_INTR_TP V_PL_INTR_TP(1U)
  1348. #define S_PL_INTR_ULP 7
  1349. #define V_PL_INTR_ULP(x) ((x) << S_PL_INTR_ULP)
  1350. #define F_PL_INTR_ULP V_PL_INTR_ULP(1U)
  1351. #define S_PL_INTR_ESPI 8
  1352. #define V_PL_INTR_ESPI(x) ((x) << S_PL_INTR_ESPI)
  1353. #define F_PL_INTR_ESPI V_PL_INTR_ESPI(1U)
  1354. #define S_PL_INTR_CSPI 9
  1355. #define V_PL_INTR_CSPI(x) ((x) << S_PL_INTR_CSPI)
  1356. #define F_PL_INTR_CSPI V_PL_INTR_CSPI(1U)
  1357. #define S_PL_INTR_PCIX 10
  1358. #define V_PL_INTR_PCIX(x) ((x) << S_PL_INTR_PCIX)
  1359. #define F_PL_INTR_PCIX V_PL_INTR_PCIX(1U)
  1360. #define S_PL_INTR_EXT 11
  1361. #define V_PL_INTR_EXT(x) ((x) << S_PL_INTR_EXT)
  1362. #define F_PL_INTR_EXT V_PL_INTR_EXT(1U)
  1363. #define A_PL_CAUSE 0xa04
  1364. /* MC5 registers */
  1365. #define A_MC5_CONFIG 0xc04
  1366. #define S_MODE 0
  1367. #define V_MODE(x) ((x) << S_MODE)
  1368. #define F_MODE V_MODE(1U)
  1369. #define S_TCAM_RESET 1
  1370. #define V_TCAM_RESET(x) ((x) << S_TCAM_RESET)
  1371. #define F_TCAM_RESET V_TCAM_RESET(1U)
  1372. #define S_TCAM_READY 2
  1373. #define V_TCAM_READY(x) ((x) << S_TCAM_READY)
  1374. #define F_TCAM_READY V_TCAM_READY(1U)
  1375. #define S_DBGI_ENABLE 4
  1376. #define V_DBGI_ENABLE(x) ((x) << S_DBGI_ENABLE)
  1377. #define F_DBGI_ENABLE V_DBGI_ENABLE(1U)
  1378. #define S_M_BUS_ENABLE 5
  1379. #define V_M_BUS_ENABLE(x) ((x) << S_M_BUS_ENABLE)
  1380. #define F_M_BUS_ENABLE V_M_BUS_ENABLE(1U)
  1381. #define S_PARITY_ENABLE 6
  1382. #define V_PARITY_ENABLE(x) ((x) << S_PARITY_ENABLE)
  1383. #define F_PARITY_ENABLE V_PARITY_ENABLE(1U)
  1384. #define S_SYN_ISSUE_MODE 7
  1385. #define M_SYN_ISSUE_MODE 0x3
  1386. #define V_SYN_ISSUE_MODE(x) ((x) << S_SYN_ISSUE_MODE)
  1387. #define G_SYN_ISSUE_MODE(x) (((x) >> S_SYN_ISSUE_MODE) & M_SYN_ISSUE_MODE)
  1388. #define S_BUILD 16
  1389. #define V_BUILD(x) ((x) << S_BUILD)
  1390. #define F_BUILD V_BUILD(1U)
  1391. #define S_COMPRESSION_ENABLE 17
  1392. #define V_COMPRESSION_ENABLE(x) ((x) << S_COMPRESSION_ENABLE)
  1393. #define F_COMPRESSION_ENABLE V_COMPRESSION_ENABLE(1U)
  1394. #define S_NUM_LIP 18
  1395. #define M_NUM_LIP 0x3f
  1396. #define V_NUM_LIP(x) ((x) << S_NUM_LIP)
  1397. #define G_NUM_LIP(x) (((x) >> S_NUM_LIP) & M_NUM_LIP)
  1398. #define S_TCAM_PART_CNT 24
  1399. #define M_TCAM_PART_CNT 0x3
  1400. #define V_TCAM_PART_CNT(x) ((x) << S_TCAM_PART_CNT)
  1401. #define G_TCAM_PART_CNT(x) (((x) >> S_TCAM_PART_CNT) & M_TCAM_PART_CNT)
  1402. #define S_TCAM_PART_TYPE 26
  1403. #define M_TCAM_PART_TYPE 0x3
  1404. #define V_TCAM_PART_TYPE(x) ((x) << S_TCAM_PART_TYPE)
  1405. #define G_TCAM_PART_TYPE(x) (((x) >> S_TCAM_PART_TYPE) & M_TCAM_PART_TYPE)
  1406. #define S_TCAM_PART_SIZE 28
  1407. #define M_TCAM_PART_SIZE 0x3
  1408. #define V_TCAM_PART_SIZE(x) ((x) << S_TCAM_PART_SIZE)
  1409. #define G_TCAM_PART_SIZE(x) (((x) >> S_TCAM_PART_SIZE) & M_TCAM_PART_SIZE)
  1410. #define S_TCAM_PART_TYPE_HI 30
  1411. #define V_TCAM_PART_TYPE_HI(x) ((x) << S_TCAM_PART_TYPE_HI)
  1412. #define F_TCAM_PART_TYPE_HI V_TCAM_PART_TYPE_HI(1U)
  1413. #define A_MC5_SIZE 0xc08
  1414. #define S_SIZE 0
  1415. #define M_SIZE 0x3fffff
  1416. #define V_SIZE(x) ((x) << S_SIZE)
  1417. #define G_SIZE(x) (((x) >> S_SIZE) & M_SIZE)
  1418. #define A_MC5_ROUTING_TABLE_INDEX 0xc0c
  1419. #define S_START_OF_ROUTING_TABLE 0
  1420. #define M_START_OF_ROUTING_TABLE 0x3fffff
  1421. #define V_START_OF_ROUTING_TABLE(x) ((x) << S_START_OF_ROUTING_TABLE)
  1422. #define G_START_OF_ROUTING_TABLE(x) (((x) >> S_START_OF_ROUTING_TABLE) & M_START_OF_ROUTING_TABLE)
  1423. #define A_MC5_SERVER_INDEX 0xc14
  1424. #define S_START_OF_SERVER_INDEX 0
  1425. #define M_START_OF_SERVER_INDEX 0x3fffff
  1426. #define V_START_OF_SERVER_INDEX(x) ((x) << S_START_OF_SERVER_INDEX)
  1427. #define G_START_OF_SERVER_INDEX(x) (((x) >> S_START_OF_SERVER_INDEX) & M_START_OF_SERVER_INDEX)
  1428. #define A_MC5_LIP_RAM_ADDR 0xc18
  1429. #define S_LOCAL_IP_RAM_ADDR 0
  1430. #define M_LOCAL_IP_RAM_ADDR 0x3f
  1431. #define V_LOCAL_IP_RAM_ADDR(x) ((x) << S_LOCAL_IP_RAM_ADDR)
  1432. #define G_LOCAL_IP_RAM_ADDR(x) (((x) >> S_LOCAL_IP_RAM_ADDR) & M_LOCAL_IP_RAM_ADDR)
  1433. #define S_RAM_WRITE_ENABLE 8
  1434. #define V_RAM_WRITE_ENABLE(x) ((x) << S_RAM_WRITE_ENABLE)
  1435. #define F_RAM_WRITE_ENABLE V_RAM_WRITE_ENABLE(1U)
  1436. #define A_MC5_LIP_RAM_DATA 0xc1c
  1437. #define A_MC5_RSP_LATENCY 0xc20
  1438. #define S_SEARCH_RESPONSE_LATENCY 0
  1439. #define M_SEARCH_RESPONSE_LATENCY 0x1f
  1440. #define V_SEARCH_RESPONSE_LATENCY(x) ((x) << S_SEARCH_RESPONSE_LATENCY)
  1441. #define G_SEARCH_RESPONSE_LATENCY(x) (((x) >> S_SEARCH_RESPONSE_LATENCY) & M_SEARCH_RESPONSE_LATENCY)
  1442. #define S_LEARN_RESPONSE_LATENCY 8
  1443. #define M_LEARN_RESPONSE_LATENCY 0x1f
  1444. #define V_LEARN_RESPONSE_LATENCY(x) ((x) << S_LEARN_RESPONSE_LATENCY)
  1445. #define G_LEARN_RESPONSE_LATENCY(x) (((x) >> S_LEARN_RESPONSE_LATENCY) & M_LEARN_RESPONSE_LATENCY)
  1446. #define A_MC5_PARITY_LATENCY 0xc24
  1447. #define S_SRCHLAT 0
  1448. #define M_SRCHLAT 0x1f
  1449. #define V_SRCHLAT(x) ((x) << S_SRCHLAT)
  1450. #define G_SRCHLAT(x) (((x) >> S_SRCHLAT) & M_SRCHLAT)
  1451. #define S_PARLAT 8
  1452. #define M_PARLAT 0x1f
  1453. #define V_PARLAT(x) ((x) << S_PARLAT)
  1454. #define G_PARLAT(x) (((x) >> S_PARLAT) & M_PARLAT)
  1455. #define A_MC5_WR_LRN_VERIFY 0xc28
  1456. #define S_POVEREN 0
  1457. #define V_POVEREN(x) ((x) << S_POVEREN)
  1458. #define F_POVEREN V_POVEREN(1U)
  1459. #define S_LRNVEREN 1
  1460. #define V_LRNVEREN(x) ((x) << S_LRNVEREN)
  1461. #define F_LRNVEREN V_LRNVEREN(1U)
  1462. #define S_VWVEREN 2
  1463. #define V_VWVEREN(x) ((x) << S_VWVEREN)
  1464. #define F_VWVEREN V_VWVEREN(1U)
  1465. #define A_MC5_PART_ID_INDEX 0xc2c
  1466. #define S_IDINDEX 0
  1467. #define M_IDINDEX 0xf
  1468. #define V_IDINDEX(x) ((x) << S_IDINDEX)
  1469. #define G_IDINDEX(x) (((x) >> S_IDINDEX) & M_IDINDEX)
  1470. #define A_MC5_RESET_MAX 0xc30
  1471. #define S_RSTMAX 0
  1472. #define M_RSTMAX 0x1ff
  1473. #define V_RSTMAX(x) ((x) << S_RSTMAX)
  1474. #define G_RSTMAX(x) (((x) >> S_RSTMAX) & M_RSTMAX)
  1475. #define A_MC5_INT_ENABLE 0xc40
  1476. #define S_MC5_INT_HIT_OUT_ACTIVE_REGION_ERR 0
  1477. #define V_MC5_INT_HIT_OUT_ACTIVE_REGION_ERR(x) ((x) << S_MC5_INT_HIT_OUT_ACTIVE_REGION_ERR)
  1478. #define F_MC5_INT_HIT_OUT_ACTIVE_REGION_ERR V_MC5_INT_HIT_OUT_ACTIVE_REGION_ERR(1U)
  1479. #define S_MC5_INT_HIT_IN_ACTIVE_REGION_ERR 1
  1480. #define V_MC5_INT_HIT_IN_ACTIVE_REGION_ERR(x) ((x) << S_MC5_INT_HIT_IN_ACTIVE_REGION_ERR)
  1481. #define F_MC5_INT_HIT_IN_ACTIVE_REGION_ERR V_MC5_INT_HIT_IN_ACTIVE_REGION_ERR(1U)
  1482. #define S_MC5_INT_HIT_IN_RT_REGION_ERR 2
  1483. #define V_MC5_INT_HIT_IN_RT_REGION_ERR(x) ((x) << S_MC5_INT_HIT_IN_RT_REGION_ERR)
  1484. #define F_MC5_INT_HIT_IN_RT_REGION_ERR V_MC5_INT_HIT_IN_RT_REGION_ERR(1U)
  1485. #define S_MC5_INT_MISS_ERR 3
  1486. #define V_MC5_INT_MISS_ERR(x) ((x) << S_MC5_INT_MISS_ERR)
  1487. #define F_MC5_INT_MISS_ERR V_MC5_INT_MISS_ERR(1U)
  1488. #define S_MC5_INT_LIP0_ERR 4
  1489. #define V_MC5_INT_LIP0_ERR(x) ((x) << S_MC5_INT_LIP0_ERR)
  1490. #define F_MC5_INT_LIP0_ERR V_MC5_INT_LIP0_ERR(1U)
  1491. #define S_MC5_INT_LIP_MISS_ERR 5
  1492. #define V_MC5_INT_LIP_MISS_ERR(x) ((x) << S_MC5_INT_LIP_MISS_ERR)
  1493. #define F_MC5_INT_LIP_MISS_ERR V_MC5_INT_LIP_MISS_ERR(1U)
  1494. #define S_MC5_INT_PARITY_ERR 6
  1495. #define V_MC5_INT_PARITY_ERR(x) ((x) << S_MC5_INT_PARITY_ERR)
  1496. #define F_MC5_INT_PARITY_ERR V_MC5_INT_PARITY_ERR(1U)
  1497. #define S_MC5_INT_ACTIVE_REGION_FULL 7
  1498. #define V_MC5_INT_ACTIVE_REGION_FULL(x) ((x) << S_MC5_INT_ACTIVE_REGION_FULL)
  1499. #define F_MC5_INT_ACTIVE_REGION_FULL V_MC5_INT_ACTIVE_REGION_FULL(1U)
  1500. #define S_MC5_INT_NFA_SRCH_ERR 8
  1501. #define V_MC5_INT_NFA_SRCH_ERR(x) ((x) << S_MC5_INT_NFA_SRCH_ERR)
  1502. #define F_MC5_INT_NFA_SRCH_ERR V_MC5_INT_NFA_SRCH_ERR(1U)
  1503. #define S_MC5_INT_SYN_COOKIE 9
  1504. #define V_MC5_INT_SYN_COOKIE(x) ((x) << S_MC5_INT_SYN_COOKIE)
  1505. #define F_MC5_INT_SYN_COOKIE V_MC5_INT_SYN_COOKIE(1U)
  1506. #define S_MC5_INT_SYN_COOKIE_BAD 10
  1507. #define V_MC5_INT_SYN_COOKIE_BAD(x) ((x) << S_MC5_INT_SYN_COOKIE_BAD)
  1508. #define F_MC5_INT_SYN_COOKIE_BAD V_MC5_INT_SYN_COOKIE_BAD(1U)
  1509. #define S_MC5_INT_SYN_COOKIE_OFF 11
  1510. #define V_MC5_INT_SYN_COOKIE_OFF(x) ((x) << S_MC5_INT_SYN_COOKIE_OFF)
  1511. #define F_MC5_INT_SYN_COOKIE_OFF V_MC5_INT_SYN_COOKIE_OFF(1U)
  1512. #define S_MC5_INT_UNKNOWN_CMD 15
  1513. #define V_MC5_INT_UNKNOWN_CMD(x) ((x) << S_MC5_INT_UNKNOWN_CMD)
  1514. #define F_MC5_INT_UNKNOWN_CMD V_MC5_INT_UNKNOWN_CMD(1U)
  1515. #define S_MC5_INT_REQUESTQ_PARITY_ERR 16
  1516. #define V_MC5_INT_REQUESTQ_PARITY_ERR(x) ((x) << S_MC5_INT_REQUESTQ_PARITY_ERR)
  1517. #define F_MC5_INT_REQUESTQ_PARITY_ERR V_MC5_INT_REQUESTQ_PARITY_ERR(1U)
  1518. #define S_MC5_INT_DISPATCHQ_PARITY_ERR 17
  1519. #define V_MC5_INT_DISPATCHQ_PARITY_ERR(x) ((x) << S_MC5_INT_DISPATCHQ_PARITY_ERR)
  1520. #define F_MC5_INT_DISPATCHQ_PARITY_ERR V_MC5_INT_DISPATCHQ_PARITY_ERR(1U)
  1521. #define S_MC5_INT_DEL_ACT_EMPTY 18
  1522. #define V_MC5_INT_DEL_ACT_EMPTY(x) ((x) << S_MC5_INT_DEL_ACT_EMPTY)
  1523. #define F_MC5_INT_DEL_ACT_EMPTY V_MC5_INT_DEL_ACT_EMPTY(1U)
  1524. #define A_MC5_INT_CAUSE 0xc44
  1525. #define A_MC5_INT_TID 0xc48
  1526. #define A_MC5_INT_PTID 0xc4c
  1527. #define A_MC5_DBGI_CONFIG 0xc74
  1528. #define A_MC5_DBGI_REQ_CMD 0xc78
  1529. #define S_CMDMODE 0
  1530. #define M_CMDMODE 0x7
  1531. #define V_CMDMODE(x) ((x) << S_CMDMODE)
  1532. #define G_CMDMODE(x) (((x) >> S_CMDMODE) & M_CMDMODE)
  1533. #define S_SADRSEL 4
  1534. #define V_SADRSEL(x) ((x) << S_SADRSEL)
  1535. #define F_SADRSEL V_SADRSEL(1U)
  1536. #define S_WRITE_BURST_SIZE 22
  1537. #define M_WRITE_BURST_SIZE 0x3ff
  1538. #define V_WRITE_BURST_SIZE(x) ((x) << S_WRITE_BURST_SIZE)
  1539. #define G_WRITE_BURST_SIZE(x) (((x) >> S_WRITE_BURST_SIZE) & M_WRITE_BURST_SIZE)
  1540. #define A_MC5_DBGI_REQ_ADDR0 0xc7c
  1541. #define A_MC5_DBGI_REQ_ADDR1 0xc80
  1542. #define A_MC5_DBGI_REQ_ADDR2 0xc84
  1543. #define A_MC5_DBGI_REQ_DATA0 0xc88
  1544. #define A_MC5_DBGI_REQ_DATA1 0xc8c
  1545. #define A_MC5_DBGI_REQ_DATA2 0xc90
  1546. #define A_MC5_DBGI_REQ_DATA3 0xc94
  1547. #define A_MC5_DBGI_REQ_DATA4 0xc98
  1548. #define A_MC5_DBGI_REQ_MASK0 0xc9c
  1549. #define A_MC5_DBGI_REQ_MASK1 0xca0
  1550. #define A_MC5_DBGI_REQ_MASK2 0xca4
  1551. #define A_MC5_DBGI_REQ_MASK3 0xca8
  1552. #define A_MC5_DBGI_REQ_MASK4 0xcac
  1553. #define A_MC5_DBGI_RSP_STATUS 0xcb0
  1554. #define S_DBGI_RSP_VALID 0
  1555. #define V_DBGI_RSP_VALID(x) ((x) << S_DBGI_RSP_VALID)
  1556. #define F_DBGI_RSP_VALID V_DBGI_RSP_VALID(1U)
  1557. #define S_DBGI_RSP_HIT 1
  1558. #define V_DBGI_RSP_HIT(x) ((x) << S_DBGI_RSP_HIT)
  1559. #define F_DBGI_RSP_HIT V_DBGI_RSP_HIT(1U)
  1560. #define S_DBGI_RSP_ERR 2
  1561. #define V_DBGI_RSP_ERR(x) ((x) << S_DBGI_RSP_ERR)
  1562. #define F_DBGI_RSP_ERR V_DBGI_RSP_ERR(1U)
  1563. #define S_DBGI_RSP_ERR_REASON 8
  1564. #define M_DBGI_RSP_ERR_REASON 0x7
  1565. #define V_DBGI_RSP_ERR_REASON(x) ((x) << S_DBGI_RSP_ERR_REASON)
  1566. #define G_DBGI_RSP_ERR_REASON(x) (((x) >> S_DBGI_RSP_ERR_REASON) & M_DBGI_RSP_ERR_REASON)
  1567. #define A_MC5_DBGI_RSP_DATA0 0xcb4
  1568. #define A_MC5_DBGI_RSP_DATA1 0xcb8
  1569. #define A_MC5_DBGI_RSP_DATA2 0xcbc
  1570. #define A_MC5_DBGI_RSP_DATA3 0xcc0
  1571. #define A_MC5_DBGI_RSP_DATA4 0xcc4
  1572. #define A_MC5_DBGI_RSP_LAST_CMD 0xcc8
  1573. #define A_MC5_POPEN_DATA_WR_CMD 0xccc
  1574. #define A_MC5_POPEN_MASK_WR_CMD 0xcd0
  1575. #define A_MC5_AOPEN_SRCH_CMD 0xcd4
  1576. #define A_MC5_AOPEN_LRN_CMD 0xcd8
  1577. #define A_MC5_SYN_SRCH_CMD 0xcdc
  1578. #define A_MC5_SYN_LRN_CMD 0xce0
  1579. #define A_MC5_ACK_SRCH_CMD 0xce4
  1580. #define A_MC5_ACK_LRN_CMD 0xce8
  1581. #define A_MC5_ILOOKUP_CMD 0xcec
  1582. #define A_MC5_ELOOKUP_CMD 0xcf0
  1583. #define A_MC5_DATA_WRITE_CMD 0xcf4
  1584. #define A_MC5_DATA_READ_CMD 0xcf8
  1585. #define A_MC5_MASK_WRITE_CMD 0xcfc
  1586. /* PCICFG registers */
  1587. #define A_PCICFG_PM_CSR 0x44
  1588. #define A_PCICFG_VPD_ADDR 0x4a
  1589. #define S_VPD_ADDR 0
  1590. #define M_VPD_ADDR 0x7fff
  1591. #define V_VPD_ADDR(x) ((x) << S_VPD_ADDR)
  1592. #define G_VPD_ADDR(x) (((x) >> S_VPD_ADDR) & M_VPD_ADDR)
  1593. #define S_VPD_OP_FLAG 15
  1594. #define V_VPD_OP_FLAG(x) ((x) << S_VPD_OP_FLAG)
  1595. #define F_VPD_OP_FLAG V_VPD_OP_FLAG(1U)
  1596. #define A_PCICFG_VPD_DATA 0x4c
  1597. #define A_PCICFG_PCIX_CMD 0x60
  1598. #define A_PCICFG_INTR_ENABLE 0xf4
  1599. #define S_MASTER_PARITY_ERR 0
  1600. #define V_MASTER_PARITY_ERR(x) ((x) << S_MASTER_PARITY_ERR)
  1601. #define F_MASTER_PARITY_ERR V_MASTER_PARITY_ERR(1U)
  1602. #define S_SIG_TARGET_ABORT 1
  1603. #define V_SIG_TARGET_ABORT(x) ((x) << S_SIG_TARGET_ABORT)
  1604. #define F_SIG_TARGET_ABORT V_SIG_TARGET_ABORT(1U)
  1605. #define S_RCV_TARGET_ABORT 2
  1606. #define V_RCV_TARGET_ABORT(x) ((x) << S_RCV_TARGET_ABORT)
  1607. #define F_RCV_TARGET_ABORT V_RCV_TARGET_ABORT(1U)
  1608. #define S_RCV_MASTER_ABORT 3
  1609. #define V_RCV_MASTER_ABORT(x) ((x) << S_RCV_MASTER_ABORT)
  1610. #define F_RCV_MASTER_ABORT V_RCV_MASTER_ABORT(1U)
  1611. #define S_SIG_SYS_ERR 4
  1612. #define V_SIG_SYS_ERR(x) ((x) << S_SIG_SYS_ERR)
  1613. #define F_SIG_SYS_ERR V_SIG_SYS_ERR(1U)
  1614. #define S_DET_PARITY_ERR 5
  1615. #define V_DET_PARITY_ERR(x) ((x) << S_DET_PARITY_ERR)
  1616. #define F_DET_PARITY_ERR V_DET_PARITY_ERR(1U)
  1617. #define S_PIO_PARITY_ERR 6
  1618. #define V_PIO_PARITY_ERR(x) ((x) << S_PIO_PARITY_ERR)
  1619. #define F_PIO_PARITY_ERR V_PIO_PARITY_ERR(1U)
  1620. #define S_WF_PARITY_ERR 7
  1621. #define V_WF_PARITY_ERR(x) ((x) << S_WF_PARITY_ERR)
  1622. #define F_WF_PARITY_ERR V_WF_PARITY_ERR(1U)
  1623. #define S_RF_PARITY_ERR 8
  1624. #define M_RF_PARITY_ERR 0x3
  1625. #define V_RF_PARITY_ERR(x) ((x) << S_RF_PARITY_ERR)
  1626. #define G_RF_PARITY_ERR(x) (((x) >> S_RF_PARITY_ERR) & M_RF_PARITY_ERR)
  1627. #define S_CF_PARITY_ERR 10
  1628. #define M_CF_PARITY_ERR 0x3
  1629. #define V_CF_PARITY_ERR(x) ((x) << S_CF_PARITY_ERR)
  1630. #define G_CF_PARITY_ERR(x) (((x) >> S_CF_PARITY_ERR) & M_CF_PARITY_ERR)
  1631. #define A_PCICFG_INTR_CAUSE 0xf8
  1632. #define A_PCICFG_MODE 0xfc
  1633. #define S_PCI_MODE_64BIT 0
  1634. #define V_PCI_MODE_64BIT(x) ((x) << S_PCI_MODE_64BIT)
  1635. #define F_PCI_MODE_64BIT V_PCI_MODE_64BIT(1U)
  1636. #define S_PCI_MODE_66MHZ 1
  1637. #define V_PCI_MODE_66MHZ(x) ((x) << S_PCI_MODE_66MHZ)
  1638. #define F_PCI_MODE_66MHZ V_PCI_MODE_66MHZ(1U)
  1639. #define S_PCI_MODE_PCIX_INITPAT 2
  1640. #define M_PCI_MODE_PCIX_INITPAT 0x7
  1641. #define V_PCI_MODE_PCIX_INITPAT(x) ((x) << S_PCI_MODE_PCIX_INITPAT)
  1642. #define G_PCI_MODE_PCIX_INITPAT(x) (((x) >> S_PCI_MODE_PCIX_INITPAT) & M_PCI_MODE_PCIX_INITPAT)
  1643. #define S_PCI_MODE_PCIX 5
  1644. #define V_PCI_MODE_PCIX(x) ((x) << S_PCI_MODE_PCIX)
  1645. #define F_PCI_MODE_PCIX V_PCI_MODE_PCIX(1U)
  1646. #define S_PCI_MODE_CLK 6
  1647. #define M_PCI_MODE_CLK 0x3
  1648. #define V_PCI_MODE_CLK(x) ((x) << S_PCI_MODE_CLK)
  1649. #define G_PCI_MODE_CLK(x) (((x) >> S_PCI_MODE_CLK) & M_PCI_MODE_CLK)
  1650. #endif /* _CXGB_REGS_H_ */