clock.h 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348
  1. /*
  2. * Copyright (C) 2015 Freescale Semiconductor, Inc.
  3. *
  4. * Author:
  5. * Peng Fan <Peng.Fan@freescale.com>
  6. *
  7. * SPDX-License-Identifier: GPL-2.0+
  8. */
  9. #ifndef _ASM_ARCH_CLOCK_H
  10. #define _ASM_ARCH_CLOCK_H
  11. #include <common.h>
  12. #include <asm/arch/crm_regs.h>
  13. #ifdef CONFIG_SYS_MX7_HCLK
  14. #define MXC_HCLK CONFIG_SYS_MX7_HCLK
  15. #else
  16. #define MXC_HCLK 24000000
  17. #endif
  18. #ifdef CONFIG_SYS_MX7_CLK32
  19. #define MXC_CLK32 CONFIG_SYS_MX7_CLK32
  20. #else
  21. #define MXC_CLK32 32768
  22. #endif
  23. /* Mainly for compatible to imx common code. */
  24. enum mxc_clock {
  25. MXC_ARM_CLK = 0,
  26. MXC_AHB_CLK,
  27. MXC_IPG_CLK,
  28. MXC_UART_CLK,
  29. MXC_CSPI_CLK,
  30. MXC_AXI_CLK,
  31. MXC_DDR_CLK,
  32. MXC_ESDHC_CLK,
  33. MXC_ESDHC2_CLK,
  34. MXC_ESDHC3_CLK,
  35. MXC_I2C_CLK,
  36. };
  37. /* PLL supported by i.mx7d */
  38. enum pll_clocks {
  39. PLL_CORE, /* Core PLL */
  40. PLL_SYS, /* System PLL*/
  41. PLL_ENET, /* Enet PLL */
  42. PLL_AUDIO, /* Audio PLL */
  43. PLL_VIDEO, /* Video PLL*/
  44. PLL_DDR, /* Dram PLL */
  45. PLL_USB, /* USB PLL, fixed at 480MHZ */
  46. };
  47. /* clk src for clock root gen */
  48. enum clk_root_src {
  49. OSC_24M_CLK,
  50. PLL_ARM_MAIN_800M_CLK,
  51. PLL_SYS_MAIN_480M_CLK,
  52. PLL_SYS_MAIN_240M_CLK,
  53. PLL_SYS_MAIN_120M_CLK,
  54. PLL_SYS_PFD0_392M_CLK,
  55. PLL_SYS_PFD0_196M_CLK,
  56. PLL_SYS_PFD1_332M_CLK,
  57. PLL_SYS_PFD1_166M_CLK,
  58. PLL_SYS_PFD2_270M_CLK,
  59. PLL_SYS_PFD2_135M_CLK,
  60. PLL_SYS_PFD3_CLK,
  61. PLL_SYS_PFD4_CLK,
  62. PLL_SYS_PFD5_CLK,
  63. PLL_SYS_PFD6_CLK,
  64. PLL_SYS_PFD7_CLK,
  65. PLL_ENET_MAIN_500M_CLK,
  66. PLL_ENET_MAIN_250M_CLK,
  67. PLL_ENET_MAIN_125M_CLK,
  68. PLL_ENET_MAIN_100M_CLK,
  69. PLL_ENET_MAIN_50M_CLK,
  70. PLL_ENET_MAIN_40M_CLK,
  71. PLL_ENET_MAIN_25M_CLK,
  72. PLL_DRAM_MAIN_1066M_CLK,
  73. PLL_DRAM_MAIN_533M_CLK,
  74. PLL_AUDIO_MAIN_CLK,
  75. PLL_VIDEO_MAIN_CLK,
  76. PLL_USB_MAIN_480M_CLK, /* fixed at 480MHZ */
  77. EXT_CLK_1,
  78. EXT_CLK_2,
  79. EXT_CLK_3,
  80. EXT_CLK_4,
  81. REF_1M_CLK,
  82. OSC_32K_CLK,
  83. };
  84. /*
  85. * Clock root index
  86. */
  87. enum clk_root_index {
  88. ARM_A7_CLK_ROOT = 0,
  89. ARM_M4_CLK_ROOT = 1,
  90. ARM_M0_CLK_ROOT = 2,
  91. MAIN_AXI_CLK_ROOT = 16,
  92. DISP_AXI_CLK_ROOT = 17,
  93. ENET_AXI_CLK_ROOT = 18,
  94. NAND_USDHC_BUS_CLK_ROOT = 19,
  95. AHB_CLK_ROOT = 32,
  96. DRAM_PHYM_CLK_ROOT = 48,
  97. DRAM_CLK_ROOT = 49,
  98. DRAM_PHYM_ALT_CLK_ROOT = 64,
  99. DRAM_ALT_CLK_ROOT = 65,
  100. USB_HSIC_CLK_ROOT = 66,
  101. PCIE_CTRL_CLK_ROOT = 67,
  102. PCIE_PHY_CLK_ROOT = 68,
  103. EPDC_PIXEL_CLK_ROOT = 69,
  104. LCDIF_PIXEL_CLK_ROOT = 70,
  105. MIPI_DSI_EXTSER_CLK_ROOT = 71,
  106. MIPI_CSI_WARP_CLK_ROOT = 72,
  107. MIPI_DPHY_REF_CLK_ROOT = 73,
  108. SAI1_CLK_ROOT = 74,
  109. SAI2_CLK_ROOT = 75,
  110. SAI3_CLK_ROOT = 76,
  111. SPDIF_CLK_ROOT = 77,
  112. ENET1_REF_CLK_ROOT = 78,
  113. ENET1_TIME_CLK_ROOT = 79,
  114. ENET2_REF_CLK_ROOT = 80,
  115. ENET2_TIME_CLK_ROOT = 81,
  116. ENET_PHY_REF_CLK_ROOT = 82,
  117. EIM_CLK_ROOT = 83,
  118. NAND_CLK_ROOT = 84,
  119. QSPI_CLK_ROOT = 85,
  120. USDHC1_CLK_ROOT = 86,
  121. USDHC2_CLK_ROOT = 87,
  122. USDHC3_CLK_ROOT = 88,
  123. CAN1_CLK_ROOT = 89,
  124. CAN2_CLK_ROOT = 90,
  125. I2C1_CLK_ROOT = 91,
  126. I2C2_CLK_ROOT = 92,
  127. I2C3_CLK_ROOT = 93,
  128. I2C4_CLK_ROOT = 94,
  129. UART1_CLK_ROOT = 95,
  130. UART2_CLK_ROOT = 96,
  131. UART3_CLK_ROOT = 97,
  132. UART4_CLK_ROOT = 98,
  133. UART5_CLK_ROOT = 99,
  134. UART6_CLK_ROOT = 100,
  135. UART7_CLK_ROOT = 101,
  136. ECSPI1_CLK_ROOT = 102,
  137. ECSPI2_CLK_ROOT = 103,
  138. ECSPI3_CLK_ROOT = 104,
  139. ECSPI4_CLK_ROOT = 105,
  140. PWM1_CLK_ROOT = 106,
  141. PWM2_CLK_ROOT = 107,
  142. PWM3_CLK_ROOT = 108,
  143. PWM4_CLK_ROOT = 109,
  144. FLEXTIMER1_CLK_ROOT = 110,
  145. FLEXTIMER2_CLK_ROOT = 111,
  146. SIM1_CLK_ROOT = 112,
  147. SIM2_CLK_ROOT = 113,
  148. GPT1_CLK_ROOT = 114,
  149. GPT2_CLK_ROOT = 115,
  150. GPT3_CLK_ROOT = 116,
  151. GPT4_CLK_ROOT = 117,
  152. TRACE_CLK_ROOT = 118,
  153. WDOG_CLK_ROOT = 119,
  154. CSI_MCLK_CLK_ROOT = 120,
  155. AUDIO_MCLK_CLK_ROOT = 121,
  156. WRCLK_CLK_ROOT = 122,
  157. IPP_DO_CLKO1 = 123,
  158. IPP_DO_CLKO2 = 124,
  159. CLK_ROOT_MAX,
  160. };
  161. struct clk_root_setting {
  162. enum clk_root_index root;
  163. u32 setting;
  164. };
  165. /*
  166. * CCGR mapping
  167. */
  168. enum clk_ccgr_index {
  169. CCGR_CPU = 0,
  170. CCGR_M4 = 1,
  171. CCGR_SIM_MAIN = 4,
  172. CCGR_SIM_DISPLAY = 5,
  173. CCGR_SIM_ENET = 6,
  174. CCGR_SIM_M = 7,
  175. CCGR_SIM_S = 8,
  176. CCGR_SIM_WAKEUP = 9,
  177. CCGR_IPMUX1 = 10,
  178. CCGR_IPMUX2 = 11,
  179. CCGR_IPMUX3 = 12,
  180. CCGR_ROM = 16,
  181. CCGR_OCRAM = 17,
  182. CCGR_OCRAM_S = 18,
  183. CCGR_DRAM = 19,
  184. CCGR_RAWNAND = 20,
  185. CCGR_QSPI = 21,
  186. CCGR_WEIM = 22,
  187. CCGR_ADC = 32,
  188. CCGR_ANATOP = 33,
  189. CCGR_SCTR = 34,
  190. CCGR_OCOTP = 35,
  191. CCGR_CAAM = 36,
  192. CCGR_SNVS = 37,
  193. CCGR_RDC = 38,
  194. CCGR_MU = 39,
  195. CCGR_HS = 40,
  196. CCGR_DVFS = 41,
  197. CCGR_QOS = 42,
  198. CCGR_QOS_DISPMIX = 43,
  199. CCGR_QOS_MEGAMIX = 44,
  200. CCGR_CSU = 45,
  201. CCGR_DBGMON = 46,
  202. CCGR_DEBUG = 47,
  203. CCGR_TRACE = 48,
  204. CCGR_SEC_DEBUG = 49,
  205. CCGR_SEMA1 = 64,
  206. CCGR_SEMA2 = 65,
  207. CCGR_PERFMON1 = 68,
  208. CCGR_PERFMON2 = 69,
  209. CCGR_SDMA = 72,
  210. CCGR_CSI = 73,
  211. CCGR_EPDC = 74,
  212. CCGR_LCDIF = 75,
  213. CCGR_PXP = 76,
  214. CCGR_PCIE = 96,
  215. CCGR_MIPI_CSI = 100,
  216. CCGR_MIPI_DSI = 101,
  217. CCGR_MIPI_MEM_PHY = 102,
  218. CCGR_USB_CTRL = 104,
  219. CCGR_USB_HSIC = 105,
  220. CCGR_USB_PHY1 = 106,
  221. CCGR_USB_PHY2 = 107,
  222. CCGR_USDHC1 = 108,
  223. CCGR_USDHC2 = 109,
  224. CCGR_USDHC3 = 110,
  225. CCGR_ENET1 = 112,
  226. CCGR_ENET2 = 113,
  227. CCGR_CAN1 = 116,
  228. CCGR_CAN2 = 117,
  229. CCGR_ECSPI1 = 120,
  230. CCGR_ECSPI2 = 121,
  231. CCGR_ECSPI3 = 122,
  232. CCGR_ECSPI4 = 123,
  233. CCGR_GPT1 = 124,
  234. CCGR_GPT2 = 125,
  235. CCGR_GPT3 = 126,
  236. CCGR_GPT4 = 127,
  237. CCGR_FTM1 = 128,
  238. CCGR_FTM2 = 129,
  239. CCGR_PWM1 = 132,
  240. CCGR_PWM2 = 133,
  241. CCGR_PWM3 = 134,
  242. CCGR_PWM4 = 135,
  243. CCGR_I2C1 = 136,
  244. CCGR_I2C2 = 137,
  245. CCGR_I2C3 = 138,
  246. CCGR_I2C4 = 139,
  247. CCGR_SAI1 = 140,
  248. CCGR_SAI2 = 141,
  249. CCGR_SAI3 = 142,
  250. CCGR_SIM1 = 144,
  251. CCGR_SIM2 = 145,
  252. CCGR_UART1 = 148,
  253. CCGR_UART2 = 149,
  254. CCGR_UART3 = 150,
  255. CCGR_UART4 = 151,
  256. CCGR_UART5 = 152,
  257. CCGR_UART6 = 153,
  258. CCGR_UART7 = 154,
  259. CCGR_WDOG1 = 156,
  260. CCGR_WDOG2 = 157,
  261. CCGR_WDOG3 = 158,
  262. CCGR_WDOG4 = 159,
  263. CCGR_GPIO1 = 160,
  264. CCGR_GPIO2 = 161,
  265. CCGR_GPIO3 = 162,
  266. CCGR_GPIO4 = 163,
  267. CCGR_GPIO5 = 164,
  268. CCGR_GPIO6 = 165,
  269. CCGR_GPIO7 = 166,
  270. CCGR_IOMUX = 168,
  271. CCGR_IOMUX_LPSR = 169,
  272. CCGR_KPP = 170,
  273. CCGR_SKIP,
  274. CCGR_MAX,
  275. };
  276. /* Clock root channel */
  277. enum clk_root_type {
  278. CCM_CORE_CHANNEL,
  279. CCM_BUS_CHANNEL,
  280. CCM_AHB_CHANNEL,
  281. CCM_DRAM_PHYM_CHANNEL,
  282. CCM_DRAM_CHANNEL,
  283. CCM_IP_CHANNEL,
  284. };
  285. #include <asm/arch/clock_slice.h>
  286. /*
  287. * entry: the clock root index
  288. * type: ccm channel
  289. * src_mux: each entry corresponding to the clock src, detailed info in CCM RM
  290. */
  291. struct clk_root_map {
  292. enum clk_root_index entry;
  293. enum clk_root_type type;
  294. uint8_t src_mux[8];
  295. };
  296. enum enet_freq {
  297. ENET_25MHz,
  298. ENET_50MHz,
  299. ENET_125MHz,
  300. };
  301. u32 get_root_clk(enum clk_root_index clock_id);
  302. u32 mxc_get_clock(enum mxc_clock clk);
  303. u32 imx_get_uartclk(void);
  304. u32 imx_get_fecclk(void);
  305. void clock_init(void);
  306. #ifdef CONFIG_SYS_I2C_MXC
  307. int enable_i2c_clk(unsigned char enable, unsigned i2c_num);
  308. #endif
  309. #ifdef CONFIG_FEC_MXC
  310. int set_clk_enet(enum enet_freq type);
  311. #endif
  312. int set_clk_qspi(void);
  313. int set_clk_nand(void);
  314. #ifdef CONFIG_MXC_OCOTP
  315. void enable_ocotp_clk(unsigned char enable);
  316. #endif
  317. void enable_usboh3_clk(unsigned char enable);
  318. #ifdef CONFIG_SECURE_BOOT
  319. void hab_caam_clock_enable(unsigned char enable);
  320. #endif
  321. void mxs_set_lcdclk(uint32_t base_addr, uint32_t freq);
  322. void enable_thermal_clk(void);
  323. #endif