clock.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525
  1. /*
  2. * Copyright (C) 2009 ST-Ericsson
  3. * Copyright (C) 2009 STMicroelectronics
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License version 2 as
  7. * published by the Free Software Foundation.
  8. */
  9. #include <linux/module.h>
  10. #include <linux/kernel.h>
  11. #include <linux/list.h>
  12. #include <linux/errno.h>
  13. #include <linux/err.h>
  14. #include <linux/clk.h>
  15. #include <linux/io.h>
  16. #include <asm/clkdev.h>
  17. #include <mach/hardware.h>
  18. #include "clock.h"
  19. #define PRCC_PCKEN 0x00
  20. #define PRCC_PCKDIS 0x04
  21. #define PRCC_KCKEN 0x08
  22. #define PRCC_KCKDIS 0x0C
  23. #define PRCM_YYCLKEN0_MGT_SET 0x510
  24. #define PRCM_YYCLKEN1_MGT_SET 0x514
  25. #define PRCM_YYCLKEN0_MGT_CLR 0x518
  26. #define PRCM_YYCLKEN1_MGT_CLR 0x51C
  27. #define PRCM_YYCLKEN0_MGT_VAL 0x520
  28. #define PRCM_YYCLKEN1_MGT_VAL 0x524
  29. #define PRCM_SVAMMDSPCLK_MGT 0x008
  30. #define PRCM_SIAMMDSPCLK_MGT 0x00C
  31. #define PRCM_SGACLK_MGT 0x014
  32. #define PRCM_UARTCLK_MGT 0x018
  33. #define PRCM_MSP02CLK_MGT 0x01C
  34. #define PRCM_MSP1CLK_MGT 0x288
  35. #define PRCM_I2CCLK_MGT 0x020
  36. #define PRCM_SDMMCCLK_MGT 0x024
  37. #define PRCM_SLIMCLK_MGT 0x028
  38. #define PRCM_PER1CLK_MGT 0x02C
  39. #define PRCM_PER2CLK_MGT 0x030
  40. #define PRCM_PER3CLK_MGT 0x034
  41. #define PRCM_PER5CLK_MGT 0x038
  42. #define PRCM_PER6CLK_MGT 0x03C
  43. #define PRCM_PER7CLK_MGT 0x040
  44. #define PRCM_LCDCLK_MGT 0x044
  45. #define PRCM_BMLCLK_MGT 0x04C
  46. #define PRCM_HSITXCLK_MGT 0x050
  47. #define PRCM_HSIRXCLK_MGT 0x054
  48. #define PRCM_HDMICLK_MGT 0x058
  49. #define PRCM_APEATCLK_MGT 0x05C
  50. #define PRCM_APETRACECLK_MGT 0x060
  51. #define PRCM_MCDECLK_MGT 0x064
  52. #define PRCM_IPI2CCLK_MGT 0x068
  53. #define PRCM_DSIALTCLK_MGT 0x06C
  54. #define PRCM_DMACLK_MGT 0x074
  55. #define PRCM_B2R2CLK_MGT 0x078
  56. #define PRCM_TVCLK_MGT 0x07C
  57. #define PRCM_UNIPROCLK_MGT 0x278
  58. #define PRCM_SSPCLK_MGT 0x280
  59. #define PRCM_RNGCLK_MGT 0x284
  60. #define PRCM_UICCCLK_MGT 0x27C
  61. #define PRCM_MGT_ENABLE (1 << 8)
  62. static DEFINE_SPINLOCK(clocks_lock);
  63. static void __clk_enable(struct clk *clk)
  64. {
  65. if (clk->enabled++ == 0) {
  66. if (clk->parent_cluster)
  67. __clk_enable(clk->parent_cluster);
  68. if (clk->parent_periph)
  69. __clk_enable(clk->parent_periph);
  70. if (clk->ops && clk->ops->enable)
  71. clk->ops->enable(clk);
  72. }
  73. }
  74. int clk_enable(struct clk *clk)
  75. {
  76. unsigned long flags;
  77. spin_lock_irqsave(&clocks_lock, flags);
  78. __clk_enable(clk);
  79. spin_unlock_irqrestore(&clocks_lock, flags);
  80. return 0;
  81. }
  82. EXPORT_SYMBOL(clk_enable);
  83. static void __clk_disable(struct clk *clk)
  84. {
  85. if (--clk->enabled == 0) {
  86. if (clk->ops && clk->ops->disable)
  87. clk->ops->disable(clk);
  88. if (clk->parent_periph)
  89. __clk_disable(clk->parent_periph);
  90. if (clk->parent_cluster)
  91. __clk_disable(clk->parent_cluster);
  92. }
  93. }
  94. void clk_disable(struct clk *clk)
  95. {
  96. unsigned long flags;
  97. WARN_ON(!clk->enabled);
  98. spin_lock_irqsave(&clocks_lock, flags);
  99. __clk_disable(clk);
  100. spin_unlock_irqrestore(&clocks_lock, flags);
  101. }
  102. EXPORT_SYMBOL(clk_disable);
  103. unsigned long clk_get_rate(struct clk *clk)
  104. {
  105. unsigned long rate;
  106. if (clk->ops && clk->ops->get_rate)
  107. return clk->ops->get_rate(clk);
  108. rate = clk->rate;
  109. if (!rate) {
  110. if (clk->parent_periph)
  111. rate = clk_get_rate(clk->parent_periph);
  112. else if (clk->parent_cluster)
  113. rate = clk_get_rate(clk->parent_cluster);
  114. }
  115. return rate;
  116. }
  117. EXPORT_SYMBOL(clk_get_rate);
  118. long clk_round_rate(struct clk *clk, unsigned long rate)
  119. {
  120. /*TODO*/
  121. return rate;
  122. }
  123. EXPORT_SYMBOL(clk_round_rate);
  124. int clk_set_rate(struct clk *clk, unsigned long rate)
  125. {
  126. clk->rate = rate;
  127. return 0;
  128. }
  129. EXPORT_SYMBOL(clk_set_rate);
  130. static void clk_prcmu_enable(struct clk *clk)
  131. {
  132. void __iomem *cg_set_reg = __io_address(U8500_PRCMU_BASE)
  133. + PRCM_YYCLKEN0_MGT_SET + clk->prcmu_cg_off;
  134. writel(1 << clk->prcmu_cg_bit, cg_set_reg);
  135. }
  136. static void clk_prcmu_disable(struct clk *clk)
  137. {
  138. void __iomem *cg_clr_reg = __io_address(U8500_PRCMU_BASE)
  139. + PRCM_YYCLKEN0_MGT_CLR + clk->prcmu_cg_off;
  140. writel(1 << clk->prcmu_cg_bit, cg_clr_reg);
  141. }
  142. /* ED doesn't have the combined set/clr registers */
  143. static void clk_prcmu_ed_enable(struct clk *clk)
  144. {
  145. void __iomem *addr = __io_address(U8500_PRCMU_BASE)
  146. + clk->prcmu_cg_mgt;
  147. writel(readl(addr) | PRCM_MGT_ENABLE, addr);
  148. }
  149. static void clk_prcmu_ed_disable(struct clk *clk)
  150. {
  151. void __iomem *addr = __io_address(U8500_PRCMU_BASE)
  152. + clk->prcmu_cg_mgt;
  153. writel(readl(addr) & ~PRCM_MGT_ENABLE, addr);
  154. }
  155. static struct clkops clk_prcmu_ops = {
  156. .enable = clk_prcmu_enable,
  157. .disable = clk_prcmu_disable,
  158. };
  159. static unsigned int clkrst_base[] = {
  160. [1] = U8500_CLKRST1_BASE,
  161. [2] = U8500_CLKRST2_BASE,
  162. [3] = U8500_CLKRST3_BASE,
  163. [5] = U8500_CLKRST5_BASE,
  164. [6] = U8500_CLKRST6_BASE,
  165. [7] = U8500_CLKRST7_BASE_ED,
  166. };
  167. static void clk_prcc_enable(struct clk *clk)
  168. {
  169. void __iomem *addr = __io_address(clkrst_base[clk->cluster]);
  170. if (clk->prcc_kernel != -1)
  171. writel(1 << clk->prcc_kernel, addr + PRCC_KCKEN);
  172. if (clk->prcc_bus != -1)
  173. writel(1 << clk->prcc_bus, addr + PRCC_PCKEN);
  174. }
  175. static void clk_prcc_disable(struct clk *clk)
  176. {
  177. void __iomem *addr = __io_address(clkrst_base[clk->cluster]);
  178. if (clk->prcc_bus != -1)
  179. writel(1 << clk->prcc_bus, addr + PRCC_PCKDIS);
  180. if (clk->prcc_kernel != -1)
  181. writel(1 << clk->prcc_kernel, addr + PRCC_KCKDIS);
  182. }
  183. static struct clkops clk_prcc_ops = {
  184. .enable = clk_prcc_enable,
  185. .disable = clk_prcc_disable,
  186. };
  187. static struct clk clk_32khz = {
  188. .rate = 32000,
  189. };
  190. /*
  191. * PRCMU level clock gating
  192. */
  193. /* Bank 0 */
  194. static DEFINE_PRCMU_CLK(svaclk, 0x0, 2, SVAMMDSPCLK);
  195. static DEFINE_PRCMU_CLK(siaclk, 0x0, 3, SIAMMDSPCLK);
  196. static DEFINE_PRCMU_CLK(sgaclk, 0x0, 4, SGACLK);
  197. static DEFINE_PRCMU_CLK_RATE(uartclk, 0x0, 5, UARTCLK, 38400000);
  198. static DEFINE_PRCMU_CLK(msp02clk, 0x0, 6, MSP02CLK);
  199. static DEFINE_PRCMU_CLK(msp1clk, 0x0, 7, MSP1CLK); /* v1 */
  200. static DEFINE_PRCMU_CLK_RATE(i2cclk, 0x0, 8, I2CCLK, 48000000);
  201. static DEFINE_PRCMU_CLK_RATE(sdmmcclk, 0x0, 9, SDMMCCLK, 50000000);
  202. static DEFINE_PRCMU_CLK(slimclk, 0x0, 10, SLIMCLK);
  203. static DEFINE_PRCMU_CLK(per1clk, 0x0, 11, PER1CLK);
  204. static DEFINE_PRCMU_CLK(per2clk, 0x0, 12, PER2CLK);
  205. static DEFINE_PRCMU_CLK(per3clk, 0x0, 13, PER3CLK);
  206. static DEFINE_PRCMU_CLK(per5clk, 0x0, 14, PER5CLK);
  207. static DEFINE_PRCMU_CLK_RATE(per6clk, 0x0, 15, PER6CLK, 133330000);
  208. static DEFINE_PRCMU_CLK_RATE(per7clk, 0x0, 16, PER7CLK, 100000000);
  209. static DEFINE_PRCMU_CLK(lcdclk, 0x0, 17, LCDCLK);
  210. static DEFINE_PRCMU_CLK(bmlclk, 0x0, 18, BMLCLK);
  211. static DEFINE_PRCMU_CLK(hsitxclk, 0x0, 19, HSITXCLK);
  212. static DEFINE_PRCMU_CLK(hsirxclk, 0x0, 20, HSIRXCLK);
  213. static DEFINE_PRCMU_CLK(hdmiclk, 0x0, 21, HDMICLK);
  214. static DEFINE_PRCMU_CLK(apeatclk, 0x0, 22, APEATCLK);
  215. static DEFINE_PRCMU_CLK(apetraceclk, 0x0, 23, APETRACECLK);
  216. static DEFINE_PRCMU_CLK(mcdeclk, 0x0, 24, MCDECLK);
  217. static DEFINE_PRCMU_CLK(ipi2clk, 0x0, 25, IPI2CCLK);
  218. static DEFINE_PRCMU_CLK(dsialtclk, 0x0, 26, DSIALTCLK); /* v1 */
  219. static DEFINE_PRCMU_CLK(dmaclk, 0x0, 27, DMACLK);
  220. static DEFINE_PRCMU_CLK(b2r2clk, 0x0, 28, B2R2CLK);
  221. static DEFINE_PRCMU_CLK(tvclk, 0x0, 29, TVCLK);
  222. static DEFINE_PRCMU_CLK(uniproclk, 0x0, 30, UNIPROCLK); /* v1 */
  223. static DEFINE_PRCMU_CLK_RATE(sspclk, 0x0, 31, SSPCLK, 48000000); /* v1 */
  224. /* Bank 1 */
  225. static DEFINE_PRCMU_CLK(rngclk, 0x4, 0, RNGCLK); /* v1 */
  226. static DEFINE_PRCMU_CLK(uiccclk, 0x4, 1, UICCCLK); /* v1 */
  227. /*
  228. * PRCC level clock gating
  229. * Format: per#, clk, PCKEN bit, KCKEN bit, parent
  230. */
  231. /* Peripheral Cluster #1 */
  232. static DEFINE_PRCC_CLK(1, i2c4, 10, 9, &clk_i2cclk);
  233. static DEFINE_PRCC_CLK(1, gpio0, 9, -1, NULL);
  234. static DEFINE_PRCC_CLK(1, slimbus0, 8, 8, &clk_slimclk);
  235. static DEFINE_PRCC_CLK(1, spi3_ed, 7, 7, NULL);
  236. static DEFINE_PRCC_CLK(1, spi3_v1, 7, -1, NULL);
  237. static DEFINE_PRCC_CLK(1, i2c2, 6, 6, &clk_i2cclk);
  238. static DEFINE_PRCC_CLK(1, sdi0, 5, 5, &clk_sdmmcclk);
  239. static DEFINE_PRCC_CLK(1, msp1_ed, 4, 4, &clk_msp02clk);
  240. static DEFINE_PRCC_CLK(1, msp1_v1, 4, 4, &clk_msp1clk);
  241. static DEFINE_PRCC_CLK(1, msp0, 3, 3, &clk_msp02clk);
  242. static DEFINE_PRCC_CLK(1, i2c1, 2, 2, &clk_i2cclk);
  243. static DEFINE_PRCC_CLK(1, uart1, 1, 1, &clk_uartclk);
  244. static DEFINE_PRCC_CLK(1, uart0, 0, 0, &clk_uartclk);
  245. /* Peripheral Cluster #2 */
  246. static DEFINE_PRCC_CLK(2, gpio1_ed, 12, -1, NULL);
  247. static DEFINE_PRCC_CLK(2, ssitx_ed, 11, -1, NULL);
  248. static DEFINE_PRCC_CLK(2, ssirx_ed, 10, -1, NULL);
  249. static DEFINE_PRCC_CLK(2, spi0_ed, 9, -1, NULL);
  250. static DEFINE_PRCC_CLK(2, sdi3_ed, 8, 6, &clk_sdmmcclk);
  251. static DEFINE_PRCC_CLK(2, sdi1_ed, 7, 5, &clk_sdmmcclk);
  252. static DEFINE_PRCC_CLK(2, msp2_ed, 6, 4, &clk_msp02clk);
  253. static DEFINE_PRCC_CLK(2, sdi4_ed, 4, 2, &clk_sdmmcclk);
  254. static DEFINE_PRCC_CLK(2, pwl_ed, 3, 1, NULL);
  255. static DEFINE_PRCC_CLK(2, spi1_ed, 2, -1, NULL);
  256. static DEFINE_PRCC_CLK(2, spi2_ed, 1, -1, NULL);
  257. static DEFINE_PRCC_CLK(2, i2c3_ed, 0, 0, &clk_i2cclk);
  258. static DEFINE_PRCC_CLK(2, gpio1_v1, 11, -1, NULL);
  259. static DEFINE_PRCC_CLK(2, ssitx_v1, 10, 7, NULL);
  260. static DEFINE_PRCC_CLK(2, ssirx_v1, 9, 6, NULL);
  261. static DEFINE_PRCC_CLK(2, spi0_v1, 8, -1, NULL);
  262. static DEFINE_PRCC_CLK(2, sdi3_v1, 7, 5, &clk_sdmmcclk);
  263. static DEFINE_PRCC_CLK(2, sdi1_v1, 6, 4, &clk_sdmmcclk);
  264. static DEFINE_PRCC_CLK(2, msp2_v1, 5, 3, &clk_msp02clk);
  265. static DEFINE_PRCC_CLK(2, sdi4_v1, 4, 2, &clk_sdmmcclk);
  266. static DEFINE_PRCC_CLK(2, pwl_v1, 3, 1, NULL);
  267. static DEFINE_PRCC_CLK(2, spi1_v1, 2, -1, NULL);
  268. static DEFINE_PRCC_CLK(2, spi2_v1, 1, -1, NULL);
  269. static DEFINE_PRCC_CLK(2, i2c3_v1, 0, 0, &clk_i2cclk);
  270. /* Peripheral Cluster #3 */
  271. static DEFINE_PRCC_CLK(3, gpio2, 8, -1, NULL);
  272. static DEFINE_PRCC_CLK(3, sdi5, 7, 7, &clk_sdmmcclk);
  273. static DEFINE_PRCC_CLK(3, uart2, 6, 6, &clk_uartclk);
  274. static DEFINE_PRCC_CLK(3, ske, 5, 5, &clk_32khz);
  275. static DEFINE_PRCC_CLK(3, sdi2, 4, 4, &clk_sdmmcclk);
  276. static DEFINE_PRCC_CLK(3, i2c0, 3, 3, &clk_i2cclk);
  277. static DEFINE_PRCC_CLK(3, ssp1_ed, 2, 2, &clk_i2cclk);
  278. static DEFINE_PRCC_CLK(3, ssp0_ed, 1, 1, &clk_i2cclk);
  279. static DEFINE_PRCC_CLK(3, ssp1_v1, 2, 2, &clk_sspclk);
  280. static DEFINE_PRCC_CLK(3, ssp0_v1, 1, 1, &clk_sspclk);
  281. static DEFINE_PRCC_CLK(3, fsmc, 0, -1, NULL);
  282. /* Peripheral Cluster #4 is in the always on domain */
  283. /* Peripheral Cluster #5 */
  284. static DEFINE_PRCC_CLK(5, gpio3, 1, -1, NULL);
  285. static DEFINE_PRCC_CLK(5, usb_ed, 0, 0, &clk_i2cclk);
  286. static DEFINE_PRCC_CLK(5, usb_v1, 0, 0, NULL);
  287. /* Peripheral Cluster #6 */
  288. static DEFINE_PRCC_CLK(6, mtu1_v1, 8, -1, NULL);
  289. static DEFINE_PRCC_CLK(6, mtu0_v1, 7, -1, NULL);
  290. static DEFINE_PRCC_CLK(6, cfgreg_v1, 6, 6, NULL);
  291. static DEFINE_PRCC_CLK(6, dmc_ed, 6, 6, NULL);
  292. static DEFINE_PRCC_CLK(6, hash1, 5, -1, NULL);
  293. static DEFINE_PRCC_CLK(6, unipro_v1, 4, 1, &clk_uniproclk);
  294. static DEFINE_PRCC_CLK(6, cryp1_ed, 4, -1, NULL);
  295. static DEFINE_PRCC_CLK(6, pka, 3, -1, NULL);
  296. static DEFINE_PRCC_CLK(6, hash0, 2, -1, NULL);
  297. static DEFINE_PRCC_CLK(6, cryp0, 1, -1, NULL);
  298. static DEFINE_PRCC_CLK(6, rng_ed, 0, 0, &clk_i2cclk);
  299. static DEFINE_PRCC_CLK(6, rng_v1, 0, 0, &clk_rngclk);
  300. /* Peripheral Cluster #7 */
  301. static DEFINE_PRCC_CLK(7, tzpc0_ed, 4, -1, NULL);
  302. static DEFINE_PRCC_CLK(7, mtu1_ed, 3, -1, NULL);
  303. static DEFINE_PRCC_CLK(7, mtu0_ed, 2, -1, NULL);
  304. static DEFINE_PRCC_CLK(7, wdg_ed, 1, -1, NULL);
  305. static DEFINE_PRCC_CLK(7, cfgreg_ed, 0, -1, NULL);
  306. static struct clk_lookup u8500_common_clks[] = {
  307. /* Peripheral Cluster #1 */
  308. CLK(gpio0, "gpio.0", NULL),
  309. CLK(gpio0, "gpio.1", NULL),
  310. CLK(slimbus0, "slimbus0", NULL),
  311. CLK(i2c2, "nmk-i2c.2", NULL),
  312. CLK(sdi0, "sdi0", NULL),
  313. CLK(msp0, "msp0", NULL),
  314. CLK(i2c1, "nmk-i2c.1", NULL),
  315. CLK(uart1, "uart1", NULL),
  316. CLK(uart0, "uart0", NULL),
  317. /* Peripheral Cluster #3 */
  318. CLK(gpio2, "gpio.2", NULL),
  319. CLK(gpio2, "gpio.3", NULL),
  320. CLK(gpio2, "gpio.4", NULL),
  321. CLK(gpio2, "gpio.5", NULL),
  322. CLK(sdi5, "sdi5", NULL),
  323. CLK(uart2, "uart2", NULL),
  324. CLK(ske, "ske", NULL),
  325. CLK(sdi2, "sdi2", NULL),
  326. CLK(i2c0, "nmk-i2c.0", NULL),
  327. CLK(fsmc, "fsmc", NULL),
  328. /* Peripheral Cluster #5 */
  329. CLK(gpio3, "gpio.8", NULL),
  330. /* Peripheral Cluster #6 */
  331. CLK(hash1, "hash1", NULL),
  332. CLK(pka, "pka", NULL),
  333. CLK(hash0, "hash0", NULL),
  334. CLK(cryp0, "cryp0", NULL),
  335. /* PRCMU level clock gating */
  336. /* Bank 0 */
  337. CLK(svaclk, "sva", NULL),
  338. CLK(siaclk, "sia", NULL),
  339. CLK(sgaclk, "sga", NULL),
  340. CLK(slimclk, "slim", NULL),
  341. CLK(lcdclk, "lcd", NULL),
  342. CLK(bmlclk, "bml", NULL),
  343. CLK(hsitxclk, "stm-hsi.0", NULL),
  344. CLK(hsirxclk, "stm-hsi.1", NULL),
  345. CLK(hdmiclk, "hdmi", NULL),
  346. CLK(apeatclk, "apeat", NULL),
  347. CLK(apetraceclk, "apetrace", NULL),
  348. CLK(mcdeclk, "mcde", NULL),
  349. CLK(ipi2clk, "ipi2", NULL),
  350. CLK(dmaclk, "dma40", NULL),
  351. CLK(b2r2clk, "b2r2", NULL),
  352. CLK(tvclk, "tv", NULL),
  353. };
  354. static struct clk_lookup u8500_ed_clks[] = {
  355. /* Peripheral Cluster #1 */
  356. CLK(spi3_ed, "spi3", NULL),
  357. CLK(msp1_ed, "msp1", NULL),
  358. /* Peripheral Cluster #2 */
  359. CLK(gpio1_ed, "gpio.6", NULL),
  360. CLK(gpio1_ed, "gpio.7", NULL),
  361. CLK(ssitx_ed, "ssitx", NULL),
  362. CLK(ssirx_ed, "ssirx", NULL),
  363. CLK(spi0_ed, "spi0", NULL),
  364. CLK(sdi3_ed, "sdi3", NULL),
  365. CLK(sdi1_ed, "sdi1", NULL),
  366. CLK(msp2_ed, "msp2", NULL),
  367. CLK(sdi4_ed, "sdi4", NULL),
  368. CLK(pwl_ed, "pwl", NULL),
  369. CLK(spi1_ed, "spi1", NULL),
  370. CLK(spi2_ed, "spi2", NULL),
  371. CLK(i2c3_ed, "nmk-i2c.3", NULL),
  372. /* Peripheral Cluster #3 */
  373. CLK(ssp1_ed, "ssp1", NULL),
  374. CLK(ssp0_ed, "ssp0", NULL),
  375. /* Peripheral Cluster #5 */
  376. CLK(usb_ed, "musb_hdrc.0", "usb"),
  377. /* Peripheral Cluster #6 */
  378. CLK(dmc_ed, "dmc", NULL),
  379. CLK(cryp1_ed, "cryp1", NULL),
  380. CLK(rng_ed, "rng", NULL),
  381. /* Peripheral Cluster #7 */
  382. CLK(tzpc0_ed, "tzpc0", NULL),
  383. CLK(mtu1_ed, "mtu1", NULL),
  384. CLK(mtu0_ed, "mtu0", NULL),
  385. CLK(wdg_ed, "wdg", NULL),
  386. CLK(cfgreg_ed, "cfgreg", NULL),
  387. };
  388. static struct clk_lookup u8500_v1_clks[] = {
  389. /* Peripheral Cluster #1 */
  390. CLK(i2c4, "nmk-i2c.4", NULL),
  391. CLK(spi3_v1, "spi3", NULL),
  392. CLK(msp1_v1, "msp1", NULL),
  393. /* Peripheral Cluster #2 */
  394. CLK(gpio1_v1, "gpio.6", NULL),
  395. CLK(gpio1_v1, "gpio.7", NULL),
  396. CLK(ssitx_v1, "ssitx", NULL),
  397. CLK(ssirx_v1, "ssirx", NULL),
  398. CLK(spi0_v1, "spi0", NULL),
  399. CLK(sdi3_v1, "sdi3", NULL),
  400. CLK(sdi1_v1, "sdi1", NULL),
  401. CLK(msp2_v1, "msp2", NULL),
  402. CLK(sdi4_v1, "sdi4", NULL),
  403. CLK(pwl_v1, "pwl", NULL),
  404. CLK(spi1_v1, "spi1", NULL),
  405. CLK(spi2_v1, "spi2", NULL),
  406. CLK(i2c3_v1, "nmk-i2c.3", NULL),
  407. /* Peripheral Cluster #3 */
  408. CLK(ssp1_v1, "ssp1", NULL),
  409. CLK(ssp0_v1, "ssp0", NULL),
  410. /* Peripheral Cluster #5 */
  411. CLK(usb_v1, "musb_hdrc.0", "usb"),
  412. /* Peripheral Cluster #6 */
  413. CLK(mtu1_v1, "mtu1", NULL),
  414. CLK(mtu0_v1, "mtu0", NULL),
  415. CLK(cfgreg_v1, "cfgreg", NULL),
  416. CLK(hash1, "hash1", NULL),
  417. CLK(unipro_v1, "unipro", NULL),
  418. CLK(rng_v1, "rng", NULL),
  419. /* PRCMU level clock gating */
  420. /* Bank 0 */
  421. CLK(uniproclk, "uniproclk", NULL),
  422. CLK(dsialtclk, "dsialt", NULL),
  423. /* Bank 1 */
  424. CLK(rngclk, "rng", NULL),
  425. CLK(uiccclk, "uicc", NULL),
  426. };
  427. static int __init clk_init(void)
  428. {
  429. if (cpu_is_u8500ed()) {
  430. clk_prcmu_ops.enable = clk_prcmu_ed_enable;
  431. clk_prcmu_ops.disable = clk_prcmu_ed_disable;
  432. } else if (cpu_is_u5500()) {
  433. /* Clock tree for U5500 not implemented yet */
  434. clk_prcc_ops.enable = clk_prcc_ops.disable = NULL;
  435. clk_prcmu_ops.enable = clk_prcmu_ops.disable = NULL;
  436. }
  437. clkdev_add_table(u8500_common_clks, ARRAY_SIZE(u8500_common_clks));
  438. if (cpu_is_u8500ed())
  439. clkdev_add_table(u8500_ed_clks, ARRAY_SIZE(u8500_ed_clks));
  440. else
  441. clkdev_add_table(u8500_v1_clks, ARRAY_SIZE(u8500_v1_clks));
  442. return 0;
  443. }
  444. arch_initcall(clk_init);