system_clock.c 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2011-01-13 weety first version
  9. */
  10. #include <rtthread.h>
  11. /*
  12. static rt_list_t clocks;
  13. struct clk {
  14. char name[32];
  15. rt_uint32_t rate_hz;
  16. struct clk *parent;
  17. rt_list_t node;
  18. };
  19. static struct clk clk32k = {
  20. "clk32k",
  21. AT91_SLOW_CLOCK,
  22. RT_NULL,
  23. {RT_NULL, RT_NULL},
  24. };
  25. static struct clk main_clk = {
  26. "main",
  27. 0,
  28. RT_NULL,
  29. {RT_NULL, RT_NULL},
  30. };
  31. static struct clk plla = {
  32. "plla",
  33. 0,
  34. RT_NULL,
  35. {RT_NULL, RT_NULL},
  36. };
  37. static struct clk mck = {
  38. "mck",
  39. 0,
  40. RT_NULL,
  41. {RT_NULL, RT_NULL},
  42. };
  43. static struct clk uhpck = {
  44. "uhpck",
  45. 0,
  46. RT_NULL,
  47. {RT_NULL, RT_NULL},
  48. };
  49. static struct clk pllb = {
  50. "pllb",
  51. 0,
  52. &main_clk,
  53. {RT_NULL, RT_NULL},
  54. };
  55. static struct clk udpck = {
  56. "udpck",
  57. 0,
  58. &pllb,
  59. {RT_NULL, RT_NULL},
  60. };
  61. static struct clk *const standard_pmc_clocks[] = {
  62. // four primary clocks
  63. &clk32k,
  64. &main_clk,
  65. &plla,
  66. // MCK
  67. &mck
  68. };
  69. // clocks cannot be de-registered no refcounting necessary
  70. struct clk *clk_get(const char *id)
  71. {
  72. struct clk *clk;
  73. rt_list_t *list;
  74. for (list = (&clocks)->next; list != &clocks; list = list->next)
  75. {
  76. clk = (struct clk *)rt_list_entry(list, struct clk, node);
  77. if (rt_strcmp(id, clk->name) == 0)
  78. return clk;
  79. }
  80. return RT_NULL;
  81. }
  82. rt_uint32_t clk_get_rate(struct clk *clk)
  83. {
  84. rt_uint32_t rate;
  85. for (;;) {
  86. rate = clk->rate_hz;
  87. if (rate || !clk->parent)
  88. break;
  89. clk = clk->parent;
  90. }
  91. return rate;
  92. }
  93. static rt_uint32_t at91_pll_rate(struct clk *pll, rt_uint32_t freq, rt_uint32_t reg)
  94. {
  95. unsigned mul, div;
  96. div = reg & 0xff;
  97. mul = (reg >> 16) & 0x7ff;
  98. if (div && mul) {
  99. freq /= div;
  100. freq *= mul + 1;
  101. } else
  102. freq = 0;
  103. return freq;
  104. }
  105. static unsigned at91_pll_calc(unsigned main_freq, unsigned out_freq)
  106. {
  107. unsigned i, div = 0, mul = 0, diff = 1 << 30;
  108. unsigned ret = (out_freq > 155000000) ? 0xbe00 : 0x3e00;
  109. //PLL output max 240 MHz (or 180 MHz per errata)
  110. if (out_freq > 240000000)
  111. goto fail;
  112. for (i = 1; i < 256; i++) {
  113. int diff1;
  114. unsigned input, mul1;
  115. //
  116. // PLL input between 1MHz and 32MHz per spec, but lower
  117. // frequences seem necessary in some cases so allow 100K.
  118. // Warning: some newer products need 2MHz min.
  119. //
  120. input = main_freq / i;
  121. if (input < 100000)
  122. continue;
  123. if (input > 32000000)
  124. continue;
  125. mul1 = out_freq / input;
  126. if (mul1 > 2048)
  127. continue;
  128. if (mul1 < 2)
  129. goto fail;
  130. diff1 = out_freq - input * mul1;
  131. if (diff1 < 0)
  132. diff1 = -diff1;
  133. if (diff > diff1) {
  134. diff = diff1;
  135. div = i;
  136. mul = mul1;
  137. if (diff == 0)
  138. break;
  139. }
  140. }
  141. if (i == 256 && diff > (out_freq >> 5))
  142. goto fail;
  143. return ret | ((mul - 1) << 16) | div;
  144. fail:
  145. return 0;
  146. }
  147. static rt_uint32_t at91_usb_rate(struct clk *pll, rt_uint32_t freq, rt_uint32_t reg)
  148. {
  149. if (pll == &pllb && (reg & AT91_PMC_USB96M))
  150. return freq / 2;
  151. else
  152. return freq;
  153. }
  154. // PLLB generated USB full speed clock init
  155. static void at91_pllb_usbfs_clock_init(rt_uint32_t main_clock)
  156. {
  157. rt_uint32_t at91_pllb_usb_init;
  158. //
  159. // USB clock init: choose 48 MHz PLLB value,
  160. // disable 48MHz clock during usb peripheral suspend.
  161. //
  162. // REVISIT: assumes MCK doesn't derive from PLLB!
  163. //
  164. uhpck.parent = &pllb;
  165. at91_pllb_usb_init = at91_pll_calc(main_clock, 48000000 * 2) | AT91_PMC_USB96M;
  166. pllb.rate_hz = at91_pll_rate(&pllb, main_clock, at91_pllb_usb_init);
  167. at91_sys_write(AT91_CKGR_PLLBR, 0);
  168. udpck.rate_hz = at91_usb_rate(&pllb, pllb.rate_hz, at91_pllb_usb_init);
  169. uhpck.rate_hz = at91_usb_rate(&pllb, pllb.rate_hz, at91_pllb_usb_init);
  170. }
  171. static struct clk *at91_css_to_clk(unsigned long css)
  172. {
  173. switch (css) {
  174. case AT91_PMC_CSS_SLOW:
  175. return &clk32k;
  176. case AT91_PMC_CSS_MAIN:
  177. return &main_clk;
  178. case AT91_PMC_CSS_PLLA:
  179. return &plla;
  180. case AT91_PMC_CSS_PLLB:
  181. return &pllb;
  182. }
  183. return RT_NULL;
  184. }
  185. #define false 0
  186. #define true 1
  187. int at91_clock_init(rt_uint32_t main_clock)
  188. {
  189. unsigned tmp, freq, mckr;
  190. int i;
  191. int pll_overclock = false;
  192. //
  193. // When the bootloader initialized the main oscillator correctly,
  194. // there's no problem using the cycle counter. But if it didn't,
  195. // or when using oscillator bypass mode, we must be told the speed
  196. // of the main clock.
  197. //
  198. if (!main_clock) {
  199. do {
  200. tmp = at91_sys_read(AT91_CKGR_MCFR);
  201. } while (!(tmp & AT91_PMC_MAINRDY));
  202. main_clock = (tmp & AT91_PMC_MAINF) * (AT91_SLOW_CLOCK / 16);
  203. }
  204. main_clk.rate_hz = main_clock;
  205. // report if PLLA is more than mildly overclocked
  206. plla.rate_hz = at91_pll_rate(&plla, main_clock, at91_sys_read(AT91_CKGR_PLLAR));
  207. if (plla.rate_hz > 209000000)
  208. pll_overclock = true;
  209. if (pll_overclock)
  210. ;//rt_kprintf("Clocks: PLLA overclocked, %ld MHz\n", plla.rate_hz / 1000000);
  211. at91_pllb_usbfs_clock_init(main_clock);
  212. //
  213. // MCK and CPU derive from one of those primary clocks.
  214. // For now, assume this parentage won't change.
  215. //
  216. mckr = at91_sys_read(AT91_PMC_MCKR);
  217. mck.parent = at91_css_to_clk(mckr & AT91_PMC_CSS);
  218. freq = mck.parent->rate_hz;
  219. freq /= (1 << ((mckr & AT91_PMC_PRES) >> 2)); // prescale
  220. mck.rate_hz = freq / (1 << ((mckr & AT91_PMC_MDIV) >> 8)); // mdiv
  221. // Register the PMC's standard clocks
  222. rt_list_init(&clocks);
  223. for (i = 0; i < ARRAY_SIZE(standard_pmc_clocks); i++)
  224. rt_list_insert_after(&clocks, &standard_pmc_clocks[i]->node);
  225. rt_list_insert_after(&clocks, &pllb.node);
  226. rt_list_insert_after(&clocks, &uhpck.node);
  227. rt_list_insert_after(&clocks, &udpck.node);
  228. // MCK and CPU clock are "always on"
  229. //clk_enable(&mck);
  230. //rt_kprintf("Clocks: CPU %u MHz, master %u MHz, main %u.%03u MHz\n",
  231. // freq / 1000000, (unsigned) mck.rate_hz / 1000000,
  232. // (unsigned) main_clock / 1000000,
  233. // ((unsigned) main_clock % 1000000) / 1000); //cause blocked
  234. return 0;
  235. }
  236. */
  237. // @brief System Clock Configuration
  238. void rt_hw_clock_init(void)
  239. {
  240. //at91_clock_init(18432000);
  241. }