fsl_lsch2_speed.c 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. /*
  2. * Copyright 2015 Freescale Semiconductor, Inc.
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. #include <common.h>
  7. #include <linux/compiler.h>
  8. #include <asm/io.h>
  9. #include <asm/processor.h>
  10. #include <asm/arch/clock.h>
  11. #include <asm/arch/soc.h>
  12. #include <fsl_ifc.h>
  13. DECLARE_GLOBAL_DATA_PTR;
  14. #ifndef CONFIG_SYS_FSL_NUM_CC_PLLS
  15. #define CONFIG_SYS_FSL_NUM_CC_PLLS 2
  16. #endif
  17. void get_sys_info(struct sys_info *sys_info)
  18. {
  19. struct ccsr_gur __iomem *gur = (void *)(CONFIG_SYS_FSL_GUTS_ADDR);
  20. #ifdef CONFIG_FSL_IFC
  21. struct fsl_ifc ifc_regs = {(void *)CONFIG_SYS_IFC_ADDR, (void *)NULL};
  22. u32 ccr;
  23. #endif
  24. #if (defined(CONFIG_FSL_ESDHC) &&\
  25. defined(CONFIG_FSL_ESDHC_USE_PERIPHERAL_CLK)) ||\
  26. defined(CONFIG_SYS_DPAA_FMAN)
  27. u32 rcw_tmp;
  28. #endif
  29. struct ccsr_clk *clk = (void *)(CONFIG_SYS_FSL_CLK_ADDR);
  30. unsigned int cpu;
  31. const u8 core_cplx_pll[8] = {
  32. [0] = 0, /* CC1 PPL / 1 */
  33. [1] = 0, /* CC1 PPL / 2 */
  34. [4] = 1, /* CC2 PPL / 1 */
  35. [5] = 1, /* CC2 PPL / 2 */
  36. };
  37. const u8 core_cplx_pll_div[8] = {
  38. [0] = 1, /* CC1 PPL / 1 */
  39. [1] = 2, /* CC1 PPL / 2 */
  40. [4] = 1, /* CC2 PPL / 1 */
  41. [5] = 2, /* CC2 PPL / 2 */
  42. };
  43. uint i;
  44. uint freq_c_pll[CONFIG_SYS_FSL_NUM_CC_PLLS];
  45. uint ratio[CONFIG_SYS_FSL_NUM_CC_PLLS];
  46. unsigned long sysclk = CONFIG_SYS_CLK_FREQ;
  47. sys_info->freq_systembus = sysclk;
  48. #ifdef CONFIG_DDR_CLK_FREQ
  49. sys_info->freq_ddrbus = CONFIG_DDR_CLK_FREQ;
  50. #else
  51. sys_info->freq_ddrbus = sysclk;
  52. #endif
  53. #ifdef CONFIG_LS1012A
  54. sys_info->freq_ddrbus *= (gur_in32(&gur->rcwsr[0]) >>
  55. FSL_CHASSIS2_RCWSR0_SYS_PLL_RAT_SHIFT) &
  56. FSL_CHASSIS2_RCWSR0_SYS_PLL_RAT_MASK;
  57. #else
  58. sys_info->freq_systembus *= (gur_in32(&gur->rcwsr[0]) >>
  59. FSL_CHASSIS2_RCWSR0_SYS_PLL_RAT_SHIFT) &
  60. FSL_CHASSIS2_RCWSR0_SYS_PLL_RAT_MASK;
  61. sys_info->freq_ddrbus *= (gur_in32(&gur->rcwsr[0]) >>
  62. FSL_CHASSIS2_RCWSR0_MEM_PLL_RAT_SHIFT) &
  63. FSL_CHASSIS2_RCWSR0_MEM_PLL_RAT_MASK;
  64. #endif
  65. for (i = 0; i < CONFIG_SYS_FSL_NUM_CC_PLLS; i++) {
  66. ratio[i] = (in_be32(&clk->pllcgsr[i].pllcngsr) >> 1) & 0xff;
  67. if (ratio[i] > 4)
  68. freq_c_pll[i] = sysclk * ratio[i];
  69. else
  70. freq_c_pll[i] = sys_info->freq_systembus * ratio[i];
  71. }
  72. for (cpu = 0; cpu < CONFIG_MAX_CPUS; cpu++) {
  73. u32 c_pll_sel = (in_be32(&clk->clkcsr[cpu].clkcncsr) >> 27)
  74. & 0xf;
  75. u32 cplx_pll = core_cplx_pll[c_pll_sel];
  76. sys_info->freq_processor[cpu] =
  77. freq_c_pll[cplx_pll] / core_cplx_pll_div[c_pll_sel];
  78. }
  79. #ifdef CONFIG_LS1012A
  80. sys_info->freq_systembus = sys_info->freq_ddrbus / 2;
  81. sys_info->freq_ddrbus *= 2;
  82. #endif
  83. #define HWA_CGA_M1_CLK_SEL 0xe0000000
  84. #define HWA_CGA_M1_CLK_SHIFT 29
  85. #ifdef CONFIG_SYS_DPAA_FMAN
  86. rcw_tmp = in_be32(&gur->rcwsr[7]);
  87. switch ((rcw_tmp & HWA_CGA_M1_CLK_SEL) >> HWA_CGA_M1_CLK_SHIFT) {
  88. case 2:
  89. sys_info->freq_fman[0] = freq_c_pll[0] / 2;
  90. break;
  91. case 3:
  92. sys_info->freq_fman[0] = freq_c_pll[0] / 3;
  93. break;
  94. case 6:
  95. sys_info->freq_fman[0] = freq_c_pll[1] / 2;
  96. break;
  97. case 7:
  98. sys_info->freq_fman[0] = freq_c_pll[1] / 3;
  99. break;
  100. default:
  101. printf("Error: Unknown FMan1 clock select!\n");
  102. break;
  103. }
  104. #endif
  105. #define HWA_CGA_M2_CLK_SEL 0x00000007
  106. #define HWA_CGA_M2_CLK_SHIFT 0
  107. #ifdef CONFIG_FSL_ESDHC
  108. #ifdef CONFIG_FSL_ESDHC_USE_PERIPHERAL_CLK
  109. rcw_tmp = in_be32(&gur->rcwsr[15]);
  110. rcw_tmp = (rcw_tmp & HWA_CGA_M2_CLK_SEL) >> HWA_CGA_M2_CLK_SHIFT;
  111. sys_info->freq_sdhc = freq_c_pll[1] / rcw_tmp;
  112. #else
  113. sys_info->freq_sdhc = sys_info->freq_systembus;
  114. #endif
  115. #endif
  116. #if defined(CONFIG_FSL_IFC)
  117. ccr = ifc_in32(&ifc_regs.gregs->ifc_ccr);
  118. ccr = ((ccr & IFC_CCR_CLK_DIV_MASK) >> IFC_CCR_CLK_DIV_SHIFT) + 1;
  119. sys_info->freq_localbus = sys_info->freq_systembus / ccr;
  120. #endif
  121. }
  122. int get_clocks(void)
  123. {
  124. struct sys_info sys_info;
  125. get_sys_info(&sys_info);
  126. gd->cpu_clk = sys_info.freq_processor[0];
  127. gd->bus_clk = sys_info.freq_systembus;
  128. gd->mem_clk = sys_info.freq_ddrbus;
  129. #ifdef CONFIG_FSL_ESDHC
  130. gd->arch.sdhc_clk = sys_info.freq_sdhc;
  131. #endif
  132. if (gd->cpu_clk != 0)
  133. return 0;
  134. else
  135. return 1;
  136. }
  137. ulong get_bus_freq(ulong dummy)
  138. {
  139. return gd->bus_clk;
  140. }
  141. ulong get_ddr_freq(ulong dummy)
  142. {
  143. return gd->mem_clk;
  144. }
  145. #ifdef CONFIG_FSL_ESDHC
  146. int get_sdhc_freq(ulong dummy)
  147. {
  148. return gd->arch.sdhc_clk;
  149. }
  150. #endif
  151. int get_serial_clock(void)
  152. {
  153. return gd->bus_clk;
  154. }
  155. unsigned int mxc_get_clock(enum mxc_clock clk)
  156. {
  157. switch (clk) {
  158. case MXC_I2C_CLK:
  159. return get_bus_freq(0);
  160. #if defined(CONFIG_FSL_ESDHC)
  161. case MXC_ESDHC_CLK:
  162. return get_sdhc_freq(0);
  163. #endif
  164. case MXC_DSPI_CLK:
  165. return get_bus_freq(0);
  166. case MXC_UART_CLK:
  167. return get_bus_freq(0);
  168. default:
  169. printf("Unsupported clock\n");
  170. }
  171. return 0;
  172. }