cvmx-agl-defs.h 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194
  1. /***********************license start***************
  2. * Author: Cavium Networks
  3. *
  4. * Contact: support@caviumnetworks.com
  5. * This file is part of the OCTEON SDK
  6. *
  7. * Copyright (c) 2003-2008 Cavium Networks
  8. *
  9. * This file 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. * This file is distributed in the hope that it will be useful, but
  14. * AS-IS and WITHOUT ANY WARRANTY; without even the implied warranty
  15. * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, TITLE, or
  16. * NONINFRINGEMENT. See the GNU General Public License for more
  17. * details.
  18. *
  19. * You should have received a copy of the GNU General Public License
  20. * along with this file; if not, write to the Free Software
  21. * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
  22. * or visit http://www.gnu.org/licenses/.
  23. *
  24. * This file may also be available under a different license from Cavium.
  25. * Contact Cavium Networks for more information
  26. ***********************license end**************************************/
  27. #ifndef __CVMX_AGL_DEFS_H__
  28. #define __CVMX_AGL_DEFS_H__
  29. #define CVMX_AGL_GMX_BAD_REG \
  30. CVMX_ADD_IO_SEG(0x00011800E0000518ull)
  31. #define CVMX_AGL_GMX_BIST \
  32. CVMX_ADD_IO_SEG(0x00011800E0000400ull)
  33. #define CVMX_AGL_GMX_DRV_CTL \
  34. CVMX_ADD_IO_SEG(0x00011800E00007F0ull)
  35. #define CVMX_AGL_GMX_INF_MODE \
  36. CVMX_ADD_IO_SEG(0x00011800E00007F8ull)
  37. #define CVMX_AGL_GMX_PRTX_CFG(offset) \
  38. CVMX_ADD_IO_SEG(0x00011800E0000010ull + (((offset) & 1) * 2048))
  39. #define CVMX_AGL_GMX_RXX_ADR_CAM0(offset) \
  40. CVMX_ADD_IO_SEG(0x00011800E0000180ull + (((offset) & 1) * 2048))
  41. #define CVMX_AGL_GMX_RXX_ADR_CAM1(offset) \
  42. CVMX_ADD_IO_SEG(0x00011800E0000188ull + (((offset) & 1) * 2048))
  43. #define CVMX_AGL_GMX_RXX_ADR_CAM2(offset) \
  44. CVMX_ADD_IO_SEG(0x00011800E0000190ull + (((offset) & 1) * 2048))
  45. #define CVMX_AGL_GMX_RXX_ADR_CAM3(offset) \
  46. CVMX_ADD_IO_SEG(0x00011800E0000198ull + (((offset) & 1) * 2048))
  47. #define CVMX_AGL_GMX_RXX_ADR_CAM4(offset) \
  48. CVMX_ADD_IO_SEG(0x00011800E00001A0ull + (((offset) & 1) * 2048))
  49. #define CVMX_AGL_GMX_RXX_ADR_CAM5(offset) \
  50. CVMX_ADD_IO_SEG(0x00011800E00001A8ull + (((offset) & 1) * 2048))
  51. #define CVMX_AGL_GMX_RXX_ADR_CAM_EN(offset) \
  52. CVMX_ADD_IO_SEG(0x00011800E0000108ull + (((offset) & 1) * 2048))
  53. #define CVMX_AGL_GMX_RXX_ADR_CTL(offset) \
  54. CVMX_ADD_IO_SEG(0x00011800E0000100ull + (((offset) & 1) * 2048))
  55. #define CVMX_AGL_GMX_RXX_DECISION(offset) \
  56. CVMX_ADD_IO_SEG(0x00011800E0000040ull + (((offset) & 1) * 2048))
  57. #define CVMX_AGL_GMX_RXX_FRM_CHK(offset) \
  58. CVMX_ADD_IO_SEG(0x00011800E0000020ull + (((offset) & 1) * 2048))
  59. #define CVMX_AGL_GMX_RXX_FRM_CTL(offset) \
  60. CVMX_ADD_IO_SEG(0x00011800E0000018ull + (((offset) & 1) * 2048))
  61. #define CVMX_AGL_GMX_RXX_FRM_MAX(offset) \
  62. CVMX_ADD_IO_SEG(0x00011800E0000030ull + (((offset) & 1) * 2048))
  63. #define CVMX_AGL_GMX_RXX_FRM_MIN(offset) \
  64. CVMX_ADD_IO_SEG(0x00011800E0000028ull + (((offset) & 1) * 2048))
  65. #define CVMX_AGL_GMX_RXX_IFG(offset) \
  66. CVMX_ADD_IO_SEG(0x00011800E0000058ull + (((offset) & 1) * 2048))
  67. #define CVMX_AGL_GMX_RXX_INT_EN(offset) \
  68. CVMX_ADD_IO_SEG(0x00011800E0000008ull + (((offset) & 1) * 2048))
  69. #define CVMX_AGL_GMX_RXX_INT_REG(offset) \
  70. CVMX_ADD_IO_SEG(0x00011800E0000000ull + (((offset) & 1) * 2048))
  71. #define CVMX_AGL_GMX_RXX_JABBER(offset) \
  72. CVMX_ADD_IO_SEG(0x00011800E0000038ull + (((offset) & 1) * 2048))
  73. #define CVMX_AGL_GMX_RXX_PAUSE_DROP_TIME(offset) \
  74. CVMX_ADD_IO_SEG(0x00011800E0000068ull + (((offset) & 1) * 2048))
  75. #define CVMX_AGL_GMX_RXX_STATS_CTL(offset) \
  76. CVMX_ADD_IO_SEG(0x00011800E0000050ull + (((offset) & 1) * 2048))
  77. #define CVMX_AGL_GMX_RXX_STATS_OCTS(offset) \
  78. CVMX_ADD_IO_SEG(0x00011800E0000088ull + (((offset) & 1) * 2048))
  79. #define CVMX_AGL_GMX_RXX_STATS_OCTS_CTL(offset) \
  80. CVMX_ADD_IO_SEG(0x00011800E0000098ull + (((offset) & 1) * 2048))
  81. #define CVMX_AGL_GMX_RXX_STATS_OCTS_DMAC(offset) \
  82. CVMX_ADD_IO_SEG(0x00011800E00000A8ull + (((offset) & 1) * 2048))
  83. #define CVMX_AGL_GMX_RXX_STATS_OCTS_DRP(offset) \
  84. CVMX_ADD_IO_SEG(0x00011800E00000B8ull + (((offset) & 1) * 2048))
  85. #define CVMX_AGL_GMX_RXX_STATS_PKTS(offset) \
  86. CVMX_ADD_IO_SEG(0x00011800E0000080ull + (((offset) & 1) * 2048))
  87. #define CVMX_AGL_GMX_RXX_STATS_PKTS_BAD(offset) \
  88. CVMX_ADD_IO_SEG(0x00011800E00000C0ull + (((offset) & 1) * 2048))
  89. #define CVMX_AGL_GMX_RXX_STATS_PKTS_CTL(offset) \
  90. CVMX_ADD_IO_SEG(0x00011800E0000090ull + (((offset) & 1) * 2048))
  91. #define CVMX_AGL_GMX_RXX_STATS_PKTS_DMAC(offset) \
  92. CVMX_ADD_IO_SEG(0x00011800E00000A0ull + (((offset) & 1) * 2048))
  93. #define CVMX_AGL_GMX_RXX_STATS_PKTS_DRP(offset) \
  94. CVMX_ADD_IO_SEG(0x00011800E00000B0ull + (((offset) & 1) * 2048))
  95. #define CVMX_AGL_GMX_RXX_UDD_SKP(offset) \
  96. CVMX_ADD_IO_SEG(0x00011800E0000048ull + (((offset) & 1) * 2048))
  97. #define CVMX_AGL_GMX_RX_BP_DROPX(offset) \
  98. CVMX_ADD_IO_SEG(0x00011800E0000420ull + (((offset) & 1) * 8))
  99. #define CVMX_AGL_GMX_RX_BP_OFFX(offset) \
  100. CVMX_ADD_IO_SEG(0x00011800E0000460ull + (((offset) & 1) * 8))
  101. #define CVMX_AGL_GMX_RX_BP_ONX(offset) \
  102. CVMX_ADD_IO_SEG(0x00011800E0000440ull + (((offset) & 1) * 8))
  103. #define CVMX_AGL_GMX_RX_PRT_INFO \
  104. CVMX_ADD_IO_SEG(0x00011800E00004E8ull)
  105. #define CVMX_AGL_GMX_RX_TX_STATUS \
  106. CVMX_ADD_IO_SEG(0x00011800E00007E8ull)
  107. #define CVMX_AGL_GMX_SMACX(offset) \
  108. CVMX_ADD_IO_SEG(0x00011800E0000230ull + (((offset) & 1) * 2048))
  109. #define CVMX_AGL_GMX_STAT_BP \
  110. CVMX_ADD_IO_SEG(0x00011800E0000520ull)
  111. #define CVMX_AGL_GMX_TXX_APPEND(offset) \
  112. CVMX_ADD_IO_SEG(0x00011800E0000218ull + (((offset) & 1) * 2048))
  113. #define CVMX_AGL_GMX_TXX_CTL(offset) \
  114. CVMX_ADD_IO_SEG(0x00011800E0000270ull + (((offset) & 1) * 2048))
  115. #define CVMX_AGL_GMX_TXX_MIN_PKT(offset) \
  116. CVMX_ADD_IO_SEG(0x00011800E0000240ull + (((offset) & 1) * 2048))
  117. #define CVMX_AGL_GMX_TXX_PAUSE_PKT_INTERVAL(offset) \
  118. CVMX_ADD_IO_SEG(0x00011800E0000248ull + (((offset) & 1) * 2048))
  119. #define CVMX_AGL_GMX_TXX_PAUSE_PKT_TIME(offset) \
  120. CVMX_ADD_IO_SEG(0x00011800E0000238ull + (((offset) & 1) * 2048))
  121. #define CVMX_AGL_GMX_TXX_PAUSE_TOGO(offset) \
  122. CVMX_ADD_IO_SEG(0x00011800E0000258ull + (((offset) & 1) * 2048))
  123. #define CVMX_AGL_GMX_TXX_PAUSE_ZERO(offset) \
  124. CVMX_ADD_IO_SEG(0x00011800E0000260ull + (((offset) & 1) * 2048))
  125. #define CVMX_AGL_GMX_TXX_SOFT_PAUSE(offset) \
  126. CVMX_ADD_IO_SEG(0x00011800E0000250ull + (((offset) & 1) * 2048))
  127. #define CVMX_AGL_GMX_TXX_STAT0(offset) \
  128. CVMX_ADD_IO_SEG(0x00011800E0000280ull + (((offset) & 1) * 2048))
  129. #define CVMX_AGL_GMX_TXX_STAT1(offset) \
  130. CVMX_ADD_IO_SEG(0x00011800E0000288ull + (((offset) & 1) * 2048))
  131. #define CVMX_AGL_GMX_TXX_STAT2(offset) \
  132. CVMX_ADD_IO_SEG(0x00011800E0000290ull + (((offset) & 1) * 2048))
  133. #define CVMX_AGL_GMX_TXX_STAT3(offset) \
  134. CVMX_ADD_IO_SEG(0x00011800E0000298ull + (((offset) & 1) * 2048))
  135. #define CVMX_AGL_GMX_TXX_STAT4(offset) \
  136. CVMX_ADD_IO_SEG(0x00011800E00002A0ull + (((offset) & 1) * 2048))
  137. #define CVMX_AGL_GMX_TXX_STAT5(offset) \
  138. CVMX_ADD_IO_SEG(0x00011800E00002A8ull + (((offset) & 1) * 2048))
  139. #define CVMX_AGL_GMX_TXX_STAT6(offset) \
  140. CVMX_ADD_IO_SEG(0x00011800E00002B0ull + (((offset) & 1) * 2048))
  141. #define CVMX_AGL_GMX_TXX_STAT7(offset) \
  142. CVMX_ADD_IO_SEG(0x00011800E00002B8ull + (((offset) & 1) * 2048))
  143. #define CVMX_AGL_GMX_TXX_STAT8(offset) \
  144. CVMX_ADD_IO_SEG(0x00011800E00002C0ull + (((offset) & 1) * 2048))
  145. #define CVMX_AGL_GMX_TXX_STAT9(offset) \
  146. CVMX_ADD_IO_SEG(0x00011800E00002C8ull + (((offset) & 1) * 2048))
  147. #define CVMX_AGL_GMX_TXX_STATS_CTL(offset) \
  148. CVMX_ADD_IO_SEG(0x00011800E0000268ull + (((offset) & 1) * 2048))
  149. #define CVMX_AGL_GMX_TXX_THRESH(offset) \
  150. CVMX_ADD_IO_SEG(0x00011800E0000210ull + (((offset) & 1) * 2048))
  151. #define CVMX_AGL_GMX_TX_BP \
  152. CVMX_ADD_IO_SEG(0x00011800E00004D0ull)
  153. #define CVMX_AGL_GMX_TX_COL_ATTEMPT \
  154. CVMX_ADD_IO_SEG(0x00011800E0000498ull)
  155. #define CVMX_AGL_GMX_TX_IFG \
  156. CVMX_ADD_IO_SEG(0x00011800E0000488ull)
  157. #define CVMX_AGL_GMX_TX_INT_EN \
  158. CVMX_ADD_IO_SEG(0x00011800E0000508ull)
  159. #define CVMX_AGL_GMX_TX_INT_REG \
  160. CVMX_ADD_IO_SEG(0x00011800E0000500ull)
  161. #define CVMX_AGL_GMX_TX_JAM \
  162. CVMX_ADD_IO_SEG(0x00011800E0000490ull)
  163. #define CVMX_AGL_GMX_TX_LFSR \
  164. CVMX_ADD_IO_SEG(0x00011800E00004F8ull)
  165. #define CVMX_AGL_GMX_TX_OVR_BP \
  166. CVMX_ADD_IO_SEG(0x00011800E00004C8ull)
  167. #define CVMX_AGL_GMX_TX_PAUSE_PKT_DMAC \
  168. CVMX_ADD_IO_SEG(0x00011800E00004A0ull)
  169. #define CVMX_AGL_GMX_TX_PAUSE_PKT_TYPE \
  170. CVMX_ADD_IO_SEG(0x00011800E00004A8ull)
  171. union cvmx_agl_gmx_bad_reg {
  172. uint64_t u64;
  173. struct cvmx_agl_gmx_bad_reg_s {
  174. uint64_t reserved_38_63:26;
  175. uint64_t txpsh1:1;
  176. uint64_t txpop1:1;
  177. uint64_t ovrflw1:1;
  178. uint64_t txpsh:1;
  179. uint64_t txpop:1;
  180. uint64_t ovrflw:1;
  181. uint64_t reserved_27_31:5;
  182. uint64_t statovr:1;
  183. uint64_t reserved_23_25:3;
  184. uint64_t loststat:1;
  185. uint64_t reserved_4_21:18;
  186. uint64_t out_ovr:2;
  187. uint64_t reserved_0_1:2;
  188. } s;
  189. struct cvmx_agl_gmx_bad_reg_s cn52xx;
  190. struct cvmx_agl_gmx_bad_reg_s cn52xxp1;
  191. struct cvmx_agl_gmx_bad_reg_cn56xx {
  192. uint64_t reserved_35_63:29;
  193. uint64_t txpsh:1;
  194. uint64_t txpop:1;
  195. uint64_t ovrflw:1;
  196. uint64_t reserved_27_31:5;
  197. uint64_t statovr:1;
  198. uint64_t reserved_23_25:3;
  199. uint64_t loststat:1;
  200. uint64_t reserved_3_21:19;
  201. uint64_t out_ovr:1;
  202. uint64_t reserved_0_1:2;
  203. } cn56xx;
  204. struct cvmx_agl_gmx_bad_reg_cn56xx cn56xxp1;
  205. };
  206. union cvmx_agl_gmx_bist {
  207. uint64_t u64;
  208. struct cvmx_agl_gmx_bist_s {
  209. uint64_t reserved_10_63:54;
  210. uint64_t status:10;
  211. } s;
  212. struct cvmx_agl_gmx_bist_s cn52xx;
  213. struct cvmx_agl_gmx_bist_s cn52xxp1;
  214. struct cvmx_agl_gmx_bist_s cn56xx;
  215. struct cvmx_agl_gmx_bist_s cn56xxp1;
  216. };
  217. union cvmx_agl_gmx_drv_ctl {
  218. uint64_t u64;
  219. struct cvmx_agl_gmx_drv_ctl_s {
  220. uint64_t reserved_49_63:15;
  221. uint64_t byp_en1:1;
  222. uint64_t reserved_45_47:3;
  223. uint64_t pctl1:5;
  224. uint64_t reserved_37_39:3;
  225. uint64_t nctl1:5;
  226. uint64_t reserved_17_31:15;
  227. uint64_t byp_en:1;
  228. uint64_t reserved_13_15:3;
  229. uint64_t pctl:5;
  230. uint64_t reserved_5_7:3;
  231. uint64_t nctl:5;
  232. } s;
  233. struct cvmx_agl_gmx_drv_ctl_s cn52xx;
  234. struct cvmx_agl_gmx_drv_ctl_s cn52xxp1;
  235. struct cvmx_agl_gmx_drv_ctl_cn56xx {
  236. uint64_t reserved_17_63:47;
  237. uint64_t byp_en:1;
  238. uint64_t reserved_13_15:3;
  239. uint64_t pctl:5;
  240. uint64_t reserved_5_7:3;
  241. uint64_t nctl:5;
  242. } cn56xx;
  243. struct cvmx_agl_gmx_drv_ctl_cn56xx cn56xxp1;
  244. };
  245. union cvmx_agl_gmx_inf_mode {
  246. uint64_t u64;
  247. struct cvmx_agl_gmx_inf_mode_s {
  248. uint64_t reserved_2_63:62;
  249. uint64_t en:1;
  250. uint64_t reserved_0_0:1;
  251. } s;
  252. struct cvmx_agl_gmx_inf_mode_s cn52xx;
  253. struct cvmx_agl_gmx_inf_mode_s cn52xxp1;
  254. struct cvmx_agl_gmx_inf_mode_s cn56xx;
  255. struct cvmx_agl_gmx_inf_mode_s cn56xxp1;
  256. };
  257. union cvmx_agl_gmx_prtx_cfg {
  258. uint64_t u64;
  259. struct cvmx_agl_gmx_prtx_cfg_s {
  260. uint64_t reserved_6_63:58;
  261. uint64_t tx_en:1;
  262. uint64_t rx_en:1;
  263. uint64_t slottime:1;
  264. uint64_t duplex:1;
  265. uint64_t speed:1;
  266. uint64_t en:1;
  267. } s;
  268. struct cvmx_agl_gmx_prtx_cfg_s cn52xx;
  269. struct cvmx_agl_gmx_prtx_cfg_s cn52xxp1;
  270. struct cvmx_agl_gmx_prtx_cfg_s cn56xx;
  271. struct cvmx_agl_gmx_prtx_cfg_s cn56xxp1;
  272. };
  273. union cvmx_agl_gmx_rxx_adr_cam0 {
  274. uint64_t u64;
  275. struct cvmx_agl_gmx_rxx_adr_cam0_s {
  276. uint64_t adr:64;
  277. } s;
  278. struct cvmx_agl_gmx_rxx_adr_cam0_s cn52xx;
  279. struct cvmx_agl_gmx_rxx_adr_cam0_s cn52xxp1;
  280. struct cvmx_agl_gmx_rxx_adr_cam0_s cn56xx;
  281. struct cvmx_agl_gmx_rxx_adr_cam0_s cn56xxp1;
  282. };
  283. union cvmx_agl_gmx_rxx_adr_cam1 {
  284. uint64_t u64;
  285. struct cvmx_agl_gmx_rxx_adr_cam1_s {
  286. uint64_t adr:64;
  287. } s;
  288. struct cvmx_agl_gmx_rxx_adr_cam1_s cn52xx;
  289. struct cvmx_agl_gmx_rxx_adr_cam1_s cn52xxp1;
  290. struct cvmx_agl_gmx_rxx_adr_cam1_s cn56xx;
  291. struct cvmx_agl_gmx_rxx_adr_cam1_s cn56xxp1;
  292. };
  293. union cvmx_agl_gmx_rxx_adr_cam2 {
  294. uint64_t u64;
  295. struct cvmx_agl_gmx_rxx_adr_cam2_s {
  296. uint64_t adr:64;
  297. } s;
  298. struct cvmx_agl_gmx_rxx_adr_cam2_s cn52xx;
  299. struct cvmx_agl_gmx_rxx_adr_cam2_s cn52xxp1;
  300. struct cvmx_agl_gmx_rxx_adr_cam2_s cn56xx;
  301. struct cvmx_agl_gmx_rxx_adr_cam2_s cn56xxp1;
  302. };
  303. union cvmx_agl_gmx_rxx_adr_cam3 {
  304. uint64_t u64;
  305. struct cvmx_agl_gmx_rxx_adr_cam3_s {
  306. uint64_t adr:64;
  307. } s;
  308. struct cvmx_agl_gmx_rxx_adr_cam3_s cn52xx;
  309. struct cvmx_agl_gmx_rxx_adr_cam3_s cn52xxp1;
  310. struct cvmx_agl_gmx_rxx_adr_cam3_s cn56xx;
  311. struct cvmx_agl_gmx_rxx_adr_cam3_s cn56xxp1;
  312. };
  313. union cvmx_agl_gmx_rxx_adr_cam4 {
  314. uint64_t u64;
  315. struct cvmx_agl_gmx_rxx_adr_cam4_s {
  316. uint64_t adr:64;
  317. } s;
  318. struct cvmx_agl_gmx_rxx_adr_cam4_s cn52xx;
  319. struct cvmx_agl_gmx_rxx_adr_cam4_s cn52xxp1;
  320. struct cvmx_agl_gmx_rxx_adr_cam4_s cn56xx;
  321. struct cvmx_agl_gmx_rxx_adr_cam4_s cn56xxp1;
  322. };
  323. union cvmx_agl_gmx_rxx_adr_cam5 {
  324. uint64_t u64;
  325. struct cvmx_agl_gmx_rxx_adr_cam5_s {
  326. uint64_t adr:64;
  327. } s;
  328. struct cvmx_agl_gmx_rxx_adr_cam5_s cn52xx;
  329. struct cvmx_agl_gmx_rxx_adr_cam5_s cn52xxp1;
  330. struct cvmx_agl_gmx_rxx_adr_cam5_s cn56xx;
  331. struct cvmx_agl_gmx_rxx_adr_cam5_s cn56xxp1;
  332. };
  333. union cvmx_agl_gmx_rxx_adr_cam_en {
  334. uint64_t u64;
  335. struct cvmx_agl_gmx_rxx_adr_cam_en_s {
  336. uint64_t reserved_8_63:56;
  337. uint64_t en:8;
  338. } s;
  339. struct cvmx_agl_gmx_rxx_adr_cam_en_s cn52xx;
  340. struct cvmx_agl_gmx_rxx_adr_cam_en_s cn52xxp1;
  341. struct cvmx_agl_gmx_rxx_adr_cam_en_s cn56xx;
  342. struct cvmx_agl_gmx_rxx_adr_cam_en_s cn56xxp1;
  343. };
  344. union cvmx_agl_gmx_rxx_adr_ctl {
  345. uint64_t u64;
  346. struct cvmx_agl_gmx_rxx_adr_ctl_s {
  347. uint64_t reserved_4_63:60;
  348. uint64_t cam_mode:1;
  349. uint64_t mcst:2;
  350. uint64_t bcst:1;
  351. } s;
  352. struct cvmx_agl_gmx_rxx_adr_ctl_s cn52xx;
  353. struct cvmx_agl_gmx_rxx_adr_ctl_s cn52xxp1;
  354. struct cvmx_agl_gmx_rxx_adr_ctl_s cn56xx;
  355. struct cvmx_agl_gmx_rxx_adr_ctl_s cn56xxp1;
  356. };
  357. union cvmx_agl_gmx_rxx_decision {
  358. uint64_t u64;
  359. struct cvmx_agl_gmx_rxx_decision_s {
  360. uint64_t reserved_5_63:59;
  361. uint64_t cnt:5;
  362. } s;
  363. struct cvmx_agl_gmx_rxx_decision_s cn52xx;
  364. struct cvmx_agl_gmx_rxx_decision_s cn52xxp1;
  365. struct cvmx_agl_gmx_rxx_decision_s cn56xx;
  366. struct cvmx_agl_gmx_rxx_decision_s cn56xxp1;
  367. };
  368. union cvmx_agl_gmx_rxx_frm_chk {
  369. uint64_t u64;
  370. struct cvmx_agl_gmx_rxx_frm_chk_s {
  371. uint64_t reserved_9_63:55;
  372. uint64_t skperr:1;
  373. uint64_t rcverr:1;
  374. uint64_t lenerr:1;
  375. uint64_t alnerr:1;
  376. uint64_t fcserr:1;
  377. uint64_t jabber:1;
  378. uint64_t maxerr:1;
  379. uint64_t reserved_1_1:1;
  380. uint64_t minerr:1;
  381. } s;
  382. struct cvmx_agl_gmx_rxx_frm_chk_s cn52xx;
  383. struct cvmx_agl_gmx_rxx_frm_chk_s cn52xxp1;
  384. struct cvmx_agl_gmx_rxx_frm_chk_s cn56xx;
  385. struct cvmx_agl_gmx_rxx_frm_chk_s cn56xxp1;
  386. };
  387. union cvmx_agl_gmx_rxx_frm_ctl {
  388. uint64_t u64;
  389. struct cvmx_agl_gmx_rxx_frm_ctl_s {
  390. uint64_t reserved_10_63:54;
  391. uint64_t pre_align:1;
  392. uint64_t pad_len:1;
  393. uint64_t vlan_len:1;
  394. uint64_t pre_free:1;
  395. uint64_t ctl_smac:1;
  396. uint64_t ctl_mcst:1;
  397. uint64_t ctl_bck:1;
  398. uint64_t ctl_drp:1;
  399. uint64_t pre_strp:1;
  400. uint64_t pre_chk:1;
  401. } s;
  402. struct cvmx_agl_gmx_rxx_frm_ctl_s cn52xx;
  403. struct cvmx_agl_gmx_rxx_frm_ctl_s cn52xxp1;
  404. struct cvmx_agl_gmx_rxx_frm_ctl_s cn56xx;
  405. struct cvmx_agl_gmx_rxx_frm_ctl_s cn56xxp1;
  406. };
  407. union cvmx_agl_gmx_rxx_frm_max {
  408. uint64_t u64;
  409. struct cvmx_agl_gmx_rxx_frm_max_s {
  410. uint64_t reserved_16_63:48;
  411. uint64_t len:16;
  412. } s;
  413. struct cvmx_agl_gmx_rxx_frm_max_s cn52xx;
  414. struct cvmx_agl_gmx_rxx_frm_max_s cn52xxp1;
  415. struct cvmx_agl_gmx_rxx_frm_max_s cn56xx;
  416. struct cvmx_agl_gmx_rxx_frm_max_s cn56xxp1;
  417. };
  418. union cvmx_agl_gmx_rxx_frm_min {
  419. uint64_t u64;
  420. struct cvmx_agl_gmx_rxx_frm_min_s {
  421. uint64_t reserved_16_63:48;
  422. uint64_t len:16;
  423. } s;
  424. struct cvmx_agl_gmx_rxx_frm_min_s cn52xx;
  425. struct cvmx_agl_gmx_rxx_frm_min_s cn52xxp1;
  426. struct cvmx_agl_gmx_rxx_frm_min_s cn56xx;
  427. struct cvmx_agl_gmx_rxx_frm_min_s cn56xxp1;
  428. };
  429. union cvmx_agl_gmx_rxx_ifg {
  430. uint64_t u64;
  431. struct cvmx_agl_gmx_rxx_ifg_s {
  432. uint64_t reserved_4_63:60;
  433. uint64_t ifg:4;
  434. } s;
  435. struct cvmx_agl_gmx_rxx_ifg_s cn52xx;
  436. struct cvmx_agl_gmx_rxx_ifg_s cn52xxp1;
  437. struct cvmx_agl_gmx_rxx_ifg_s cn56xx;
  438. struct cvmx_agl_gmx_rxx_ifg_s cn56xxp1;
  439. };
  440. union cvmx_agl_gmx_rxx_int_en {
  441. uint64_t u64;
  442. struct cvmx_agl_gmx_rxx_int_en_s {
  443. uint64_t reserved_20_63:44;
  444. uint64_t pause_drp:1;
  445. uint64_t reserved_16_18:3;
  446. uint64_t ifgerr:1;
  447. uint64_t coldet:1;
  448. uint64_t falerr:1;
  449. uint64_t rsverr:1;
  450. uint64_t pcterr:1;
  451. uint64_t ovrerr:1;
  452. uint64_t reserved_9_9:1;
  453. uint64_t skperr:1;
  454. uint64_t rcverr:1;
  455. uint64_t lenerr:1;
  456. uint64_t alnerr:1;
  457. uint64_t fcserr:1;
  458. uint64_t jabber:1;
  459. uint64_t maxerr:1;
  460. uint64_t reserved_1_1:1;
  461. uint64_t minerr:1;
  462. } s;
  463. struct cvmx_agl_gmx_rxx_int_en_s cn52xx;
  464. struct cvmx_agl_gmx_rxx_int_en_s cn52xxp1;
  465. struct cvmx_agl_gmx_rxx_int_en_s cn56xx;
  466. struct cvmx_agl_gmx_rxx_int_en_s cn56xxp1;
  467. };
  468. union cvmx_agl_gmx_rxx_int_reg {
  469. uint64_t u64;
  470. struct cvmx_agl_gmx_rxx_int_reg_s {
  471. uint64_t reserved_20_63:44;
  472. uint64_t pause_drp:1;
  473. uint64_t reserved_16_18:3;
  474. uint64_t ifgerr:1;
  475. uint64_t coldet:1;
  476. uint64_t falerr:1;
  477. uint64_t rsverr:1;
  478. uint64_t pcterr:1;
  479. uint64_t ovrerr:1;
  480. uint64_t reserved_9_9:1;
  481. uint64_t skperr:1;
  482. uint64_t rcverr:1;
  483. uint64_t lenerr:1;
  484. uint64_t alnerr:1;
  485. uint64_t fcserr:1;
  486. uint64_t jabber:1;
  487. uint64_t maxerr:1;
  488. uint64_t reserved_1_1:1;
  489. uint64_t minerr:1;
  490. } s;
  491. struct cvmx_agl_gmx_rxx_int_reg_s cn52xx;
  492. struct cvmx_agl_gmx_rxx_int_reg_s cn52xxp1;
  493. struct cvmx_agl_gmx_rxx_int_reg_s cn56xx;
  494. struct cvmx_agl_gmx_rxx_int_reg_s cn56xxp1;
  495. };
  496. union cvmx_agl_gmx_rxx_jabber {
  497. uint64_t u64;
  498. struct cvmx_agl_gmx_rxx_jabber_s {
  499. uint64_t reserved_16_63:48;
  500. uint64_t cnt:16;
  501. } s;
  502. struct cvmx_agl_gmx_rxx_jabber_s cn52xx;
  503. struct cvmx_agl_gmx_rxx_jabber_s cn52xxp1;
  504. struct cvmx_agl_gmx_rxx_jabber_s cn56xx;
  505. struct cvmx_agl_gmx_rxx_jabber_s cn56xxp1;
  506. };
  507. union cvmx_agl_gmx_rxx_pause_drop_time {
  508. uint64_t u64;
  509. struct cvmx_agl_gmx_rxx_pause_drop_time_s {
  510. uint64_t reserved_16_63:48;
  511. uint64_t status:16;
  512. } s;
  513. struct cvmx_agl_gmx_rxx_pause_drop_time_s cn52xx;
  514. struct cvmx_agl_gmx_rxx_pause_drop_time_s cn52xxp1;
  515. struct cvmx_agl_gmx_rxx_pause_drop_time_s cn56xx;
  516. struct cvmx_agl_gmx_rxx_pause_drop_time_s cn56xxp1;
  517. };
  518. union cvmx_agl_gmx_rxx_stats_ctl {
  519. uint64_t u64;
  520. struct cvmx_agl_gmx_rxx_stats_ctl_s {
  521. uint64_t reserved_1_63:63;
  522. uint64_t rd_clr:1;
  523. } s;
  524. struct cvmx_agl_gmx_rxx_stats_ctl_s cn52xx;
  525. struct cvmx_agl_gmx_rxx_stats_ctl_s cn52xxp1;
  526. struct cvmx_agl_gmx_rxx_stats_ctl_s cn56xx;
  527. struct cvmx_agl_gmx_rxx_stats_ctl_s cn56xxp1;
  528. };
  529. union cvmx_agl_gmx_rxx_stats_octs {
  530. uint64_t u64;
  531. struct cvmx_agl_gmx_rxx_stats_octs_s {
  532. uint64_t reserved_48_63:16;
  533. uint64_t cnt:48;
  534. } s;
  535. struct cvmx_agl_gmx_rxx_stats_octs_s cn52xx;
  536. struct cvmx_agl_gmx_rxx_stats_octs_s cn52xxp1;
  537. struct cvmx_agl_gmx_rxx_stats_octs_s cn56xx;
  538. struct cvmx_agl_gmx_rxx_stats_octs_s cn56xxp1;
  539. };
  540. union cvmx_agl_gmx_rxx_stats_octs_ctl {
  541. uint64_t u64;
  542. struct cvmx_agl_gmx_rxx_stats_octs_ctl_s {
  543. uint64_t reserved_48_63:16;
  544. uint64_t cnt:48;
  545. } s;
  546. struct cvmx_agl_gmx_rxx_stats_octs_ctl_s cn52xx;
  547. struct cvmx_agl_gmx_rxx_stats_octs_ctl_s cn52xxp1;
  548. struct cvmx_agl_gmx_rxx_stats_octs_ctl_s cn56xx;
  549. struct cvmx_agl_gmx_rxx_stats_octs_ctl_s cn56xxp1;
  550. };
  551. union cvmx_agl_gmx_rxx_stats_octs_dmac {
  552. uint64_t u64;
  553. struct cvmx_agl_gmx_rxx_stats_octs_dmac_s {
  554. uint64_t reserved_48_63:16;
  555. uint64_t cnt:48;
  556. } s;
  557. struct cvmx_agl_gmx_rxx_stats_octs_dmac_s cn52xx;
  558. struct cvmx_agl_gmx_rxx_stats_octs_dmac_s cn52xxp1;
  559. struct cvmx_agl_gmx_rxx_stats_octs_dmac_s cn56xx;
  560. struct cvmx_agl_gmx_rxx_stats_octs_dmac_s cn56xxp1;
  561. };
  562. union cvmx_agl_gmx_rxx_stats_octs_drp {
  563. uint64_t u64;
  564. struct cvmx_agl_gmx_rxx_stats_octs_drp_s {
  565. uint64_t reserved_48_63:16;
  566. uint64_t cnt:48;
  567. } s;
  568. struct cvmx_agl_gmx_rxx_stats_octs_drp_s cn52xx;
  569. struct cvmx_agl_gmx_rxx_stats_octs_drp_s cn52xxp1;
  570. struct cvmx_agl_gmx_rxx_stats_octs_drp_s cn56xx;
  571. struct cvmx_agl_gmx_rxx_stats_octs_drp_s cn56xxp1;
  572. };
  573. union cvmx_agl_gmx_rxx_stats_pkts {
  574. uint64_t u64;
  575. struct cvmx_agl_gmx_rxx_stats_pkts_s {
  576. uint64_t reserved_32_63:32;
  577. uint64_t cnt:32;
  578. } s;
  579. struct cvmx_agl_gmx_rxx_stats_pkts_s cn52xx;
  580. struct cvmx_agl_gmx_rxx_stats_pkts_s cn52xxp1;
  581. struct cvmx_agl_gmx_rxx_stats_pkts_s cn56xx;
  582. struct cvmx_agl_gmx_rxx_stats_pkts_s cn56xxp1;
  583. };
  584. union cvmx_agl_gmx_rxx_stats_pkts_bad {
  585. uint64_t u64;
  586. struct cvmx_agl_gmx_rxx_stats_pkts_bad_s {
  587. uint64_t reserved_32_63:32;
  588. uint64_t cnt:32;
  589. } s;
  590. struct cvmx_agl_gmx_rxx_stats_pkts_bad_s cn52xx;
  591. struct cvmx_agl_gmx_rxx_stats_pkts_bad_s cn52xxp1;
  592. struct cvmx_agl_gmx_rxx_stats_pkts_bad_s cn56xx;
  593. struct cvmx_agl_gmx_rxx_stats_pkts_bad_s cn56xxp1;
  594. };
  595. union cvmx_agl_gmx_rxx_stats_pkts_ctl {
  596. uint64_t u64;
  597. struct cvmx_agl_gmx_rxx_stats_pkts_ctl_s {
  598. uint64_t reserved_32_63:32;
  599. uint64_t cnt:32;
  600. } s;
  601. struct cvmx_agl_gmx_rxx_stats_pkts_ctl_s cn52xx;
  602. struct cvmx_agl_gmx_rxx_stats_pkts_ctl_s cn52xxp1;
  603. struct cvmx_agl_gmx_rxx_stats_pkts_ctl_s cn56xx;
  604. struct cvmx_agl_gmx_rxx_stats_pkts_ctl_s cn56xxp1;
  605. };
  606. union cvmx_agl_gmx_rxx_stats_pkts_dmac {
  607. uint64_t u64;
  608. struct cvmx_agl_gmx_rxx_stats_pkts_dmac_s {
  609. uint64_t reserved_32_63:32;
  610. uint64_t cnt:32;
  611. } s;
  612. struct cvmx_agl_gmx_rxx_stats_pkts_dmac_s cn52xx;
  613. struct cvmx_agl_gmx_rxx_stats_pkts_dmac_s cn52xxp1;
  614. struct cvmx_agl_gmx_rxx_stats_pkts_dmac_s cn56xx;
  615. struct cvmx_agl_gmx_rxx_stats_pkts_dmac_s cn56xxp1;
  616. };
  617. union cvmx_agl_gmx_rxx_stats_pkts_drp {
  618. uint64_t u64;
  619. struct cvmx_agl_gmx_rxx_stats_pkts_drp_s {
  620. uint64_t reserved_32_63:32;
  621. uint64_t cnt:32;
  622. } s;
  623. struct cvmx_agl_gmx_rxx_stats_pkts_drp_s cn52xx;
  624. struct cvmx_agl_gmx_rxx_stats_pkts_drp_s cn52xxp1;
  625. struct cvmx_agl_gmx_rxx_stats_pkts_drp_s cn56xx;
  626. struct cvmx_agl_gmx_rxx_stats_pkts_drp_s cn56xxp1;
  627. };
  628. union cvmx_agl_gmx_rxx_udd_skp {
  629. uint64_t u64;
  630. struct cvmx_agl_gmx_rxx_udd_skp_s {
  631. uint64_t reserved_9_63:55;
  632. uint64_t fcssel:1;
  633. uint64_t reserved_7_7:1;
  634. uint64_t len:7;
  635. } s;
  636. struct cvmx_agl_gmx_rxx_udd_skp_s cn52xx;
  637. struct cvmx_agl_gmx_rxx_udd_skp_s cn52xxp1;
  638. struct cvmx_agl_gmx_rxx_udd_skp_s cn56xx;
  639. struct cvmx_agl_gmx_rxx_udd_skp_s cn56xxp1;
  640. };
  641. union cvmx_agl_gmx_rx_bp_dropx {
  642. uint64_t u64;
  643. struct cvmx_agl_gmx_rx_bp_dropx_s {
  644. uint64_t reserved_6_63:58;
  645. uint64_t mark:6;
  646. } s;
  647. struct cvmx_agl_gmx_rx_bp_dropx_s cn52xx;
  648. struct cvmx_agl_gmx_rx_bp_dropx_s cn52xxp1;
  649. struct cvmx_agl_gmx_rx_bp_dropx_s cn56xx;
  650. struct cvmx_agl_gmx_rx_bp_dropx_s cn56xxp1;
  651. };
  652. union cvmx_agl_gmx_rx_bp_offx {
  653. uint64_t u64;
  654. struct cvmx_agl_gmx_rx_bp_offx_s {
  655. uint64_t reserved_6_63:58;
  656. uint64_t mark:6;
  657. } s;
  658. struct cvmx_agl_gmx_rx_bp_offx_s cn52xx;
  659. struct cvmx_agl_gmx_rx_bp_offx_s cn52xxp1;
  660. struct cvmx_agl_gmx_rx_bp_offx_s cn56xx;
  661. struct cvmx_agl_gmx_rx_bp_offx_s cn56xxp1;
  662. };
  663. union cvmx_agl_gmx_rx_bp_onx {
  664. uint64_t u64;
  665. struct cvmx_agl_gmx_rx_bp_onx_s {
  666. uint64_t reserved_9_63:55;
  667. uint64_t mark:9;
  668. } s;
  669. struct cvmx_agl_gmx_rx_bp_onx_s cn52xx;
  670. struct cvmx_agl_gmx_rx_bp_onx_s cn52xxp1;
  671. struct cvmx_agl_gmx_rx_bp_onx_s cn56xx;
  672. struct cvmx_agl_gmx_rx_bp_onx_s cn56xxp1;
  673. };
  674. union cvmx_agl_gmx_rx_prt_info {
  675. uint64_t u64;
  676. struct cvmx_agl_gmx_rx_prt_info_s {
  677. uint64_t reserved_18_63:46;
  678. uint64_t drop:2;
  679. uint64_t reserved_2_15:14;
  680. uint64_t commit:2;
  681. } s;
  682. struct cvmx_agl_gmx_rx_prt_info_s cn52xx;
  683. struct cvmx_agl_gmx_rx_prt_info_s cn52xxp1;
  684. struct cvmx_agl_gmx_rx_prt_info_cn56xx {
  685. uint64_t reserved_17_63:47;
  686. uint64_t drop:1;
  687. uint64_t reserved_1_15:15;
  688. uint64_t commit:1;
  689. } cn56xx;
  690. struct cvmx_agl_gmx_rx_prt_info_cn56xx cn56xxp1;
  691. };
  692. union cvmx_agl_gmx_rx_tx_status {
  693. uint64_t u64;
  694. struct cvmx_agl_gmx_rx_tx_status_s {
  695. uint64_t reserved_6_63:58;
  696. uint64_t tx:2;
  697. uint64_t reserved_2_3:2;
  698. uint64_t rx:2;
  699. } s;
  700. struct cvmx_agl_gmx_rx_tx_status_s cn52xx;
  701. struct cvmx_agl_gmx_rx_tx_status_s cn52xxp1;
  702. struct cvmx_agl_gmx_rx_tx_status_cn56xx {
  703. uint64_t reserved_5_63:59;
  704. uint64_t tx:1;
  705. uint64_t reserved_1_3:3;
  706. uint64_t rx:1;
  707. } cn56xx;
  708. struct cvmx_agl_gmx_rx_tx_status_cn56xx cn56xxp1;
  709. };
  710. union cvmx_agl_gmx_smacx {
  711. uint64_t u64;
  712. struct cvmx_agl_gmx_smacx_s {
  713. uint64_t reserved_48_63:16;
  714. uint64_t smac:48;
  715. } s;
  716. struct cvmx_agl_gmx_smacx_s cn52xx;
  717. struct cvmx_agl_gmx_smacx_s cn52xxp1;
  718. struct cvmx_agl_gmx_smacx_s cn56xx;
  719. struct cvmx_agl_gmx_smacx_s cn56xxp1;
  720. };
  721. union cvmx_agl_gmx_stat_bp {
  722. uint64_t u64;
  723. struct cvmx_agl_gmx_stat_bp_s {
  724. uint64_t reserved_17_63:47;
  725. uint64_t bp:1;
  726. uint64_t cnt:16;
  727. } s;
  728. struct cvmx_agl_gmx_stat_bp_s cn52xx;
  729. struct cvmx_agl_gmx_stat_bp_s cn52xxp1;
  730. struct cvmx_agl_gmx_stat_bp_s cn56xx;
  731. struct cvmx_agl_gmx_stat_bp_s cn56xxp1;
  732. };
  733. union cvmx_agl_gmx_txx_append {
  734. uint64_t u64;
  735. struct cvmx_agl_gmx_txx_append_s {
  736. uint64_t reserved_4_63:60;
  737. uint64_t force_fcs:1;
  738. uint64_t fcs:1;
  739. uint64_t pad:1;
  740. uint64_t preamble:1;
  741. } s;
  742. struct cvmx_agl_gmx_txx_append_s cn52xx;
  743. struct cvmx_agl_gmx_txx_append_s cn52xxp1;
  744. struct cvmx_agl_gmx_txx_append_s cn56xx;
  745. struct cvmx_agl_gmx_txx_append_s cn56xxp1;
  746. };
  747. union cvmx_agl_gmx_txx_ctl {
  748. uint64_t u64;
  749. struct cvmx_agl_gmx_txx_ctl_s {
  750. uint64_t reserved_2_63:62;
  751. uint64_t xsdef_en:1;
  752. uint64_t xscol_en:1;
  753. } s;
  754. struct cvmx_agl_gmx_txx_ctl_s cn52xx;
  755. struct cvmx_agl_gmx_txx_ctl_s cn52xxp1;
  756. struct cvmx_agl_gmx_txx_ctl_s cn56xx;
  757. struct cvmx_agl_gmx_txx_ctl_s cn56xxp1;
  758. };
  759. union cvmx_agl_gmx_txx_min_pkt {
  760. uint64_t u64;
  761. struct cvmx_agl_gmx_txx_min_pkt_s {
  762. uint64_t reserved_8_63:56;
  763. uint64_t min_size:8;
  764. } s;
  765. struct cvmx_agl_gmx_txx_min_pkt_s cn52xx;
  766. struct cvmx_agl_gmx_txx_min_pkt_s cn52xxp1;
  767. struct cvmx_agl_gmx_txx_min_pkt_s cn56xx;
  768. struct cvmx_agl_gmx_txx_min_pkt_s cn56xxp1;
  769. };
  770. union cvmx_agl_gmx_txx_pause_pkt_interval {
  771. uint64_t u64;
  772. struct cvmx_agl_gmx_txx_pause_pkt_interval_s {
  773. uint64_t reserved_16_63:48;
  774. uint64_t interval:16;
  775. } s;
  776. struct cvmx_agl_gmx_txx_pause_pkt_interval_s cn52xx;
  777. struct cvmx_agl_gmx_txx_pause_pkt_interval_s cn52xxp1;
  778. struct cvmx_agl_gmx_txx_pause_pkt_interval_s cn56xx;
  779. struct cvmx_agl_gmx_txx_pause_pkt_interval_s cn56xxp1;
  780. };
  781. union cvmx_agl_gmx_txx_pause_pkt_time {
  782. uint64_t u64;
  783. struct cvmx_agl_gmx_txx_pause_pkt_time_s {
  784. uint64_t reserved_16_63:48;
  785. uint64_t time:16;
  786. } s;
  787. struct cvmx_agl_gmx_txx_pause_pkt_time_s cn52xx;
  788. struct cvmx_agl_gmx_txx_pause_pkt_time_s cn52xxp1;
  789. struct cvmx_agl_gmx_txx_pause_pkt_time_s cn56xx;
  790. struct cvmx_agl_gmx_txx_pause_pkt_time_s cn56xxp1;
  791. };
  792. union cvmx_agl_gmx_txx_pause_togo {
  793. uint64_t u64;
  794. struct cvmx_agl_gmx_txx_pause_togo_s {
  795. uint64_t reserved_16_63:48;
  796. uint64_t time:16;
  797. } s;
  798. struct cvmx_agl_gmx_txx_pause_togo_s cn52xx;
  799. struct cvmx_agl_gmx_txx_pause_togo_s cn52xxp1;
  800. struct cvmx_agl_gmx_txx_pause_togo_s cn56xx;
  801. struct cvmx_agl_gmx_txx_pause_togo_s cn56xxp1;
  802. };
  803. union cvmx_agl_gmx_txx_pause_zero {
  804. uint64_t u64;
  805. struct cvmx_agl_gmx_txx_pause_zero_s {
  806. uint64_t reserved_1_63:63;
  807. uint64_t send:1;
  808. } s;
  809. struct cvmx_agl_gmx_txx_pause_zero_s cn52xx;
  810. struct cvmx_agl_gmx_txx_pause_zero_s cn52xxp1;
  811. struct cvmx_agl_gmx_txx_pause_zero_s cn56xx;
  812. struct cvmx_agl_gmx_txx_pause_zero_s cn56xxp1;
  813. };
  814. union cvmx_agl_gmx_txx_soft_pause {
  815. uint64_t u64;
  816. struct cvmx_agl_gmx_txx_soft_pause_s {
  817. uint64_t reserved_16_63:48;
  818. uint64_t time:16;
  819. } s;
  820. struct cvmx_agl_gmx_txx_soft_pause_s cn52xx;
  821. struct cvmx_agl_gmx_txx_soft_pause_s cn52xxp1;
  822. struct cvmx_agl_gmx_txx_soft_pause_s cn56xx;
  823. struct cvmx_agl_gmx_txx_soft_pause_s cn56xxp1;
  824. };
  825. union cvmx_agl_gmx_txx_stat0 {
  826. uint64_t u64;
  827. struct cvmx_agl_gmx_txx_stat0_s {
  828. uint64_t xsdef:32;
  829. uint64_t xscol:32;
  830. } s;
  831. struct cvmx_agl_gmx_txx_stat0_s cn52xx;
  832. struct cvmx_agl_gmx_txx_stat0_s cn52xxp1;
  833. struct cvmx_agl_gmx_txx_stat0_s cn56xx;
  834. struct cvmx_agl_gmx_txx_stat0_s cn56xxp1;
  835. };
  836. union cvmx_agl_gmx_txx_stat1 {
  837. uint64_t u64;
  838. struct cvmx_agl_gmx_txx_stat1_s {
  839. uint64_t scol:32;
  840. uint64_t mcol:32;
  841. } s;
  842. struct cvmx_agl_gmx_txx_stat1_s cn52xx;
  843. struct cvmx_agl_gmx_txx_stat1_s cn52xxp1;
  844. struct cvmx_agl_gmx_txx_stat1_s cn56xx;
  845. struct cvmx_agl_gmx_txx_stat1_s cn56xxp1;
  846. };
  847. union cvmx_agl_gmx_txx_stat2 {
  848. uint64_t u64;
  849. struct cvmx_agl_gmx_txx_stat2_s {
  850. uint64_t reserved_48_63:16;
  851. uint64_t octs:48;
  852. } s;
  853. struct cvmx_agl_gmx_txx_stat2_s cn52xx;
  854. struct cvmx_agl_gmx_txx_stat2_s cn52xxp1;
  855. struct cvmx_agl_gmx_txx_stat2_s cn56xx;
  856. struct cvmx_agl_gmx_txx_stat2_s cn56xxp1;
  857. };
  858. union cvmx_agl_gmx_txx_stat3 {
  859. uint64_t u64;
  860. struct cvmx_agl_gmx_txx_stat3_s {
  861. uint64_t reserved_32_63:32;
  862. uint64_t pkts:32;
  863. } s;
  864. struct cvmx_agl_gmx_txx_stat3_s cn52xx;
  865. struct cvmx_agl_gmx_txx_stat3_s cn52xxp1;
  866. struct cvmx_agl_gmx_txx_stat3_s cn56xx;
  867. struct cvmx_agl_gmx_txx_stat3_s cn56xxp1;
  868. };
  869. union cvmx_agl_gmx_txx_stat4 {
  870. uint64_t u64;
  871. struct cvmx_agl_gmx_txx_stat4_s {
  872. uint64_t hist1:32;
  873. uint64_t hist0:32;
  874. } s;
  875. struct cvmx_agl_gmx_txx_stat4_s cn52xx;
  876. struct cvmx_agl_gmx_txx_stat4_s cn52xxp1;
  877. struct cvmx_agl_gmx_txx_stat4_s cn56xx;
  878. struct cvmx_agl_gmx_txx_stat4_s cn56xxp1;
  879. };
  880. union cvmx_agl_gmx_txx_stat5 {
  881. uint64_t u64;
  882. struct cvmx_agl_gmx_txx_stat5_s {
  883. uint64_t hist3:32;
  884. uint64_t hist2:32;
  885. } s;
  886. struct cvmx_agl_gmx_txx_stat5_s cn52xx;
  887. struct cvmx_agl_gmx_txx_stat5_s cn52xxp1;
  888. struct cvmx_agl_gmx_txx_stat5_s cn56xx;
  889. struct cvmx_agl_gmx_txx_stat5_s cn56xxp1;
  890. };
  891. union cvmx_agl_gmx_txx_stat6 {
  892. uint64_t u64;
  893. struct cvmx_agl_gmx_txx_stat6_s {
  894. uint64_t hist5:32;
  895. uint64_t hist4:32;
  896. } s;
  897. struct cvmx_agl_gmx_txx_stat6_s cn52xx;
  898. struct cvmx_agl_gmx_txx_stat6_s cn52xxp1;
  899. struct cvmx_agl_gmx_txx_stat6_s cn56xx;
  900. struct cvmx_agl_gmx_txx_stat6_s cn56xxp1;
  901. };
  902. union cvmx_agl_gmx_txx_stat7 {
  903. uint64_t u64;
  904. struct cvmx_agl_gmx_txx_stat7_s {
  905. uint64_t hist7:32;
  906. uint64_t hist6:32;
  907. } s;
  908. struct cvmx_agl_gmx_txx_stat7_s cn52xx;
  909. struct cvmx_agl_gmx_txx_stat7_s cn52xxp1;
  910. struct cvmx_agl_gmx_txx_stat7_s cn56xx;
  911. struct cvmx_agl_gmx_txx_stat7_s cn56xxp1;
  912. };
  913. union cvmx_agl_gmx_txx_stat8 {
  914. uint64_t u64;
  915. struct cvmx_agl_gmx_txx_stat8_s {
  916. uint64_t mcst:32;
  917. uint64_t bcst:32;
  918. } s;
  919. struct cvmx_agl_gmx_txx_stat8_s cn52xx;
  920. struct cvmx_agl_gmx_txx_stat8_s cn52xxp1;
  921. struct cvmx_agl_gmx_txx_stat8_s cn56xx;
  922. struct cvmx_agl_gmx_txx_stat8_s cn56xxp1;
  923. };
  924. union cvmx_agl_gmx_txx_stat9 {
  925. uint64_t u64;
  926. struct cvmx_agl_gmx_txx_stat9_s {
  927. uint64_t undflw:32;
  928. uint64_t ctl:32;
  929. } s;
  930. struct cvmx_agl_gmx_txx_stat9_s cn52xx;
  931. struct cvmx_agl_gmx_txx_stat9_s cn52xxp1;
  932. struct cvmx_agl_gmx_txx_stat9_s cn56xx;
  933. struct cvmx_agl_gmx_txx_stat9_s cn56xxp1;
  934. };
  935. union cvmx_agl_gmx_txx_stats_ctl {
  936. uint64_t u64;
  937. struct cvmx_agl_gmx_txx_stats_ctl_s {
  938. uint64_t reserved_1_63:63;
  939. uint64_t rd_clr:1;
  940. } s;
  941. struct cvmx_agl_gmx_txx_stats_ctl_s cn52xx;
  942. struct cvmx_agl_gmx_txx_stats_ctl_s cn52xxp1;
  943. struct cvmx_agl_gmx_txx_stats_ctl_s cn56xx;
  944. struct cvmx_agl_gmx_txx_stats_ctl_s cn56xxp1;
  945. };
  946. union cvmx_agl_gmx_txx_thresh {
  947. uint64_t u64;
  948. struct cvmx_agl_gmx_txx_thresh_s {
  949. uint64_t reserved_6_63:58;
  950. uint64_t cnt:6;
  951. } s;
  952. struct cvmx_agl_gmx_txx_thresh_s cn52xx;
  953. struct cvmx_agl_gmx_txx_thresh_s cn52xxp1;
  954. struct cvmx_agl_gmx_txx_thresh_s cn56xx;
  955. struct cvmx_agl_gmx_txx_thresh_s cn56xxp1;
  956. };
  957. union cvmx_agl_gmx_tx_bp {
  958. uint64_t u64;
  959. struct cvmx_agl_gmx_tx_bp_s {
  960. uint64_t reserved_2_63:62;
  961. uint64_t bp:2;
  962. } s;
  963. struct cvmx_agl_gmx_tx_bp_s cn52xx;
  964. struct cvmx_agl_gmx_tx_bp_s cn52xxp1;
  965. struct cvmx_agl_gmx_tx_bp_cn56xx {
  966. uint64_t reserved_1_63:63;
  967. uint64_t bp:1;
  968. } cn56xx;
  969. struct cvmx_agl_gmx_tx_bp_cn56xx cn56xxp1;
  970. };
  971. union cvmx_agl_gmx_tx_col_attempt {
  972. uint64_t u64;
  973. struct cvmx_agl_gmx_tx_col_attempt_s {
  974. uint64_t reserved_5_63:59;
  975. uint64_t limit:5;
  976. } s;
  977. struct cvmx_agl_gmx_tx_col_attempt_s cn52xx;
  978. struct cvmx_agl_gmx_tx_col_attempt_s cn52xxp1;
  979. struct cvmx_agl_gmx_tx_col_attempt_s cn56xx;
  980. struct cvmx_agl_gmx_tx_col_attempt_s cn56xxp1;
  981. };
  982. union cvmx_agl_gmx_tx_ifg {
  983. uint64_t u64;
  984. struct cvmx_agl_gmx_tx_ifg_s {
  985. uint64_t reserved_8_63:56;
  986. uint64_t ifg2:4;
  987. uint64_t ifg1:4;
  988. } s;
  989. struct cvmx_agl_gmx_tx_ifg_s cn52xx;
  990. struct cvmx_agl_gmx_tx_ifg_s cn52xxp1;
  991. struct cvmx_agl_gmx_tx_ifg_s cn56xx;
  992. struct cvmx_agl_gmx_tx_ifg_s cn56xxp1;
  993. };
  994. union cvmx_agl_gmx_tx_int_en {
  995. uint64_t u64;
  996. struct cvmx_agl_gmx_tx_int_en_s {
  997. uint64_t reserved_18_63:46;
  998. uint64_t late_col:2;
  999. uint64_t reserved_14_15:2;
  1000. uint64_t xsdef:2;
  1001. uint64_t reserved_10_11:2;
  1002. uint64_t xscol:2;
  1003. uint64_t reserved_4_7:4;
  1004. uint64_t undflw:2;
  1005. uint64_t reserved_1_1:1;
  1006. uint64_t pko_nxa:1;
  1007. } s;
  1008. struct cvmx_agl_gmx_tx_int_en_s cn52xx;
  1009. struct cvmx_agl_gmx_tx_int_en_s cn52xxp1;
  1010. struct cvmx_agl_gmx_tx_int_en_cn56xx {
  1011. uint64_t reserved_17_63:47;
  1012. uint64_t late_col:1;
  1013. uint64_t reserved_13_15:3;
  1014. uint64_t xsdef:1;
  1015. uint64_t reserved_9_11:3;
  1016. uint64_t xscol:1;
  1017. uint64_t reserved_3_7:5;
  1018. uint64_t undflw:1;
  1019. uint64_t reserved_1_1:1;
  1020. uint64_t pko_nxa:1;
  1021. } cn56xx;
  1022. struct cvmx_agl_gmx_tx_int_en_cn56xx cn56xxp1;
  1023. };
  1024. union cvmx_agl_gmx_tx_int_reg {
  1025. uint64_t u64;
  1026. struct cvmx_agl_gmx_tx_int_reg_s {
  1027. uint64_t reserved_18_63:46;
  1028. uint64_t late_col:2;
  1029. uint64_t reserved_14_15:2;
  1030. uint64_t xsdef:2;
  1031. uint64_t reserved_10_11:2;
  1032. uint64_t xscol:2;
  1033. uint64_t reserved_4_7:4;
  1034. uint64_t undflw:2;
  1035. uint64_t reserved_1_1:1;
  1036. uint64_t pko_nxa:1;
  1037. } s;
  1038. struct cvmx_agl_gmx_tx_int_reg_s cn52xx;
  1039. struct cvmx_agl_gmx_tx_int_reg_s cn52xxp1;
  1040. struct cvmx_agl_gmx_tx_int_reg_cn56xx {
  1041. uint64_t reserved_17_63:47;
  1042. uint64_t late_col:1;
  1043. uint64_t reserved_13_15:3;
  1044. uint64_t xsdef:1;
  1045. uint64_t reserved_9_11:3;
  1046. uint64_t xscol:1;
  1047. uint64_t reserved_3_7:5;
  1048. uint64_t undflw:1;
  1049. uint64_t reserved_1_1:1;
  1050. uint64_t pko_nxa:1;
  1051. } cn56xx;
  1052. struct cvmx_agl_gmx_tx_int_reg_cn56xx cn56xxp1;
  1053. };
  1054. union cvmx_agl_gmx_tx_jam {
  1055. uint64_t u64;
  1056. struct cvmx_agl_gmx_tx_jam_s {
  1057. uint64_t reserved_8_63:56;
  1058. uint64_t jam:8;
  1059. } s;
  1060. struct cvmx_agl_gmx_tx_jam_s cn52xx;
  1061. struct cvmx_agl_gmx_tx_jam_s cn52xxp1;
  1062. struct cvmx_agl_gmx_tx_jam_s cn56xx;
  1063. struct cvmx_agl_gmx_tx_jam_s cn56xxp1;
  1064. };
  1065. union cvmx_agl_gmx_tx_lfsr {
  1066. uint64_t u64;
  1067. struct cvmx_agl_gmx_tx_lfsr_s {
  1068. uint64_t reserved_16_63:48;
  1069. uint64_t lfsr:16;
  1070. } s;
  1071. struct cvmx_agl_gmx_tx_lfsr_s cn52xx;
  1072. struct cvmx_agl_gmx_tx_lfsr_s cn52xxp1;
  1073. struct cvmx_agl_gmx_tx_lfsr_s cn56xx;
  1074. struct cvmx_agl_gmx_tx_lfsr_s cn56xxp1;
  1075. };
  1076. union cvmx_agl_gmx_tx_ovr_bp {
  1077. uint64_t u64;
  1078. struct cvmx_agl_gmx_tx_ovr_bp_s {
  1079. uint64_t reserved_10_63:54;
  1080. uint64_t en:2;
  1081. uint64_t reserved_6_7:2;
  1082. uint64_t bp:2;
  1083. uint64_t reserved_2_3:2;
  1084. uint64_t ign_full:2;
  1085. } s;
  1086. struct cvmx_agl_gmx_tx_ovr_bp_s cn52xx;
  1087. struct cvmx_agl_gmx_tx_ovr_bp_s cn52xxp1;
  1088. struct cvmx_agl_gmx_tx_ovr_bp_cn56xx {
  1089. uint64_t reserved_9_63:55;
  1090. uint64_t en:1;
  1091. uint64_t reserved_5_7:3;
  1092. uint64_t bp:1;
  1093. uint64_t reserved_1_3:3;
  1094. uint64_t ign_full:1;
  1095. } cn56xx;
  1096. struct cvmx_agl_gmx_tx_ovr_bp_cn56xx cn56xxp1;
  1097. };
  1098. union cvmx_agl_gmx_tx_pause_pkt_dmac {
  1099. uint64_t u64;
  1100. struct cvmx_agl_gmx_tx_pause_pkt_dmac_s {
  1101. uint64_t reserved_48_63:16;
  1102. uint64_t dmac:48;
  1103. } s;
  1104. struct cvmx_agl_gmx_tx_pause_pkt_dmac_s cn52xx;
  1105. struct cvmx_agl_gmx_tx_pause_pkt_dmac_s cn52xxp1;
  1106. struct cvmx_agl_gmx_tx_pause_pkt_dmac_s cn56xx;
  1107. struct cvmx_agl_gmx_tx_pause_pkt_dmac_s cn56xxp1;
  1108. };
  1109. union cvmx_agl_gmx_tx_pause_pkt_type {
  1110. uint64_t u64;
  1111. struct cvmx_agl_gmx_tx_pause_pkt_type_s {
  1112. uint64_t reserved_16_63:48;
  1113. uint64_t type:16;
  1114. } s;
  1115. struct cvmx_agl_gmx_tx_pause_pkt_type_s cn52xx;
  1116. struct cvmx_agl_gmx_tx_pause_pkt_type_s cn52xxp1;
  1117. struct cvmx_agl_gmx_tx_pause_pkt_type_s cn56xx;
  1118. struct cvmx_agl_gmx_tx_pause_pkt_type_s cn56xxp1;
  1119. };
  1120. #endif