clocks.c 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495
  1. /*
  2. *
  3. * Clock initialization for OMAP5
  4. *
  5. * (C) Copyright 2010
  6. * Texas Instruments, <www.ti.com>
  7. *
  8. * Aneesh V <aneesh@ti.com>
  9. * Sricharan R <r.sricharan@ti.com>
  10. *
  11. * Based on previous work by:
  12. * Santosh Shilimkar <santosh.shilimkar@ti.com>
  13. * Rajendra Nayak <rnayak@ti.com>
  14. *
  15. * See file CREDITS for list of people who contributed to this
  16. * project.
  17. *
  18. * This program is free software; you can redistribute it and/or
  19. * modify it under the terms of the GNU General Public License as
  20. * published by the Free Software Foundation; either version 2 of
  21. * the License, or (at your option) any later version.
  22. *
  23. * This program is distributed in the hope that it will be useful,
  24. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  25. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  26. * GNU General Public License for more details.
  27. *
  28. * You should have received a copy of the GNU General Public License
  29. * along with this program; if not, write to the Free Software
  30. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  31. * MA 02111-1307 USA
  32. */
  33. #include <common.h>
  34. #include <asm/omap_common.h>
  35. #include <asm/arch/clocks.h>
  36. #include <asm/arch/sys_proto.h>
  37. #include <asm/utils.h>
  38. #include <asm/omap_gpio.h>
  39. #include <asm/emif.h>
  40. #ifndef CONFIG_SPL_BUILD
  41. /*
  42. * printing to console doesn't work unless
  43. * this code is executed from SPL
  44. */
  45. #define printf(fmt, args...)
  46. #define puts(s)
  47. #endif
  48. struct omap5_prcm_regs *const prcm = (struct omap5_prcm_regs *)0x4A004100;
  49. const u32 sys_clk_array[8] = {
  50. 12000000, /* 12 MHz */
  51. 0, /* NA */
  52. 16800000, /* 16.8 MHz */
  53. 19200000, /* 19.2 MHz */
  54. 26000000, /* 26 MHz */
  55. 0, /* NA */
  56. 38400000, /* 38.4 MHz */
  57. };
  58. static const struct dpll_params mpu_dpll_params_1_5ghz[NUM_SYS_CLKS] = {
  59. {125, 0, 1, -1, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  60. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  61. {625, 6, 1, -1, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  62. {625, 7, 1, -1, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  63. {750, 12, 1, -1, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  64. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  65. {625, 15, 1, -1, -1, -1, -1, -1, -1, -1} /* 38.4 MHz */
  66. };
  67. static const struct dpll_params mpu_dpll_params_2ghz[NUM_SYS_CLKS] = {
  68. {500, 2, 1, -1, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  69. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  70. {2024, 16, 1, -1, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  71. {625, 5, 1, -1, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  72. {1000, 12, 1, -1, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  73. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  74. {625, 11, 1, -1, -1, -1, -1, -1, -1, -1} /* 38.4 MHz */
  75. };
  76. static const struct dpll_params mpu_dpll_params_1100mhz[NUM_SYS_CLKS] = {
  77. {275, 2, 1, -1, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  78. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  79. {1375, 20, 1, -1, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  80. {1375, 23, 1, -1, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  81. {550, 12, 1, -1, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  82. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  83. {1375, 47, 1, -1, -1, -1, -1, -1, -1, -1} /* 38.4 MHz */
  84. };
  85. static const struct dpll_params mpu_dpll_params_800mhz[NUM_SYS_CLKS] = {
  86. {200, 2, 1, -1, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  87. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  88. {1000, 20, 1, -1, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  89. {375, 8, 1, -1, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  90. {400, 12, 1, -1, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  91. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  92. {375, 17, 1, -1, -1, -1, -1, -1, -1, -1} /* 38.4 MHz */
  93. };
  94. static const struct dpll_params mpu_dpll_params_400mhz[NUM_SYS_CLKS] = {
  95. {200, 2, 2, -1, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  96. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  97. {1000, 20, 2, -1, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  98. {375, 8, 2, -1, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  99. {400, 12, 2, -1, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  100. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  101. {375, 17, 2, -1, -1, -1, -1, -1, -1, -1} /* 38.4 MHz */
  102. };
  103. static const struct dpll_params mpu_dpll_params_550mhz[NUM_SYS_CLKS] = {
  104. {275, 2, 2, -1, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  105. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  106. {1375, 20, 2, -1, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  107. {1375, 23, 2, -1, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  108. {550, 12, 2, -1, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  109. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  110. {1375, 47, 2, -1, -1, -1, -1, -1, -1, -1} /* 38.4 MHz */
  111. };
  112. static const struct dpll_params
  113. core_dpll_params_2128mhz_ddr532[NUM_SYS_CLKS] = {
  114. {266, 2, 2, 5, 8, 4, 62, 5, 5, 7}, /* 12 MHz */
  115. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  116. {570, 8, 2, 5, 8, 4, 62, 5, 5, 7}, /* 16.8 MHz */
  117. {665, 11, 2, 5, 8, 4, 62, 5, 5, 7}, /* 19.2 MHz */
  118. {532, 12, 2, 5, 8, 4, 62, 5, 5, 7}, /* 26 MHz */
  119. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  120. {665, 23, 2, 5, 8, 4, 62, 5, 5, 7} /* 38.4 MHz */
  121. };
  122. static const struct dpll_params
  123. core_dpll_params_2128mhz_ddr266[NUM_SYS_CLKS] = {
  124. {266, 2, 4, 5, 8, 8, 62, 10, 10, 14}, /* 12 MHz */
  125. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  126. {570, 8, 4, 5, 8, 8, 62, 10, 10, 14}, /* 16.8 MHz */
  127. {665, 11, 4, 5, 8, 8, 62, 10, 10, 14}, /* 19.2 MHz */
  128. {532, 12, 4, 8, 8, 8, 62, 10, 10, 14}, /* 26 MHz */
  129. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  130. {665, 23, 4, 8, 8, 8, 62, 10, 10, 14} /* 38.4 MHz */
  131. };
  132. static const struct dpll_params per_dpll_params_768mhz[NUM_SYS_CLKS] = {
  133. {32, 0, 4, 3, 6, 4, -1, 2, -1, -1}, /* 12 MHz */
  134. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  135. {160, 6, 4, 3, 6, 4, -1, 2, -1, -1}, /* 16.8 MHz */
  136. {20, 0, 4, 3, 6, 4, -1, 2, -1, -1}, /* 19.2 MHz */
  137. {192, 12, 4, 3, 6, 4, -1, 2, -1, -1}, /* 26 MHz */
  138. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  139. {10, 0, 4, 3, 6, 4, -1, 2, -1, -1} /* 38.4 MHz */
  140. };
  141. static const struct dpll_params iva_dpll_params_2330mhz[NUM_SYS_CLKS] = {
  142. {1165, 11, -1, -1, 5, 6, -1, -1, -1, -1}, /* 12 MHz */
  143. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  144. {2011, 28, -1, -1, 5, 6, -1, -1, -1, -1}, /* 16.8 MHz */
  145. {1881, 30, -1, -1, 5, 6, -1, -1, -1, -1}, /* 19.2 MHz */
  146. {1165, 25, -1, -1, 5, 6, -1, -1, -1, -1}, /* 26 MHz */
  147. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  148. {1972, 64, -1, -1, 5, 6, -1, -1, -1, -1} /* 38.4 MHz */
  149. };
  150. /* ABE M & N values with sys_clk as source */
  151. static const struct dpll_params
  152. abe_dpll_params_sysclk_196608khz[NUM_SYS_CLKS] = {
  153. {49, 5, 1, -1, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  154. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  155. {35, 5, 1, 1, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  156. {46, 8, 1, 1, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  157. {34, 8, 1, 1, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  158. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  159. {64, 24, 1, 1, -1, -1, -1, -1, -1, -1} /* 38.4 MHz */
  160. };
  161. /* ABE M & N values with 32K clock as source */
  162. static const struct dpll_params abe_dpll_params_32k_196608khz = {
  163. 750, 0, 1, 1, -1, -1, -1, -1, -1, -1
  164. };
  165. static const struct dpll_params usb_dpll_params_1920mhz[NUM_SYS_CLKS] = {
  166. {400, 4, 2, -1, -1, -1, -1, -1, -1, -1}, /* 12 MHz */
  167. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 13 MHz */
  168. {400, 6, 2, -1, -1, -1, -1, -1, -1, -1}, /* 16.8 MHz */
  169. {400, 7, 2, -1, -1, -1, -1, -1, -1, -1}, /* 19.2 MHz */
  170. {480, 12, 2, -1, -1, -1, -1, -1, -1, -1}, /* 26 MHz */
  171. {-1, -1, -1, -1, -1, -1, -1, -1, -1, -1}, /* 27 MHz */
  172. {400, 15, 2, -1, -1, -1, -1, -1, -1, -1} /* 38.4 MHz */
  173. };
  174. void setup_post_dividers(u32 *const base, const struct dpll_params *params)
  175. {
  176. struct dpll_regs *const dpll_regs = (struct dpll_regs *)base;
  177. /* Setup post-dividers */
  178. if (params->m2 >= 0)
  179. writel(params->m2, &dpll_regs->cm_div_m2_dpll);
  180. if (params->m3 >= 0)
  181. writel(params->m3, &dpll_regs->cm_div_m3_dpll);
  182. if (params->h11 >= 0)
  183. writel(params->h11, &dpll_regs->cm_div_h11_dpll);
  184. if (params->h12 >= 0)
  185. writel(params->h12, &dpll_regs->cm_div_h12_dpll);
  186. if (params->h13 >= 0)
  187. writel(params->h13, &dpll_regs->cm_div_h13_dpll);
  188. if (params->h14 >= 0)
  189. writel(params->h14, &dpll_regs->cm_div_h14_dpll);
  190. if (params->h22 >= 0)
  191. writel(params->h22, &dpll_regs->cm_div_h22_dpll);
  192. if (params->h23 >= 0)
  193. writel(params->h23, &dpll_regs->cm_div_h23_dpll);
  194. }
  195. const struct dpll_params *get_mpu_dpll_params(void)
  196. {
  197. u32 sysclk_ind = get_sys_clk_index();
  198. return &mpu_dpll_params_800mhz[sysclk_ind];
  199. }
  200. const struct dpll_params *get_core_dpll_params(void)
  201. {
  202. u32 sysclk_ind = get_sys_clk_index();
  203. /* Configuring the DDR to be at 532mhz */
  204. return &core_dpll_params_2128mhz_ddr532[sysclk_ind];
  205. }
  206. const struct dpll_params *get_per_dpll_params(void)
  207. {
  208. u32 sysclk_ind = get_sys_clk_index();
  209. return &per_dpll_params_768mhz[sysclk_ind];
  210. }
  211. const struct dpll_params *get_iva_dpll_params(void)
  212. {
  213. u32 sysclk_ind = get_sys_clk_index();
  214. return &iva_dpll_params_2330mhz[sysclk_ind];
  215. }
  216. const struct dpll_params *get_usb_dpll_params(void)
  217. {
  218. u32 sysclk_ind = get_sys_clk_index();
  219. return &usb_dpll_params_1920mhz[sysclk_ind];
  220. }
  221. const struct dpll_params *get_abe_dpll_params(void)
  222. {
  223. #ifdef CONFIG_SYS_OMAP_ABE_SYSCK
  224. u32 sysclk_ind = get_sys_clk_index();
  225. return &abe_dpll_params_sysclk_196608khz[sysclk_ind];
  226. #else
  227. return &abe_dpll_params_32k_196608khz;
  228. #endif
  229. }
  230. /*
  231. * Setup the voltages for vdd_mpu, vdd_core, and vdd_iva
  232. * We set the maximum voltages allowed here because Smart-Reflex is not
  233. * enabled in bootloader. Voltage initialization in the kernel will set
  234. * these to the nominal values after enabling Smart-Reflex
  235. */
  236. void scale_vcores(void)
  237. {
  238. u32 volt_core, volt_mpu, volt_mm;
  239. omap_vc_init(PRM_VC_I2C_CHANNEL_FREQ_KHZ);
  240. /* Palmas settings */
  241. if (omap_revision() != OMAP5432_ES1_0) {
  242. volt_core = VDD_CORE;
  243. volt_mpu = VDD_MPU;
  244. volt_mm = VDD_MM;
  245. } else {
  246. volt_core = VDD_CORE_5432;
  247. volt_mpu = VDD_MPU_5432;
  248. volt_mm = VDD_MM_5432;
  249. }
  250. do_scale_vcore(SMPS_REG_ADDR_8_CORE, volt_core);
  251. do_scale_vcore(SMPS_REG_ADDR_12_MPU, volt_mpu);
  252. do_scale_vcore(SMPS_REG_ADDR_45_IVA, volt_mm);
  253. if (emif_sdram_type() == EMIF_SDRAM_TYPE_DDR3) {
  254. /* Configure LDO SRAM "magic" bits */
  255. writel(2, &prcm->prm_sldo_core_setup);
  256. writel(2, &prcm->prm_sldo_mpu_setup);
  257. writel(2, &prcm->prm_sldo_mm_setup);
  258. }
  259. }
  260. u32 get_offset_code(u32 volt_offset)
  261. {
  262. u32 offset_code, step = 10000; /* 10 mV represented in uV */
  263. volt_offset -= PALMAS_SMPS_BASE_VOLT_UV;
  264. offset_code = (volt_offset + step - 1) / step;
  265. /*
  266. * Offset codes 1-6 all give the base voltage in Palmas
  267. * Offset code 0 switches OFF the SMPS
  268. */
  269. return offset_code + 6;
  270. }
  271. /*
  272. * Enable essential clock domains, modules and
  273. * do some additional special settings needed
  274. */
  275. void enable_basic_clocks(void)
  276. {
  277. u32 *const clk_domains_essential[] = {
  278. &prcm->cm_l4per_clkstctrl,
  279. &prcm->cm_l3init_clkstctrl,
  280. &prcm->cm_memif_clkstctrl,
  281. &prcm->cm_l4cfg_clkstctrl,
  282. 0
  283. };
  284. u32 *const clk_modules_hw_auto_essential[] = {
  285. &prcm->cm_l3_2_gpmc_clkctrl,
  286. &prcm->cm_memif_emif_1_clkctrl,
  287. &prcm->cm_memif_emif_2_clkctrl,
  288. &prcm->cm_l4cfg_l4_cfg_clkctrl,
  289. &prcm->cm_wkup_gpio1_clkctrl,
  290. &prcm->cm_l4per_gpio2_clkctrl,
  291. &prcm->cm_l4per_gpio3_clkctrl,
  292. &prcm->cm_l4per_gpio4_clkctrl,
  293. &prcm->cm_l4per_gpio5_clkctrl,
  294. &prcm->cm_l4per_gpio6_clkctrl,
  295. 0
  296. };
  297. u32 *const clk_modules_explicit_en_essential[] = {
  298. &prcm->cm_wkup_gptimer1_clkctrl,
  299. &prcm->cm_l3init_hsmmc1_clkctrl,
  300. &prcm->cm_l3init_hsmmc2_clkctrl,
  301. &prcm->cm_l4per_gptimer2_clkctrl,
  302. &prcm->cm_wkup_wdtimer2_clkctrl,
  303. &prcm->cm_l4per_uart3_clkctrl,
  304. &prcm->cm_l4per_i2c1_clkctrl,
  305. 0
  306. };
  307. /* Enable optional additional functional clock for GPIO4 */
  308. setbits_le32(&prcm->cm_l4per_gpio4_clkctrl,
  309. GPIO4_CLKCTRL_OPTFCLKEN_MASK);
  310. /* Enable 96 MHz clock for MMC1 & MMC2 */
  311. setbits_le32(&prcm->cm_l3init_hsmmc1_clkctrl,
  312. HSMMC_CLKCTRL_CLKSEL_MASK);
  313. setbits_le32(&prcm->cm_l3init_hsmmc2_clkctrl,
  314. HSMMC_CLKCTRL_CLKSEL_MASK);
  315. /* Set the correct clock dividers for mmc */
  316. setbits_le32(&prcm->cm_l3init_hsmmc1_clkctrl,
  317. HSMMC_CLKCTRL_CLKSEL_DIV_MASK);
  318. setbits_le32(&prcm->cm_l3init_hsmmc2_clkctrl,
  319. HSMMC_CLKCTRL_CLKSEL_DIV_MASK);
  320. /* Select 32KHz clock as the source of GPTIMER1 */
  321. setbits_le32(&prcm->cm_wkup_gptimer1_clkctrl,
  322. GPTIMER1_CLKCTRL_CLKSEL_MASK);
  323. do_enable_clocks(clk_domains_essential,
  324. clk_modules_hw_auto_essential,
  325. clk_modules_explicit_en_essential,
  326. 1);
  327. /* Select 384Mhz for GPU as its the POR for ES1.0 */
  328. setbits_le32(&prcm->cm_sgx_sgx_clkctrl,
  329. CLKSEL_GPU_HYD_GCLK_MASK);
  330. setbits_le32(&prcm->cm_sgx_sgx_clkctrl,
  331. CLKSEL_GPU_CORE_GCLK_MASK);
  332. /* Enable SCRM OPT clocks for PER and CORE dpll */
  333. setbits_le32(&prcm->cm_wkupaon_scrm_clkctrl,
  334. OPTFCLKEN_SCRM_PER_MASK);
  335. setbits_le32(&prcm->cm_wkupaon_scrm_clkctrl,
  336. OPTFCLKEN_SCRM_CORE_MASK);
  337. }
  338. void enable_basic_uboot_clocks(void)
  339. {
  340. u32 *const clk_domains_essential[] = {
  341. 0
  342. };
  343. u32 *const clk_modules_hw_auto_essential[] = {
  344. 0
  345. };
  346. u32 *const clk_modules_explicit_en_essential[] = {
  347. &prcm->cm_l4per_mcspi1_clkctrl,
  348. &prcm->cm_l4per_i2c2_clkctrl,
  349. &prcm->cm_l4per_i2c3_clkctrl,
  350. &prcm->cm_l4per_i2c4_clkctrl,
  351. &prcm->cm_l3init_hsusbtll_clkctrl,
  352. &prcm->cm_l3init_hsusbhost_clkctrl,
  353. &prcm->cm_l3init_fsusb_clkctrl,
  354. 0
  355. };
  356. do_enable_clocks(clk_domains_essential,
  357. clk_modules_hw_auto_essential,
  358. clk_modules_explicit_en_essential,
  359. 1);
  360. }
  361. /*
  362. * Enable non-essential clock domains, modules and
  363. * do some additional special settings needed
  364. */
  365. void enable_non_essential_clocks(void)
  366. {
  367. u32 *const clk_domains_non_essential[] = {
  368. &prcm->cm_mpu_m3_clkstctrl,
  369. &prcm->cm_ivahd_clkstctrl,
  370. &prcm->cm_dsp_clkstctrl,
  371. &prcm->cm_dss_clkstctrl,
  372. &prcm->cm_sgx_clkstctrl,
  373. &prcm->cm1_abe_clkstctrl,
  374. &prcm->cm_c2c_clkstctrl,
  375. &prcm->cm_cam_clkstctrl,
  376. &prcm->cm_dss_clkstctrl,
  377. &prcm->cm_sdma_clkstctrl,
  378. 0
  379. };
  380. u32 *const clk_modules_hw_auto_non_essential[] = {
  381. &prcm->cm_mpu_m3_mpu_m3_clkctrl,
  382. &prcm->cm_ivahd_ivahd_clkctrl,
  383. &prcm->cm_ivahd_sl2_clkctrl,
  384. &prcm->cm_dsp_dsp_clkctrl,
  385. &prcm->cm_l3instr_l3_3_clkctrl,
  386. &prcm->cm_l3instr_l3_instr_clkctrl,
  387. &prcm->cm_l3instr_intrconn_wp1_clkctrl,
  388. &prcm->cm_l3init_hsi_clkctrl,
  389. &prcm->cm_l4per_hdq1w_clkctrl,
  390. 0
  391. };
  392. u32 *const clk_modules_explicit_en_non_essential[] = {
  393. &prcm->cm1_abe_aess_clkctrl,
  394. &prcm->cm1_abe_pdm_clkctrl,
  395. &prcm->cm1_abe_dmic_clkctrl,
  396. &prcm->cm1_abe_mcasp_clkctrl,
  397. &prcm->cm1_abe_mcbsp1_clkctrl,
  398. &prcm->cm1_abe_mcbsp2_clkctrl,
  399. &prcm->cm1_abe_mcbsp3_clkctrl,
  400. &prcm->cm1_abe_slimbus_clkctrl,
  401. &prcm->cm1_abe_timer5_clkctrl,
  402. &prcm->cm1_abe_timer6_clkctrl,
  403. &prcm->cm1_abe_timer7_clkctrl,
  404. &prcm->cm1_abe_timer8_clkctrl,
  405. &prcm->cm1_abe_wdt3_clkctrl,
  406. &prcm->cm_l4per_gptimer9_clkctrl,
  407. &prcm->cm_l4per_gptimer10_clkctrl,
  408. &prcm->cm_l4per_gptimer11_clkctrl,
  409. &prcm->cm_l4per_gptimer3_clkctrl,
  410. &prcm->cm_l4per_gptimer4_clkctrl,
  411. &prcm->cm_l4per_mcspi2_clkctrl,
  412. &prcm->cm_l4per_mcspi3_clkctrl,
  413. &prcm->cm_l4per_mcspi4_clkctrl,
  414. &prcm->cm_l4per_mmcsd3_clkctrl,
  415. &prcm->cm_l4per_mmcsd4_clkctrl,
  416. &prcm->cm_l4per_mmcsd5_clkctrl,
  417. &prcm->cm_l4per_uart1_clkctrl,
  418. &prcm->cm_l4per_uart2_clkctrl,
  419. &prcm->cm_l4per_uart4_clkctrl,
  420. &prcm->cm_wkup_keyboard_clkctrl,
  421. &prcm->cm_wkup_wdtimer2_clkctrl,
  422. &prcm->cm_cam_iss_clkctrl,
  423. &prcm->cm_cam_fdif_clkctrl,
  424. &prcm->cm_dss_dss_clkctrl,
  425. &prcm->cm_sgx_sgx_clkctrl,
  426. 0
  427. };
  428. /* Enable optional functional clock for ISS */
  429. setbits_le32(&prcm->cm_cam_iss_clkctrl, ISS_CLKCTRL_OPTFCLKEN_MASK);
  430. /* Enable all optional functional clocks of DSS */
  431. setbits_le32(&prcm->cm_dss_dss_clkctrl, DSS_CLKCTRL_OPTFCLKEN_MASK);
  432. do_enable_clocks(clk_domains_non_essential,
  433. clk_modules_hw_auto_non_essential,
  434. clk_modules_explicit_en_non_essential,
  435. 0);
  436. /* Put camera module in no sleep mode */
  437. clrsetbits_le32(&prcm->cm_cam_clkstctrl, MODULE_CLKCTRL_MODULEMODE_MASK,
  438. CD_CLKCTRL_CLKTRCTRL_NO_SLEEP <<
  439. MODULE_CLKCTRL_MODULEMODE_SHIFT);
  440. }