hw_data.c 25 KB

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