psu_init_gpl.c 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * (c) Copyright 2015 Xilinx, Inc. All rights reserved.
  4. */
  5. #include <asm/arch/psu_init_gpl.h>
  6. #include <xil_io.h>
  7. static unsigned long psu_pll_init_data(void)
  8. {
  9. psu_mask_write(0xFF5E0034, 0xFE7FEDEFU, 0x7E4B0C62U);
  10. psu_mask_write(0xFF5E0030, 0x00717F00U, 0x00014800U);
  11. psu_mask_write(0xFF5E0030, 0x00000008U, 0x00000008U);
  12. psu_mask_write(0xFF5E0030, 0x00000001U, 0x00000001U);
  13. psu_mask_write(0xFF5E0030, 0x00000001U, 0x00000000U);
  14. mask_poll(0xFF5E0040, 0x00000002U);
  15. psu_mask_write(0xFF5E0030, 0x00000008U, 0x00000000U);
  16. psu_mask_write(0xFF5E0048, 0x00003F00U, 0x00000300U);
  17. psu_mask_write(0xFF5E0038, 0x8000FFFFU, 0x00000000U);
  18. psu_mask_write(0xFF5E0024, 0xFE7FEDEFU, 0x7E672C6CU);
  19. psu_mask_write(0xFF5E0020, 0x00717F00U, 0x00002D00U);
  20. psu_mask_write(0xFF5E0020, 0x00000008U, 0x00000008U);
  21. psu_mask_write(0xFF5E0020, 0x00000001U, 0x00000001U);
  22. psu_mask_write(0xFF5E0020, 0x00000001U, 0x00000000U);
  23. mask_poll(0xFF5E0040, 0x00000001U);
  24. psu_mask_write(0xFF5E0020, 0x00000008U, 0x00000000U);
  25. psu_mask_write(0xFF5E0044, 0x00003F00U, 0x00000300U);
  26. psu_mask_write(0xFF5E0028, 0x8000FFFFU, 0x00000000U);
  27. psu_mask_write(0xFD1A0024, 0xFE7FEDEFU, 0x7E4B0C62U);
  28. psu_mask_write(0xFD1A0020, 0x00717F00U, 0x00014800U);
  29. psu_mask_write(0xFD1A0020, 0x00000008U, 0x00000008U);
  30. psu_mask_write(0xFD1A0020, 0x00000001U, 0x00000001U);
  31. psu_mask_write(0xFD1A0020, 0x00000001U, 0x00000000U);
  32. mask_poll(0xFD1A0044, 0x00000001U);
  33. psu_mask_write(0xFD1A0020, 0x00000008U, 0x00000000U);
  34. psu_mask_write(0xFD1A0048, 0x00003F00U, 0x00000300U);
  35. psu_mask_write(0xFD1A0028, 0x8000FFFFU, 0x00000000U);
  36. psu_mask_write(0xFD1A0030, 0xFE7FEDEFU, 0x7E4B0C62U);
  37. psu_mask_write(0xFD1A002C, 0x00717F00U, 0x00014000U);
  38. psu_mask_write(0xFD1A002C, 0x00000008U, 0x00000008U);
  39. psu_mask_write(0xFD1A002C, 0x00000001U, 0x00000001U);
  40. psu_mask_write(0xFD1A002C, 0x00000001U, 0x00000000U);
  41. mask_poll(0xFD1A0044, 0x00000002U);
  42. psu_mask_write(0xFD1A002C, 0x00000008U, 0x00000000U);
  43. psu_mask_write(0xFD1A004C, 0x00003F00U, 0x00000300U);
  44. psu_mask_write(0xFD1A0034, 0x8000FFFFU, 0x00000000U);
  45. psu_mask_write(0xFD1A003C, 0xFE7FEDEFU, 0x7E514C62U);
  46. psu_mask_write(0xFD1A0038, 0x00717F00U, 0x00013900U);
  47. psu_mask_write(0xFD1A0038, 0x00000008U, 0x00000008U);
  48. psu_mask_write(0xFD1A0038, 0x00000001U, 0x00000001U);
  49. psu_mask_write(0xFD1A0038, 0x00000001U, 0x00000000U);
  50. mask_poll(0xFD1A0044, 0x00000004U);
  51. psu_mask_write(0xFD1A0038, 0x00000008U, 0x00000000U);
  52. psu_mask_write(0xFD1A0050, 0x00003F00U, 0x00000300U);
  53. psu_mask_write(0xFD1A0040, 0x8000FFFFU, 0x8000820CU);
  54. return 1;
  55. }
  56. static unsigned long psu_clock_init_data(void)
  57. {
  58. psu_mask_write(0xFF5E005C, 0x063F3F07U, 0x06010C00U);
  59. psu_mask_write(0xFF5E0060, 0x023F3F07U, 0x02010600U);
  60. psu_mask_write(0xFF5E004C, 0x023F3F07U, 0x020F0500U);
  61. psu_mask_write(0xFF5E0068, 0x013F3F07U, 0x01010C00U);
  62. psu_mask_write(0xFF5E0070, 0x013F3F07U, 0x01010602U);
  63. psu_mask_write(0xFF18030C, 0x00020000U, 0x00000000U);
  64. psu_mask_write(0xFF5E0074, 0x013F3F07U, 0x01010F00U);
  65. psu_mask_write(0xFF5E0078, 0x013F3F07U, 0x01010F00U);
  66. psu_mask_write(0xFF5E0120, 0x013F3F07U, 0x01010F00U);
  67. psu_mask_write(0xFF5E0124, 0x013F3F07U, 0x01010F00U);
  68. psu_mask_write(0xFF5E0088, 0x013F3F07U, 0x01010F00U);
  69. psu_mask_write(0xFF5E0090, 0x01003F07U, 0x01000302U);
  70. psu_mask_write(0xFF5E009C, 0x01003F07U, 0x01000602U);
  71. psu_mask_write(0xFF5E00A4, 0x01003F07U, 0x01000602U);
  72. psu_mask_write(0xFF5E00A8, 0x01003F07U, 0x01000302U);
  73. psu_mask_write(0xFF5E00AC, 0x01003F07U, 0x01000F02U);
  74. psu_mask_write(0xFF5E00B0, 0x01003F07U, 0x01000602U);
  75. psu_mask_write(0xFF5E00B8, 0x01003F07U, 0x01000302U);
  76. psu_mask_write(0xFF5E00C0, 0x013F3F07U, 0x01010F00U);
  77. psu_mask_write(0xFF5E00C4, 0x013F3F07U, 0x01040F00U);
  78. psu_mask_write(0xFF5E00C8, 0x013F3F07U, 0x01010402U);
  79. psu_mask_write(0xFF5E00CC, 0x013F3F07U, 0x01010302U);
  80. psu_mask_write(0xFF5E0108, 0x013F3F07U, 0x01011D02U);
  81. psu_mask_write(0xFF5E0104, 0x00000007U, 0x00000000U);
  82. psu_mask_write(0xFF5E0128, 0x01003F07U, 0x01000F00U);
  83. psu_mask_write(0xFD1A00A0, 0x01003F07U, 0x01000200U);
  84. psu_mask_write(0xFD1A0070, 0x013F3F07U, 0x01010303U);
  85. psu_mask_write(0xFD1A0074, 0x013F3F07U, 0x01012700U);
  86. psu_mask_write(0xFD1A007C, 0x013F3F07U, 0x01011103U);
  87. psu_mask_write(0xFD1A0060, 0x03003F07U, 0x03000100U);
  88. psu_mask_write(0xFD1A0064, 0x01003F07U, 0x01000200U);
  89. psu_mask_write(0xFD1A0068, 0x01003F07U, 0x01000200U);
  90. psu_mask_write(0xFD1A0080, 0x00003F07U, 0x00000200U);
  91. psu_mask_write(0xFD1A0084, 0x07003F07U, 0x07000100U);
  92. psu_mask_write(0xFD1A00B8, 0x01003F07U, 0x01000200U);
  93. psu_mask_write(0xFD1A00BC, 0x01003F07U, 0x01000200U);
  94. psu_mask_write(0xFD1A00C0, 0x01003F07U, 0x01000202U);
  95. psu_mask_write(0xFD1A00C4, 0x01003F07U, 0x01000502U);
  96. psu_mask_write(0xFD1A00F8, 0x00003F07U, 0x00000200U);
  97. psu_mask_write(0xFF180380, 0x000000FFU, 0x00000000U);
  98. psu_mask_write(0xFD610100, 0x00000001U, 0x00000000U);
  99. psu_mask_write(0xFF180300, 0x00000001U, 0x00000000U);
  100. psu_mask_write(0xFF410050, 0x00000001U, 0x00000000U);
  101. return 1;
  102. }
  103. static unsigned long psu_ddr_init_data(void)
  104. {
  105. psu_mask_write(0xFD1A0108, 0x00000008U, 0x00000008U);
  106. psu_mask_write(0xFD070000, 0xE30FBE3DU, 0x41040010U);
  107. psu_mask_write(0xFD070010, 0x8000F03FU, 0x00000030U);
  108. psu_mask_write(0xFD070020, 0x000003F3U, 0x00000300U);
  109. psu_mask_write(0xFD070024, 0xFFFFFFFFU, 0x00800000U);
  110. psu_mask_write(0xFD070030, 0x0000007FU, 0x00000000U);
  111. psu_mask_write(0xFD070034, 0x00FFFF1FU, 0x00408410U);
  112. psu_mask_write(0xFD070050, 0x00F1F1F4U, 0x00210000U);
  113. psu_mask_write(0xFD070060, 0x00000073U, 0x00000001U);
  114. psu_mask_write(0xFD070064, 0x0FFF83FFU, 0x0082808BU);
  115. psu_mask_write(0xFD070070, 0x00000017U, 0x00000010U);
  116. psu_mask_write(0xFD070074, 0x00000003U, 0x00000000U);
  117. psu_mask_write(0xFD0700C4, 0x3F000391U, 0x10000200U);
  118. psu_mask_write(0xFD0700C8, 0x01FF1F3FU, 0x0040051FU);
  119. psu_mask_write(0xFD0700D0, 0xC3FF0FFFU, 0x00020106U);
  120. psu_mask_write(0xFD0700D4, 0x01FF7F0FU, 0x00020000U);
  121. psu_mask_write(0xFD0700D8, 0x0000FF0FU, 0x00002305U);
  122. psu_mask_write(0xFD0700DC, 0xFFFFFFFFU, 0x09300301U);
  123. psu_mask_write(0xFD0700E0, 0xFFFFFFFFU, 0x00200200U);
  124. psu_mask_write(0xFD0700E4, 0x00FF03FFU, 0x00210004U);
  125. psu_mask_write(0xFD0700E8, 0xFFFFFFFFU, 0x000006C0U);
  126. psu_mask_write(0xFD0700EC, 0xFFFF0000U, 0x08190000U);
  127. psu_mask_write(0xFD0700F0, 0x0000003FU, 0x00000010U);
  128. psu_mask_write(0xFD0700F4, 0x00000FFFU, 0x0000066FU);
  129. psu_mask_write(0xFD070100, 0x7F3F7F3FU, 0x11112412U);
  130. psu_mask_write(0xFD070104, 0x001F1F7FU, 0x0004041AU);
  131. psu_mask_write(0xFD070108, 0x3F3F3F3FU, 0x0708060EU);
  132. psu_mask_write(0xFD07010C, 0x3FF3F3FFU, 0x0050400CU);
  133. psu_mask_write(0xFD070110, 0x1F0F0F1FU, 0x08030309U);
  134. psu_mask_write(0xFD070114, 0x0F0F3F1FU, 0x06060403U);
  135. psu_mask_write(0xFD070118, 0x0F0F000FU, 0x01010004U);
  136. psu_mask_write(0xFD07011C, 0x00000F0FU, 0x00000606U);
  137. psu_mask_write(0xFD070120, 0x7F7F7F7FU, 0x04040D06U);
  138. psu_mask_write(0xFD070124, 0x40070F3FU, 0x0002020BU);
  139. psu_mask_write(0xFD07012C, 0x7F1F031FU, 0x6F07010EU);
  140. psu_mask_write(0xFD070130, 0x00030F1FU, 0x00020608U);
  141. psu_mask_write(0xFD070180, 0xF7FF03FFU, 0x81000040U);
  142. psu_mask_write(0xFD070184, 0x3FFFFFFFU, 0x02019707U);
  143. psu_mask_write(0xFD070190, 0x1FBFBF3FU, 0x048B820BU);
  144. psu_mask_write(0xFD070194, 0xF31F0F0FU, 0x00030304U);
  145. psu_mask_write(0xFD070198, 0x0FF1F1F1U, 0x07000101U);
  146. psu_mask_write(0xFD07019C, 0x000000F1U, 0x00000021U);
  147. psu_mask_write(0xFD0701A4, 0x00FF00FFU, 0x004100E2U);
  148. psu_mask_write(0xFD0701B0, 0x00000007U, 0x00000000U);
  149. psu_mask_write(0xFD0701B4, 0x00003F3FU, 0x00000906U);
  150. psu_mask_write(0xFD0701C0, 0x00000007U, 0x00000001U);
  151. psu_mask_write(0xFD070200, 0x0000001FU, 0x0000001FU);
  152. psu_mask_write(0xFD070204, 0x001F1F1FU, 0x001F0A0AU);
  153. psu_mask_write(0xFD070208, 0x0F0F0F0FU, 0x00000000U);
  154. psu_mask_write(0xFD07020C, 0x0F0F0F0FU, 0x00000000U);
  155. psu_mask_write(0xFD070210, 0x00000F0FU, 0x00000F0FU);
  156. psu_mask_write(0xFD070214, 0x0F0F0F0FU, 0x080F0808U);
  157. psu_mask_write(0xFD070218, 0x8F0F0F0FU, 0x0F080808U);
  158. psu_mask_write(0xFD07021C, 0x00000F0FU, 0x00000F0FU);
  159. psu_mask_write(0xFD070220, 0x00001F1FU, 0x00000808U);
  160. psu_mask_write(0xFD070224, 0x0F0F0F0FU, 0x08080808U);
  161. psu_mask_write(0xFD070228, 0x0F0F0F0FU, 0x08080808U);
  162. psu_mask_write(0xFD07022C, 0x0000000FU, 0x00000008U);
  163. psu_mask_write(0xFD070240, 0x0F1F0F7CU, 0x06000600U);
  164. psu_mask_write(0xFD070244, 0x00003333U, 0x00000001U);
  165. psu_mask_write(0xFD070250, 0x7FFF3F07U, 0x01002001U);
  166. psu_mask_write(0xFD070264, 0xFF00FFFFU, 0x08000040U);
  167. psu_mask_write(0xFD07026C, 0xFF00FFFFU, 0x08000040U);
  168. psu_mask_write(0xFD070294, 0x00000001U, 0x00000001U);
  169. psu_mask_write(0xFD070300, 0x00000011U, 0x00000000U);
  170. psu_mask_write(0xFD07030C, 0x80000033U, 0x00000000U);
  171. psu_mask_write(0xFD070320, 0x00000001U, 0x00000000U);
  172. psu_mask_write(0xFD070400, 0x00000111U, 0x00000001U);
  173. psu_mask_write(0xFD070404, 0x000073FFU, 0x0000200FU);
  174. psu_mask_write(0xFD070408, 0x000073FFU, 0x0000600FU);
  175. psu_mask_write(0xFD070490, 0x00000001U, 0x00000001U);
  176. psu_mask_write(0xFD070494, 0x0033000FU, 0x0020000BU);
  177. psu_mask_write(0xFD070498, 0x07FF07FFU, 0x00000000U);
  178. psu_mask_write(0xFD0704B4, 0x000073FFU, 0x0000200FU);
  179. psu_mask_write(0xFD0704B8, 0x000073FFU, 0x0000600FU);
  180. psu_mask_write(0xFD070540, 0x00000001U, 0x00000001U);
  181. psu_mask_write(0xFD070544, 0x03330F0FU, 0x02000B03U);
  182. psu_mask_write(0xFD070548, 0x07FF07FFU, 0x00000000U);
  183. psu_mask_write(0xFD070564, 0x000073FFU, 0x0000200FU);
  184. psu_mask_write(0xFD070568, 0x000073FFU, 0x0000600FU);
  185. psu_mask_write(0xFD0705F0, 0x00000001U, 0x00000001U);
  186. psu_mask_write(0xFD0705F4, 0x03330F0FU, 0x02000B03U);
  187. psu_mask_write(0xFD0705F8, 0x07FF07FFU, 0x00000000U);
  188. psu_mask_write(0xFD070614, 0x000073FFU, 0x0000200FU);
  189. psu_mask_write(0xFD070618, 0x000073FFU, 0x0000600FU);
  190. psu_mask_write(0xFD0706A0, 0x00000001U, 0x00000001U);
  191. psu_mask_write(0xFD0706A4, 0x0033000FU, 0x00100003U);
  192. psu_mask_write(0xFD0706A8, 0x07FF07FFU, 0x0000004FU);
  193. psu_mask_write(0xFD0706AC, 0x0033000FU, 0x00100003U);
  194. psu_mask_write(0xFD0706B0, 0x000007FFU, 0x0000004FU);
  195. psu_mask_write(0xFD0706C4, 0x000073FFU, 0x0000600FU);
  196. psu_mask_write(0xFD0706C8, 0x000073FFU, 0x0000600FU);
  197. psu_mask_write(0xFD070750, 0x00000001U, 0x00000001U);
  198. psu_mask_write(0xFD070754, 0x0033000FU, 0x00100003U);
  199. psu_mask_write(0xFD070758, 0x07FF07FFU, 0x0000004FU);
  200. psu_mask_write(0xFD07075C, 0x0033000FU, 0x00100003U);
  201. psu_mask_write(0xFD070760, 0x000007FFU, 0x0000004FU);
  202. psu_mask_write(0xFD070774, 0x000073FFU, 0x0000200FU);
  203. psu_mask_write(0xFD070778, 0x000073FFU, 0x0000600FU);
  204. psu_mask_write(0xFD070800, 0x00000001U, 0x00000001U);
  205. psu_mask_write(0xFD070804, 0x0033000FU, 0x00100003U);
  206. psu_mask_write(0xFD070808, 0x07FF07FFU, 0x0000004FU);
  207. psu_mask_write(0xFD07080C, 0x0033000FU, 0x00100003U);
  208. psu_mask_write(0xFD070810, 0x000007FFU, 0x0000004FU);
  209. psu_mask_write(0xFD070F04, 0x000001FFU, 0x00000000U);
  210. psu_mask_write(0xFD070F08, 0x000000FFU, 0x00000000U);
  211. psu_mask_write(0xFD070F0C, 0x000001FFU, 0x00000010U);
  212. psu_mask_write(0xFD070F10, 0x000000FFU, 0x0000000FU);
  213. psu_mask_write(0xFD072190, 0x1FBFBF3FU, 0x07828002U);
  214. psu_mask_write(0xFD1A0108, 0x00000008U, 0x00000000U);
  215. psu_mask_write(0xFD080010, 0xFFFFFFFFU, 0x07001E00U);
  216. psu_mask_write(0xFD080018, 0xFFFFFFFFU, 0x00F10028U);
  217. psu_mask_write(0xFD08001C, 0xFFFFFFFFU, 0x55AA5480U);
  218. psu_mask_write(0xFD080024, 0xFFFFFFFFU, 0x010100F4U);
  219. psu_mask_write(0xFD080040, 0xFFFFFFFFU, 0x5E001810U);
  220. psu_mask_write(0xFD080044, 0xFFFFFFFFU, 0x008005F0U);
  221. psu_mask_write(0xFD080090, 0xFFFFFFFFU, 0x02A04121U);
  222. psu_mask_write(0xFD080100, 0xFFFFFFFFU, 0x0800040CU);
  223. psu_mask_write(0xFD080110, 0xFFFFFFFFU, 0x06240F09U);
  224. psu_mask_write(0xFD080114, 0xFFFFFFFFU, 0x28220708U);
  225. psu_mask_write(0xFD080118, 0xFFFFFFFFU, 0x00080200U);
  226. psu_mask_write(0xFD08011C, 0xFFFFFFFFU, 0x83000800U);
  227. psu_mask_write(0xFD080120, 0xFFFFFFFFU, 0x01162B08U);
  228. psu_mask_write(0xFD080124, 0xFFFFFFFFU, 0x00340F09U);
  229. psu_mask_write(0xFD080128, 0xFFFFFFFFU, 0x00000E0FU);
  230. psu_mask_write(0xFD080140, 0xFFFFFFFFU, 0x08400020U);
  231. psu_mask_write(0xFD080144, 0xFFFFFFFFU, 0x00000C80U);
  232. psu_mask_write(0xFD080150, 0xFFFFFFFFU, 0x00000000U);
  233. psu_mask_write(0xFD080154, 0xFFFFFFFFU, 0x00000200U);
  234. psu_mask_write(0xFD080180, 0xFFFFFFFFU, 0x00000830U);
  235. psu_mask_write(0xFD080184, 0xFFFFFFFFU, 0x00000301U);
  236. psu_mask_write(0xFD080188, 0xFFFFFFFFU, 0x00000020U);
  237. psu_mask_write(0xFD08018C, 0xFFFFFFFFU, 0x00000200U);
  238. psu_mask_write(0xFD080190, 0xFFFFFFFFU, 0x00000000U);
  239. psu_mask_write(0xFD080194, 0xFFFFFFFFU, 0x000006C0U);
  240. psu_mask_write(0xFD080198, 0xFFFFFFFFU, 0x00000819U);
  241. psu_mask_write(0xFD0801AC, 0xFFFFFFFFU, 0x00000000U);
  242. psu_mask_write(0xFD0801B0, 0xFFFFFFFFU, 0x0000004DU);
  243. psu_mask_write(0xFD0801B4, 0xFFFFFFFFU, 0x00000008U);
  244. psu_mask_write(0xFD0801B8, 0xFFFFFFFFU, 0x0000004DU);
  245. psu_mask_write(0xFD0801D8, 0xFFFFFFFFU, 0x00000000U);
  246. psu_mask_write(0xFD080200, 0xFFFFFFFFU, 0x800091C7U);
  247. psu_mask_write(0xFD080204, 0xFFFFFFFFU, 0x00010236U);
  248. psu_mask_write(0xFD080240, 0xFFFFFFFFU, 0x00141054U);
  249. psu_mask_write(0xFD080414, 0xFFFFFFFFU, 0x12341000U);
  250. psu_mask_write(0xFD0804F4, 0xFFFFFFFFU, 0x00000005U);
  251. psu_mask_write(0xFD080500, 0xFFFFFFFFU, 0x30000028U);
  252. psu_mask_write(0xFD080508, 0xFFFFFFFFU, 0x0A000000U);
  253. psu_mask_write(0xFD08050C, 0xFFFFFFFFU, 0x00000009U);
  254. psu_mask_write(0xFD080510, 0xFFFFFFFFU, 0x0A000000U);
  255. psu_mask_write(0xFD080520, 0xFFFFFFFFU, 0x0300B0B0U);
  256. psu_mask_write(0xFD080528, 0xFFFFFFFFU, 0xF9032019U);
  257. psu_mask_write(0xFD08052C, 0xFFFFFFFFU, 0x07F001E3U);
  258. psu_mask_write(0xFD080544, 0xFFFFFFFFU, 0x00000000U);
  259. psu_mask_write(0xFD080548, 0xFFFFFFFFU, 0x00000000U);
  260. psu_mask_write(0xFD080558, 0xFFFFFFFFU, 0x00000000U);
  261. psu_mask_write(0xFD08055C, 0xFFFFFFFFU, 0x00000000U);
  262. psu_mask_write(0xFD080560, 0xFFFFFFFFU, 0x00000000U);
  263. psu_mask_write(0xFD080564, 0xFFFFFFFFU, 0x00000000U);
  264. psu_mask_write(0xFD080680, 0xFFFFFFFFU, 0x008A2A58U);
  265. psu_mask_write(0xFD080684, 0xFFFFFFFFU, 0x000077DDU);
  266. psu_mask_write(0xFD080694, 0xFFFFFFFFU, 0x01E10210U);
  267. psu_mask_write(0xFD080698, 0xFFFFFFFFU, 0x01E10000U);
  268. psu_mask_write(0xFD0806A4, 0xFFFFFFFFU, 0x00087BDBU);
  269. psu_mask_write(0xFD080700, 0xFFFFFFFFU, 0x40800604U);
  270. psu_mask_write(0xFD080710, 0xFFFFFFFFU, 0x0E00B03CU);
  271. psu_mask_write(0xFD080714, 0xFFFFFFFFU, 0x09094F4FU);
  272. psu_mask_write(0xFD080718, 0xFFFFFFFFU, 0x09092B2BU);
  273. psu_mask_write(0xFD080788, 0xFFFFFFFFU, 0x00000000U);
  274. psu_mask_write(0xFD0807C0, 0xFFFFFFFFU, 0x00020000U);
  275. psu_mask_write(0xFD080800, 0xFFFFFFFFU, 0x40800604U);
  276. psu_mask_write(0xFD080810, 0xFFFFFFFFU, 0x0E00B03CU);
  277. psu_mask_write(0xFD080814, 0xFFFFFFFFU, 0x09094F4FU);
  278. psu_mask_write(0xFD080818, 0xFFFFFFFFU, 0x09092B2BU);
  279. psu_mask_write(0xFD080888, 0xFFFFFFFFU, 0x00000000U);
  280. psu_mask_write(0xFD0808C0, 0xFFFFFFFFU, 0x00020000U);
  281. psu_mask_write(0xFD080900, 0xFFFFFFFFU, 0x40800604U);
  282. psu_mask_write(0xFD080904, 0xFFFFFFFFU, 0x00007FFFU);
  283. psu_mask_write(0xFD080910, 0xFFFFFFFFU, 0x0E00B03CU);
  284. psu_mask_write(0xFD080914, 0xFFFFFFFFU, 0x09094F4FU);
  285. psu_mask_write(0xFD080918, 0xFFFFFFFFU, 0x09092B2BU);
  286. psu_mask_write(0xFD080988, 0xFFFFFFFFU, 0x00000000U);
  287. psu_mask_write(0xFD0809C0, 0xFFFFFFFFU, 0x00020000U);
  288. psu_mask_write(0xFD080A00, 0xFFFFFFFFU, 0x40800604U);
  289. psu_mask_write(0xFD080A04, 0xFFFFFFFFU, 0x00007FFFU);
  290. psu_mask_write(0xFD080A10, 0xFFFFFFFFU, 0x0E00B03CU);
  291. psu_mask_write(0xFD080A14, 0xFFFFFFFFU, 0x09094F4FU);
  292. psu_mask_write(0xFD080A18, 0xFFFFFFFFU, 0x09092B2BU);
  293. psu_mask_write(0xFD080A88, 0xFFFFFFFFU, 0x00000000U);
  294. psu_mask_write(0xFD080AC0, 0xFFFFFFFFU, 0x00020000U);
  295. psu_mask_write(0xFD080B00, 0xFFFFFFFFU, 0x40800604U);
  296. psu_mask_write(0xFD080B04, 0xFFFFFFFFU, 0x00007FFFU);
  297. psu_mask_write(0xFD080B10, 0xFFFFFFFFU, 0x0E00B03CU);
  298. psu_mask_write(0xFD080B14, 0xFFFFFFFFU, 0x09094F4FU);
  299. psu_mask_write(0xFD080B18, 0xFFFFFFFFU, 0x09092B2BU);
  300. psu_mask_write(0xFD080B88, 0xFFFFFFFFU, 0x00000000U);
  301. psu_mask_write(0xFD080BC0, 0xFFFFFFFFU, 0x00020000U);
  302. psu_mask_write(0xFD080C00, 0xFFFFFFFFU, 0x40800604U);
  303. psu_mask_write(0xFD080C04, 0xFFFFFFFFU, 0x00007FFFU);
  304. psu_mask_write(0xFD080C10, 0xFFFFFFFFU, 0x0E00B03CU);
  305. psu_mask_write(0xFD080C14, 0xFFFFFFFFU, 0x09094F4FU);
  306. psu_mask_write(0xFD080C18, 0xFFFFFFFFU, 0x09092B2BU);
  307. psu_mask_write(0xFD080C88, 0xFFFFFFFFU, 0x00000000U);
  308. psu_mask_write(0xFD080CC0, 0xFFFFFFFFU, 0x00020000U);
  309. psu_mask_write(0xFD080D00, 0xFFFFFFFFU, 0x40800604U);
  310. psu_mask_write(0xFD080D04, 0xFFFFFFFFU, 0x00007FFFU);
  311. psu_mask_write(0xFD080D10, 0xFFFFFFFFU, 0x0E00B03CU);
  312. psu_mask_write(0xFD080D14, 0xFFFFFFFFU, 0x09094F4FU);
  313. psu_mask_write(0xFD080D18, 0xFFFFFFFFU, 0x09092B2BU);
  314. psu_mask_write(0xFD080D88, 0xFFFFFFFFU, 0x00000000U);
  315. psu_mask_write(0xFD080DC0, 0xFFFFFFFFU, 0x00020000U);
  316. psu_mask_write(0xFD080E00, 0xFFFFFFFFU, 0x40800604U);
  317. psu_mask_write(0xFD080E04, 0xFFFFFFFFU, 0x00007FFFU);
  318. psu_mask_write(0xFD080E10, 0xFFFFFFFFU, 0x0E00B03CU);
  319. psu_mask_write(0xFD080E14, 0xFFFFFFFFU, 0x09094F4FU);
  320. psu_mask_write(0xFD080E18, 0xFFFFFFFFU, 0x09092B2BU);
  321. psu_mask_write(0xFD080E88, 0xFFFFFFFFU, 0x0000000AU);
  322. psu_mask_write(0xFD080EC0, 0xFFFFFFFFU, 0x00020000U);
  323. psu_mask_write(0xFD080F00, 0xFFFFFFFFU, 0x40800624U);
  324. psu_mask_write(0xFD080F04, 0xFFFFFFFFU, 0x00007F00U);
  325. psu_mask_write(0xFD080F10, 0xFFFFFFFFU, 0x0E00B03CU);
  326. psu_mask_write(0xFD080F14, 0xFFFFFFFFU, 0x09094F4FU);
  327. psu_mask_write(0xFD080F18, 0xFFFFFFFFU, 0x09092B2BU);
  328. psu_mask_write(0xFD080F88, 0xFFFFFFFFU, 0x00000000U);
  329. psu_mask_write(0xFD080FC0, 0xFFFFFFFFU, 0x00020000U);
  330. psu_mask_write(0xFD081400, 0xFFFFFFFFU, 0x2A019FFEU);
  331. psu_mask_write(0xFD08141C, 0xFFFFFFFFU, 0x01264300U);
  332. psu_mask_write(0xFD08142C, 0xFFFFFFFFU, 0x00041800U);
  333. psu_mask_write(0xFD081430, 0xFFFFFFFFU, 0x70800000U);
  334. psu_mask_write(0xFD081440, 0xFFFFFFFFU, 0x2A019FFEU);
  335. psu_mask_write(0xFD08145C, 0xFFFFFFFFU, 0x01264300U);
  336. psu_mask_write(0xFD08146C, 0xFFFFFFFFU, 0x00041800U);
  337. psu_mask_write(0xFD081470, 0xFFFFFFFFU, 0x70800000U);
  338. psu_mask_write(0xFD081480, 0xFFFFFFFFU, 0x2A019FFEU);
  339. psu_mask_write(0xFD08149C, 0xFFFFFFFFU, 0x01264300U);
  340. psu_mask_write(0xFD0814AC, 0xFFFFFFFFU, 0x00041800U);
  341. psu_mask_write(0xFD0814B0, 0xFFFFFFFFU, 0x70800000U);
  342. psu_mask_write(0xFD0814C0, 0xFFFFFFFFU, 0x2A019FFEU);
  343. psu_mask_write(0xFD0814DC, 0xFFFFFFFFU, 0x01264300U);
  344. psu_mask_write(0xFD0814EC, 0xFFFFFFFFU, 0x00041800U);
  345. psu_mask_write(0xFD0814F0, 0xFFFFFFFFU, 0x70800000U);
  346. psu_mask_write(0xFD081500, 0xFFFFFFFFU, 0x2A019FFEU);
  347. psu_mask_write(0xFD08151C, 0xFFFFFFFFU, 0x01264300U);
  348. psu_mask_write(0xFD08152C, 0xFFFFFFFFU, 0x00041800U);
  349. psu_mask_write(0xFD081530, 0xFFFFFFFFU, 0x70800000U);
  350. psu_mask_write(0xFD0817DC, 0xFFFFFFFFU, 0x012643C4U);
  351. psu_mask_write(0xFD080004, 0xFFFFFFFFU, 0x00040073U);
  352. return 1;
  353. }
  354. static unsigned long psu_mio_init_data(void)
  355. {
  356. psu_mask_write(0xFF180000, 0x000000FEU, 0x00000002U);
  357. psu_mask_write(0xFF180004, 0x000000FEU, 0x00000002U);
  358. psu_mask_write(0xFF180008, 0x000000FEU, 0x00000002U);
  359. psu_mask_write(0xFF18000C, 0x000000FEU, 0x00000002U);
  360. psu_mask_write(0xFF180010, 0x000000FEU, 0x00000002U);
  361. psu_mask_write(0xFF180014, 0x000000FEU, 0x00000002U);
  362. psu_mask_write(0xFF180018, 0x000000FEU, 0x00000002U);
  363. psu_mask_write(0xFF18001C, 0x000000FEU, 0x00000002U);
  364. psu_mask_write(0xFF180020, 0x000000FEU, 0x00000002U);
  365. psu_mask_write(0xFF180024, 0x000000FEU, 0x00000002U);
  366. psu_mask_write(0xFF180028, 0x000000FEU, 0x00000002U);
  367. psu_mask_write(0xFF18002C, 0x000000FEU, 0x00000002U);
  368. psu_mask_write(0xFF180030, 0x000000FEU, 0x00000002U);
  369. psu_mask_write(0xFF180034, 0x000000FEU, 0x00000000U);
  370. psu_mask_write(0xFF180038, 0x000000FEU, 0x00000040U);
  371. psu_mask_write(0xFF18003C, 0x000000FEU, 0x00000040U);
  372. psu_mask_write(0xFF180040, 0x000000FEU, 0x00000040U);
  373. psu_mask_write(0xFF180044, 0x000000FEU, 0x00000040U);
  374. psu_mask_write(0xFF180048, 0x000000FEU, 0x000000C0U);
  375. psu_mask_write(0xFF18004C, 0x000000FEU, 0x000000C0U);
  376. psu_mask_write(0xFF180050, 0x000000FEU, 0x000000C0U);
  377. psu_mask_write(0xFF180054, 0x000000FEU, 0x000000C0U);
  378. psu_mask_write(0xFF180058, 0x000000FEU, 0x00000000U);
  379. psu_mask_write(0xFF18005C, 0x000000FEU, 0x00000000U);
  380. psu_mask_write(0xFF180060, 0x000000FEU, 0x00000020U);
  381. psu_mask_write(0xFF180064, 0x000000FEU, 0x00000020U);
  382. psu_mask_write(0xFF180068, 0x000000FEU, 0x00000000U);
  383. psu_mask_write(0xFF18006C, 0x000000FEU, 0x00000018U);
  384. psu_mask_write(0xFF180070, 0x000000FEU, 0x00000018U);
  385. psu_mask_write(0xFF180074, 0x000000FEU, 0x00000018U);
  386. psu_mask_write(0xFF180078, 0x000000FEU, 0x00000018U);
  387. psu_mask_write(0xFF18007C, 0x000000FEU, 0x00000000U);
  388. psu_mask_write(0xFF180080, 0x000000FEU, 0x00000008U);
  389. psu_mask_write(0xFF180084, 0x000000FEU, 0x00000008U);
  390. psu_mask_write(0xFF180088, 0x000000FEU, 0x00000008U);
  391. psu_mask_write(0xFF18008C, 0x000000FEU, 0x00000008U);
  392. psu_mask_write(0xFF180090, 0x000000FEU, 0x00000008U);
  393. psu_mask_write(0xFF180094, 0x000000FEU, 0x00000008U);
  394. psu_mask_write(0xFF180098, 0x000000FEU, 0x00000000U);
  395. psu_mask_write(0xFF18009C, 0x000000FEU, 0x00000000U);
  396. psu_mask_write(0xFF1800A0, 0x000000FEU, 0x00000000U);
  397. psu_mask_write(0xFF1800A4, 0x000000FEU, 0x00000000U);
  398. psu_mask_write(0xFF1800A8, 0x000000FEU, 0x00000000U);
  399. psu_mask_write(0xFF1800AC, 0x000000FEU, 0x00000010U);
  400. psu_mask_write(0xFF1800B0, 0x000000FEU, 0x00000010U);
  401. psu_mask_write(0xFF1800B4, 0x000000FEU, 0x00000010U);
  402. psu_mask_write(0xFF1800B8, 0x000000FEU, 0x00000010U);
  403. psu_mask_write(0xFF1800BC, 0x000000FEU, 0x00000010U);
  404. psu_mask_write(0xFF1800C0, 0x000000FEU, 0x00000010U);
  405. psu_mask_write(0xFF1800C4, 0x000000FEU, 0x00000010U);
  406. psu_mask_write(0xFF1800C8, 0x000000FEU, 0x00000010U);
  407. psu_mask_write(0xFF1800CC, 0x000000FEU, 0x00000010U);
  408. psu_mask_write(0xFF1800D0, 0x000000FEU, 0x00000004U);
  409. psu_mask_write(0xFF1800D4, 0x000000FEU, 0x00000004U);
  410. psu_mask_write(0xFF1800D8, 0x000000FEU, 0x00000004U);
  411. psu_mask_write(0xFF1800DC, 0x000000FEU, 0x00000004U);
  412. psu_mask_write(0xFF1800E0, 0x000000FEU, 0x00000004U);
  413. psu_mask_write(0xFF1800E4, 0x000000FEU, 0x00000004U);
  414. psu_mask_write(0xFF1800E8, 0x000000FEU, 0x00000004U);
  415. psu_mask_write(0xFF1800EC, 0x000000FEU, 0x00000004U);
  416. psu_mask_write(0xFF1800F0, 0x000000FEU, 0x00000004U);
  417. psu_mask_write(0xFF1800F4, 0x000000FEU, 0x00000004U);
  418. psu_mask_write(0xFF1800F8, 0x000000FEU, 0x00000004U);
  419. psu_mask_write(0xFF1800FC, 0x000000FEU, 0x00000004U);
  420. psu_mask_write(0xFF180100, 0x000000FEU, 0x00000002U);
  421. psu_mask_write(0xFF180104, 0x000000FEU, 0x00000002U);
  422. psu_mask_write(0xFF180108, 0x000000FEU, 0x00000002U);
  423. psu_mask_write(0xFF18010C, 0x000000FEU, 0x00000002U);
  424. psu_mask_write(0xFF180110, 0x000000FEU, 0x00000002U);
  425. psu_mask_write(0xFF180114, 0x000000FEU, 0x00000002U);
  426. psu_mask_write(0xFF180118, 0x000000FEU, 0x00000002U);
  427. psu_mask_write(0xFF18011C, 0x000000FEU, 0x00000002U);
  428. psu_mask_write(0xFF180120, 0x000000FEU, 0x00000002U);
  429. psu_mask_write(0xFF180124, 0x000000FEU, 0x00000002U);
  430. psu_mask_write(0xFF180128, 0x000000FEU, 0x00000002U);
  431. psu_mask_write(0xFF18012C, 0x000000FEU, 0x00000002U);
  432. psu_mask_write(0xFF180130, 0x000000FEU, 0x000000C0U);
  433. psu_mask_write(0xFF180134, 0x000000FEU, 0x000000C0U);
  434. psu_mask_write(0xFF180204, 0xFFFFFFFFU, 0x52240000U);
  435. psu_mask_write(0xFF180208, 0xFFFFFFFFU, 0x00B03000U);
  436. psu_mask_write(0xFF18020C, 0x00003FFFU, 0x00000FC0U);
  437. psu_mask_write(0xFF180138, 0x03FFFFFFU, 0x03FFFFFFU);
  438. psu_mask_write(0xFF18013C, 0x03FFFFFFU, 0x03FFFFFFU);
  439. psu_mask_write(0xFF180140, 0x03FFFFFFU, 0x00000000U);
  440. psu_mask_write(0xFF180144, 0x03FFFFFFU, 0x03FFFFFFU);
  441. psu_mask_write(0xFF180148, 0x03FFFFFFU, 0x03FFFFFFU);
  442. psu_mask_write(0xFF18014C, 0x03FFFFFFU, 0x00000000U);
  443. psu_mask_write(0xFF180154, 0x03FFFFFFU, 0x03FFFFFFU);
  444. psu_mask_write(0xFF180158, 0x03FFFFFFU, 0x03FFFFFFU);
  445. psu_mask_write(0xFF18015C, 0x03FFFFFFU, 0x00000000U);
  446. psu_mask_write(0xFF180160, 0x03FFFFFFU, 0x03FFFFFFU);
  447. psu_mask_write(0xFF180164, 0x03FFFFFFU, 0x03FFFFFFU);
  448. psu_mask_write(0xFF180168, 0x03FFFFFFU, 0x00000000U);
  449. psu_mask_write(0xFF180170, 0x03FFFFFFU, 0x03FFFFFFU);
  450. psu_mask_write(0xFF180174, 0x03FFFFFFU, 0x03FFFFFFU);
  451. psu_mask_write(0xFF180178, 0x03FFFFFFU, 0x00000000U);
  452. psu_mask_write(0xFF18017C, 0x03FFFFFFU, 0x03FFFFFFU);
  453. psu_mask_write(0xFF180180, 0x03FFFFFFU, 0x03FFFFFFU);
  454. psu_mask_write(0xFF180184, 0x03FFFFFFU, 0x00000000U);
  455. psu_mask_write(0xFF180200, 0x0000000FU, 0x00000000U);
  456. return 1;
  457. }
  458. static unsigned long psu_peripherals_init_data(void)
  459. {
  460. psu_mask_write(0xFF5E0238, 0x00100000U, 0x00000000U);
  461. psu_mask_write(0xFF5E0230, 0x00000008U, 0x00000000U);
  462. psu_mask_write(0xFF5E0238, 0x00000001U, 0x00000000U);
  463. psu_mask_write(0xFF180390, 0x00000004U, 0x00000004U);
  464. psu_mask_write(0xFF5E023C, 0x00000540U, 0x00000000U);
  465. psu_mask_write(0xFD1A0100, 0x0001807EU, 0x00000000U);
  466. psu_mask_write(0xFF5E0238, 0x00000040U, 0x00000000U);
  467. psu_mask_write(0xFF180310, 0x00008000U, 0x00000000U);
  468. psu_mask_write(0xFF180320, 0x33800000U, 0x00800000U);
  469. psu_mask_write(0xFF18031C, 0x7F800000U, 0x63800000U);
  470. psu_mask_write(0xFF180324, 0x03C00000U, 0x00000000U);
  471. psu_mask_write(0xFF5E0238, 0x00000100U, 0x00000000U);
  472. psu_mask_write(0xFF5E0238, 0x00000600U, 0x00000000U);
  473. psu_mask_write(0xFF5E0238, 0x00008000U, 0x00000000U);
  474. psu_mask_write(0xFF5E0238, 0x00007800U, 0x00000000U);
  475. psu_mask_write(0xFF5E0238, 0x00000006U, 0x00000000U);
  476. psu_mask_write(0xFE980FB0, 0xFFFFFFFFU, 0xC5ACCE55U);
  477. psu_mask_write(0xFE980004, 0x80000000U, 0x80000000U);
  478. psu_mask_write(0xFE980FB0, 0xFFFFFFFFU, 0x00000000U);
  479. psu_mask_write(0xFF000034, 0x000000FFU, 0x00000005U);
  480. psu_mask_write(0xFF000018, 0x0000FFFFU, 0x0000008FU);
  481. psu_mask_write(0xFF000000, 0x000001FFU, 0x00000017U);
  482. psu_mask_write(0xFF000004, 0x000003FFU, 0x00000020U);
  483. psu_mask_write(0xFF010034, 0x000000FFU, 0x00000005U);
  484. psu_mask_write(0xFF010018, 0x0000FFFFU, 0x0000008FU);
  485. psu_mask_write(0xFF010000, 0x000001FFU, 0x00000017U);
  486. psu_mask_write(0xFF010004, 0x000003FFU, 0x00000020U);
  487. psu_mask_write(0xFF4B0024, 0x000000FFU, 0x000000FFU);
  488. psu_mask_write(0xFFCA5000, 0x00001FFFU, 0x00000000U);
  489. psu_mask_write(0xFD5C0060, 0x000F000FU, 0x00000000U);
  490. psu_mask_write(0xFFA60040, 0x80000000U, 0x80000000U);
  491. psu_mask_write(0xFF260020, 0xFFFFFFFFU, 0x05F5E100U);
  492. psu_mask_write(0xFF260000, 0x00000001U, 0x00000001U);
  493. return 1;
  494. }
  495. static unsigned long psu_serdes_init_data(void)
  496. {
  497. psu_mask_write(0xFD410000, 0x0000001FU, 0x00000009U);
  498. psu_mask_write(0xFD410004, 0x0000001FU, 0x00000009U);
  499. psu_mask_write(0xFD410008, 0x0000001FU, 0x00000008U);
  500. psu_mask_write(0xFD41000C, 0x0000001FU, 0x0000000FU);
  501. psu_mask_write(0xFD402860, 0x00000088U, 0x00000008U);
  502. psu_mask_write(0xFD402864, 0x00000088U, 0x00000008U);
  503. psu_mask_write(0xFD402868, 0x00000080U, 0x00000080U);
  504. psu_mask_write(0xFD40286C, 0x00000082U, 0x00000002U);
  505. psu_mask_write(0xFD40A094, 0x00000010U, 0x00000010U);
  506. psu_mask_write(0xFD40A368, 0x000000FFU, 0x00000038U);
  507. psu_mask_write(0xFD40A36C, 0x00000007U, 0x00000003U);
  508. psu_mask_write(0xFD40E368, 0x000000FFU, 0x000000E0U);
  509. psu_mask_write(0xFD40E36C, 0x00000007U, 0x00000003U);
  510. psu_mask_write(0xFD402368, 0x000000FFU, 0x00000058U);
  511. psu_mask_write(0xFD40236C, 0x00000007U, 0x00000003U);
  512. psu_mask_write(0xFD406368, 0x000000FFU, 0x00000058U);
  513. psu_mask_write(0xFD40636C, 0x00000007U, 0x00000003U);
  514. psu_mask_write(0xFD402370, 0x000000FFU, 0x0000007CU);
  515. psu_mask_write(0xFD402374, 0x000000FFU, 0x00000033U);
  516. psu_mask_write(0xFD402378, 0x000000FFU, 0x00000002U);
  517. psu_mask_write(0xFD40237C, 0x00000033U, 0x00000030U);
  518. psu_mask_write(0xFD406370, 0x000000FFU, 0x0000007CU);
  519. psu_mask_write(0xFD406374, 0x000000FFU, 0x00000033U);
  520. psu_mask_write(0xFD406378, 0x000000FFU, 0x00000002U);
  521. psu_mask_write(0xFD40637C, 0x00000033U, 0x00000030U);
  522. psu_mask_write(0xFD40A370, 0x000000FFU, 0x000000F4U);
  523. psu_mask_write(0xFD40A374, 0x000000FFU, 0x00000031U);
  524. psu_mask_write(0xFD40A378, 0x000000FFU, 0x00000002U);
  525. psu_mask_write(0xFD40A37C, 0x00000033U, 0x00000030U);
  526. psu_mask_write(0xFD40E370, 0x000000FFU, 0x000000C9U);
  527. psu_mask_write(0xFD40E374, 0x000000FFU, 0x000000D2U);
  528. psu_mask_write(0xFD40E378, 0x000000FFU, 0x00000001U);
  529. psu_mask_write(0xFD40E37C, 0x000000B3U, 0x000000B0U);
  530. psu_mask_write(0xFD40906C, 0x00000003U, 0x00000003U);
  531. psu_mask_write(0xFD4080F4, 0x00000003U, 0x00000003U);
  532. psu_mask_write(0xFD40E360, 0x00000040U, 0x00000040U);
  533. psu_mask_write(0xFD40D06C, 0x0000000FU, 0x0000000FU);
  534. psu_mask_write(0xFD40C0F4, 0x0000000BU, 0x0000000BU);
  535. psu_mask_write(0xFD40CB00, 0x000000F0U, 0x000000F0U);
  536. psu_mask_write(0xFD4090CC, 0x00000020U, 0x00000020U);
  537. psu_mask_write(0xFD401074, 0x00000010U, 0x00000010U);
  538. psu_mask_write(0xFD405074, 0x00000010U, 0x00000010U);
  539. psu_mask_write(0xFD409074, 0x00000010U, 0x00000010U);
  540. psu_mask_write(0xFD40D074, 0x00000010U, 0x00000010U);
  541. psu_mask_write(0xFD40989C, 0x00000080U, 0x00000080U);
  542. psu_mask_write(0xFD4098F8, 0x000000FFU, 0x0000001AU);
  543. psu_mask_write(0xFD4098FC, 0x000000FFU, 0x0000001AU);
  544. psu_mask_write(0xFD409990, 0x000000FFU, 0x00000010U);
  545. psu_mask_write(0xFD409924, 0x000000FFU, 0x000000FEU);
  546. psu_mask_write(0xFD409928, 0x000000FFU, 0x00000000U);
  547. psu_mask_write(0xFD409900, 0x000000FFU, 0x0000001AU);
  548. psu_mask_write(0xFD40992C, 0x000000FFU, 0x00000000U);
  549. psu_mask_write(0xFD409980, 0x000000FFU, 0x000000FFU);
  550. psu_mask_write(0xFD409914, 0x000000FFU, 0x000000F7U);
  551. psu_mask_write(0xFD409918, 0x00000001U, 0x00000001U);
  552. psu_mask_write(0xFD409940, 0x000000FFU, 0x000000F7U);
  553. psu_mask_write(0xFD409944, 0x00000001U, 0x00000001U);
  554. psu_mask_write(0xFD40D89C, 0x00000080U, 0x00000080U);
  555. psu_mask_write(0xFD40D8F8, 0x000000FFU, 0x0000007DU);
  556. psu_mask_write(0xFD40D8FC, 0x000000FFU, 0x0000007DU);
  557. psu_mask_write(0xFD40D990, 0x000000FFU, 0x00000001U);
  558. psu_mask_write(0xFD40D924, 0x000000FFU, 0x0000009CU);
  559. psu_mask_write(0xFD40D928, 0x000000FFU, 0x00000039U);
  560. psu_mask_write(0xFD40D98C, 0x000000F0U, 0x00000020U);
  561. psu_mask_write(0xFD40D900, 0x000000FFU, 0x0000007DU);
  562. psu_mask_write(0xFD40D92C, 0x000000FFU, 0x00000064U);
  563. psu_mask_write(0xFD40D980, 0x000000FFU, 0x000000FFU);
  564. psu_mask_write(0xFD40D914, 0x000000FFU, 0x000000F7U);
  565. psu_mask_write(0xFD40D918, 0x00000001U, 0x00000001U);
  566. psu_mask_write(0xFD40D940, 0x000000FFU, 0x000000F7U);
  567. psu_mask_write(0xFD40D944, 0x00000001U, 0x00000001U);
  568. psu_mask_write(0xFD4019A4, 0x000000FFU, 0x000000FFU);
  569. psu_mask_write(0xFD401038, 0x00000040U, 0x00000040U);
  570. psu_mask_write(0xFD40102C, 0x00000040U, 0x00000040U);
  571. psu_mask_write(0xFD4059A4, 0x000000FFU, 0x000000FFU);
  572. psu_mask_write(0xFD405038, 0x00000040U, 0x00000040U);
  573. psu_mask_write(0xFD40502C, 0x00000040U, 0x00000040U);
  574. psu_mask_write(0xFD4099A4, 0x000000FFU, 0x000000FFU);
  575. psu_mask_write(0xFD409038, 0x00000040U, 0x00000040U);
  576. psu_mask_write(0xFD40902C, 0x00000040U, 0x00000040U);
  577. psu_mask_write(0xFD40D9A4, 0x000000FFU, 0x000000FFU);
  578. psu_mask_write(0xFD40D038, 0x00000040U, 0x00000040U);
  579. psu_mask_write(0xFD40D02C, 0x00000040U, 0x00000040U);
  580. psu_mask_write(0xFD410010, 0x00000077U, 0x00000044U);
  581. psu_mask_write(0xFD410014, 0x00000077U, 0x00000023U);
  582. psu_mask_write(0xFD400CB4, 0x00000037U, 0x00000037U);
  583. psu_mask_write(0xFD404CB4, 0x00000037U, 0x00000037U);
  584. psu_mask_write(0xFD4001D8, 0x00000001U, 0x00000001U);
  585. psu_mask_write(0xFD4041D8, 0x00000001U, 0x00000001U);
  586. psu_mask_write(0xFD40C1D8, 0x00000001U, 0x00000001U);
  587. psu_mask_write(0xFD40DC14, 0x000000FFU, 0x000000E6U);
  588. psu_mask_write(0xFD40DC40, 0x0000001FU, 0x0000000CU);
  589. psu_mask_write(0xFD40D94C, 0x00000020U, 0x00000020U);
  590. psu_mask_write(0xFD40D950, 0x00000007U, 0x00000006U);
  591. psu_mask_write(0xFD404CC0, 0x0000001FU, 0x00000000U);
  592. psu_mask_write(0xFD400CC0, 0x0000001FU, 0x00000000U);
  593. psu_mask_write(0xFD404048, 0x000000FFU, 0x00000000U);
  594. psu_mask_write(0xFD400048, 0x000000FFU, 0x00000000U);
  595. psu_mask_write(0xFD40C048, 0x000000FFU, 0x00000001U);
  596. return 1;
  597. }
  598. static unsigned long psu_resetout_init_data(void)
  599. {
  600. psu_mask_write(0xFF5E023C, 0x00000400U, 0x00000000U);
  601. psu_mask_write(0xFF9D0080, 0x00000001U, 0x00000001U);
  602. psu_mask_write(0xFF9D007C, 0x00000001U, 0x00000000U);
  603. psu_mask_write(0xFF5E023C, 0x00000140U, 0x00000000U);
  604. psu_mask_write(0xFF5E0230, 0x00000008U, 0x00000000U);
  605. psu_mask_write(0xFD3D0100, 0x00000003U, 0x00000003U);
  606. psu_mask_write(0xFD1A0100, 0x00000002U, 0x00000000U);
  607. psu_mask_write(0xFD1A0100, 0x00010000U, 0x00000000U);
  608. psu_mask_write(0xFD4A0200, 0x00000002U, 0x00000000U);
  609. psu_mask_write(0xFD4A0238, 0x0000000FU, 0x00000000U);
  610. psu_mask_write(0xFE20C200, 0x00003FBFU, 0x00002417U);
  611. psu_mask_write(0xFE20C630, 0x003FFF00U, 0x00000000U);
  612. psu_mask_write(0xFD480064, 0x00000200U, 0x00000200U);
  613. mask_poll(0xFD4063E4, 0x00000010U);
  614. mask_poll(0xFD40A3E4, 0x00000010U);
  615. mask_poll(0xFD40E3E4, 0x00000010U);
  616. psu_mask_write(0xFD0C00AC, 0xFFFFFFFFU, 0x28184018U);
  617. psu_mask_write(0xFD0C00B0, 0xFFFFFFFFU, 0x0E081406U);
  618. psu_mask_write(0xFD0C00B4, 0xFFFFFFFFU, 0x064A0813U);
  619. psu_mask_write(0xFD0C00B8, 0xFFFFFFFFU, 0x3FFC96A4U);
  620. return 1;
  621. }
  622. static unsigned long psu_resetin_init_data(void)
  623. {
  624. psu_mask_write(0xFF5E023C, 0x00000540U, 0x00000540U);
  625. psu_mask_write(0xFF5E0230, 0x00000008U, 0x00000008U);
  626. psu_mask_write(0xFD1A0100, 0x00000002U, 0x00000002U);
  627. psu_mask_write(0xFD4A0238, 0x0000000FU, 0x0000000AU);
  628. psu_mask_write(0xFD4A0200, 0x00000002U, 0x00000002U);
  629. psu_mask_write(0xFD1A0100, 0x00010000U, 0x00010000U);
  630. return 1;
  631. }
  632. static unsigned long psu_ddr_phybringup_data(void)
  633. {
  634. unsigned int regval = 0;
  635. int dpll_divisor;
  636. dpll_divisor = (Xil_In32(0xFD1A0080U) & 0x00003F00U) >> 0x00000008U;
  637. prog_reg(0xFD1A0080U, 0x00003F00U, 0x00000008U, 0x00000005U);
  638. prog_reg(0xFD080028U, 0x00000001U, 0x00000000U, 0x00000001U);
  639. Xil_Out32(0xFD080004U, 0x00040003U);
  640. while ((Xil_In32(0xFD080030U) & 0x00000001U) != 0x00000001U)
  641. ;
  642. prog_reg(0xFD080684U, 0x06000000U, 0x00000019U, 0x00000001U);
  643. prog_reg(0xFD0806A4U, 0x06000000U, 0x00000019U, 0x00000001U);
  644. prog_reg(0xFD0806C4U, 0x06000000U, 0x00000019U, 0x00000001U);
  645. prog_reg(0xFD0806E4U, 0x06000000U, 0x00000019U, 0x00000001U);
  646. prog_reg(0xFD1A0080, 0x3F00, 0x8, dpll_divisor);
  647. Xil_Out32(0xFD080004U, 0x40040071U);
  648. while ((Xil_In32(0xFD080030U) & 0x00000001U) != 0x00000001U)
  649. ;
  650. Xil_Out32(0xFD080004U, 0x40040001U);
  651. while ((Xil_In32(0xFD080030U) & 0x00000001U) != 0x00000001U)
  652. ;
  653. while ((Xil_In32(0xFD080030U) & 0x0000000FU) != 0x0000000FU)
  654. ;
  655. prog_reg(0xFD080004U, 0x00000001U, 0x00000000U, 0x00000001U);
  656. while ((Xil_In32(0xFD080030U) & 0x000000FFU) != 0x0000001FU)
  657. ;
  658. Xil_Out32(0xFD0701B0U, 0x00000001U);
  659. Xil_Out32(0xFD070320U, 0x00000001U);
  660. while ((Xil_In32(0xFD070004U) & 0x0000000FU) != 0x00000001U)
  661. ;
  662. prog_reg(0xFD080014U, 0x00000040U, 0x00000006U, 0x00000001U);
  663. Xil_Out32(0xFD080004, 0x0004FE01);
  664. regval = Xil_In32(0xFD080030);
  665. while (regval != 0x80000FFF)
  666. regval = Xil_In32(0xFD080030);
  667. Xil_Out32(0xFD080200U, 0x100091C7U);
  668. Xil_Out32(0xFD080018U, 0x00F01EF2U);
  669. Xil_Out32(0xFD08001CU, 0x55AA5498U);
  670. Xil_Out32(0xFD08142CU, 0x00041830U);
  671. Xil_Out32(0xFD08146CU, 0x00041830U);
  672. Xil_Out32(0xFD0814ACU, 0x00041830U);
  673. Xil_Out32(0xFD0814ECU, 0x00041830U);
  674. Xil_Out32(0xFD08152CU, 0x00041830U);
  675. Xil_Out32(0xFD080004, 0x00060001);
  676. regval = Xil_In32(0xFD080030);
  677. while ((regval & 0x80004001) != 0x80004001)
  678. regval = Xil_In32(0xFD080030);
  679. Xil_Out32(0xFD080200U, 0x800091C7U);
  680. Xil_Out32(0xFD080018U, 0x00F12302U);
  681. Xil_Out32(0xFD08001CU, 0x55AA5480U);
  682. Xil_Out32(0xFD08142CU, 0x00041800U);
  683. Xil_Out32(0xFD08146CU, 0x00041800U);
  684. Xil_Out32(0xFD0814ACU, 0x00041800U);
  685. Xil_Out32(0xFD0814ECU, 0x00041800U);
  686. Xil_Out32(0xFD08152CU, 0x00041800U);
  687. Xil_Out32(0xFD080004, 0x0000C001);
  688. regval = Xil_In32(0xFD080030);
  689. while ((regval & 0x80000C01) != 0x80000C01)
  690. regval = Xil_In32(0xFD080030);
  691. Xil_Out32(0xFD070180U, 0x01000040U);
  692. Xil_Out32(0xFD070060U, 0x00000000U);
  693. prog_reg(0xFD080014U, 0x00000040U, 0x00000006U, 0x00000000U);
  694. return 1;
  695. }
  696. static int serdes_fixcal_code(void)
  697. {
  698. int maskstatus = 1;
  699. unsigned int tmp_0_1, tmp_0_2, tmp_0_3, tmp_0_2_mod;
  700. Xil_Out32(0xFD40EC4C, 0x00000020);
  701. Xil_Out32(0xFD410010, 0x00000001);
  702. maskstatus = mask_poll(0xFD40EF14, 0x2);
  703. if (maskstatus == 0) {
  704. /* xil_printf("SERDES initialization timed out\n\r"); */
  705. return maskstatus;
  706. }
  707. tmp_0_1 = mask_read(0xFD400B0C, 0x3F);
  708. tmp_0_2 = tmp_0_1 & (0x7);
  709. tmp_0_3 = tmp_0_1 & (0x38);
  710. Xil_Out32(0xFD410010, 0x00000000);
  711. Xil_Out32(0xFD410014, 0x00000000);
  712. tmp_0_2_mod = (tmp_0_2 << 1) | (0x1);
  713. tmp_0_2_mod = (tmp_0_2_mod << 4);
  714. tmp_0_3 = tmp_0_3 >> 3;
  715. Xil_Out32(0xFD40EC4C, tmp_0_3);
  716. Xil_Out32(0xFD40EC48, tmp_0_2_mod);
  717. return maskstatus;
  718. }
  719. static int serdes_enb_coarse_saturation(void)
  720. {
  721. Xil_Out32(0xFD402094, 0x00000010);
  722. Xil_Out32(0xFD406094, 0x00000010);
  723. Xil_Out32(0xFD40A094, 0x00000010);
  724. Xil_Out32(0xFD40E094, 0x00000010);
  725. return 1;
  726. }
  727. static int init_serdes(void)
  728. {
  729. int status = 1;
  730. status &= psu_resetin_init_data();
  731. status &= serdes_fixcal_code();
  732. status &= serdes_enb_coarse_saturation();
  733. status &= psu_serdes_init_data();
  734. status &= psu_resetout_init_data();
  735. return status;
  736. }
  737. static void init_peripheral(void)
  738. {
  739. unsigned int regvalue;
  740. unsigned int tmp_regval;
  741. Xil_Out32(((0xFF5E0000U) + 0x00000230U), 0x00000000);
  742. Xil_Out32(((0xFF5E0000U) + 0x00000234U), 0x00000000);
  743. Xil_Out32(((0xFF5E0000U) + 0x00000238U), 0x00000000);
  744. regvalue = Xil_In32(((0xFF5E0000U) + 0x0000023CU));
  745. regvalue &= 0x7;
  746. Xil_Out32(((0xFF5E0000U) + 0x0000023CU), regvalue);
  747. Xil_Out32(((0xFD1A0000U) + 0x00000100U), 0x00000000);
  748. tmp_regval = Xil_In32(0xFD690040);
  749. tmp_regval &= ~0x00000001;
  750. Xil_Out32(0xFD690040, tmp_regval);
  751. tmp_regval = Xil_In32(0xFD690030);
  752. tmp_regval &= ~0x00000001;
  753. Xil_Out32(0xFD690030, tmp_regval);
  754. }
  755. int psu_init(void)
  756. {
  757. int status = 1;
  758. status &= psu_mio_init_data();
  759. status &= psu_pll_init_data();
  760. status &= psu_clock_init_data();
  761. status &= psu_ddr_init_data();
  762. status &= psu_ddr_phybringup_data();
  763. status &= psu_peripherals_init_data();
  764. status &= init_serdes();
  765. init_peripheral();
  766. if (status == 0)
  767. return 1;
  768. return 0;
  769. }