clock_ti814x.c 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505
  1. /*
  2. * clock_ti814x.c
  3. *
  4. * Clocks for TI814X based boards
  5. *
  6. * Copyright (C) 2013, Texas Instruments, Incorporated
  7. *
  8. * This program is free software; you can redistribute it and/or
  9. * modify it under the terms of the GNU General Public License as
  10. * published by the Free Software Foundation; either version 2 of
  11. * the License, or (at your option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR /PURPOSE. See the
  16. * GNU General Public License for more details.
  17. */
  18. #include <common.h>
  19. #include <asm/arch/cpu.h>
  20. #include <asm/arch/clock.h>
  21. #include <asm/arch/hardware.h>
  22. #include <asm/io.h>
  23. /* PRCM */
  24. #define PRCM_MOD_EN 0x2
  25. /* CLK_SRC */
  26. #define OSC_SRC0 0
  27. #define OSC_SRC1 1
  28. #define L3_OSC_SRC OSC_SRC0
  29. #define OSC_0_FREQ 20
  30. #define DCO_HS2_MIN 500
  31. #define DCO_HS2_MAX 1000
  32. #define DCO_HS1_MIN 1000
  33. #define DCO_HS1_MAX 2000
  34. #define SELFREQDCO_HS2 0x00000801
  35. #define SELFREQDCO_HS1 0x00001001
  36. #define MPU_N 0x1
  37. #define MPU_M 0x3C
  38. #define MPU_M2 1
  39. #define MPU_CLKCTRL 0x1
  40. #define L3_N 19
  41. #define L3_M 880
  42. #define L3_M2 4
  43. #define L3_CLKCTRL 0x801
  44. #define DDR_N 19
  45. #define DDR_M 666
  46. #define DDR_M2 2
  47. #define DDR_CLKCTRL 0x801
  48. /* ADPLLJ register values */
  49. #define ADPLLJ_CLKCTRL_HS2 0x00000801 /* HS2 mode, TINT2 = 1 */
  50. #define ADPLLJ_CLKCTRL_HS1 0x00001001 /* HS1 mode, TINT2 = 1 */
  51. #define ADPLLJ_CLKCTRL_CLKDCOLDOEN (1 << 29)
  52. #define ADPLLJ_CLKCTRL_IDLE (1 << 23)
  53. #define ADPLLJ_CLKCTRL_CLKOUTEN (1 << 20)
  54. #define ADPLLJ_CLKCTRL_CLKOUTLDOEN (1 << 19)
  55. #define ADPLLJ_CLKCTRL_CLKDCOLDOPWDNZ (1 << 17)
  56. #define ADPLLJ_CLKCTRL_LPMODE (1 << 12)
  57. #define ADPLLJ_CLKCTRL_DRIFTGUARDIAN (1 << 11)
  58. #define ADPLLJ_CLKCTRL_REGM4XEN (1 << 10)
  59. #define ADPLLJ_CLKCTRL_TINITZ (1 << 0)
  60. #define ADPLLJ_CLKCTRL_CLKDCO (ADPLLJ_CLKCTRL_CLKDCOLDOEN | \
  61. ADPLLJ_CLKCTRL_CLKOUTEN | \
  62. ADPLLJ_CLKCTRL_CLKOUTLDOEN | \
  63. ADPLLJ_CLKCTRL_CLKDCOLDOPWDNZ)
  64. #define ADPLLJ_STATUS_PHASELOCK (1 << 10)
  65. #define ADPLLJ_STATUS_FREQLOCK (1 << 9)
  66. #define ADPLLJ_STATUS_PHSFRQLOCK (ADPLLJ_STATUS_PHASELOCK | \
  67. ADPLLJ_STATUS_FREQLOCK)
  68. #define ADPLLJ_STATUS_BYPASSACK (1 << 8)
  69. #define ADPLLJ_STATUS_BYPASS (1 << 0)
  70. #define ADPLLJ_STATUS_BYPASSANDACK (ADPLLJ_STATUS_BYPASSACK | \
  71. ADPLLJ_STATUS_BYPASS)
  72. #define ADPLLJ_TENABLE_ENB (1 << 0)
  73. #define ADPLLJ_TENABLEDIV_ENB (1 << 0)
  74. #define ADPLLJ_M2NDIV_M2SHIFT 16
  75. #define MPU_PLL_BASE (PLL_SUBSYS_BASE + 0x048)
  76. #define L3_PLL_BASE (PLL_SUBSYS_BASE + 0x110)
  77. #define DDR_PLL_BASE (PLL_SUBSYS_BASE + 0x290)
  78. struct ad_pll {
  79. unsigned int pwrctrl;
  80. unsigned int clkctrl;
  81. unsigned int tenable;
  82. unsigned int tenablediv;
  83. unsigned int m2ndiv;
  84. unsigned int mn2div;
  85. unsigned int fracdiv;
  86. unsigned int bwctrl;
  87. unsigned int fracctrl;
  88. unsigned int status;
  89. unsigned int m3div;
  90. unsigned int rampctrl;
  91. };
  92. #define OSC_SRC_CTRL (PLL_SUBSYS_BASE + 0x2C0)
  93. /* PRCM */
  94. #define ENET_CLKCTRL_CMPL 0x30000
  95. #define CM_DEFAULT_BASE (PRCM_BASE + 0x0500)
  96. struct cm_def {
  97. unsigned int resv0[2];
  98. unsigned int l3fastclkstctrl;
  99. unsigned int resv1[1];
  100. unsigned int pciclkstctrl;
  101. unsigned int resv2[1];
  102. unsigned int ducaticlkstctrl;
  103. unsigned int resv3[1];
  104. unsigned int emif0clkctrl;
  105. unsigned int emif1clkctrl;
  106. unsigned int dmmclkctrl;
  107. unsigned int fwclkctrl;
  108. unsigned int resv4[10];
  109. unsigned int usbclkctrl;
  110. unsigned int resv5[1];
  111. unsigned int sataclkctrl;
  112. unsigned int resv6[4];
  113. unsigned int ducaticlkctrl;
  114. unsigned int pciclkctrl;
  115. };
  116. #define CM_ALWON_BASE (PRCM_BASE + 0x1400)
  117. struct cm_alwon {
  118. unsigned int l3slowclkstctrl;
  119. unsigned int ethclkstctrl;
  120. unsigned int l3medclkstctrl;
  121. unsigned int mmu_clkstctrl;
  122. unsigned int mmucfg_clkstctrl;
  123. unsigned int ocmc0clkstctrl;
  124. unsigned int vcpclkstctrl;
  125. unsigned int mpuclkstctrl;
  126. unsigned int sysclk4clkstctrl;
  127. unsigned int sysclk5clkstctrl;
  128. unsigned int sysclk6clkstctrl;
  129. unsigned int rtcclkstctrl;
  130. unsigned int l3fastclkstctrl;
  131. unsigned int resv0[67];
  132. unsigned int mcasp0clkctrl;
  133. unsigned int mcasp1clkctrl;
  134. unsigned int mcasp2clkctrl;
  135. unsigned int mcbspclkctrl;
  136. unsigned int uart0clkctrl;
  137. unsigned int uart1clkctrl;
  138. unsigned int uart2clkctrl;
  139. unsigned int gpio0clkctrl;
  140. unsigned int gpio1clkctrl;
  141. unsigned int i2c0clkctrl;
  142. unsigned int i2c1clkctrl;
  143. unsigned int mcasp345clkctrl;
  144. unsigned int atlclkctrl;
  145. unsigned int mlbclkctrl;
  146. unsigned int pataclkctrl;
  147. unsigned int resv1[1];
  148. unsigned int uart3clkctrl;
  149. unsigned int uart4clkctrl;
  150. unsigned int uart5clkctrl;
  151. unsigned int wdtimerclkctrl;
  152. unsigned int spiclkctrl;
  153. unsigned int mailboxclkctrl;
  154. unsigned int spinboxclkctrl;
  155. unsigned int mmudataclkctrl;
  156. unsigned int resv2[2];
  157. unsigned int mmucfgclkctrl;
  158. unsigned int resv3[2];
  159. unsigned int ocmc0clkctrl;
  160. unsigned int vcpclkctrl;
  161. unsigned int resv4[2];
  162. unsigned int controlclkctrl;
  163. unsigned int resv5[2];
  164. unsigned int gpmcclkctrl;
  165. unsigned int ethernet0clkctrl;
  166. unsigned int ethernet1clkctrl;
  167. unsigned int mpuclkctrl;
  168. unsigned int debugssclkctrl;
  169. unsigned int l3clkctrl;
  170. unsigned int l4hsclkctrl;
  171. unsigned int l4lsclkctrl;
  172. unsigned int rtcclkctrl;
  173. unsigned int tpccclkctrl;
  174. unsigned int tptc0clkctrl;
  175. unsigned int tptc1clkctrl;
  176. unsigned int tptc2clkctrl;
  177. unsigned int tptc3clkctrl;
  178. unsigned int resv7[4];
  179. unsigned int dcan01clkctrl;
  180. unsigned int mmchs0clkctrl;
  181. unsigned int mmchs1clkctrl;
  182. unsigned int mmchs2clkctrl;
  183. unsigned int custefuseclkctrl;
  184. };
  185. #define SATA_PLL_BASE (CTRL_BASE + 0x0720)
  186. struct sata_pll {
  187. unsigned int pllcfg0;
  188. unsigned int pllcfg1;
  189. unsigned int pllcfg2;
  190. unsigned int pllcfg3;
  191. unsigned int pllcfg4;
  192. unsigned int pllstatus;
  193. unsigned int rxstatus;
  194. unsigned int txstatus;
  195. unsigned int testcfg;
  196. };
  197. #define SEL_IN_FREQ (0x1 << 31)
  198. #define DIGCLRZ (0x1 << 30)
  199. #define ENDIGLDO (0x1 << 4)
  200. #define APLL_CP_CURR (0x1 << 3)
  201. #define ENBGSC_REF (0x1 << 2)
  202. #define ENPLLLDO (0x1 << 1)
  203. #define ENPLL (0x1 << 0)
  204. #define SATA_PLLCFG0_1 (SEL_IN_FREQ | ENBGSC_REF)
  205. #define SATA_PLLCFG0_2 (SEL_IN_FREQ | ENDIGLDO | ENBGSC_REF)
  206. #define SATA_PLLCFG0_3 (SEL_IN_FREQ | ENDIGLDO | ENBGSC_REF | ENPLLLDO)
  207. #define SATA_PLLCFG0_4 (SEL_IN_FREQ | DIGCLRZ | ENDIGLDO | ENBGSC_REF | \
  208. ENPLLLDO | ENPLL)
  209. #define PLL_LOCK (0x1 << 0)
  210. #define ENSATAMODE (0x1 << 31)
  211. #define PLLREFSEL (0x1 << 30)
  212. #define MDIVINT (0x4b << 18)
  213. #define EN_CLKAUX (0x1 << 5)
  214. #define EN_CLK125M (0x1 << 4)
  215. #define EN_CLK100M (0x1 << 3)
  216. #define EN_CLK50M (0x1 << 2)
  217. #define SATA_PLLCFG1 (ENSATAMODE | \
  218. PLLREFSEL | \
  219. MDIVINT | \
  220. EN_CLKAUX | \
  221. EN_CLK125M | \
  222. EN_CLK100M | \
  223. EN_CLK50M)
  224. #define DIGLDO_EN_CAPLESSMODE (0x1 << 22)
  225. #define PLLDO_EN_LDO_STABLE (0x1 << 11)
  226. #define PLLDO_EN_BUF_CUR (0x1 << 7)
  227. #define PLLDO_EN_LP (0x1 << 6)
  228. #define PLLDO_CTRL_TRIM_1_4V (0x10 << 1)
  229. #define SATA_PLLCFG3 (DIGLDO_EN_CAPLESSMODE | \
  230. PLLDO_EN_LDO_STABLE | \
  231. PLLDO_EN_BUF_CUR | \
  232. PLLDO_EN_LP | \
  233. PLLDO_CTRL_TRIM_1_4V)
  234. const struct cm_alwon *cmalwon = (struct cm_alwon *)CM_ALWON_BASE;
  235. const struct cm_def *cmdef = (struct cm_def *)CM_DEFAULT_BASE;
  236. const struct sata_pll *spll = (struct sata_pll *)SATA_PLL_BASE;
  237. /*
  238. * Enable the peripheral clock for required peripherals
  239. */
  240. static void enable_per_clocks(void)
  241. {
  242. /* UART0 */
  243. writel(PRCM_MOD_EN, &cmalwon->uart0clkctrl);
  244. while (readl(&cmalwon->uart0clkctrl) != PRCM_MOD_EN)
  245. ;
  246. /* HSMMC1 */
  247. writel(PRCM_MOD_EN, &cmalwon->mmchs1clkctrl);
  248. while (readl(&cmalwon->mmchs1clkctrl) != PRCM_MOD_EN)
  249. ;
  250. /* Ethernet */
  251. writel(PRCM_MOD_EN, &cmalwon->ethclkstctrl);
  252. writel(PRCM_MOD_EN, &cmalwon->ethernet0clkctrl);
  253. while ((readl(&cmalwon->ethernet0clkctrl) & ENET_CLKCTRL_CMPL) != 0)
  254. ;
  255. writel(PRCM_MOD_EN, &cmalwon->ethernet1clkctrl);
  256. while ((readl(&cmalwon->ethernet1clkctrl) & ENET_CLKCTRL_CMPL) != 0)
  257. ;
  258. }
  259. /*
  260. * select the HS1 or HS2 for DCO Freq
  261. * return : CLKCTRL
  262. */
  263. static u32 pll_dco_freq_sel(u32 clkout_dco)
  264. {
  265. if (clkout_dco >= DCO_HS2_MIN && clkout_dco < DCO_HS2_MAX)
  266. return SELFREQDCO_HS2;
  267. else if (clkout_dco >= DCO_HS1_MIN && clkout_dco < DCO_HS1_MAX)
  268. return SELFREQDCO_HS1;
  269. else
  270. return -1;
  271. }
  272. /*
  273. * select the sigma delta config
  274. * return: sigma delta val
  275. */
  276. static u32 pll_sigma_delta_val(u32 clkout_dco)
  277. {
  278. u32 sig_val = 0;
  279. float frac_div;
  280. frac_div = (float) clkout_dco / 250;
  281. frac_div = frac_div + 0.90;
  282. sig_val = (int)frac_div;
  283. sig_val = sig_val << 24;
  284. return sig_val;
  285. }
  286. /*
  287. * configure individual ADPLLJ
  288. */
  289. static void pll_config(u32 base, u32 n, u32 m, u32 m2,
  290. u32 clkctrl_val, int adpllj)
  291. {
  292. const struct ad_pll *adpll = (struct ad_pll *)base;
  293. u32 m2nval, mn2val, read_clkctrl = 0, clkout_dco = 0;
  294. u32 sig_val = 0, hs_mod = 0;
  295. m2nval = (m2 << ADPLLJ_M2NDIV_M2SHIFT) | n;
  296. mn2val = m;
  297. /* calculate clkout_dco */
  298. clkout_dco = ((OSC_0_FREQ / (n+1)) * m);
  299. /* sigma delta & Hs mode selection skip for ADPLLS*/
  300. if (adpllj) {
  301. sig_val = pll_sigma_delta_val(clkout_dco);
  302. hs_mod = pll_dco_freq_sel(clkout_dco);
  303. }
  304. /* by-pass pll */
  305. read_clkctrl = readl(&adpll->clkctrl);
  306. writel((read_clkctrl | ADPLLJ_CLKCTRL_IDLE), &adpll->clkctrl);
  307. while ((readl(&adpll->status) & ADPLLJ_STATUS_BYPASSANDACK)
  308. != ADPLLJ_STATUS_BYPASSANDACK)
  309. ;
  310. /* clear TINITZ */
  311. read_clkctrl = readl(&adpll->clkctrl);
  312. writel((read_clkctrl & ~ADPLLJ_CLKCTRL_TINITZ), &adpll->clkctrl);
  313. /*
  314. * ref_clk = 20/(n + 1);
  315. * clkout_dco = ref_clk * m;
  316. * clk_out = clkout_dco/m2;
  317. */
  318. read_clkctrl = readl(&adpll->clkctrl) &
  319. ~(ADPLLJ_CLKCTRL_LPMODE |
  320. ADPLLJ_CLKCTRL_DRIFTGUARDIAN |
  321. ADPLLJ_CLKCTRL_REGM4XEN);
  322. writel(m2nval, &adpll->m2ndiv);
  323. writel(mn2val, &adpll->mn2div);
  324. /* Skip for modena(ADPLLS) */
  325. if (adpllj) {
  326. writel(sig_val, &adpll->fracdiv);
  327. writel((read_clkctrl | hs_mod), &adpll->clkctrl);
  328. }
  329. /* Load M2, N2 dividers of ADPLL */
  330. writel(ADPLLJ_TENABLEDIV_ENB, &adpll->tenablediv);
  331. writel(~ADPLLJ_TENABLEDIV_ENB, &adpll->tenablediv);
  332. /* Load M, N dividers of ADPLL */
  333. writel(ADPLLJ_TENABLE_ENB, &adpll->tenable);
  334. writel(~ADPLLJ_TENABLE_ENB, &adpll->tenable);
  335. /* Configure CLKDCOLDOEN,CLKOUTLDOEN,CLKOUT Enable BITS */
  336. read_clkctrl = readl(&adpll->clkctrl) & ~ADPLLJ_CLKCTRL_CLKDCO;
  337. if (adpllj)
  338. writel((read_clkctrl | ADPLLJ_CLKCTRL_CLKDCO),
  339. &adpll->clkctrl);
  340. /* Enable TINTZ and disable IDLE(PLL in Active & Locked Mode */
  341. read_clkctrl = readl(&adpll->clkctrl) & ~ADPLLJ_CLKCTRL_IDLE;
  342. writel((read_clkctrl | ADPLLJ_CLKCTRL_TINITZ), &adpll->clkctrl);
  343. /* Wait for phase and freq lock */
  344. while ((readl(&adpll->status) & ADPLLJ_STATUS_PHSFRQLOCK) !=
  345. ADPLLJ_STATUS_PHSFRQLOCK)
  346. ;
  347. }
  348. static void unlock_pll_control_mmr(void)
  349. {
  350. /* TRM 2.10.1.4 and 3.2.7-3.2.11 */
  351. writel(0x1EDA4C3D, 0x481C5040);
  352. writel(0x2FF1AC2B, 0x48140060);
  353. writel(0xF757FDC0, 0x48140064);
  354. writel(0xE2BC3A6D, 0x48140068);
  355. writel(0x1EBF131D, 0x4814006c);
  356. writel(0x6F361E05, 0x48140070);
  357. }
  358. static void mpu_pll_config(void)
  359. {
  360. pll_config(MPU_PLL_BASE, MPU_N, MPU_M, MPU_M2, MPU_CLKCTRL, 0);
  361. }
  362. static void l3_pll_config(void)
  363. {
  364. u32 l3_osc_src, rd_osc_src = 0;
  365. l3_osc_src = L3_OSC_SRC;
  366. rd_osc_src = readl(OSC_SRC_CTRL);
  367. if (OSC_SRC0 == l3_osc_src)
  368. writel((rd_osc_src & 0xfffffffe)|0x0, OSC_SRC_CTRL);
  369. else
  370. writel((rd_osc_src & 0xfffffffe)|0x1, OSC_SRC_CTRL);
  371. pll_config(L3_PLL_BASE, L3_N, L3_M, L3_M2, L3_CLKCTRL, 1);
  372. }
  373. void ddr_pll_config(unsigned int ddrpll_m)
  374. {
  375. pll_config(DDR_PLL_BASE, DDR_N, DDR_M, DDR_M2, DDR_CLKCTRL, 1);
  376. }
  377. void sata_pll_config(void)
  378. {
  379. /*
  380. * This sequence for configuring the SATA PLL
  381. * resident in the control module is documented
  382. * in TI8148 TRM section 21.3.1
  383. */
  384. writel(SATA_PLLCFG1, &spll->pllcfg1);
  385. udelay(50);
  386. writel(SATA_PLLCFG3, &spll->pllcfg3);
  387. udelay(50);
  388. writel(SATA_PLLCFG0_1, &spll->pllcfg0);
  389. udelay(50);
  390. writel(SATA_PLLCFG0_2, &spll->pllcfg0);
  391. udelay(50);
  392. writel(SATA_PLLCFG0_3, &spll->pllcfg0);
  393. udelay(50);
  394. writel(SATA_PLLCFG0_4, &spll->pllcfg0);
  395. udelay(50);
  396. while (((readl(&spll->pllstatus) & PLL_LOCK) == 0))
  397. ;
  398. }
  399. void enable_emif_clocks(void) {};
  400. void enable_dmm_clocks(void)
  401. {
  402. writel(PRCM_MOD_EN, &cmdef->fwclkctrl);
  403. writel(PRCM_MOD_EN, &cmdef->l3fastclkstctrl);
  404. writel(PRCM_MOD_EN, &cmdef->emif0clkctrl);
  405. while ((readl(&cmdef->emif0clkctrl)) != PRCM_MOD_EN)
  406. ;
  407. writel(PRCM_MOD_EN, &cmdef->emif1clkctrl);
  408. while ((readl(&cmdef->emif1clkctrl)) != PRCM_MOD_EN)
  409. ;
  410. while ((readl(&cmdef->l3fastclkstctrl) & 0x300) != 0x300)
  411. ;
  412. writel(PRCM_MOD_EN, &cmdef->dmmclkctrl);
  413. while ((readl(&cmdef->dmmclkctrl)) != PRCM_MOD_EN)
  414. ;
  415. writel(PRCM_MOD_EN, &cmalwon->l3slowclkstctrl);
  416. while ((readl(&cmalwon->l3slowclkstctrl) & 0x2100) != 0x2100)
  417. ;
  418. }
  419. /*
  420. * Configure the PLL/PRCM for necessary peripherals
  421. */
  422. void pll_init()
  423. {
  424. unlock_pll_control_mmr();
  425. /* Enable the control module */
  426. writel(PRCM_MOD_EN, &cmalwon->controlclkctrl);
  427. /* Configure PLLs */
  428. mpu_pll_config();
  429. l3_pll_config();
  430. sata_pll_config();
  431. /* Enable the required peripherals */
  432. enable_per_clocks();
  433. }