xlnx-versal-pmc-iou-slcr.c 53 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446
  1. /*
  2. * QEMU model of Versal's PMC IOU SLCR (system level control registers)
  3. *
  4. * Copyright (c) 2021 Xilinx Inc.
  5. * Written by Edgar E. Iglesias <edgar.iglesias@xilinx.com>
  6. *
  7. * Permission is hereby granted, free of charge, to any person obtaining a copy
  8. * of this software and associated documentation files (the "Software"), to deal
  9. * in the Software without restriction, including without limitation the rights
  10. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  11. * copies of the Software, and to permit persons to whom the Software is
  12. * furnished to do so, subject to the following conditions:
  13. *
  14. * The above copyright notice and this permission notice shall be included in
  15. * all copies or substantial portions of the Software.
  16. *
  17. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  18. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  19. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
  20. * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  21. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  22. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  23. * THE SOFTWARE.
  24. */
  25. #include "qemu/osdep.h"
  26. #include "hw/sysbus.h"
  27. #include "hw/register.h"
  28. #include "hw/irq.h"
  29. #include "qemu/bitops.h"
  30. #include "qemu/log.h"
  31. #include "migration/vmstate.h"
  32. #include "hw/qdev-properties.h"
  33. #include "hw/misc/xlnx-versal-pmc-iou-slcr.h"
  34. #ifndef XILINX_VERSAL_PMC_IOU_SLCR_ERR_DEBUG
  35. #define XILINX_VERSAL_PMC_IOU_SLCR_ERR_DEBUG 0
  36. #endif
  37. REG32(MIO_PIN_0, 0x0)
  38. FIELD(MIO_PIN_0, L3_SEL, 7, 3)
  39. FIELD(MIO_PIN_0, L2_SEL, 5, 2)
  40. FIELD(MIO_PIN_0, L1_SEL, 3, 2)
  41. FIELD(MIO_PIN_0, L0_SEL, 1, 2)
  42. REG32(MIO_PIN_1, 0x4)
  43. FIELD(MIO_PIN_1, L3_SEL, 7, 3)
  44. FIELD(MIO_PIN_1, L2_SEL, 5, 2)
  45. FIELD(MIO_PIN_1, L1_SEL, 3, 2)
  46. FIELD(MIO_PIN_1, L0_SEL, 1, 2)
  47. REG32(MIO_PIN_2, 0x8)
  48. FIELD(MIO_PIN_2, L3_SEL, 7, 3)
  49. FIELD(MIO_PIN_2, L2_SEL, 5, 2)
  50. FIELD(MIO_PIN_2, L1_SEL, 3, 2)
  51. FIELD(MIO_PIN_2, L0_SEL, 1, 2)
  52. REG32(MIO_PIN_3, 0xc)
  53. FIELD(MIO_PIN_3, L3_SEL, 7, 3)
  54. FIELD(MIO_PIN_3, L2_SEL, 5, 2)
  55. FIELD(MIO_PIN_3, L1_SEL, 3, 2)
  56. FIELD(MIO_PIN_3, L0_SEL, 1, 2)
  57. REG32(MIO_PIN_4, 0x10)
  58. FIELD(MIO_PIN_4, L3_SEL, 7, 3)
  59. FIELD(MIO_PIN_4, L2_SEL, 5, 2)
  60. FIELD(MIO_PIN_4, L1_SEL, 3, 2)
  61. FIELD(MIO_PIN_4, L0_SEL, 1, 2)
  62. REG32(MIO_PIN_5, 0x14)
  63. FIELD(MIO_PIN_5, L3_SEL, 7, 3)
  64. FIELD(MIO_PIN_5, L2_SEL, 5, 2)
  65. FIELD(MIO_PIN_5, L1_SEL, 3, 2)
  66. FIELD(MIO_PIN_5, L0_SEL, 1, 2)
  67. REG32(MIO_PIN_6, 0x18)
  68. FIELD(MIO_PIN_6, L3_SEL, 7, 3)
  69. FIELD(MIO_PIN_6, L2_SEL, 5, 2)
  70. FIELD(MIO_PIN_6, L1_SEL, 3, 2)
  71. FIELD(MIO_PIN_6, L0_SEL, 1, 2)
  72. REG32(MIO_PIN_7, 0x1c)
  73. FIELD(MIO_PIN_7, L3_SEL, 7, 3)
  74. FIELD(MIO_PIN_7, L2_SEL, 5, 2)
  75. FIELD(MIO_PIN_7, L1_SEL, 3, 2)
  76. FIELD(MIO_PIN_7, L0_SEL, 1, 2)
  77. REG32(MIO_PIN_8, 0x20)
  78. FIELD(MIO_PIN_8, L3_SEL, 7, 3)
  79. FIELD(MIO_PIN_8, L2_SEL, 5, 2)
  80. FIELD(MIO_PIN_8, L1_SEL, 3, 2)
  81. FIELD(MIO_PIN_8, L0_SEL, 1, 2)
  82. REG32(MIO_PIN_9, 0x24)
  83. FIELD(MIO_PIN_9, L3_SEL, 7, 3)
  84. FIELD(MIO_PIN_9, L2_SEL, 5, 2)
  85. FIELD(MIO_PIN_9, L1_SEL, 3, 2)
  86. FIELD(MIO_PIN_9, L0_SEL, 1, 2)
  87. REG32(MIO_PIN_10, 0x28)
  88. FIELD(MIO_PIN_10, L3_SEL, 7, 3)
  89. FIELD(MIO_PIN_10, L2_SEL, 5, 2)
  90. FIELD(MIO_PIN_10, L1_SEL, 3, 2)
  91. FIELD(MIO_PIN_10, L0_SEL, 1, 2)
  92. REG32(MIO_PIN_11, 0x2c)
  93. FIELD(MIO_PIN_11, L3_SEL, 7, 3)
  94. FIELD(MIO_PIN_11, L2_SEL, 5, 2)
  95. FIELD(MIO_PIN_11, L1_SEL, 3, 2)
  96. FIELD(MIO_PIN_11, L0_SEL, 1, 2)
  97. REG32(MIO_PIN_12, 0x30)
  98. FIELD(MIO_PIN_12, L3_SEL, 7, 3)
  99. FIELD(MIO_PIN_12, L2_SEL, 5, 2)
  100. FIELD(MIO_PIN_12, L1_SEL, 3, 2)
  101. FIELD(MIO_PIN_12, L0_SEL, 1, 2)
  102. REG32(MIO_PIN_13, 0x34)
  103. FIELD(MIO_PIN_13, L3_SEL, 7, 3)
  104. FIELD(MIO_PIN_13, L2_SEL, 5, 2)
  105. FIELD(MIO_PIN_13, L1_SEL, 3, 2)
  106. FIELD(MIO_PIN_13, L0_SEL, 1, 2)
  107. REG32(MIO_PIN_14, 0x38)
  108. FIELD(MIO_PIN_14, L3_SEL, 7, 3)
  109. FIELD(MIO_PIN_14, L2_SEL, 5, 2)
  110. FIELD(MIO_PIN_14, L1_SEL, 3, 2)
  111. FIELD(MIO_PIN_14, L0_SEL, 1, 2)
  112. REG32(MIO_PIN_15, 0x3c)
  113. FIELD(MIO_PIN_15, L3_SEL, 7, 3)
  114. FIELD(MIO_PIN_15, L2_SEL, 5, 2)
  115. FIELD(MIO_PIN_15, L1_SEL, 3, 2)
  116. FIELD(MIO_PIN_15, L0_SEL, 1, 2)
  117. REG32(MIO_PIN_16, 0x40)
  118. FIELD(MIO_PIN_16, L3_SEL, 7, 3)
  119. FIELD(MIO_PIN_16, L2_SEL, 5, 2)
  120. FIELD(MIO_PIN_16, L1_SEL, 3, 2)
  121. FIELD(MIO_PIN_16, L0_SEL, 1, 2)
  122. REG32(MIO_PIN_17, 0x44)
  123. FIELD(MIO_PIN_17, L3_SEL, 7, 3)
  124. FIELD(MIO_PIN_17, L2_SEL, 5, 2)
  125. FIELD(MIO_PIN_17, L1_SEL, 3, 2)
  126. FIELD(MIO_PIN_17, L0_SEL, 1, 2)
  127. REG32(MIO_PIN_18, 0x48)
  128. FIELD(MIO_PIN_18, L3_SEL, 7, 3)
  129. FIELD(MIO_PIN_18, L2_SEL, 5, 2)
  130. FIELD(MIO_PIN_18, L1_SEL, 3, 2)
  131. FIELD(MIO_PIN_18, L0_SEL, 1, 2)
  132. REG32(MIO_PIN_19, 0x4c)
  133. FIELD(MIO_PIN_19, L3_SEL, 7, 3)
  134. FIELD(MIO_PIN_19, L2_SEL, 5, 2)
  135. FIELD(MIO_PIN_19, L1_SEL, 3, 2)
  136. FIELD(MIO_PIN_19, L0_SEL, 1, 2)
  137. REG32(MIO_PIN_20, 0x50)
  138. FIELD(MIO_PIN_20, L3_SEL, 7, 3)
  139. FIELD(MIO_PIN_20, L2_SEL, 5, 2)
  140. FIELD(MIO_PIN_20, L1_SEL, 3, 2)
  141. FIELD(MIO_PIN_20, L0_SEL, 1, 2)
  142. REG32(MIO_PIN_21, 0x54)
  143. FIELD(MIO_PIN_21, L3_SEL, 7, 3)
  144. FIELD(MIO_PIN_21, L2_SEL, 5, 2)
  145. FIELD(MIO_PIN_21, L1_SEL, 3, 2)
  146. FIELD(MIO_PIN_21, L0_SEL, 1, 2)
  147. REG32(MIO_PIN_22, 0x58)
  148. FIELD(MIO_PIN_22, L3_SEL, 7, 3)
  149. FIELD(MIO_PIN_22, L2_SEL, 5, 2)
  150. FIELD(MIO_PIN_22, L1_SEL, 3, 2)
  151. FIELD(MIO_PIN_22, L0_SEL, 1, 2)
  152. REG32(MIO_PIN_23, 0x5c)
  153. FIELD(MIO_PIN_23, L3_SEL, 7, 3)
  154. FIELD(MIO_PIN_23, L2_SEL, 5, 2)
  155. FIELD(MIO_PIN_23, L1_SEL, 3, 2)
  156. FIELD(MIO_PIN_23, L0_SEL, 1, 2)
  157. REG32(MIO_PIN_24, 0x60)
  158. FIELD(MIO_PIN_24, L3_SEL, 7, 3)
  159. FIELD(MIO_PIN_24, L2_SEL, 5, 2)
  160. FIELD(MIO_PIN_24, L1_SEL, 3, 2)
  161. FIELD(MIO_PIN_24, L0_SEL, 1, 2)
  162. REG32(MIO_PIN_25, 0x64)
  163. FIELD(MIO_PIN_25, L3_SEL, 7, 3)
  164. FIELD(MIO_PIN_25, L2_SEL, 5, 2)
  165. FIELD(MIO_PIN_25, L1_SEL, 3, 2)
  166. FIELD(MIO_PIN_25, L0_SEL, 1, 2)
  167. REG32(MIO_PIN_26, 0x68)
  168. FIELD(MIO_PIN_26, L3_SEL, 7, 3)
  169. FIELD(MIO_PIN_26, L2_SEL, 5, 2)
  170. FIELD(MIO_PIN_26, L1_SEL, 3, 2)
  171. FIELD(MIO_PIN_26, L0_SEL, 1, 2)
  172. REG32(MIO_PIN_27, 0x6c)
  173. FIELD(MIO_PIN_27, L3_SEL, 7, 3)
  174. FIELD(MIO_PIN_27, L2_SEL, 5, 2)
  175. FIELD(MIO_PIN_27, L1_SEL, 3, 2)
  176. FIELD(MIO_PIN_27, L0_SEL, 1, 2)
  177. REG32(MIO_PIN_28, 0x70)
  178. FIELD(MIO_PIN_28, L3_SEL, 7, 3)
  179. FIELD(MIO_PIN_28, L2_SEL, 5, 2)
  180. FIELD(MIO_PIN_28, L1_SEL, 3, 2)
  181. FIELD(MIO_PIN_28, L0_SEL, 1, 2)
  182. REG32(MIO_PIN_29, 0x74)
  183. FIELD(MIO_PIN_29, L3_SEL, 7, 3)
  184. FIELD(MIO_PIN_29, L2_SEL, 5, 2)
  185. FIELD(MIO_PIN_29, L1_SEL, 3, 2)
  186. FIELD(MIO_PIN_29, L0_SEL, 1, 2)
  187. REG32(MIO_PIN_30, 0x78)
  188. FIELD(MIO_PIN_30, L3_SEL, 7, 3)
  189. FIELD(MIO_PIN_30, L2_SEL, 5, 2)
  190. FIELD(MIO_PIN_30, L1_SEL, 3, 2)
  191. FIELD(MIO_PIN_30, L0_SEL, 1, 2)
  192. REG32(MIO_PIN_31, 0x7c)
  193. FIELD(MIO_PIN_31, L3_SEL, 7, 3)
  194. FIELD(MIO_PIN_31, L2_SEL, 5, 2)
  195. FIELD(MIO_PIN_31, L1_SEL, 3, 2)
  196. FIELD(MIO_PIN_31, L0_SEL, 1, 2)
  197. REG32(MIO_PIN_32, 0x80)
  198. FIELD(MIO_PIN_32, L3_SEL, 7, 3)
  199. FIELD(MIO_PIN_32, L2_SEL, 5, 2)
  200. FIELD(MIO_PIN_32, L1_SEL, 3, 2)
  201. FIELD(MIO_PIN_32, L0_SEL, 1, 2)
  202. REG32(MIO_PIN_33, 0x84)
  203. FIELD(MIO_PIN_33, L3_SEL, 7, 3)
  204. FIELD(MIO_PIN_33, L2_SEL, 5, 2)
  205. FIELD(MIO_PIN_33, L1_SEL, 3, 2)
  206. FIELD(MIO_PIN_33, L0_SEL, 1, 2)
  207. REG32(MIO_PIN_34, 0x88)
  208. FIELD(MIO_PIN_34, L3_SEL, 7, 3)
  209. FIELD(MIO_PIN_34, L2_SEL, 5, 2)
  210. FIELD(MIO_PIN_34, L1_SEL, 3, 2)
  211. FIELD(MIO_PIN_34, L0_SEL, 1, 2)
  212. REG32(MIO_PIN_35, 0x8c)
  213. FIELD(MIO_PIN_35, L3_SEL, 7, 3)
  214. FIELD(MIO_PIN_35, L2_SEL, 5, 2)
  215. FIELD(MIO_PIN_35, L1_SEL, 3, 2)
  216. FIELD(MIO_PIN_35, L0_SEL, 1, 2)
  217. REG32(MIO_PIN_36, 0x90)
  218. FIELD(MIO_PIN_36, L3_SEL, 7, 3)
  219. FIELD(MIO_PIN_36, L2_SEL, 5, 2)
  220. FIELD(MIO_PIN_36, L1_SEL, 3, 2)
  221. FIELD(MIO_PIN_36, L0_SEL, 1, 2)
  222. REG32(MIO_PIN_37, 0x94)
  223. FIELD(MIO_PIN_37, L3_SEL, 7, 3)
  224. FIELD(MIO_PIN_37, L2_SEL, 5, 2)
  225. FIELD(MIO_PIN_37, L1_SEL, 3, 2)
  226. FIELD(MIO_PIN_37, L0_SEL, 1, 2)
  227. REG32(MIO_PIN_38, 0x98)
  228. FIELD(MIO_PIN_38, L3_SEL, 7, 3)
  229. FIELD(MIO_PIN_38, L2_SEL, 5, 2)
  230. FIELD(MIO_PIN_38, L1_SEL, 3, 2)
  231. FIELD(MIO_PIN_38, L0_SEL, 1, 2)
  232. REG32(MIO_PIN_39, 0x9c)
  233. FIELD(MIO_PIN_39, L3_SEL, 7, 3)
  234. FIELD(MIO_PIN_39, L2_SEL, 5, 2)
  235. FIELD(MIO_PIN_39, L1_SEL, 3, 2)
  236. FIELD(MIO_PIN_39, L0_SEL, 1, 2)
  237. REG32(MIO_PIN_40, 0xa0)
  238. FIELD(MIO_PIN_40, L3_SEL, 7, 3)
  239. FIELD(MIO_PIN_40, L2_SEL, 5, 2)
  240. FIELD(MIO_PIN_40, L1_SEL, 3, 2)
  241. FIELD(MIO_PIN_40, L0_SEL, 1, 2)
  242. REG32(MIO_PIN_41, 0xa4)
  243. FIELD(MIO_PIN_41, L3_SEL, 7, 3)
  244. FIELD(MIO_PIN_41, L2_SEL, 5, 2)
  245. FIELD(MIO_PIN_41, L1_SEL, 3, 2)
  246. FIELD(MIO_PIN_41, L0_SEL, 1, 2)
  247. REG32(MIO_PIN_42, 0xa8)
  248. FIELD(MIO_PIN_42, L3_SEL, 7, 3)
  249. FIELD(MIO_PIN_42, L2_SEL, 5, 2)
  250. FIELD(MIO_PIN_42, L1_SEL, 3, 2)
  251. FIELD(MIO_PIN_42, L0_SEL, 1, 2)
  252. REG32(MIO_PIN_43, 0xac)
  253. FIELD(MIO_PIN_43, L3_SEL, 7, 3)
  254. FIELD(MIO_PIN_43, L2_SEL, 5, 2)
  255. FIELD(MIO_PIN_43, L1_SEL, 3, 2)
  256. FIELD(MIO_PIN_43, L0_SEL, 1, 2)
  257. REG32(MIO_PIN_44, 0xb0)
  258. FIELD(MIO_PIN_44, L3_SEL, 7, 3)
  259. FIELD(MIO_PIN_44, L2_SEL, 5, 2)
  260. FIELD(MIO_PIN_44, L1_SEL, 3, 2)
  261. FIELD(MIO_PIN_44, L0_SEL, 1, 2)
  262. REG32(MIO_PIN_45, 0xb4)
  263. FIELD(MIO_PIN_45, L3_SEL, 7, 3)
  264. FIELD(MIO_PIN_45, L2_SEL, 5, 2)
  265. FIELD(MIO_PIN_45, L1_SEL, 3, 2)
  266. FIELD(MIO_PIN_45, L0_SEL, 1, 2)
  267. REG32(MIO_PIN_46, 0xb8)
  268. FIELD(MIO_PIN_46, L3_SEL, 7, 3)
  269. FIELD(MIO_PIN_46, L2_SEL, 5, 2)
  270. FIELD(MIO_PIN_46, L1_SEL, 3, 2)
  271. FIELD(MIO_PIN_46, L0_SEL, 1, 2)
  272. REG32(MIO_PIN_47, 0xbc)
  273. FIELD(MIO_PIN_47, L3_SEL, 7, 3)
  274. FIELD(MIO_PIN_47, L2_SEL, 5, 2)
  275. FIELD(MIO_PIN_47, L1_SEL, 3, 2)
  276. FIELD(MIO_PIN_47, L0_SEL, 1, 2)
  277. REG32(MIO_PIN_48, 0xc0)
  278. FIELD(MIO_PIN_48, L3_SEL, 7, 3)
  279. FIELD(MIO_PIN_48, L2_SEL, 5, 2)
  280. FIELD(MIO_PIN_48, L1_SEL, 3, 2)
  281. FIELD(MIO_PIN_48, L0_SEL, 1, 2)
  282. REG32(MIO_PIN_49, 0xc4)
  283. FIELD(MIO_PIN_49, L3_SEL, 7, 3)
  284. FIELD(MIO_PIN_49, L2_SEL, 5, 2)
  285. FIELD(MIO_PIN_49, L1_SEL, 3, 2)
  286. FIELD(MIO_PIN_49, L0_SEL, 1, 2)
  287. REG32(MIO_PIN_50, 0xc8)
  288. FIELD(MIO_PIN_50, L3_SEL, 7, 3)
  289. FIELD(MIO_PIN_50, L2_SEL, 5, 2)
  290. FIELD(MIO_PIN_50, L1_SEL, 3, 2)
  291. FIELD(MIO_PIN_50, L0_SEL, 1, 2)
  292. REG32(MIO_PIN_51, 0xcc)
  293. FIELD(MIO_PIN_51, L3_SEL, 7, 3)
  294. FIELD(MIO_PIN_51, L2_SEL, 5, 2)
  295. FIELD(MIO_PIN_51, L1_SEL, 3, 2)
  296. FIELD(MIO_PIN_51, L0_SEL, 1, 2)
  297. REG32(BNK0_EN_RX, 0x100)
  298. FIELD(BNK0_EN_RX, BNK0_EN_RX, 0, 26)
  299. REG32(BNK0_SEL_RX0, 0x104)
  300. REG32(BNK0_SEL_RX1, 0x108)
  301. FIELD(BNK0_SEL_RX1, BNK0_SEL_RX, 0, 20)
  302. REG32(BNK0_EN_RX_SCHMITT_HYST, 0x10c)
  303. FIELD(BNK0_EN_RX_SCHMITT_HYST, BNK0_EN_RX_SCHMITT_HYST, 0, 26)
  304. REG32(BNK0_EN_WK_PD, 0x110)
  305. FIELD(BNK0_EN_WK_PD, BNK0_EN_WK_PD, 0, 26)
  306. REG32(BNK0_EN_WK_PU, 0x114)
  307. FIELD(BNK0_EN_WK_PU, BNK0_EN_WK_PU, 0, 26)
  308. REG32(BNK0_SEL_DRV0, 0x118)
  309. REG32(BNK0_SEL_DRV1, 0x11c)
  310. FIELD(BNK0_SEL_DRV1, BNK0_SEL_DRV, 0, 20)
  311. REG32(BNK0_SEL_SLEW, 0x120)
  312. FIELD(BNK0_SEL_SLEW, BNK0_SEL_SLEW, 0, 26)
  313. REG32(BNK0_EN_DFT_OPT_INV, 0x124)
  314. FIELD(BNK0_EN_DFT_OPT_INV, BNK0_EN_DFT_OPT_INV, 0, 26)
  315. REG32(BNK0_EN_PAD2PAD_LOOPBACK, 0x128)
  316. FIELD(BNK0_EN_PAD2PAD_LOOPBACK, BNK0_EN_PAD2PAD_LOOPBACK, 0, 13)
  317. REG32(BNK0_RX_SPARE0, 0x12c)
  318. REG32(BNK0_RX_SPARE1, 0x130)
  319. FIELD(BNK0_RX_SPARE1, BNK0_RX_SPARE, 0, 20)
  320. REG32(BNK0_TX_SPARE0, 0x134)
  321. REG32(BNK0_TX_SPARE1, 0x138)
  322. FIELD(BNK0_TX_SPARE1, BNK0_TX_SPARE, 0, 20)
  323. REG32(BNK0_SEL_EN1P8, 0x13c)
  324. FIELD(BNK0_SEL_EN1P8, BNK0_SEL_EN1P8, 0, 1)
  325. REG32(BNK0_EN_B_POR_DETECT, 0x140)
  326. FIELD(BNK0_EN_B_POR_DETECT, BNK0_EN_B_POR_DETECT, 0, 1)
  327. REG32(BNK0_LPF_BYP_POR_DETECT, 0x144)
  328. FIELD(BNK0_LPF_BYP_POR_DETECT, BNK0_LPF_BYP_POR_DETECT, 0, 1)
  329. REG32(BNK0_EN_LATCH, 0x148)
  330. FIELD(BNK0_EN_LATCH, BNK0_EN_LATCH, 0, 1)
  331. REG32(BNK0_VBG_LPF_BYP_B, 0x14c)
  332. FIELD(BNK0_VBG_LPF_BYP_B, BNK0_VBG_LPF_BYP_B, 0, 1)
  333. REG32(BNK0_EN_AMP_B, 0x150)
  334. FIELD(BNK0_EN_AMP_B, BNK0_EN_AMP_B, 0, 2)
  335. REG32(BNK0_SPARE_BIAS, 0x154)
  336. FIELD(BNK0_SPARE_BIAS, BNK0_SPARE_BIAS, 0, 4)
  337. REG32(BNK0_DRIVER_BIAS, 0x158)
  338. FIELD(BNK0_DRIVER_BIAS, BNK0_DRIVER_BIAS, 0, 15)
  339. REG32(BNK0_VMODE, 0x15c)
  340. FIELD(BNK0_VMODE, BNK0_VMODE, 0, 1)
  341. REG32(BNK0_SEL_AUX_IO_RX, 0x160)
  342. FIELD(BNK0_SEL_AUX_IO_RX, BNK0_SEL_AUX_IO_RX, 0, 26)
  343. REG32(BNK0_EN_TX_HS_MODE, 0x164)
  344. FIELD(BNK0_EN_TX_HS_MODE, BNK0_EN_TX_HS_MODE, 0, 26)
  345. REG32(MIO_MST_TRI0, 0x200)
  346. FIELD(MIO_MST_TRI0, PIN_25_TRI, 25, 1)
  347. FIELD(MIO_MST_TRI0, PIN_24_TRI, 24, 1)
  348. FIELD(MIO_MST_TRI0, PIN_23_TRI, 23, 1)
  349. FIELD(MIO_MST_TRI0, PIN_22_TRI, 22, 1)
  350. FIELD(MIO_MST_TRI0, PIN_21_TRI, 21, 1)
  351. FIELD(MIO_MST_TRI0, PIN_20_TRI, 20, 1)
  352. FIELD(MIO_MST_TRI0, PIN_19_TRI, 19, 1)
  353. FIELD(MIO_MST_TRI0, PIN_18_TRI, 18, 1)
  354. FIELD(MIO_MST_TRI0, PIN_17_TRI, 17, 1)
  355. FIELD(MIO_MST_TRI0, PIN_16_TRI, 16, 1)
  356. FIELD(MIO_MST_TRI0, PIN_15_TRI, 15, 1)
  357. FIELD(MIO_MST_TRI0, PIN_14_TRI, 14, 1)
  358. FIELD(MIO_MST_TRI0, PIN_13_TRI, 13, 1)
  359. FIELD(MIO_MST_TRI0, PIN_12_TRI, 12, 1)
  360. FIELD(MIO_MST_TRI0, PIN_11_TRI, 11, 1)
  361. FIELD(MIO_MST_TRI0, PIN_10_TRI, 10, 1)
  362. FIELD(MIO_MST_TRI0, PIN_09_TRI, 9, 1)
  363. FIELD(MIO_MST_TRI0, PIN_08_TRI, 8, 1)
  364. FIELD(MIO_MST_TRI0, PIN_07_TRI, 7, 1)
  365. FIELD(MIO_MST_TRI0, PIN_06_TRI, 6, 1)
  366. FIELD(MIO_MST_TRI0, PIN_05_TRI, 5, 1)
  367. FIELD(MIO_MST_TRI0, PIN_04_TRI, 4, 1)
  368. FIELD(MIO_MST_TRI0, PIN_03_TRI, 3, 1)
  369. FIELD(MIO_MST_TRI0, PIN_02_TRI, 2, 1)
  370. FIELD(MIO_MST_TRI0, PIN_01_TRI, 1, 1)
  371. FIELD(MIO_MST_TRI0, PIN_00_TRI, 0, 1)
  372. REG32(MIO_MST_TRI1, 0x204)
  373. FIELD(MIO_MST_TRI1, PIN_51_TRI, 25, 1)
  374. FIELD(MIO_MST_TRI1, PIN_50_TRI, 24, 1)
  375. FIELD(MIO_MST_TRI1, PIN_49_TRI, 23, 1)
  376. FIELD(MIO_MST_TRI1, PIN_48_TRI, 22, 1)
  377. FIELD(MIO_MST_TRI1, PIN_47_TRI, 21, 1)
  378. FIELD(MIO_MST_TRI1, PIN_46_TRI, 20, 1)
  379. FIELD(MIO_MST_TRI1, PIN_45_TRI, 19, 1)
  380. FIELD(MIO_MST_TRI1, PIN_44_TRI, 18, 1)
  381. FIELD(MIO_MST_TRI1, PIN_43_TRI, 17, 1)
  382. FIELD(MIO_MST_TRI1, PIN_42_TRI, 16, 1)
  383. FIELD(MIO_MST_TRI1, PIN_41_TRI, 15, 1)
  384. FIELD(MIO_MST_TRI1, PIN_40_TRI, 14, 1)
  385. FIELD(MIO_MST_TRI1, PIN_39_TRI, 13, 1)
  386. FIELD(MIO_MST_TRI1, PIN_38_TRI, 12, 1)
  387. FIELD(MIO_MST_TRI1, PIN_37_TRI, 11, 1)
  388. FIELD(MIO_MST_TRI1, PIN_36_TRI, 10, 1)
  389. FIELD(MIO_MST_TRI1, PIN_35_TRI, 9, 1)
  390. FIELD(MIO_MST_TRI1, PIN_34_TRI, 8, 1)
  391. FIELD(MIO_MST_TRI1, PIN_33_TRI, 7, 1)
  392. FIELD(MIO_MST_TRI1, PIN_32_TRI, 6, 1)
  393. FIELD(MIO_MST_TRI1, PIN_31_TRI, 5, 1)
  394. FIELD(MIO_MST_TRI1, PIN_30_TRI, 4, 1)
  395. FIELD(MIO_MST_TRI1, PIN_29_TRI, 3, 1)
  396. FIELD(MIO_MST_TRI1, PIN_28_TRI, 2, 1)
  397. FIELD(MIO_MST_TRI1, PIN_27_TRI, 1, 1)
  398. FIELD(MIO_MST_TRI1, PIN_26_TRI, 0, 1)
  399. REG32(BNK1_EN_RX, 0x300)
  400. FIELD(BNK1_EN_RX, BNK1_EN_RX, 0, 26)
  401. REG32(BNK1_SEL_RX0, 0x304)
  402. REG32(BNK1_SEL_RX1, 0x308)
  403. FIELD(BNK1_SEL_RX1, BNK1_SEL_RX, 0, 20)
  404. REG32(BNK1_EN_RX_SCHMITT_HYST, 0x30c)
  405. FIELD(BNK1_EN_RX_SCHMITT_HYST, BNK1_EN_RX_SCHMITT_HYST, 0, 26)
  406. REG32(BNK1_EN_WK_PD, 0x310)
  407. FIELD(BNK1_EN_WK_PD, BNK1_EN_WK_PD, 0, 26)
  408. REG32(BNK1_EN_WK_PU, 0x314)
  409. FIELD(BNK1_EN_WK_PU, BNK1_EN_WK_PU, 0, 26)
  410. REG32(BNK1_SEL_DRV0, 0x318)
  411. REG32(BNK1_SEL_DRV1, 0x31c)
  412. FIELD(BNK1_SEL_DRV1, BNK1_SEL_DRV, 0, 20)
  413. REG32(BNK1_SEL_SLEW, 0x320)
  414. FIELD(BNK1_SEL_SLEW, BNK1_SEL_SLEW, 0, 26)
  415. REG32(BNK1_EN_DFT_OPT_INV, 0x324)
  416. FIELD(BNK1_EN_DFT_OPT_INV, BNK1_EN_DFT_OPT_INV, 0, 26)
  417. REG32(BNK1_EN_PAD2PAD_LOOPBACK, 0x328)
  418. FIELD(BNK1_EN_PAD2PAD_LOOPBACK, BNK1_EN_PAD2PAD_LOOPBACK, 0, 13)
  419. REG32(BNK1_RX_SPARE0, 0x32c)
  420. REG32(BNK1_RX_SPARE1, 0x330)
  421. FIELD(BNK1_RX_SPARE1, BNK1_RX_SPARE, 0, 20)
  422. REG32(BNK1_TX_SPARE0, 0x334)
  423. REG32(BNK1_TX_SPARE1, 0x338)
  424. FIELD(BNK1_TX_SPARE1, BNK1_TX_SPARE, 0, 20)
  425. REG32(BNK1_SEL_EN1P8, 0x33c)
  426. FIELD(BNK1_SEL_EN1P8, BNK1_SEL_EN1P8, 0, 1)
  427. REG32(BNK1_EN_B_POR_DETECT, 0x340)
  428. FIELD(BNK1_EN_B_POR_DETECT, BNK1_EN_B_POR_DETECT, 0, 1)
  429. REG32(BNK1_LPF_BYP_POR_DETECT, 0x344)
  430. FIELD(BNK1_LPF_BYP_POR_DETECT, BNK1_LPF_BYP_POR_DETECT, 0, 1)
  431. REG32(BNK1_EN_LATCH, 0x348)
  432. FIELD(BNK1_EN_LATCH, BNK1_EN_LATCH, 0, 1)
  433. REG32(BNK1_VBG_LPF_BYP_B, 0x34c)
  434. FIELD(BNK1_VBG_LPF_BYP_B, BNK1_VBG_LPF_BYP_B, 0, 1)
  435. REG32(BNK1_EN_AMP_B, 0x350)
  436. FIELD(BNK1_EN_AMP_B, BNK1_EN_AMP_B, 0, 2)
  437. REG32(BNK1_SPARE_BIAS, 0x354)
  438. FIELD(BNK1_SPARE_BIAS, BNK1_SPARE_BIAS, 0, 4)
  439. REG32(BNK1_DRIVER_BIAS, 0x358)
  440. FIELD(BNK1_DRIVER_BIAS, BNK1_DRIVER_BIAS, 0, 15)
  441. REG32(BNK1_VMODE, 0x35c)
  442. FIELD(BNK1_VMODE, BNK1_VMODE, 0, 1)
  443. REG32(BNK1_SEL_AUX_IO_RX, 0x360)
  444. FIELD(BNK1_SEL_AUX_IO_RX, BNK1_SEL_AUX_IO_RX, 0, 26)
  445. REG32(BNK1_EN_TX_HS_MODE, 0x364)
  446. FIELD(BNK1_EN_TX_HS_MODE, BNK1_EN_TX_HS_MODE, 0, 26)
  447. REG32(SD0_CLK_CTRL, 0x400)
  448. FIELD(SD0_CLK_CTRL, SDIO0_FBCLK_SEL, 2, 1)
  449. FIELD(SD0_CLK_CTRL, SDIO0_RX_SRC_SEL, 0, 2)
  450. REG32(SD0_CTRL_REG, 0x404)
  451. FIELD(SD0_CTRL_REG, SD0_EMMC_SEL, 0, 1)
  452. REG32(SD0_CONFIG_REG1, 0x410)
  453. FIELD(SD0_CONFIG_REG1, SD0_BASECLK, 7, 8)
  454. FIELD(SD0_CONFIG_REG1, SD0_TUNIGCOUNT, 1, 6)
  455. FIELD(SD0_CONFIG_REG1, SD0_ASYNCWKPENA, 0, 1)
  456. REG32(SD0_CONFIG_REG2, 0x414)
  457. FIELD(SD0_CONFIG_REG2, SD0_SLOTTYPE, 12, 2)
  458. FIELD(SD0_CONFIG_REG2, SD0_ASYCINTR, 11, 1)
  459. FIELD(SD0_CONFIG_REG2, SD0_64BIT, 10, 1)
  460. FIELD(SD0_CONFIG_REG2, SD0_1P8V, 9, 1)
  461. FIELD(SD0_CONFIG_REG2, SD0_3P0V, 8, 1)
  462. FIELD(SD0_CONFIG_REG2, SD0_3P3V, 7, 1)
  463. FIELD(SD0_CONFIG_REG2, SD0_SUSPRES, 6, 1)
  464. FIELD(SD0_CONFIG_REG2, SD0_SDMA, 5, 1)
  465. FIELD(SD0_CONFIG_REG2, SD0_HIGHSPEED, 4, 1)
  466. FIELD(SD0_CONFIG_REG2, SD0_ADMA2, 3, 1)
  467. FIELD(SD0_CONFIG_REG2, SD0_8BIT, 2, 1)
  468. FIELD(SD0_CONFIG_REG2, SD0_MAXBLK, 0, 2)
  469. REG32(SD0_CONFIG_REG3, 0x418)
  470. FIELD(SD0_CONFIG_REG3, SD0_TUNINGSDR50, 10, 1)
  471. FIELD(SD0_CONFIG_REG3, SD0_RETUNETMR, 6, 4)
  472. FIELD(SD0_CONFIG_REG3, SD0_DDRIVER, 5, 1)
  473. FIELD(SD0_CONFIG_REG3, SD0_CDRIVER, 4, 1)
  474. FIELD(SD0_CONFIG_REG3, SD0_ADRIVER, 3, 1)
  475. FIELD(SD0_CONFIG_REG3, SD0_DDR50, 2, 1)
  476. FIELD(SD0_CONFIG_REG3, SD0_SDR104, 1, 1)
  477. FIELD(SD0_CONFIG_REG3, SD0_SDR50, 0, 1)
  478. REG32(SD0_INITPRESET, 0x41c)
  479. FIELD(SD0_INITPRESET, SD0_INITPRESET, 0, 13)
  480. REG32(SD0_DSPPRESET, 0x420)
  481. FIELD(SD0_DSPPRESET, SD0_DSPPRESET, 0, 13)
  482. REG32(SD0_HSPDPRESET, 0x424)
  483. FIELD(SD0_HSPDPRESET, SD0_HSPDPRESET, 0, 13)
  484. REG32(SD0_SDR12PRESET, 0x428)
  485. FIELD(SD0_SDR12PRESET, SD0_SDR12PRESET, 0, 13)
  486. REG32(SD0_SDR25PRESET, 0x42c)
  487. FIELD(SD0_SDR25PRESET, SD0_SDR25PRESET, 0, 13)
  488. REG32(SD0_SDR50PRSET, 0x430)
  489. FIELD(SD0_SDR50PRSET, SD0_SDR50PRESET, 0, 13)
  490. REG32(SD0_SDR104PRST, 0x434)
  491. FIELD(SD0_SDR104PRST, SD0_SDR104PRESET, 0, 13)
  492. REG32(SD0_DDR50PRESET, 0x438)
  493. FIELD(SD0_DDR50PRESET, SD0_DDR50PRESET, 0, 13)
  494. REG32(SD0_MAXCUR1P8, 0x43c)
  495. FIELD(SD0_MAXCUR1P8, SD0_MAXCUR1P8, 0, 8)
  496. REG32(SD0_MAXCUR3P0, 0x440)
  497. FIELD(SD0_MAXCUR3P0, SD0_MAXCUR3P0, 0, 8)
  498. REG32(SD0_MAXCUR3P3, 0x444)
  499. FIELD(SD0_MAXCUR3P3, SD0_MAXCUR3P3, 0, 8)
  500. REG32(SD0_DLL_CTRL, 0x448)
  501. FIELD(SD0_DLL_CTRL, SD0_CLKSTABLE_CFG, 9, 1)
  502. FIELD(SD0_DLL_CTRL, SD0_DLL_CFG, 5, 4)
  503. FIELD(SD0_DLL_CTRL, SD0_DLL_PSDONE, 4, 1)
  504. FIELD(SD0_DLL_CTRL, SD0_DLL_OVF, 3, 1)
  505. FIELD(SD0_DLL_CTRL, SD0_DLL_RST, 2, 1)
  506. FIELD(SD0_DLL_CTRL, SD0_DLL_TESTMODE, 1, 1)
  507. FIELD(SD0_DLL_CTRL, SD0_DLL_LOCK, 0, 1)
  508. REG32(SD0_CDN_CTRL, 0x44c)
  509. FIELD(SD0_CDN_CTRL, SD0_CDN_CTRL, 0, 1)
  510. REG32(SD0_DLL_TEST, 0x450)
  511. FIELD(SD0_DLL_TEST, DLL_DIV, 16, 8)
  512. FIELD(SD0_DLL_TEST, DLL_TX_SEL, 9, 7)
  513. FIELD(SD0_DLL_TEST, DLL_RX_SEL, 0, 9)
  514. REG32(SD0_RX_TUNING_SEL, 0x454)
  515. FIELD(SD0_RX_TUNING_SEL, SD0_RX_SEL, 0, 9)
  516. REG32(SD0_DLL_DIV_MAP0, 0x458)
  517. FIELD(SD0_DLL_DIV_MAP0, DIV_3, 24, 8)
  518. FIELD(SD0_DLL_DIV_MAP0, DIV_2, 16, 8)
  519. FIELD(SD0_DLL_DIV_MAP0, DIV_1, 8, 8)
  520. FIELD(SD0_DLL_DIV_MAP0, DIV_0, 0, 8)
  521. REG32(SD0_DLL_DIV_MAP1, 0x45c)
  522. FIELD(SD0_DLL_DIV_MAP1, DIV_7, 24, 8)
  523. FIELD(SD0_DLL_DIV_MAP1, DIV_6, 16, 8)
  524. FIELD(SD0_DLL_DIV_MAP1, DIV_5, 8, 8)
  525. FIELD(SD0_DLL_DIV_MAP1, DIV_4, 0, 8)
  526. REG32(SD0_IOU_COHERENT_CTRL, 0x460)
  527. FIELD(SD0_IOU_COHERENT_CTRL, SD0_AXI_COH, 0, 4)
  528. REG32(SD0_IOU_INTERCONNECT_ROUTE, 0x464)
  529. FIELD(SD0_IOU_INTERCONNECT_ROUTE, SD0, 0, 1)
  530. REG32(SD0_IOU_RAM, 0x468)
  531. FIELD(SD0_IOU_RAM, EMASA0, 6, 1)
  532. FIELD(SD0_IOU_RAM, EMAB0, 3, 3)
  533. FIELD(SD0_IOU_RAM, EMAA0, 0, 3)
  534. REG32(SD0_IOU_INTERCONNECT_QOS, 0x46c)
  535. FIELD(SD0_IOU_INTERCONNECT_QOS, SD0_QOS, 0, 4)
  536. REG32(SD1_CLK_CTRL, 0x480)
  537. FIELD(SD1_CLK_CTRL, SDIO1_FBCLK_SEL, 1, 1)
  538. FIELD(SD1_CLK_CTRL, SDIO1_RX_SRC_SEL, 0, 1)
  539. REG32(SD1_CTRL_REG, 0x484)
  540. FIELD(SD1_CTRL_REG, SD1_EMMC_SEL, 0, 1)
  541. REG32(SD1_CONFIG_REG1, 0x490)
  542. FIELD(SD1_CONFIG_REG1, SD1_BASECLK, 7, 8)
  543. FIELD(SD1_CONFIG_REG1, SD1_TUNIGCOUNT, 1, 6)
  544. FIELD(SD1_CONFIG_REG1, SD1_ASYNCWKPENA, 0, 1)
  545. REG32(SD1_CONFIG_REG2, 0x494)
  546. FIELD(SD1_CONFIG_REG2, SD1_SLOTTYPE, 12, 2)
  547. FIELD(SD1_CONFIG_REG2, SD1_ASYCINTR, 11, 1)
  548. FIELD(SD1_CONFIG_REG2, SD1_64BIT, 10, 1)
  549. FIELD(SD1_CONFIG_REG2, SD1_1P8V, 9, 1)
  550. FIELD(SD1_CONFIG_REG2, SD1_3P0V, 8, 1)
  551. FIELD(SD1_CONFIG_REG2, SD1_3P3V, 7, 1)
  552. FIELD(SD1_CONFIG_REG2, SD1_SUSPRES, 6, 1)
  553. FIELD(SD1_CONFIG_REG2, SD1_SDMA, 5, 1)
  554. FIELD(SD1_CONFIG_REG2, SD1_HIGHSPEED, 4, 1)
  555. FIELD(SD1_CONFIG_REG2, SD1_ADMA2, 3, 1)
  556. FIELD(SD1_CONFIG_REG2, SD1_8BIT, 2, 1)
  557. FIELD(SD1_CONFIG_REG2, SD1_MAXBLK, 0, 2)
  558. REG32(SD1_CONFIG_REG3, 0x498)
  559. FIELD(SD1_CONFIG_REG3, SD1_TUNINGSDR50, 10, 1)
  560. FIELD(SD1_CONFIG_REG3, SD1_RETUNETMR, 6, 4)
  561. FIELD(SD1_CONFIG_REG3, SD1_DDRIVER, 5, 1)
  562. FIELD(SD1_CONFIG_REG3, SD1_CDRIVER, 4, 1)
  563. FIELD(SD1_CONFIG_REG3, SD1_ADRIVER, 3, 1)
  564. FIELD(SD1_CONFIG_REG3, SD1_DDR50, 2, 1)
  565. FIELD(SD1_CONFIG_REG3, SD1_SDR104, 1, 1)
  566. FIELD(SD1_CONFIG_REG3, SD1_SDR50, 0, 1)
  567. REG32(SD1_INITPRESET, 0x49c)
  568. FIELD(SD1_INITPRESET, SD1_INITPRESET, 0, 13)
  569. REG32(SD1_DSPPRESET, 0x4a0)
  570. FIELD(SD1_DSPPRESET, SD1_DSPPRESET, 0, 13)
  571. REG32(SD1_HSPDPRESET, 0x4a4)
  572. FIELD(SD1_HSPDPRESET, SD1_HSPDPRESET, 0, 13)
  573. REG32(SD1_SDR12PRESET, 0x4a8)
  574. FIELD(SD1_SDR12PRESET, SD1_SDR12PRESET, 0, 13)
  575. REG32(SD1_SDR25PRESET, 0x4ac)
  576. FIELD(SD1_SDR25PRESET, SD1_SDR25PRESET, 0, 13)
  577. REG32(SD1_SDR50PRSET, 0x4b0)
  578. FIELD(SD1_SDR50PRSET, SD1_SDR50PRESET, 0, 13)
  579. REG32(SD1_SDR104PRST, 0x4b4)
  580. FIELD(SD1_SDR104PRST, SD1_SDR104PRESET, 0, 13)
  581. REG32(SD1_DDR50PRESET, 0x4b8)
  582. FIELD(SD1_DDR50PRESET, SD1_DDR50PRESET, 0, 13)
  583. REG32(SD1_MAXCUR1P8, 0x4bc)
  584. FIELD(SD1_MAXCUR1P8, SD1_MAXCUR1P8, 0, 8)
  585. REG32(SD1_MAXCUR3P0, 0x4c0)
  586. FIELD(SD1_MAXCUR3P0, SD1_MAXCUR3P0, 0, 8)
  587. REG32(SD1_MAXCUR3P3, 0x4c4)
  588. FIELD(SD1_MAXCUR3P3, SD1_MAXCUR3P3, 0, 8)
  589. REG32(SD1_DLL_CTRL, 0x4c8)
  590. FIELD(SD1_DLL_CTRL, SD1_CLKSTABLE_CFG, 9, 1)
  591. FIELD(SD1_DLL_CTRL, SD1_DLL_CFG, 5, 4)
  592. FIELD(SD1_DLL_CTRL, SD1_DLL_PSDONE, 4, 1)
  593. FIELD(SD1_DLL_CTRL, SD1_DLL_OVF, 3, 1)
  594. FIELD(SD1_DLL_CTRL, SD1_DLL_RST, 2, 1)
  595. FIELD(SD1_DLL_CTRL, SD1_DLL_TESTMODE, 1, 1)
  596. FIELD(SD1_DLL_CTRL, SD1_DLL_LOCK, 0, 1)
  597. REG32(SD1_CDN_CTRL, 0x4cc)
  598. FIELD(SD1_CDN_CTRL, SD1_CDN_CTRL, 0, 1)
  599. REG32(SD1_DLL_TEST, 0x4d0)
  600. FIELD(SD1_DLL_TEST, DLL_DIV, 16, 8)
  601. FIELD(SD1_DLL_TEST, DLL_TX_SEL, 9, 7)
  602. FIELD(SD1_DLL_TEST, DLL_RX_SEL, 0, 9)
  603. REG32(SD1_RX_TUNING_SEL, 0x4d4)
  604. FIELD(SD1_RX_TUNING_SEL, SD1_RX_SEL, 0, 9)
  605. REG32(SD1_DLL_DIV_MAP0, 0x4d8)
  606. FIELD(SD1_DLL_DIV_MAP0, DIV_3, 24, 8)
  607. FIELD(SD1_DLL_DIV_MAP0, DIV_2, 16, 8)
  608. FIELD(SD1_DLL_DIV_MAP0, DIV_1, 8, 8)
  609. FIELD(SD1_DLL_DIV_MAP0, DIV_0, 0, 8)
  610. REG32(SD1_DLL_DIV_MAP1, 0x4dc)
  611. FIELD(SD1_DLL_DIV_MAP1, DIV_7, 24, 8)
  612. FIELD(SD1_DLL_DIV_MAP1, DIV_6, 16, 8)
  613. FIELD(SD1_DLL_DIV_MAP1, DIV_5, 8, 8)
  614. FIELD(SD1_DLL_DIV_MAP1, DIV_4, 0, 8)
  615. REG32(SD1_IOU_COHERENT_CTRL, 0x4e0)
  616. FIELD(SD1_IOU_COHERENT_CTRL, SD1_AXI_COH, 0, 4)
  617. REG32(SD1_IOU_INTERCONNECT_ROUTE, 0x4e4)
  618. FIELD(SD1_IOU_INTERCONNECT_ROUTE, SD1, 0, 1)
  619. REG32(SD1_IOU_RAM, 0x4e8)
  620. FIELD(SD1_IOU_RAM, EMASA0, 6, 1)
  621. FIELD(SD1_IOU_RAM, EMAB0, 3, 3)
  622. FIELD(SD1_IOU_RAM, EMAA0, 0, 3)
  623. REG32(SD1_IOU_INTERCONNECT_QOS, 0x4ec)
  624. FIELD(SD1_IOU_INTERCONNECT_QOS, SD1_QOS, 0, 4)
  625. REG32(OSPI_QSPI_IOU_AXI_MUX_SEL, 0x504)
  626. FIELD(OSPI_QSPI_IOU_AXI_MUX_SEL, OSPI_MUX_SEL, 1, 1)
  627. FIELD(OSPI_QSPI_IOU_AXI_MUX_SEL, QSPI_OSPI_MUX_SEL, 0, 1)
  628. REG32(QSPI_IOU_COHERENT_CTRL, 0x508)
  629. FIELD(QSPI_IOU_COHERENT_CTRL, QSPI_AXI_COH, 0, 4)
  630. REG32(QSPI_IOU_INTERCONNECT_ROUTE, 0x50c)
  631. FIELD(QSPI_IOU_INTERCONNECT_ROUTE, QSPI, 0, 1)
  632. REG32(QSPI_IOU_RAM, 0x510)
  633. FIELD(QSPI_IOU_RAM, EMASA1, 13, 1)
  634. FIELD(QSPI_IOU_RAM, EMAB1, 10, 3)
  635. FIELD(QSPI_IOU_RAM, EMAA1, 7, 3)
  636. FIELD(QSPI_IOU_RAM, EMASA0, 6, 1)
  637. FIELD(QSPI_IOU_RAM, EMAB0, 3, 3)
  638. FIELD(QSPI_IOU_RAM, EMAA0, 0, 3)
  639. REG32(QSPI_IOU_INTERCONNECT_QOS, 0x514)
  640. FIELD(QSPI_IOU_INTERCONNECT_QOS, QSPI_QOS, 0, 4)
  641. REG32(OSPI_IOU_COHERENT_CTRL, 0x530)
  642. FIELD(OSPI_IOU_COHERENT_CTRL, OSPI_AXI_COH, 0, 4)
  643. REG32(OSPI_IOU_INTERCONNECT_ROUTE, 0x534)
  644. FIELD(OSPI_IOU_INTERCONNECT_ROUTE, OSPI, 0, 1)
  645. REG32(OSPI_IOU_RAM, 0x538)
  646. FIELD(OSPI_IOU_RAM, EMAS0, 5, 1)
  647. FIELD(OSPI_IOU_RAM, EMAW0, 3, 2)
  648. FIELD(OSPI_IOU_RAM, EMA0, 0, 3)
  649. REG32(OSPI_IOU_INTERCONNECT_QOS, 0x53c)
  650. FIELD(OSPI_IOU_INTERCONNECT_QOS, OSPI_QOS, 0, 4)
  651. REG32(OSPI_REFCLK_DLY_CTRL, 0x540)
  652. FIELD(OSPI_REFCLK_DLY_CTRL, DLY1, 3, 2)
  653. FIELD(OSPI_REFCLK_DLY_CTRL, DLY0, 0, 3)
  654. REG32(CUR_PWR_ST, 0x600)
  655. FIELD(CUR_PWR_ST, U2PMU, 0, 2)
  656. REG32(CONNECT_ST, 0x604)
  657. FIELD(CONNECT_ST, U2PMU, 0, 1)
  658. REG32(PW_STATE_REQ, 0x608)
  659. FIELD(PW_STATE_REQ, BIT_1_0, 0, 2)
  660. REG32(HOST_U2_PORT_DISABLE, 0x60c)
  661. FIELD(HOST_U2_PORT_DISABLE, BIT_0, 0, 1)
  662. REG32(DBG_U2PMU, 0x610)
  663. REG32(DBG_U2PMU_EXT1, 0x614)
  664. REG32(DBG_U2PMU_EXT2, 0x618)
  665. FIELD(DBG_U2PMU_EXT2, BIT_67_64, 0, 4)
  666. REG32(PME_GEN_U2PMU, 0x61c)
  667. FIELD(PME_GEN_U2PMU, BIT_0, 0, 1)
  668. REG32(PWR_CONFIG_USB2, 0x620)
  669. FIELD(PWR_CONFIG_USB2, STRAP, 0, 30)
  670. REG32(PHY_HUB, 0x624)
  671. FIELD(PHY_HUB, VBUS_CTRL, 1, 1)
  672. FIELD(PHY_HUB, OVER_CURRENT, 0, 1)
  673. REG32(CTRL, 0x700)
  674. FIELD(CTRL, SLVERR_ENABLE, 0, 1)
  675. REG32(ISR, 0x800)
  676. FIELD(ISR, ADDR_DECODE_ERR, 0, 1)
  677. REG32(IMR, 0x804)
  678. FIELD(IMR, ADDR_DECODE_ERR, 0, 1)
  679. REG32(IER, 0x808)
  680. FIELD(IER, ADDR_DECODE_ERR, 0, 1)
  681. REG32(IDR, 0x80c)
  682. FIELD(IDR, ADDR_DECODE_ERR, 0, 1)
  683. REG32(ITR, 0x810)
  684. FIELD(ITR, ADDR_DECODE_ERR, 0, 1)
  685. REG32(PARITY_ISR, 0x814)
  686. FIELD(PARITY_ISR, PERR_AXI_SD1_IOU, 12, 1)
  687. FIELD(PARITY_ISR, PERR_AXI_SD0_IOU, 11, 1)
  688. FIELD(PARITY_ISR, PERR_AXI_QSPI_IOU, 10, 1)
  689. FIELD(PARITY_ISR, PERR_AXI_OSPI_IOU, 9, 1)
  690. FIELD(PARITY_ISR, PERR_IOU_SD1, 8, 1)
  691. FIELD(PARITY_ISR, PERR_IOU_SD0, 7, 1)
  692. FIELD(PARITY_ISR, PERR_IOU_QSPI1, 6, 1)
  693. FIELD(PARITY_ISR, PERR_IOUSLCR_SECURE_APB, 5, 1)
  694. FIELD(PARITY_ISR, PERR_IOUSLCR_APB, 4, 1)
  695. FIELD(PARITY_ISR, PERR_QSPI0_APB, 3, 1)
  696. FIELD(PARITY_ISR, PERR_OSPI_APB, 2, 1)
  697. FIELD(PARITY_ISR, PERR_I2C_APB, 1, 1)
  698. FIELD(PARITY_ISR, PERR_GPIO_APB, 0, 1)
  699. REG32(PARITY_IMR, 0x818)
  700. FIELD(PARITY_IMR, PERR_AXI_SD1_IOU, 12, 1)
  701. FIELD(PARITY_IMR, PERR_AXI_SD0_IOU, 11, 1)
  702. FIELD(PARITY_IMR, PERR_AXI_QSPI_IOU, 10, 1)
  703. FIELD(PARITY_IMR, PERR_AXI_OSPI_IOU, 9, 1)
  704. FIELD(PARITY_IMR, PERR_IOU_SD1, 8, 1)
  705. FIELD(PARITY_IMR, PERR_IOU_SD0, 7, 1)
  706. FIELD(PARITY_IMR, PERR_IOU_QSPI1, 6, 1)
  707. FIELD(PARITY_IMR, PERR_IOUSLCR_SECURE_APB, 5, 1)
  708. FIELD(PARITY_IMR, PERR_IOUSLCR_APB, 4, 1)
  709. FIELD(PARITY_IMR, PERR_QSPI0_APB, 3, 1)
  710. FIELD(PARITY_IMR, PERR_OSPI_APB, 2, 1)
  711. FIELD(PARITY_IMR, PERR_I2C_APB, 1, 1)
  712. FIELD(PARITY_IMR, PERR_GPIO_APB, 0, 1)
  713. REG32(PARITY_IER, 0x81c)
  714. FIELD(PARITY_IER, PERR_AXI_SD1_IOU, 12, 1)
  715. FIELD(PARITY_IER, PERR_AXI_SD0_IOU, 11, 1)
  716. FIELD(PARITY_IER, PERR_AXI_QSPI_IOU, 10, 1)
  717. FIELD(PARITY_IER, PERR_AXI_OSPI_IOU, 9, 1)
  718. FIELD(PARITY_IER, PERR_IOU_SD1, 8, 1)
  719. FIELD(PARITY_IER, PERR_IOU_SD0, 7, 1)
  720. FIELD(PARITY_IER, PERR_IOU_QSPI1, 6, 1)
  721. FIELD(PARITY_IER, PERR_IOUSLCR_SECURE_APB, 5, 1)
  722. FIELD(PARITY_IER, PERR_IOUSLCR_APB, 4, 1)
  723. FIELD(PARITY_IER, PERR_QSPI0_APB, 3, 1)
  724. FIELD(PARITY_IER, PERR_OSPI_APB, 2, 1)
  725. FIELD(PARITY_IER, PERR_I2C_APB, 1, 1)
  726. FIELD(PARITY_IER, PERR_GPIO_APB, 0, 1)
  727. REG32(PARITY_IDR, 0x820)
  728. FIELD(PARITY_IDR, PERR_AXI_SD1_IOU, 12, 1)
  729. FIELD(PARITY_IDR, PERR_AXI_SD0_IOU, 11, 1)
  730. FIELD(PARITY_IDR, PERR_AXI_QSPI_IOU, 10, 1)
  731. FIELD(PARITY_IDR, PERR_AXI_OSPI_IOU, 9, 1)
  732. FIELD(PARITY_IDR, PERR_IOU_SD1, 8, 1)
  733. FIELD(PARITY_IDR, PERR_IOU_SD0, 7, 1)
  734. FIELD(PARITY_IDR, PERR_IOU_QSPI1, 6, 1)
  735. FIELD(PARITY_IDR, PERR_IOUSLCR_SECURE_APB, 5, 1)
  736. FIELD(PARITY_IDR, PERR_IOUSLCR_APB, 4, 1)
  737. FIELD(PARITY_IDR, PERR_QSPI0_APB, 3, 1)
  738. FIELD(PARITY_IDR, PERR_OSPI_APB, 2, 1)
  739. FIELD(PARITY_IDR, PERR_I2C_APB, 1, 1)
  740. FIELD(PARITY_IDR, PERR_GPIO_APB, 0, 1)
  741. REG32(PARITY_ITR, 0x824)
  742. FIELD(PARITY_ITR, PERR_AXI_SD1_IOU, 12, 1)
  743. FIELD(PARITY_ITR, PERR_AXI_SD0_IOU, 11, 1)
  744. FIELD(PARITY_ITR, PERR_AXI_QSPI_IOU, 10, 1)
  745. FIELD(PARITY_ITR, PERR_AXI_OSPI_IOU, 9, 1)
  746. FIELD(PARITY_ITR, PERR_IOU_SD1, 8, 1)
  747. FIELD(PARITY_ITR, PERR_IOU_SD0, 7, 1)
  748. FIELD(PARITY_ITR, PERR_IOU_QSPI1, 6, 1)
  749. FIELD(PARITY_ITR, PERR_IOUSLCR_SECURE_APB, 5, 1)
  750. FIELD(PARITY_ITR, PERR_IOUSLCR_APB, 4, 1)
  751. FIELD(PARITY_ITR, PERR_QSPI0_APB, 3, 1)
  752. FIELD(PARITY_ITR, PERR_OSPI_APB, 2, 1)
  753. FIELD(PARITY_ITR, PERR_I2C_APB, 1, 1)
  754. FIELD(PARITY_ITR, PERR_GPIO_APB, 0, 1)
  755. REG32(WPROT0, 0x828)
  756. FIELD(WPROT0, ACTIVE, 0, 1)
  757. static void parity_imr_update_irq(XlnxVersalPmcIouSlcr *s)
  758. {
  759. bool pending = s->regs[R_PARITY_ISR] & ~s->regs[R_PARITY_IMR];
  760. qemu_set_irq(s->irq_parity_imr, pending);
  761. }
  762. static void parity_isr_postw(RegisterInfo *reg, uint64_t val64)
  763. {
  764. XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
  765. parity_imr_update_irq(s);
  766. }
  767. static uint64_t parity_ier_prew(RegisterInfo *reg, uint64_t val64)
  768. {
  769. XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
  770. uint32_t val = val64;
  771. s->regs[R_PARITY_IMR] &= ~val;
  772. parity_imr_update_irq(s);
  773. return 0;
  774. }
  775. static uint64_t parity_idr_prew(RegisterInfo *reg, uint64_t val64)
  776. {
  777. XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
  778. uint32_t val = val64;
  779. s->regs[R_PARITY_IMR] |= val;
  780. parity_imr_update_irq(s);
  781. return 0;
  782. }
  783. static uint64_t parity_itr_prew(RegisterInfo *reg, uint64_t val64)
  784. {
  785. XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
  786. uint32_t val = val64;
  787. s->regs[R_PARITY_ISR] |= val;
  788. parity_imr_update_irq(s);
  789. return 0;
  790. }
  791. static void imr_update_irq(XlnxVersalPmcIouSlcr *s)
  792. {
  793. bool pending = s->regs[R_ISR] & ~s->regs[R_IMR];
  794. qemu_set_irq(s->irq_imr, pending);
  795. }
  796. static void isr_postw(RegisterInfo *reg, uint64_t val64)
  797. {
  798. XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
  799. imr_update_irq(s);
  800. }
  801. static uint64_t ier_prew(RegisterInfo *reg, uint64_t val64)
  802. {
  803. XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
  804. uint32_t val = val64;
  805. s->regs[R_IMR] &= ~val;
  806. imr_update_irq(s);
  807. return 0;
  808. }
  809. static uint64_t idr_prew(RegisterInfo *reg, uint64_t val64)
  810. {
  811. XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
  812. uint32_t val = val64;
  813. s->regs[R_IMR] |= val;
  814. imr_update_irq(s);
  815. return 0;
  816. }
  817. static uint64_t itr_prew(RegisterInfo *reg, uint64_t val64)
  818. {
  819. XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
  820. uint32_t val = val64;
  821. s->regs[R_ISR] |= val;
  822. imr_update_irq(s);
  823. return 0;
  824. }
  825. static uint64_t sd0_ctrl_reg_prew(RegisterInfo *reg, uint64_t val64)
  826. {
  827. XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
  828. uint32_t prev = ARRAY_FIELD_EX32(s->regs, SD0_CTRL_REG, SD0_EMMC_SEL);
  829. if (prev != (val64 & R_SD0_CTRL_REG_SD0_EMMC_SEL_MASK)) {
  830. qemu_set_irq(s->sd_emmc_sel[0], !!val64);
  831. }
  832. return val64;
  833. }
  834. static uint64_t sd1_ctrl_reg_prew(RegisterInfo *reg, uint64_t val64)
  835. {
  836. XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
  837. uint32_t prev = ARRAY_FIELD_EX32(s->regs, SD1_CTRL_REG, SD1_EMMC_SEL);
  838. if (prev != (val64 & R_SD1_CTRL_REG_SD1_EMMC_SEL_MASK)) {
  839. qemu_set_irq(s->sd_emmc_sel[1], !!val64);
  840. }
  841. return val64;
  842. }
  843. static uint64_t ospi_qspi_iou_axi_mux_sel_prew(RegisterInfo *reg,
  844. uint64_t val64)
  845. {
  846. XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
  847. uint32_t val32 = (uint32_t) val64;
  848. uint8_t ospi_mux_sel = FIELD_EX32(val32, OSPI_QSPI_IOU_AXI_MUX_SEL,
  849. OSPI_MUX_SEL);
  850. uint8_t qspi_ospi_mux_sel = FIELD_EX32(val32, OSPI_QSPI_IOU_AXI_MUX_SEL,
  851. QSPI_OSPI_MUX_SEL);
  852. if (ospi_mux_sel !=
  853. ARRAY_FIELD_EX32(s->regs, OSPI_QSPI_IOU_AXI_MUX_SEL, OSPI_MUX_SEL)) {
  854. qemu_set_irq(s->ospi_mux_sel, !!ospi_mux_sel);
  855. }
  856. if (qspi_ospi_mux_sel !=
  857. ARRAY_FIELD_EX32(s->regs, OSPI_QSPI_IOU_AXI_MUX_SEL,
  858. QSPI_OSPI_MUX_SEL)) {
  859. qemu_set_irq(s->qspi_ospi_mux_sel, !!qspi_ospi_mux_sel);
  860. }
  861. return val64;
  862. }
  863. static RegisterAccessInfo pmc_iou_slcr_regs_info[] = {
  864. { .name = "MIO_PIN_0", .addr = A_MIO_PIN_0,
  865. .rsvd = 0xfffffc01,
  866. },{ .name = "MIO_PIN_1", .addr = A_MIO_PIN_1,
  867. .rsvd = 0xfffffc01,
  868. },{ .name = "MIO_PIN_2", .addr = A_MIO_PIN_2,
  869. .rsvd = 0xfffffc01,
  870. },{ .name = "MIO_PIN_3", .addr = A_MIO_PIN_3,
  871. .rsvd = 0xfffffc01,
  872. },{ .name = "MIO_PIN_4", .addr = A_MIO_PIN_4,
  873. .rsvd = 0xfffffc01,
  874. },{ .name = "MIO_PIN_5", .addr = A_MIO_PIN_5,
  875. .rsvd = 0xfffffc01,
  876. },{ .name = "MIO_PIN_6", .addr = A_MIO_PIN_6,
  877. .rsvd = 0xfffffc01,
  878. },{ .name = "MIO_PIN_7", .addr = A_MIO_PIN_7,
  879. .rsvd = 0xfffffc01,
  880. },{ .name = "MIO_PIN_8", .addr = A_MIO_PIN_8,
  881. .rsvd = 0xfffffc01,
  882. },{ .name = "MIO_PIN_9", .addr = A_MIO_PIN_9,
  883. .rsvd = 0xfffffc01,
  884. },{ .name = "MIO_PIN_10", .addr = A_MIO_PIN_10,
  885. .rsvd = 0xfffffc01,
  886. },{ .name = "MIO_PIN_11", .addr = A_MIO_PIN_11,
  887. .rsvd = 0xfffffc01,
  888. },{ .name = "MIO_PIN_12", .addr = A_MIO_PIN_12,
  889. .rsvd = 0xfffffc01,
  890. },{ .name = "MIO_PIN_13", .addr = A_MIO_PIN_13,
  891. .rsvd = 0xfffffc01,
  892. },{ .name = "MIO_PIN_14", .addr = A_MIO_PIN_14,
  893. .rsvd = 0xfffffc01,
  894. },{ .name = "MIO_PIN_15", .addr = A_MIO_PIN_15,
  895. .rsvd = 0xfffffc01,
  896. },{ .name = "MIO_PIN_16", .addr = A_MIO_PIN_16,
  897. .rsvd = 0xfffffc01,
  898. },{ .name = "MIO_PIN_17", .addr = A_MIO_PIN_17,
  899. .rsvd = 0xfffffc01,
  900. },{ .name = "MIO_PIN_18", .addr = A_MIO_PIN_18,
  901. .rsvd = 0xfffffc01,
  902. },{ .name = "MIO_PIN_19", .addr = A_MIO_PIN_19,
  903. .rsvd = 0xfffffc01,
  904. },{ .name = "MIO_PIN_20", .addr = A_MIO_PIN_20,
  905. .rsvd = 0xfffffc01,
  906. },{ .name = "MIO_PIN_21", .addr = A_MIO_PIN_21,
  907. .rsvd = 0xfffffc01,
  908. },{ .name = "MIO_PIN_22", .addr = A_MIO_PIN_22,
  909. .rsvd = 0xfffffc01,
  910. },{ .name = "MIO_PIN_23", .addr = A_MIO_PIN_23,
  911. .rsvd = 0xfffffc01,
  912. },{ .name = "MIO_PIN_24", .addr = A_MIO_PIN_24,
  913. .rsvd = 0xfffffc01,
  914. },{ .name = "MIO_PIN_25", .addr = A_MIO_PIN_25,
  915. .rsvd = 0xfffffc01,
  916. },{ .name = "MIO_PIN_26", .addr = A_MIO_PIN_26,
  917. .rsvd = 0xfffffc01,
  918. },{ .name = "MIO_PIN_27", .addr = A_MIO_PIN_27,
  919. .rsvd = 0xfffffc01,
  920. },{ .name = "MIO_PIN_28", .addr = A_MIO_PIN_28,
  921. .rsvd = 0xfffffc01,
  922. },{ .name = "MIO_PIN_29", .addr = A_MIO_PIN_29,
  923. .rsvd = 0xfffffc01,
  924. },{ .name = "MIO_PIN_30", .addr = A_MIO_PIN_30,
  925. .rsvd = 0xfffffc01,
  926. },{ .name = "MIO_PIN_31", .addr = A_MIO_PIN_31,
  927. .rsvd = 0xfffffc01,
  928. },{ .name = "MIO_PIN_32", .addr = A_MIO_PIN_32,
  929. .rsvd = 0xfffffc01,
  930. },{ .name = "MIO_PIN_33", .addr = A_MIO_PIN_33,
  931. .rsvd = 0xfffffc01,
  932. },{ .name = "MIO_PIN_34", .addr = A_MIO_PIN_34,
  933. .rsvd = 0xfffffc01,
  934. },{ .name = "MIO_PIN_35", .addr = A_MIO_PIN_35,
  935. .rsvd = 0xfffffc01,
  936. },{ .name = "MIO_PIN_36", .addr = A_MIO_PIN_36,
  937. .rsvd = 0xfffffc01,
  938. },{ .name = "MIO_PIN_37", .addr = A_MIO_PIN_37,
  939. .rsvd = 0xfffffc01,
  940. },{ .name = "MIO_PIN_38", .addr = A_MIO_PIN_38,
  941. .rsvd = 0xfffffc01,
  942. },{ .name = "MIO_PIN_39", .addr = A_MIO_PIN_39,
  943. .rsvd = 0xfffffc01,
  944. },{ .name = "MIO_PIN_40", .addr = A_MIO_PIN_40,
  945. .rsvd = 0xfffffc01,
  946. },{ .name = "MIO_PIN_41", .addr = A_MIO_PIN_41,
  947. .rsvd = 0xfffffc01,
  948. },{ .name = "MIO_PIN_42", .addr = A_MIO_PIN_42,
  949. .rsvd = 0xfffffc01,
  950. },{ .name = "MIO_PIN_43", .addr = A_MIO_PIN_43,
  951. .rsvd = 0xfffffc01,
  952. },{ .name = "MIO_PIN_44", .addr = A_MIO_PIN_44,
  953. .rsvd = 0xfffffc01,
  954. },{ .name = "MIO_PIN_45", .addr = A_MIO_PIN_45,
  955. .rsvd = 0xfffffc01,
  956. },{ .name = "MIO_PIN_46", .addr = A_MIO_PIN_46,
  957. .rsvd = 0xfffffc01,
  958. },{ .name = "MIO_PIN_47", .addr = A_MIO_PIN_47,
  959. .rsvd = 0xfffffc01,
  960. },{ .name = "MIO_PIN_48", .addr = A_MIO_PIN_48,
  961. .rsvd = 0xfffffc01,
  962. },{ .name = "MIO_PIN_49", .addr = A_MIO_PIN_49,
  963. .rsvd = 0xfffffc01,
  964. },{ .name = "MIO_PIN_50", .addr = A_MIO_PIN_50,
  965. .rsvd = 0xfffffc01,
  966. },{ .name = "MIO_PIN_51", .addr = A_MIO_PIN_51,
  967. .rsvd = 0xfffffc01,
  968. },{ .name = "BNK0_EN_RX", .addr = A_BNK0_EN_RX,
  969. .reset = 0x3ffffff,
  970. .rsvd = 0xfc000000,
  971. },{ .name = "BNK0_SEL_RX0", .addr = A_BNK0_SEL_RX0,
  972. .reset = 0xffffffff,
  973. },{ .name = "BNK0_SEL_RX1", .addr = A_BNK0_SEL_RX1,
  974. .reset = 0xfffff,
  975. .rsvd = 0xfff00000,
  976. },{ .name = "BNK0_EN_RX_SCHMITT_HYST", .addr = A_BNK0_EN_RX_SCHMITT_HYST,
  977. .rsvd = 0xfc000000,
  978. },{ .name = "BNK0_EN_WK_PD", .addr = A_BNK0_EN_WK_PD,
  979. .rsvd = 0xfc000000,
  980. },{ .name = "BNK0_EN_WK_PU", .addr = A_BNK0_EN_WK_PU,
  981. .reset = 0x3ffffff,
  982. .rsvd = 0xfc000000,
  983. },{ .name = "BNK0_SEL_DRV0", .addr = A_BNK0_SEL_DRV0,
  984. .reset = 0xffffffff,
  985. },{ .name = "BNK0_SEL_DRV1", .addr = A_BNK0_SEL_DRV1,
  986. .reset = 0xfffff,
  987. .rsvd = 0xfff00000,
  988. },{ .name = "BNK0_SEL_SLEW", .addr = A_BNK0_SEL_SLEW,
  989. .rsvd = 0xfc000000,
  990. },{ .name = "BNK0_EN_DFT_OPT_INV", .addr = A_BNK0_EN_DFT_OPT_INV,
  991. .rsvd = 0xfc000000,
  992. },{ .name = "BNK0_EN_PAD2PAD_LOOPBACK",
  993. .addr = A_BNK0_EN_PAD2PAD_LOOPBACK,
  994. .rsvd = 0xffffe000,
  995. },{ .name = "BNK0_RX_SPARE0", .addr = A_BNK0_RX_SPARE0,
  996. },{ .name = "BNK0_RX_SPARE1", .addr = A_BNK0_RX_SPARE1,
  997. .rsvd = 0xfff00000,
  998. },{ .name = "BNK0_TX_SPARE0", .addr = A_BNK0_TX_SPARE0,
  999. },{ .name = "BNK0_TX_SPARE1", .addr = A_BNK0_TX_SPARE1,
  1000. .rsvd = 0xfff00000,
  1001. },{ .name = "BNK0_SEL_EN1P8", .addr = A_BNK0_SEL_EN1P8,
  1002. .rsvd = 0xfffffffe,
  1003. },{ .name = "BNK0_EN_B_POR_DETECT", .addr = A_BNK0_EN_B_POR_DETECT,
  1004. .rsvd = 0xfffffffe,
  1005. },{ .name = "BNK0_LPF_BYP_POR_DETECT", .addr = A_BNK0_LPF_BYP_POR_DETECT,
  1006. .reset = 0x1,
  1007. .rsvd = 0xfffffffe,
  1008. },{ .name = "BNK0_EN_LATCH", .addr = A_BNK0_EN_LATCH,
  1009. .rsvd = 0xfffffffe,
  1010. },{ .name = "BNK0_VBG_LPF_BYP_B", .addr = A_BNK0_VBG_LPF_BYP_B,
  1011. .reset = 0x1,
  1012. .rsvd = 0xfffffffe,
  1013. },{ .name = "BNK0_EN_AMP_B", .addr = A_BNK0_EN_AMP_B,
  1014. .rsvd = 0xfffffffc,
  1015. },{ .name = "BNK0_SPARE_BIAS", .addr = A_BNK0_SPARE_BIAS,
  1016. .rsvd = 0xfffffff0,
  1017. },{ .name = "BNK0_DRIVER_BIAS", .addr = A_BNK0_DRIVER_BIAS,
  1018. .rsvd = 0xffff8000,
  1019. },{ .name = "BNK0_VMODE", .addr = A_BNK0_VMODE,
  1020. .rsvd = 0xfffffffe,
  1021. .ro = 0x1,
  1022. },{ .name = "BNK0_SEL_AUX_IO_RX", .addr = A_BNK0_SEL_AUX_IO_RX,
  1023. .rsvd = 0xfc000000,
  1024. },{ .name = "BNK0_EN_TX_HS_MODE", .addr = A_BNK0_EN_TX_HS_MODE,
  1025. .rsvd = 0xfc000000,
  1026. },{ .name = "MIO_MST_TRI0", .addr = A_MIO_MST_TRI0,
  1027. .reset = 0x3ffffff,
  1028. .rsvd = 0xfc000000,
  1029. },{ .name = "MIO_MST_TRI1", .addr = A_MIO_MST_TRI1,
  1030. .reset = 0x3ffffff,
  1031. .rsvd = 0xfc000000,
  1032. },{ .name = "BNK1_EN_RX", .addr = A_BNK1_EN_RX,
  1033. .reset = 0x3ffffff,
  1034. .rsvd = 0xfc000000,
  1035. },{ .name = "BNK1_SEL_RX0", .addr = A_BNK1_SEL_RX0,
  1036. .reset = 0xffffffff,
  1037. },{ .name = "BNK1_SEL_RX1", .addr = A_BNK1_SEL_RX1,
  1038. .reset = 0xfffff,
  1039. .rsvd = 0xfff00000,
  1040. },{ .name = "BNK1_EN_RX_SCHMITT_HYST", .addr = A_BNK1_EN_RX_SCHMITT_HYST,
  1041. .rsvd = 0xfc000000,
  1042. },{ .name = "BNK1_EN_WK_PD", .addr = A_BNK1_EN_WK_PD,
  1043. .rsvd = 0xfc000000,
  1044. },{ .name = "BNK1_EN_WK_PU", .addr = A_BNK1_EN_WK_PU,
  1045. .reset = 0x3ffffff,
  1046. .rsvd = 0xfc000000,
  1047. },{ .name = "BNK1_SEL_DRV0", .addr = A_BNK1_SEL_DRV0,
  1048. .reset = 0xffffffff,
  1049. },{ .name = "BNK1_SEL_DRV1", .addr = A_BNK1_SEL_DRV1,
  1050. .reset = 0xfffff,
  1051. .rsvd = 0xfff00000,
  1052. },{ .name = "BNK1_SEL_SLEW", .addr = A_BNK1_SEL_SLEW,
  1053. .rsvd = 0xfc000000,
  1054. },{ .name = "BNK1_EN_DFT_OPT_INV", .addr = A_BNK1_EN_DFT_OPT_INV,
  1055. .rsvd = 0xfc000000,
  1056. },{ .name = "BNK1_EN_PAD2PAD_LOOPBACK",
  1057. .addr = A_BNK1_EN_PAD2PAD_LOOPBACK,
  1058. .rsvd = 0xffffe000,
  1059. },{ .name = "BNK1_RX_SPARE0", .addr = A_BNK1_RX_SPARE0,
  1060. },{ .name = "BNK1_RX_SPARE1", .addr = A_BNK1_RX_SPARE1,
  1061. .rsvd = 0xfff00000,
  1062. },{ .name = "BNK1_TX_SPARE0", .addr = A_BNK1_TX_SPARE0,
  1063. },{ .name = "BNK1_TX_SPARE1", .addr = A_BNK1_TX_SPARE1,
  1064. .rsvd = 0xfff00000,
  1065. },{ .name = "BNK1_SEL_EN1P8", .addr = A_BNK1_SEL_EN1P8,
  1066. .rsvd = 0xfffffffe,
  1067. },{ .name = "BNK1_EN_B_POR_DETECT", .addr = A_BNK1_EN_B_POR_DETECT,
  1068. .rsvd = 0xfffffffe,
  1069. },{ .name = "BNK1_LPF_BYP_POR_DETECT", .addr = A_BNK1_LPF_BYP_POR_DETECT,
  1070. .reset = 0x1,
  1071. .rsvd = 0xfffffffe,
  1072. },{ .name = "BNK1_EN_LATCH", .addr = A_BNK1_EN_LATCH,
  1073. .rsvd = 0xfffffffe,
  1074. },{ .name = "BNK1_VBG_LPF_BYP_B", .addr = A_BNK1_VBG_LPF_BYP_B,
  1075. .reset = 0x1,
  1076. .rsvd = 0xfffffffe,
  1077. },{ .name = "BNK1_EN_AMP_B", .addr = A_BNK1_EN_AMP_B,
  1078. .rsvd = 0xfffffffc,
  1079. },{ .name = "BNK1_SPARE_BIAS", .addr = A_BNK1_SPARE_BIAS,
  1080. .rsvd = 0xfffffff0,
  1081. },{ .name = "BNK1_DRIVER_BIAS", .addr = A_BNK1_DRIVER_BIAS,
  1082. .rsvd = 0xffff8000,
  1083. },{ .name = "BNK1_VMODE", .addr = A_BNK1_VMODE,
  1084. .rsvd = 0xfffffffe,
  1085. .ro = 0x1,
  1086. },{ .name = "BNK1_SEL_AUX_IO_RX", .addr = A_BNK1_SEL_AUX_IO_RX,
  1087. .rsvd = 0xfc000000,
  1088. },{ .name = "BNK1_EN_TX_HS_MODE", .addr = A_BNK1_EN_TX_HS_MODE,
  1089. .rsvd = 0xfc000000,
  1090. },{ .name = "SD0_CLK_CTRL", .addr = A_SD0_CLK_CTRL,
  1091. .rsvd = 0xfffffff8,
  1092. },{ .name = "SD0_CTRL_REG", .addr = A_SD0_CTRL_REG,
  1093. .rsvd = 0xfffffffe,
  1094. .pre_write = sd0_ctrl_reg_prew,
  1095. },{ .name = "SD0_CONFIG_REG1", .addr = A_SD0_CONFIG_REG1,
  1096. .reset = 0x3250,
  1097. .rsvd = 0xffff8000,
  1098. },{ .name = "SD0_CONFIG_REG2", .addr = A_SD0_CONFIG_REG2,
  1099. .reset = 0xffc,
  1100. .rsvd = 0xffffc000,
  1101. },{ .name = "SD0_CONFIG_REG3", .addr = A_SD0_CONFIG_REG3,
  1102. .reset = 0x407,
  1103. .rsvd = 0xfffff800,
  1104. },{ .name = "SD0_INITPRESET", .addr = A_SD0_INITPRESET,
  1105. .reset = 0x100,
  1106. .rsvd = 0xffffe000,
  1107. },{ .name = "SD0_DSPPRESET", .addr = A_SD0_DSPPRESET,
  1108. .reset = 0x4,
  1109. .rsvd = 0xffffe000,
  1110. },{ .name = "SD0_HSPDPRESET", .addr = A_SD0_HSPDPRESET,
  1111. .reset = 0x2,
  1112. .rsvd = 0xffffe000,
  1113. },{ .name = "SD0_SDR12PRESET", .addr = A_SD0_SDR12PRESET,
  1114. .reset = 0x4,
  1115. .rsvd = 0xffffe000,
  1116. },{ .name = "SD0_SDR25PRESET", .addr = A_SD0_SDR25PRESET,
  1117. .reset = 0x2,
  1118. .rsvd = 0xffffe000,
  1119. },{ .name = "SD0_SDR50PRSET", .addr = A_SD0_SDR50PRSET,
  1120. .reset = 0x1,
  1121. .rsvd = 0xffffe000,
  1122. },{ .name = "SD0_SDR104PRST", .addr = A_SD0_SDR104PRST,
  1123. .rsvd = 0xffffe000,
  1124. },{ .name = "SD0_DDR50PRESET", .addr = A_SD0_DDR50PRESET,
  1125. .reset = 0x2,
  1126. .rsvd = 0xffffe000,
  1127. },{ .name = "SD0_MAXCUR1P8", .addr = A_SD0_MAXCUR1P8,
  1128. .rsvd = 0xffffff00,
  1129. },{ .name = "SD0_MAXCUR3P0", .addr = A_SD0_MAXCUR3P0,
  1130. .rsvd = 0xffffff00,
  1131. },{ .name = "SD0_MAXCUR3P3", .addr = A_SD0_MAXCUR3P3,
  1132. .rsvd = 0xffffff00,
  1133. },{ .name = "SD0_DLL_CTRL", .addr = A_SD0_DLL_CTRL,
  1134. .reset = 0x1,
  1135. .rsvd = 0xfffffc00,
  1136. .ro = 0x19,
  1137. },{ .name = "SD0_CDN_CTRL", .addr = A_SD0_CDN_CTRL,
  1138. .rsvd = 0xfffffffe,
  1139. },{ .name = "SD0_DLL_TEST", .addr = A_SD0_DLL_TEST,
  1140. .rsvd = 0xff000000,
  1141. },{ .name = "SD0_RX_TUNING_SEL", .addr = A_SD0_RX_TUNING_SEL,
  1142. .rsvd = 0xfffffe00,
  1143. .ro = 0x1ff,
  1144. },{ .name = "SD0_DLL_DIV_MAP0", .addr = A_SD0_DLL_DIV_MAP0,
  1145. .reset = 0x50505050,
  1146. },{ .name = "SD0_DLL_DIV_MAP1", .addr = A_SD0_DLL_DIV_MAP1,
  1147. .reset = 0x50505050,
  1148. },{ .name = "SD0_IOU_COHERENT_CTRL", .addr = A_SD0_IOU_COHERENT_CTRL,
  1149. .rsvd = 0xfffffff0,
  1150. },{ .name = "SD0_IOU_INTERCONNECT_ROUTE",
  1151. .addr = A_SD0_IOU_INTERCONNECT_ROUTE,
  1152. .rsvd = 0xfffffffe,
  1153. },{ .name = "SD0_IOU_RAM", .addr = A_SD0_IOU_RAM,
  1154. .reset = 0x24,
  1155. .rsvd = 0xffffff80,
  1156. },{ .name = "SD0_IOU_INTERCONNECT_QOS",
  1157. .addr = A_SD0_IOU_INTERCONNECT_QOS,
  1158. .rsvd = 0xfffffff0,
  1159. },{ .name = "SD1_CLK_CTRL", .addr = A_SD1_CLK_CTRL,
  1160. .rsvd = 0xfffffffc,
  1161. },{ .name = "SD1_CTRL_REG", .addr = A_SD1_CTRL_REG,
  1162. .rsvd = 0xfffffffe,
  1163. .pre_write = sd1_ctrl_reg_prew,
  1164. },{ .name = "SD1_CONFIG_REG1", .addr = A_SD1_CONFIG_REG1,
  1165. .reset = 0x3250,
  1166. .rsvd = 0xffff8000,
  1167. },{ .name = "SD1_CONFIG_REG2", .addr = A_SD1_CONFIG_REG2,
  1168. .reset = 0xffc,
  1169. .rsvd = 0xffffc000,
  1170. },{ .name = "SD1_CONFIG_REG3", .addr = A_SD1_CONFIG_REG3,
  1171. .reset = 0x407,
  1172. .rsvd = 0xfffff800,
  1173. },{ .name = "SD1_INITPRESET", .addr = A_SD1_INITPRESET,
  1174. .reset = 0x100,
  1175. .rsvd = 0xffffe000,
  1176. },{ .name = "SD1_DSPPRESET", .addr = A_SD1_DSPPRESET,
  1177. .reset = 0x4,
  1178. .rsvd = 0xffffe000,
  1179. },{ .name = "SD1_HSPDPRESET", .addr = A_SD1_HSPDPRESET,
  1180. .reset = 0x2,
  1181. .rsvd = 0xffffe000,
  1182. },{ .name = "SD1_SDR12PRESET", .addr = A_SD1_SDR12PRESET,
  1183. .reset = 0x4,
  1184. .rsvd = 0xffffe000,
  1185. },{ .name = "SD1_SDR25PRESET", .addr = A_SD1_SDR25PRESET,
  1186. .reset = 0x2,
  1187. .rsvd = 0xffffe000,
  1188. },{ .name = "SD1_SDR50PRSET", .addr = A_SD1_SDR50PRSET,
  1189. .reset = 0x1,
  1190. .rsvd = 0xffffe000,
  1191. },{ .name = "SD1_SDR104PRST", .addr = A_SD1_SDR104PRST,
  1192. .rsvd = 0xffffe000,
  1193. },{ .name = "SD1_DDR50PRESET", .addr = A_SD1_DDR50PRESET,
  1194. .reset = 0x2,
  1195. .rsvd = 0xffffe000,
  1196. },{ .name = "SD1_MAXCUR1P8", .addr = A_SD1_MAXCUR1P8,
  1197. .rsvd = 0xffffff00,
  1198. },{ .name = "SD1_MAXCUR3P0", .addr = A_SD1_MAXCUR3P0,
  1199. .rsvd = 0xffffff00,
  1200. },{ .name = "SD1_MAXCUR3P3", .addr = A_SD1_MAXCUR3P3,
  1201. .rsvd = 0xffffff00,
  1202. },{ .name = "SD1_DLL_CTRL", .addr = A_SD1_DLL_CTRL,
  1203. .reset = 0x1,
  1204. .rsvd = 0xfffffc00,
  1205. .ro = 0x19,
  1206. },{ .name = "SD1_CDN_CTRL", .addr = A_SD1_CDN_CTRL,
  1207. .rsvd = 0xfffffffe,
  1208. },{ .name = "SD1_DLL_TEST", .addr = A_SD1_DLL_TEST,
  1209. .rsvd = 0xff000000,
  1210. },{ .name = "SD1_RX_TUNING_SEL", .addr = A_SD1_RX_TUNING_SEL,
  1211. .rsvd = 0xfffffe00,
  1212. .ro = 0x1ff,
  1213. },{ .name = "SD1_DLL_DIV_MAP0", .addr = A_SD1_DLL_DIV_MAP0,
  1214. .reset = 0x50505050,
  1215. },{ .name = "SD1_DLL_DIV_MAP1", .addr = A_SD1_DLL_DIV_MAP1,
  1216. .reset = 0x50505050,
  1217. },{ .name = "SD1_IOU_COHERENT_CTRL", .addr = A_SD1_IOU_COHERENT_CTRL,
  1218. .rsvd = 0xfffffff0,
  1219. },{ .name = "SD1_IOU_INTERCONNECT_ROUTE",
  1220. .addr = A_SD1_IOU_INTERCONNECT_ROUTE,
  1221. .rsvd = 0xfffffffe,
  1222. },{ .name = "SD1_IOU_RAM", .addr = A_SD1_IOU_RAM,
  1223. .reset = 0x24,
  1224. .rsvd = 0xffffff80,
  1225. },{ .name = "SD1_IOU_INTERCONNECT_QOS",
  1226. .addr = A_SD1_IOU_INTERCONNECT_QOS,
  1227. .rsvd = 0xfffffff0,
  1228. },{ .name = "OSPI_QSPI_IOU_AXI_MUX_SEL",
  1229. .addr = A_OSPI_QSPI_IOU_AXI_MUX_SEL,
  1230. .reset = 0x1,
  1231. .rsvd = 0xfffffffc,
  1232. .pre_write = ospi_qspi_iou_axi_mux_sel_prew,
  1233. },{ .name = "QSPI_IOU_COHERENT_CTRL", .addr = A_QSPI_IOU_COHERENT_CTRL,
  1234. .rsvd = 0xfffffff0,
  1235. },{ .name = "QSPI_IOU_INTERCONNECT_ROUTE",
  1236. .addr = A_QSPI_IOU_INTERCONNECT_ROUTE,
  1237. .rsvd = 0xfffffffe,
  1238. },{ .name = "QSPI_IOU_RAM", .addr = A_QSPI_IOU_RAM,
  1239. .reset = 0x1224,
  1240. .rsvd = 0xffffc000,
  1241. },{ .name = "QSPI_IOU_INTERCONNECT_QOS",
  1242. .addr = A_QSPI_IOU_INTERCONNECT_QOS,
  1243. .rsvd = 0xfffffff0,
  1244. },{ .name = "OSPI_IOU_COHERENT_CTRL", .addr = A_OSPI_IOU_COHERENT_CTRL,
  1245. .rsvd = 0xfffffff0,
  1246. },{ .name = "OSPI_IOU_INTERCONNECT_ROUTE",
  1247. .addr = A_OSPI_IOU_INTERCONNECT_ROUTE,
  1248. .rsvd = 0xfffffffe,
  1249. },{ .name = "OSPI_IOU_RAM", .addr = A_OSPI_IOU_RAM,
  1250. .reset = 0xa,
  1251. .rsvd = 0xffffffc0,
  1252. },{ .name = "OSPI_IOU_INTERCONNECT_QOS",
  1253. .addr = A_OSPI_IOU_INTERCONNECT_QOS,
  1254. .rsvd = 0xfffffff0,
  1255. },{ .name = "OSPI_REFCLK_DLY_CTRL", .addr = A_OSPI_REFCLK_DLY_CTRL,
  1256. .reset = 0x13,
  1257. .rsvd = 0xffffffe0,
  1258. },{ .name = "CUR_PWR_ST", .addr = A_CUR_PWR_ST,
  1259. .rsvd = 0xfffffffc,
  1260. .ro = 0x3,
  1261. },{ .name = "CONNECT_ST", .addr = A_CONNECT_ST,
  1262. .rsvd = 0xfffffffe,
  1263. .ro = 0x1,
  1264. },{ .name = "PW_STATE_REQ", .addr = A_PW_STATE_REQ,
  1265. .rsvd = 0xfffffffc,
  1266. },{ .name = "HOST_U2_PORT_DISABLE", .addr = A_HOST_U2_PORT_DISABLE,
  1267. .rsvd = 0xfffffffe,
  1268. },{ .name = "DBG_U2PMU", .addr = A_DBG_U2PMU,
  1269. .ro = 0xffffffff,
  1270. },{ .name = "DBG_U2PMU_EXT1", .addr = A_DBG_U2PMU_EXT1,
  1271. .ro = 0xffffffff,
  1272. },{ .name = "DBG_U2PMU_EXT2", .addr = A_DBG_U2PMU_EXT2,
  1273. .rsvd = 0xfffffff0,
  1274. .ro = 0xf,
  1275. },{ .name = "PME_GEN_U2PMU", .addr = A_PME_GEN_U2PMU,
  1276. .rsvd = 0xfffffffe,
  1277. .ro = 0x1,
  1278. },{ .name = "PWR_CONFIG_USB2", .addr = A_PWR_CONFIG_USB2,
  1279. .rsvd = 0xc0000000,
  1280. },{ .name = "PHY_HUB", .addr = A_PHY_HUB,
  1281. .rsvd = 0xfffffffc,
  1282. .ro = 0x2,
  1283. },{ .name = "CTRL", .addr = A_CTRL,
  1284. },{ .name = "ISR", .addr = A_ISR,
  1285. .w1c = 0x1,
  1286. .post_write = isr_postw,
  1287. },{ .name = "IMR", .addr = A_IMR,
  1288. .reset = 0x1,
  1289. .ro = 0x1,
  1290. },{ .name = "IER", .addr = A_IER,
  1291. .pre_write = ier_prew,
  1292. },{ .name = "IDR", .addr = A_IDR,
  1293. .pre_write = idr_prew,
  1294. },{ .name = "ITR", .addr = A_ITR,
  1295. .pre_write = itr_prew,
  1296. },{ .name = "PARITY_ISR", .addr = A_PARITY_ISR,
  1297. .w1c = 0x1fff,
  1298. .post_write = parity_isr_postw,
  1299. },{ .name = "PARITY_IMR", .addr = A_PARITY_IMR,
  1300. .reset = 0x1fff,
  1301. .ro = 0x1fff,
  1302. },{ .name = "PARITY_IER", .addr = A_PARITY_IER,
  1303. .pre_write = parity_ier_prew,
  1304. },{ .name = "PARITY_IDR", .addr = A_PARITY_IDR,
  1305. .pre_write = parity_idr_prew,
  1306. },{ .name = "PARITY_ITR", .addr = A_PARITY_ITR,
  1307. .pre_write = parity_itr_prew,
  1308. },{ .name = "WPROT0", .addr = A_WPROT0,
  1309. .reset = 0x1,
  1310. }
  1311. };
  1312. static void xlnx_versal_pmc_iou_slcr_reset_init(Object *obj, ResetType type)
  1313. {
  1314. XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(obj);
  1315. unsigned int i;
  1316. for (i = 0; i < ARRAY_SIZE(s->regs_info); ++i) {
  1317. register_reset(&s->regs_info[i]);
  1318. }
  1319. }
  1320. static void xlnx_versal_pmc_iou_slcr_reset_hold(Object *obj, ResetType type)
  1321. {
  1322. XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(obj);
  1323. parity_imr_update_irq(s);
  1324. imr_update_irq(s);
  1325. /*
  1326. * Setup OSPI_QSPI mux
  1327. * By default axi slave interface is enabled for ospi-dma
  1328. */
  1329. qemu_set_irq(s->ospi_mux_sel, 0);
  1330. qemu_set_irq(s->qspi_ospi_mux_sel, 1);
  1331. }
  1332. static const MemoryRegionOps pmc_iou_slcr_ops = {
  1333. .read = register_read_memory,
  1334. .write = register_write_memory,
  1335. .endianness = DEVICE_LITTLE_ENDIAN,
  1336. .valid = {
  1337. .min_access_size = 4,
  1338. .max_access_size = 4,
  1339. },
  1340. };
  1341. static void xlnx_versal_pmc_iou_slcr_realize(DeviceState *dev, Error **errp)
  1342. {
  1343. XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(dev);
  1344. qdev_init_gpio_out_named(dev, s->sd_emmc_sel, "sd-emmc-sel", 2);
  1345. qdev_init_gpio_out_named(dev, &s->qspi_ospi_mux_sel,
  1346. "qspi-ospi-mux-sel", 1);
  1347. qdev_init_gpio_out_named(dev, &s->ospi_mux_sel, "ospi-mux-sel", 1);
  1348. }
  1349. static void xlnx_versal_pmc_iou_slcr_init(Object *obj)
  1350. {
  1351. XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(obj);
  1352. SysBusDevice *sbd = SYS_BUS_DEVICE(obj);
  1353. RegisterInfoArray *reg_array;
  1354. memory_region_init(&s->iomem, obj, TYPE_XILINX_VERSAL_PMC_IOU_SLCR,
  1355. XILINX_VERSAL_PMC_IOU_SLCR_R_MAX * 4);
  1356. reg_array =
  1357. register_init_block32(DEVICE(obj), pmc_iou_slcr_regs_info,
  1358. ARRAY_SIZE(pmc_iou_slcr_regs_info),
  1359. s->regs_info, s->regs,
  1360. &pmc_iou_slcr_ops,
  1361. XILINX_VERSAL_PMC_IOU_SLCR_ERR_DEBUG,
  1362. XILINX_VERSAL_PMC_IOU_SLCR_R_MAX * 4);
  1363. memory_region_add_subregion(&s->iomem,
  1364. 0x0,
  1365. &reg_array->mem);
  1366. sysbus_init_mmio(sbd, &s->iomem);
  1367. sysbus_init_irq(sbd, &s->irq_parity_imr);
  1368. sysbus_init_irq(sbd, &s->irq_imr);
  1369. }
  1370. static const VMStateDescription vmstate_pmc_iou_slcr = {
  1371. .name = TYPE_XILINX_VERSAL_PMC_IOU_SLCR,
  1372. .version_id = 1,
  1373. .minimum_version_id = 1,
  1374. .fields = (const VMStateField[]) {
  1375. VMSTATE_UINT32_ARRAY(regs, XlnxVersalPmcIouSlcr,
  1376. XILINX_VERSAL_PMC_IOU_SLCR_R_MAX),
  1377. VMSTATE_END_OF_LIST(),
  1378. }
  1379. };
  1380. static void xlnx_versal_pmc_iou_slcr_class_init(ObjectClass *klass, void *data)
  1381. {
  1382. DeviceClass *dc = DEVICE_CLASS(klass);
  1383. ResettableClass *rc = RESETTABLE_CLASS(klass);
  1384. dc->realize = xlnx_versal_pmc_iou_slcr_realize;
  1385. dc->vmsd = &vmstate_pmc_iou_slcr;
  1386. rc->phases.enter = xlnx_versal_pmc_iou_slcr_reset_init;
  1387. rc->phases.hold = xlnx_versal_pmc_iou_slcr_reset_hold;
  1388. }
  1389. static const TypeInfo xlnx_versal_pmc_iou_slcr_info = {
  1390. .name = TYPE_XILINX_VERSAL_PMC_IOU_SLCR,
  1391. .parent = TYPE_SYS_BUS_DEVICE,
  1392. .instance_size = sizeof(XlnxVersalPmcIouSlcr),
  1393. .class_init = xlnx_versal_pmc_iou_slcr_class_init,
  1394. .instance_init = xlnx_versal_pmc_iou_slcr_init,
  1395. };
  1396. static void xlnx_versal_pmc_iou_slcr_register_types(void)
  1397. {
  1398. type_register_static(&xlnx_versal_pmc_iou_slcr_info);
  1399. }
  1400. type_init(xlnx_versal_pmc_iou_slcr_register_types)