hw_data.c 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. *
  4. * HW data initialization for OMAP5
  5. *
  6. * (C) Copyright 2013
  7. * Texas Instruments, <www.ti.com>
  8. *
  9. * Sricharan R <r.sricharan@ti.com>
  10. */
  11. #include <common.h>
  12. #include <palmas.h>
  13. #include <asm/arch/omap.h>
  14. #include <asm/arch/sys_proto.h>
  15. #include <asm/omap_common.h>
  16. #include <asm/arch/clock.h>
  17. #include <asm/omap_gpio.h>
  18. #include <asm/io.h>
  19. #include <asm/emif.h>
  20. struct prcm_regs const **prcm =
  21. (struct prcm_regs const **) OMAP_SRAM_SCRATCH_PRCM_PTR;
  22. struct dplls const **dplls_data =
  23. (struct dplls const **) OMAP_SRAM_SCRATCH_DPLLS_PTR;
  24. struct vcores_data const **omap_vcores =
  25. (struct vcores_data const **) OMAP_SRAM_SCRATCH_VCORES_PTR;
  26. struct omap_sys_ctrl_regs const **ctrl =
  27. (struct omap_sys_ctrl_regs const **)OMAP_SRAM_SCRATCH_SYS_CTRL;
  28. /* OPP NOM FREQUENCY for ES1.0 */
  29. static const struct dpll_params mpu_dpll_params_800mhz[NUM_SYS_CLKS] = {
  30. {200, 2, 1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  31. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  32. {1000, 20, 1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  33. {375, 8, 1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  34. {400, 12, 1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  35. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  36. {375, 17, 1, -1, -1, -1, -1, -1, -1, -1, -1, -1} /* 38.4 MHz */
  37. };
  38. /* OPP NOM FREQUENCY for OMAP5 ES2.0, and DRA7 ES1.0 */
  39. static const struct dpll_params mpu_dpll_params_1ghz[NUM_SYS_CLKS] = {
  40. {250, 2, 1, 1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  41. {500, 9, 1, 1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 20 MHz */
  42. {119, 1, 1, 1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  43. {625, 11, 1, 1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  44. {500, 12, 1, 1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  45. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  46. {625, 23, 1, 1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 38.4 MHz */
  47. };
  48. static const struct dpll_params
  49. core_dpll_params_2128mhz_ddr532[NUM_SYS_CLKS] = {
  50. {266, 2, 2, 5, 8, 4, 62, 5, -1, 5, 7, -1}, /* 12 MHz */
  51. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  52. {443, 6, 2, 5, 8, 4, 62, 5, -1, 5, 7, -1}, /* 16.8 MHz */
  53. {277, 4, 2, 5, 8, 4, 62, 5, -1, 5, 7, -1}, /* 19.2 MHz */
  54. {368, 8, 2, 5, 8, 4, 62, 5, -1, 5, 7, -1}, /* 26 MHz */
  55. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  56. {277, 9, 2, 5, 8, 4, 62, 5, -1, 5, 7, -1} /* 38.4 MHz */
  57. };
  58. static const struct dpll_params
  59. core_dpll_params_2128mhz_ddr532_es2[NUM_SYS_CLKS] = {
  60. {266, 2, 2, 5, 8, 4, 62, 63, 6, 5, 7, 6}, /* 12 MHz */
  61. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  62. {443, 6, 2, 5, 8, 4, 62, 63, 6, 5, 7, 6}, /* 16.8 MHz */
  63. {277, 4, 2, 5, 8, 4, 62, 63, 6, 5, 7, 6}, /* 19.2 MHz */
  64. {368, 8, 2, 5, 8, 4, 62, 63, 6, 5, 7, 6}, /* 26 MHz */
  65. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  66. {277, 9, 2, 5, 8, 4, 62, 63, 6, 5, 7, 6} /* 38.4 MHz */
  67. };
  68. static const struct dpll_params
  69. core_dpll_params_2128mhz_dra7xx[NUM_SYS_CLKS] = {
  70. {266, 2, 2, 1, -1, 4, 62, 5, -1, 5, 4, 6}, /* 12 MHz */
  71. {266, 4, 2, 1, -1, 4, 62, 5, -1, 5, 4, 6}, /* 20 MHz */
  72. {443, 6, 2, 1, -1, 4, 62, 5, -1, 5, 4, 6}, /* 16.8 MHz */
  73. {277, 4, 2, 1, -1, 4, 62, 5, -1, 5, 4, 6}, /* 19.2 MHz */
  74. {368, 8, 2, 1, -1, 4, 62, 5, -1, 5, 4, 6}, /* 26 MHz */
  75. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  76. {277, 9, 2, 1, -1, 4, 62, 5, -1, 5, 4, 6}, /* 38.4 MHz */
  77. };
  78. static const struct dpll_params per_dpll_params_768mhz[NUM_SYS_CLKS] = {
  79. {32, 0, 4, 3, 6, 4, -1, 2, -1, -1, -1, -1}, /* 12 MHz */
  80. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  81. {160, 6, 4, 3, 6, 4, -1, 2, -1, -1, -1, -1}, /* 16.8 MHz */
  82. {20, 0, 4, 3, 6, 4, -1, 2, -1, -1, -1, -1}, /* 19.2 MHz */
  83. {192, 12, 4, 3, 6, 4, -1, 2, -1, -1, -1, -1}, /* 26 MHz */
  84. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  85. {10, 0, 4, 3, 6, 4, -1, 2, -1, -1, -1, -1} /* 38.4 MHz */
  86. };
  87. static const struct dpll_params per_dpll_params_768mhz_es2[NUM_SYS_CLKS] = {
  88. {32, 0, 4, 3, 3, 4, -1, 2, -1, -1, -1, -1}, /* 12 MHz */
  89. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  90. {160, 6, 4, 3, 3, 4, -1, 2, -1, -1, -1, -1}, /* 16.8 MHz */
  91. {20, 0, 4, 3, 3, 4, -1, 2, -1, -1, -1, -1}, /* 19.2 MHz */
  92. {192, 12, 4, 3, 3, 4, -1, 2, -1, -1, -1, -1}, /* 26 MHz */
  93. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  94. {10, 0, 4, 3, 3, 4, -1, 2, -1, -1, -1, -1} /* 38.4 MHz */
  95. };
  96. static const struct dpll_params per_dpll_params_768mhz_dra7xx[NUM_SYS_CLKS] = {
  97. {32, 0, 4, 1, 3, 4, 4, 2, -1, -1, -1, -1}, /* 12 MHz */
  98. {96, 4, 4, 1, 3, 4, 10, 2, -1, -1, -1, -1}, /* 20 MHz */
  99. {160, 6, 4, 1, 3, 4, 4, 2, -1, -1, -1, -1}, /* 16.8 MHz */
  100. {20, 0, 4, 1, 3, 4, 4, 2, -1, -1, -1, -1}, /* 19.2 MHz */
  101. {192, 12, 4, 1, 3, 4, 4, 2, -1, -1, -1, -1}, /* 26 MHz */
  102. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  103. {10, 0, 4, 1, 3, 4, 4, 2, -1, -1, -1, -1}, /* 38.4 MHz */
  104. };
  105. static const struct dpll_params per_dpll_params_768mhz_dra76x[NUM_SYS_CLKS] = {
  106. {32, 0, 4, 1, 3, 4, 8, 2, -1, -1, -1, -1}, /* 12 MHz */
  107. {96, 4, 4, 1, 3, 4, 8, 2, -1, -1, -1, -1}, /* 20 MHz */
  108. {160, 6, 4, 1, 3, 4, 8, 2, -1, -1, -1, -1}, /* 16.8 MHz */
  109. {20, 0, 4, 1, 3, 4, 8, 2, -1, -1, -1, -1}, /* 19.2 MHz */
  110. {192, 12, 4, 1, 3, 4, 8, 2, -1, -1, -1, -1}, /* 26 MHz */
  111. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  112. {10, 0, 4, 1, 3, 4, 8, 2, -1, -1, -1, -1}, /* 38.4 MHz */
  113. };
  114. static const struct dpll_params iva_dpll_params_2330mhz[NUM_SYS_CLKS] = {
  115. {1165, 11, -1, -1, 5, 6, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  116. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  117. {208, 2, -1, -1, 5, 6, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  118. {182, 2, -1, -1, 5, 6, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  119. {224, 4, -1, -1, 5, 6, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  120. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  121. {91, 2, -1, -1, 5, 6, -1, -1, -1, -1, -1, -1} /* 38.4 MHz */
  122. };
  123. static const struct dpll_params iva_dpll_params_2330mhz_dra7xx[NUM_SYS_CLKS] = {
  124. {1165, 11, 3, 1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  125. {233, 3, 3, 1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 20 MHz */
  126. {208, 2, 3, 1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  127. {182, 2, 3, 1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  128. {224, 4, 3, 1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  129. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  130. {91, 2, 3, 1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 38.4 MHz */
  131. };
  132. /* ABE M & N values with sys_clk as source */
  133. #ifdef CONFIG_SYS_OMAP_ABE_SYSCK
  134. static const struct dpll_params
  135. abe_dpll_params_sysclk_196608khz[NUM_SYS_CLKS] = {
  136. {49, 5, 1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  137. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  138. {35, 5, 1, 1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  139. {46, 8, 1, 1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  140. {34, 8, 1, 1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  141. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  142. {64, 24, 1, 1, -1, -1, -1, -1, -1, -1, -1, -1} /* 38.4 MHz */
  143. };
  144. #endif
  145. /* ABE M & N values with 32K clock as source */
  146. #ifndef CONFIG_SYS_OMAP_ABE_SYSCK
  147. static const struct dpll_params abe_dpll_params_32k_196608khz = {
  148. 750, 0, 1, 1, -1, -1, -1, -1, -1, -1, -1, -1
  149. };
  150. #endif
  151. /* ABE M & N values with sysclk2(22.5792 MHz) as input */
  152. static const struct dpll_params
  153. abe_dpll_params_sysclk2_361267khz[NUM_SYS_CLKS] = {
  154. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  155. {16, 1, 1, 1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 20 MHz */
  156. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  157. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  158. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  159. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  160. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 38.4 MHz */
  161. };
  162. static const struct dpll_params usb_dpll_params_1920mhz[NUM_SYS_CLKS] = {
  163. {400, 4, 2, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  164. {480, 9, 2, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 20 MHz */
  165. {400, 6, 2, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  166. {400, 7, 2, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  167. {480, 12, 2, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  168. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  169. {400, 15, 2, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 38.4 MHz */
  170. };
  171. static const struct dpll_params ddr_dpll_params_2664mhz[NUM_SYS_CLKS] = {
  172. {111, 0, 2, 1, 8, -1, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  173. {333, 4, 2, 1, 8, -1, -1, -1, -1, -1, -1, -1}, /* 20 MHz */
  174. {555, 6, 2, 1, 8, -1, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  175. {555, 7, 2, 1, 8, -1, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  176. {666, 12, 2, 1, 8, -1, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  177. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  178. {555, 15, 2, 1, 8, -1, -1, -1, -1, -1, -1, -1}, /* 38.4 MHz */
  179. };
  180. static const struct dpll_params ddr_dpll_params_2128mhz[NUM_SYS_CLKS] = {
  181. {266, 2, 2, 1, 8, -1, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  182. {266, 4, 2, 1, 8, -1, -1, -1, -1, -1, -1, -1}, /* 20 MHz */
  183. {190, 2, 2, 1, 8, -1, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  184. {665, 11, 2, 1, 8, -1, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  185. {532, 12, 2, 1, 8, -1, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  186. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  187. {665, 23, 2, 1, 8, -1, -1, -1, -1, -1, -1, -1}, /* 38.4 MHz */
  188. };
  189. static const struct dpll_params gmac_dpll_params_2000mhz[NUM_SYS_CLKS] = {
  190. {250, 2, 4, 10, 40, 8, 10, -1, -1, -1, -1, -1}, /* 12 MHz */
  191. {250, 4, 4, 10, 40, 8, 10, -1, -1, -1, -1, -1}, /* 20 MHz */
  192. {119, 1, 4, 10, 40, 8, 10, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  193. {625, 11, 4, 10, 40, 8, 10, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  194. {500, 12, 4, 10, 40, 8, 10, -1, -1, -1, -1, -1}, /* 26 MHz */
  195. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  196. {625, 23, 4, 10, 40, 8, 10, -1, -1, -1, -1, -1}, /* 38.4 MHz */
  197. };
  198. struct dplls omap5_dplls_es1 = {
  199. .mpu = mpu_dpll_params_800mhz,
  200. .core = core_dpll_params_2128mhz_ddr532,
  201. .per = per_dpll_params_768mhz,
  202. .iva = iva_dpll_params_2330mhz,
  203. #ifdef CONFIG_SYS_OMAP_ABE_SYSCK
  204. .abe = abe_dpll_params_sysclk_196608khz,
  205. #else
  206. .abe = &abe_dpll_params_32k_196608khz,
  207. #endif
  208. .usb = usb_dpll_params_1920mhz,
  209. .ddr = NULL
  210. };
  211. struct dplls omap5_dplls_es2 = {
  212. .mpu = mpu_dpll_params_1ghz,
  213. .core = core_dpll_params_2128mhz_ddr532_es2,
  214. .per = per_dpll_params_768mhz_es2,
  215. .iva = iva_dpll_params_2330mhz,
  216. #ifdef CONFIG_SYS_OMAP_ABE_SYSCK
  217. .abe = abe_dpll_params_sysclk_196608khz,
  218. #else
  219. .abe = &abe_dpll_params_32k_196608khz,
  220. #endif
  221. .usb = usb_dpll_params_1920mhz,
  222. .ddr = NULL
  223. };
  224. struct dplls dra76x_dplls = {
  225. .mpu = mpu_dpll_params_1ghz,
  226. .core = core_dpll_params_2128mhz_dra7xx,
  227. .per = per_dpll_params_768mhz_dra76x,
  228. .abe = abe_dpll_params_sysclk2_361267khz,
  229. .iva = iva_dpll_params_2330mhz_dra7xx,
  230. .usb = usb_dpll_params_1920mhz,
  231. .ddr = ddr_dpll_params_2664mhz,
  232. .gmac = gmac_dpll_params_2000mhz,
  233. };
  234. struct dplls dra7xx_dplls = {
  235. .mpu = mpu_dpll_params_1ghz,
  236. .core = core_dpll_params_2128mhz_dra7xx,
  237. .per = per_dpll_params_768mhz_dra7xx,
  238. .abe = abe_dpll_params_sysclk2_361267khz,
  239. .iva = iva_dpll_params_2330mhz_dra7xx,
  240. .usb = usb_dpll_params_1920mhz,
  241. .ddr = ddr_dpll_params_2128mhz,
  242. .gmac = gmac_dpll_params_2000mhz,
  243. };
  244. struct dplls dra72x_dplls = {
  245. .mpu = mpu_dpll_params_1ghz,
  246. .core = core_dpll_params_2128mhz_dra7xx,
  247. .per = per_dpll_params_768mhz_dra7xx,
  248. .abe = abe_dpll_params_sysclk2_361267khz,
  249. .iva = iva_dpll_params_2330mhz_dra7xx,
  250. .usb = usb_dpll_params_1920mhz,
  251. .ddr = ddr_dpll_params_2664mhz,
  252. .gmac = gmac_dpll_params_2000mhz,
  253. };
  254. struct pmic_data palmas = {
  255. .base_offset = PALMAS_SMPS_BASE_VOLT_UV,
  256. .step = 10000, /* 10 mV represented in uV */
  257. /*
  258. * Offset codes 1-6 all give the base voltage in Palmas
  259. * Offset code 0 switches OFF the SMPS
  260. */
  261. .start_code = 6,
  262. .i2c_slave_addr = SMPS_I2C_SLAVE_ADDR,
  263. .pmic_bus_init = sri2c_init,
  264. .pmic_write = omap_vc_bypass_send_value,
  265. .gpio_en = 0,
  266. };
  267. /* The TPS659038 and TPS65917 are software-compatible, use common struct */
  268. struct pmic_data tps659038 = {
  269. .base_offset = PALMAS_SMPS_BASE_VOLT_UV,
  270. .step = 10000, /* 10 mV represented in uV */
  271. /*
  272. * Offset codes 1-6 all give the base voltage in Palmas
  273. * Offset code 0 switches OFF the SMPS
  274. */
  275. .start_code = 6,
  276. .i2c_slave_addr = TPS659038_I2C_SLAVE_ADDR,
  277. .pmic_bus_init = gpi2c_init,
  278. .pmic_write = palmas_i2c_write_u8,
  279. .gpio_en = 0,
  280. };
  281. /* The LP87565*/
  282. struct pmic_data lp87565 = {
  283. .base_offset = LP873X_BUCK_BASE_VOLT_UV,
  284. .step = 5000, /* 5 mV represented in uV */
  285. /*
  286. * Offset codes 0 - 0x13 Invalid.
  287. * Offset codes 0x14 0x17 give 10mV steps
  288. * Offset codes 0x17 through 0x9D give 5mV steps
  289. * So let us start with our operating range from .73V
  290. */
  291. .start_code = 0x17,
  292. .i2c_slave_addr = 0x60,
  293. .pmic_bus_init = gpi2c_init,
  294. .pmic_write = palmas_i2c_write_u8,
  295. };
  296. /* The LP8732 and LP8733 are software-compatible, use common struct */
  297. struct pmic_data lp8733 = {
  298. .base_offset = LP873X_BUCK_BASE_VOLT_UV,
  299. .step = 5000, /* 5 mV represented in uV */
  300. /*
  301. * Offset codes 0 - 0x13 Invalid.
  302. * Offset codes 0x14 0x17 give 10mV steps
  303. * Offset codes 0x17 through 0x9D give 5mV steps
  304. * So let us start with our operating range from .73V
  305. */
  306. .start_code = 0x17,
  307. .i2c_slave_addr = 0x60,
  308. .pmic_bus_init = gpi2c_init,
  309. .pmic_write = palmas_i2c_write_u8,
  310. };
  311. struct vcores_data omap5430_volts = {
  312. .mpu.value[OPP_NOM] = VDD_MPU,
  313. .mpu.addr = SMPS_REG_ADDR_12_MPU,
  314. .mpu.pmic = &palmas,
  315. .core.value[OPP_NOM] = VDD_CORE,
  316. .core.addr = SMPS_REG_ADDR_8_CORE,
  317. .core.pmic = &palmas,
  318. .mm.value[OPP_NOM] = VDD_MM,
  319. .mm.addr = SMPS_REG_ADDR_45_IVA,
  320. .mm.pmic = &palmas,
  321. };
  322. struct vcores_data omap5430_volts_es2 = {
  323. .mpu.value[OPP_NOM] = VDD_MPU_ES2,
  324. .mpu.addr = SMPS_REG_ADDR_12_MPU,
  325. .mpu.pmic = &palmas,
  326. .mpu.abb_tx_done_mask = OMAP_ABB_MPU_TXDONE_MASK,
  327. .core.value[OPP_NOM] = VDD_CORE_ES2,
  328. .core.addr = SMPS_REG_ADDR_8_CORE,
  329. .core.pmic = &palmas,
  330. .mm.value[OPP_NOM] = VDD_MM_ES2,
  331. .mm.addr = SMPS_REG_ADDR_45_IVA,
  332. .mm.pmic = &palmas,
  333. .mm.abb_tx_done_mask = OMAP_ABB_MM_TXDONE_MASK,
  334. .mpu.efuse.reg[OPP_NOM] = OMAP5_ES2_PROD_MPU_OPNO_VMIN,
  335. .mpu.efuse.reg_bits = OMAP5_ES2_PROD_REGBITS,
  336. .core.efuse.reg[OPP_NOM] = OMAP5_ES2_PROD_CORE_OPNO_VMIN,
  337. .core.efuse.reg_bits = OMAP5_ES2_PROD_REGBITS,
  338. .mm.efuse.reg[OPP_NOM] = OMAP5_ES2_PROD_MM_OPNO_VMIN,
  339. .mm.efuse.reg_bits = OMAP5_ES2_PROD_REGBITS,
  340. };
  341. /*
  342. * Enable essential clock domains, modules and
  343. * do some additional special settings needed
  344. */
  345. void enable_basic_clocks(void)
  346. {
  347. u32 const clk_domains_essential[] = {
  348. (*prcm)->cm_l4per_clkstctrl,
  349. (*prcm)->cm_l3init_clkstctrl,
  350. (*prcm)->cm_memif_clkstctrl,
  351. (*prcm)->cm_l4cfg_clkstctrl,
  352. #ifdef CONFIG_DRIVER_TI_CPSW
  353. (*prcm)->cm_gmac_clkstctrl,
  354. #endif
  355. 0
  356. };
  357. u32 const clk_modules_hw_auto_essential[] = {
  358. (*prcm)->cm_l3_gpmc_clkctrl,
  359. (*prcm)->cm_memif_emif_1_clkctrl,
  360. (*prcm)->cm_memif_emif_2_clkctrl,
  361. (*prcm)->cm_l4cfg_l4_cfg_clkctrl,
  362. (*prcm)->cm_wkup_gpio1_clkctrl,
  363. (*prcm)->cm_l4per_gpio2_clkctrl,
  364. (*prcm)->cm_l4per_gpio3_clkctrl,
  365. (*prcm)->cm_l4per_gpio4_clkctrl,
  366. (*prcm)->cm_l4per_gpio5_clkctrl,
  367. (*prcm)->cm_l4per_gpio6_clkctrl,
  368. (*prcm)->cm_l4per_gpio7_clkctrl,
  369. (*prcm)->cm_l4per_gpio8_clkctrl,
  370. #ifdef CONFIG_SCSI_AHCI_PLAT
  371. (*prcm)->cm_l3init_ocp2scp3_clkctrl,
  372. #endif
  373. 0
  374. };
  375. u32 const clk_modules_explicit_en_essential[] = {
  376. (*prcm)->cm_wkup_gptimer1_clkctrl,
  377. (*prcm)->cm_l3init_hsmmc1_clkctrl,
  378. (*prcm)->cm_l3init_hsmmc2_clkctrl,
  379. (*prcm)->cm_l4per_gptimer2_clkctrl,
  380. (*prcm)->cm_wkup_wdtimer2_clkctrl,
  381. (*prcm)->cm_l4per_uart3_clkctrl,
  382. (*prcm)->cm_l4per_i2c1_clkctrl,
  383. #ifdef CONFIG_DRIVER_TI_CPSW
  384. (*prcm)->cm_gmac_gmac_clkctrl,
  385. #endif
  386. #ifdef CONFIG_TI_QSPI
  387. (*prcm)->cm_l4per_qspi_clkctrl,
  388. #endif
  389. #ifdef CONFIG_SCSI_AHCI_PLAT
  390. (*prcm)->cm_l3init_sata_clkctrl,
  391. #endif
  392. 0
  393. };
  394. /* Enable optional additional functional clock for GPIO4 */
  395. setbits_le32((*prcm)->cm_l4per_gpio4_clkctrl,
  396. GPIO4_CLKCTRL_OPTFCLKEN_MASK);
  397. /* Enable 192 MHz clock for MMC1 & MMC2 */
  398. setbits_le32((*prcm)->cm_l3init_hsmmc1_clkctrl,
  399. HSMMC_CLKCTRL_CLKSEL_MASK);
  400. setbits_le32((*prcm)->cm_l3init_hsmmc2_clkctrl,
  401. HSMMC_CLKCTRL_CLKSEL_MASK);
  402. /* Set the correct clock dividers for mmc */
  403. clrbits_le32((*prcm)->cm_l3init_hsmmc1_clkctrl,
  404. HSMMC_CLKCTRL_CLKSEL_DIV_MASK);
  405. clrbits_le32((*prcm)->cm_l3init_hsmmc2_clkctrl,
  406. HSMMC_CLKCTRL_CLKSEL_DIV_MASK);
  407. /* Select 32KHz clock as the source of GPTIMER1 */
  408. setbits_le32((*prcm)->cm_wkup_gptimer1_clkctrl,
  409. GPTIMER1_CLKCTRL_CLKSEL_MASK);
  410. do_enable_clocks(clk_domains_essential,
  411. clk_modules_hw_auto_essential,
  412. clk_modules_explicit_en_essential,
  413. 1);
  414. #ifdef CONFIG_TI_QSPI
  415. setbits_le32((*prcm)->cm_l4per_qspi_clkctrl, (1<<24));
  416. #endif
  417. #ifdef CONFIG_SCSI_AHCI_PLAT
  418. /* Enable optional functional clock for SATA */
  419. setbits_le32((*prcm)->cm_l3init_sata_clkctrl,
  420. SATA_CLKCTRL_OPTFCLKEN_MASK);
  421. #endif
  422. /* Enable SCRM OPT clocks for PER and CORE dpll */
  423. setbits_le32((*prcm)->cm_wkupaon_scrm_clkctrl,
  424. OPTFCLKEN_SCRM_PER_MASK);
  425. setbits_le32((*prcm)->cm_wkupaon_scrm_clkctrl,
  426. OPTFCLKEN_SCRM_CORE_MASK);
  427. }
  428. void enable_basic_uboot_clocks(void)
  429. {
  430. u32 const clk_domains_essential[] = {
  431. #if defined(CONFIG_DRA7XX)
  432. (*prcm)->cm_ipu_clkstctrl,
  433. #endif
  434. 0
  435. };
  436. u32 const clk_modules_hw_auto_essential[] = {
  437. (*prcm)->cm_l3init_hsusbtll_clkctrl,
  438. 0
  439. };
  440. u32 const clk_modules_explicit_en_essential[] = {
  441. (*prcm)->cm_l4per_mcspi1_clkctrl,
  442. (*prcm)->cm_l4per_i2c2_clkctrl,
  443. (*prcm)->cm_l4per_i2c3_clkctrl,
  444. (*prcm)->cm_l4per_i2c4_clkctrl,
  445. #if defined(CONFIG_DRA7XX)
  446. (*prcm)->cm_ipu_i2c5_clkctrl,
  447. #else
  448. (*prcm)->cm_l4per_i2c5_clkctrl,
  449. #endif
  450. (*prcm)->cm_l3init_hsusbhost_clkctrl,
  451. (*prcm)->cm_l3init_fsusb_clkctrl,
  452. 0
  453. };
  454. do_enable_clocks(clk_domains_essential,
  455. clk_modules_hw_auto_essential,
  456. clk_modules_explicit_en_essential,
  457. 1);
  458. }
  459. #ifdef CONFIG_TI_EDMA3
  460. void enable_edma3_clocks(void)
  461. {
  462. u32 const clk_domains_edma3[] = {
  463. 0
  464. };
  465. u32 const clk_modules_hw_auto_edma3[] = {
  466. (*prcm)->cm_l3main1_tptc1_clkctrl,
  467. (*prcm)->cm_l3main1_tptc2_clkctrl,
  468. 0
  469. };
  470. u32 const clk_modules_explicit_en_edma3[] = {
  471. 0
  472. };
  473. do_enable_clocks(clk_domains_edma3,
  474. clk_modules_hw_auto_edma3,
  475. clk_modules_explicit_en_edma3,
  476. 1);
  477. }
  478. void disable_edma3_clocks(void)
  479. {
  480. u32 const clk_domains_edma3[] = {
  481. 0
  482. };
  483. u32 const clk_modules_disable_edma3[] = {
  484. (*prcm)->cm_l3main1_tptc1_clkctrl,
  485. (*prcm)->cm_l3main1_tptc2_clkctrl,
  486. 0
  487. };
  488. do_disable_clocks(clk_domains_edma3,
  489. clk_modules_disable_edma3,
  490. 1);
  491. }
  492. #endif
  493. #if defined(CONFIG_USB_DWC3) || defined(CONFIG_USB_XHCI_OMAP)
  494. void enable_usb_clocks(int index)
  495. {
  496. u32 cm_l3init_usb_otg_ss_clkctrl = 0;
  497. if (index == 0) {
  498. cm_l3init_usb_otg_ss_clkctrl =
  499. (*prcm)->cm_l3init_usb_otg_ss1_clkctrl;
  500. /* Enable 960 MHz clock for dwc3 */
  501. setbits_le32((*prcm)->cm_l3init_usb_otg_ss1_clkctrl,
  502. OPTFCLKEN_REFCLK960M);
  503. /* Enable 32 KHz clock for USB_PHY1 */
  504. setbits_le32((*prcm)->cm_coreaon_usb_phy1_core_clkctrl,
  505. USBPHY_CORE_CLKCTRL_OPTFCLKEN_CLK32K);
  506. /* Enable 32 KHz clock for USB_PHY3 */
  507. if (is_dra7xx())
  508. setbits_le32((*prcm)->cm_coreaon_usb_phy3_core_clkctrl,
  509. USBPHY_CORE_CLKCTRL_OPTFCLKEN_CLK32K);
  510. } else if (index == 1) {
  511. cm_l3init_usb_otg_ss_clkctrl =
  512. (*prcm)->cm_l3init_usb_otg_ss2_clkctrl;
  513. /* Enable 960 MHz clock for dwc3 */
  514. setbits_le32((*prcm)->cm_l3init_usb_otg_ss2_clkctrl,
  515. OPTFCLKEN_REFCLK960M);
  516. /* Enable 32 KHz clock for dwc3 */
  517. setbits_le32((*prcm)->cm_coreaon_usb_phy2_core_clkctrl,
  518. USBPHY_CORE_CLKCTRL_OPTFCLKEN_CLK32K);
  519. /* Enable 60 MHz clock for USB2PHY2 */
  520. setbits_le32((*prcm)->cm_coreaon_l3init_60m_gfclk_clkctrl,
  521. L3INIT_CLKCTRL_OPTFCLKEN_60M_GFCLK);
  522. }
  523. u32 const clk_domains_usb[] = {
  524. 0
  525. };
  526. u32 const clk_modules_hw_auto_usb[] = {
  527. (*prcm)->cm_l3init_ocp2scp1_clkctrl,
  528. cm_l3init_usb_otg_ss_clkctrl,
  529. 0
  530. };
  531. u32 const clk_modules_explicit_en_usb[] = {
  532. 0
  533. };
  534. do_enable_clocks(clk_domains_usb,
  535. clk_modules_hw_auto_usb,
  536. clk_modules_explicit_en_usb,
  537. 1);
  538. }
  539. void disable_usb_clocks(int index)
  540. {
  541. u32 cm_l3init_usb_otg_ss_clkctrl = 0;
  542. if (index == 0) {
  543. cm_l3init_usb_otg_ss_clkctrl =
  544. (*prcm)->cm_l3init_usb_otg_ss1_clkctrl;
  545. /* Disable 960 MHz clock for dwc3 */
  546. clrbits_le32((*prcm)->cm_l3init_usb_otg_ss1_clkctrl,
  547. OPTFCLKEN_REFCLK960M);
  548. /* Disable 32 KHz clock for USB_PHY1 */
  549. clrbits_le32((*prcm)->cm_coreaon_usb_phy1_core_clkctrl,
  550. USBPHY_CORE_CLKCTRL_OPTFCLKEN_CLK32K);
  551. /* Disable 32 KHz clock for USB_PHY3 */
  552. if (is_dra7xx())
  553. clrbits_le32((*prcm)->cm_coreaon_usb_phy3_core_clkctrl,
  554. USBPHY_CORE_CLKCTRL_OPTFCLKEN_CLK32K);
  555. } else if (index == 1) {
  556. cm_l3init_usb_otg_ss_clkctrl =
  557. (*prcm)->cm_l3init_usb_otg_ss2_clkctrl;
  558. /* Disable 960 MHz clock for dwc3 */
  559. clrbits_le32((*prcm)->cm_l3init_usb_otg_ss2_clkctrl,
  560. OPTFCLKEN_REFCLK960M);
  561. /* Disable 32 KHz clock for dwc3 */
  562. clrbits_le32((*prcm)->cm_coreaon_usb_phy2_core_clkctrl,
  563. USBPHY_CORE_CLKCTRL_OPTFCLKEN_CLK32K);
  564. /* Disable 60 MHz clock for USB2PHY2 */
  565. clrbits_le32((*prcm)->cm_coreaon_l3init_60m_gfclk_clkctrl,
  566. L3INIT_CLKCTRL_OPTFCLKEN_60M_GFCLK);
  567. }
  568. u32 const clk_domains_usb[] = {
  569. 0
  570. };
  571. u32 const clk_modules_disable[] = {
  572. (*prcm)->cm_l3init_ocp2scp1_clkctrl,
  573. cm_l3init_usb_otg_ss_clkctrl,
  574. 0
  575. };
  576. do_disable_clocks(clk_domains_usb,
  577. clk_modules_disable,
  578. 1);
  579. }
  580. #endif
  581. const struct ctrl_ioregs ioregs_omap5430 = {
  582. .ctrl_ddrch = DDR_IO_I_34OHM_SR_FASTEST_WD_DQ_NO_PULL_DQS_PULL_DOWN,
  583. .ctrl_lpddr2ch = DDR_IO_I_34OHM_SR_FASTEST_WD_CK_CKE_NCS_CA_PULL_DOWN,
  584. .ctrl_ddrio_0 = DDR_IO_0_DDR2_DQ_INT_EN_ALL_DDR3_CA_DIS_ALL,
  585. .ctrl_ddrio_1 = DDR_IO_1_DQ_OUT_EN_ALL_DQ_INT_EN_ALL,
  586. .ctrl_ddrio_2 = DDR_IO_2_CA_OUT_EN_ALL_CA_INT_EN_ALL,
  587. };
  588. const struct ctrl_ioregs ioregs_omap5432_es1 = {
  589. .ctrl_ddrch = DDR_IO_I_40OHM_SR_FAST_WD_DQ_NO_PULL_DQS_NO_PULL,
  590. .ctrl_lpddr2ch = 0x0,
  591. .ctrl_ddr3ch = DDR_IO_I_40OHM_SR_SLOWEST_WD_DQ_NO_PULL_DQS_NO_PULL,
  592. .ctrl_ddrio_0 = DDR_IO_0_VREF_CELLS_DDR3_VALUE,
  593. .ctrl_ddrio_1 = DDR_IO_1_VREF_CELLS_DDR3_VALUE,
  594. .ctrl_ddrio_2 = DDR_IO_2_VREF_CELLS_DDR3_VALUE,
  595. .ctrl_emif_sdram_config_ext = SDRAM_CONFIG_EXT_RD_LVL_11_SAMPLES,
  596. .ctrl_emif_sdram_config_ext_final = SDRAM_CONFIG_EXT_RD_LVL_4_SAMPLES,
  597. };
  598. const struct ctrl_ioregs ioregs_omap5432_es2 = {
  599. .ctrl_ddrch = DDR_IO_I_40OHM_SR_FAST_WD_DQ_NO_PULL_DQS_NO_PULL_ES2,
  600. .ctrl_lpddr2ch = 0x0,
  601. .ctrl_ddr3ch = DDR_IO_I_40OHM_SR_SLOWEST_WD_DQ_NO_PULL_DQS_NO_PULL_ES2,
  602. .ctrl_ddrio_0 = DDR_IO_0_VREF_CELLS_DDR3_VALUE_ES2,
  603. .ctrl_ddrio_1 = DDR_IO_1_VREF_CELLS_DDR3_VALUE_ES2,
  604. .ctrl_ddrio_2 = DDR_IO_2_VREF_CELLS_DDR3_VALUE_ES2,
  605. .ctrl_emif_sdram_config_ext = SDRAM_CONFIG_EXT_RD_LVL_11_SAMPLES,
  606. .ctrl_emif_sdram_config_ext_final = SDRAM_CONFIG_EXT_RD_LVL_4_SAMPLES,
  607. };
  608. const struct ctrl_ioregs ioregs_dra7xx_es1 = {
  609. .ctrl_ddrch = 0x40404040,
  610. .ctrl_lpddr2ch = 0x40404040,
  611. .ctrl_ddr3ch = 0x80808080,
  612. .ctrl_ddrio_0 = 0x00094A40,
  613. .ctrl_ddrio_1 = 0x04A52000,
  614. .ctrl_ddrio_2 = 0x84210000,
  615. .ctrl_emif_sdram_config_ext = 0x0001C1A7,
  616. .ctrl_emif_sdram_config_ext_final = 0x0001C1A7,
  617. .ctrl_ddr_ctrl_ext_0 = 0xA2000000,
  618. };
  619. const struct ctrl_ioregs ioregs_dra72x_es1 = {
  620. .ctrl_ddrch = 0x40404040,
  621. .ctrl_lpddr2ch = 0x40404040,
  622. .ctrl_ddr3ch = 0x60606080,
  623. .ctrl_ddrio_0 = 0x00094A40,
  624. .ctrl_ddrio_1 = 0x04A52000,
  625. .ctrl_ddrio_2 = 0x84210000,
  626. .ctrl_emif_sdram_config_ext = 0x0001C1A7,
  627. .ctrl_emif_sdram_config_ext_final = 0x0001C1A7,
  628. .ctrl_ddr_ctrl_ext_0 = 0xA2000000,
  629. };
  630. const struct ctrl_ioregs ioregs_dra72x_es2 = {
  631. .ctrl_ddrch = 0x40404040,
  632. .ctrl_lpddr2ch = 0x40404040,
  633. .ctrl_ddr3ch = 0x60606060,
  634. .ctrl_ddrio_0 = 0x00094A40,
  635. .ctrl_ddrio_1 = 0x00000000,
  636. .ctrl_ddrio_2 = 0x00000000,
  637. .ctrl_emif_sdram_config_ext = 0x0001C1A7,
  638. .ctrl_emif_sdram_config_ext_final = 0x0001C1A7,
  639. .ctrl_ddr_ctrl_ext_0 = 0xA2000000,
  640. };
  641. void __weak hw_data_init(void)
  642. {
  643. u32 omap_rev = omap_revision();
  644. switch (omap_rev) {
  645. case OMAP5430_ES1_0:
  646. case OMAP5432_ES1_0:
  647. *prcm = &omap5_es1_prcm;
  648. *dplls_data = &omap5_dplls_es1;
  649. *omap_vcores = &omap5430_volts;
  650. *ctrl = &omap5_ctrl;
  651. break;
  652. case OMAP5430_ES2_0:
  653. case OMAP5432_ES2_0:
  654. *prcm = &omap5_es2_prcm;
  655. *dplls_data = &omap5_dplls_es2;
  656. *omap_vcores = &omap5430_volts_es2;
  657. *ctrl = &omap5_ctrl;
  658. break;
  659. case DRA762_ABZ_ES1_0:
  660. case DRA762_ACD_ES1_0:
  661. case DRA762_ES1_0:
  662. *prcm = &dra7xx_prcm;
  663. *dplls_data = &dra76x_dplls;
  664. *ctrl = &dra7xx_ctrl;
  665. break;
  666. case DRA752_ES1_0:
  667. case DRA752_ES1_1:
  668. case DRA752_ES2_0:
  669. *prcm = &dra7xx_prcm;
  670. *dplls_data = &dra7xx_dplls;
  671. *ctrl = &dra7xx_ctrl;
  672. break;
  673. case DRA722_ES1_0:
  674. case DRA722_ES2_0:
  675. case DRA722_ES2_1:
  676. *prcm = &dra7xx_prcm;
  677. *dplls_data = &dra72x_dplls;
  678. *ctrl = &dra7xx_ctrl;
  679. break;
  680. default:
  681. printf("\n INVALID OMAP REVISION ");
  682. }
  683. }
  684. void get_ioregs(const struct ctrl_ioregs **regs)
  685. {
  686. u32 omap_rev = omap_revision();
  687. switch (omap_rev) {
  688. case OMAP5430_ES1_0:
  689. case OMAP5430_ES2_0:
  690. *regs = &ioregs_omap5430;
  691. break;
  692. case OMAP5432_ES1_0:
  693. *regs = &ioregs_omap5432_es1;
  694. break;
  695. case OMAP5432_ES2_0:
  696. *regs = &ioregs_omap5432_es2;
  697. break;
  698. case DRA752_ES1_0:
  699. case DRA752_ES1_1:
  700. case DRA752_ES2_0:
  701. case DRA762_ES1_0:
  702. case DRA762_ACD_ES1_0:
  703. case DRA762_ABZ_ES1_0:
  704. *regs = &ioregs_dra7xx_es1;
  705. break;
  706. case DRA722_ES1_0:
  707. *regs = &ioregs_dra72x_es1;
  708. break;
  709. case DRA722_ES2_0:
  710. case DRA722_ES2_1:
  711. *regs = &ioregs_dra72x_es2;
  712. break;
  713. default:
  714. printf("\n INVALID OMAP REVISION ");
  715. }
  716. }