fsl_lsch2_speed.c 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  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. sys_info->freq_systembus *= (gur_in32(&gur->rcwsr[0]) >>
  54. FSL_CHASSIS2_RCWSR0_SYS_PLL_RAT_SHIFT) &
  55. FSL_CHASSIS2_RCWSR0_SYS_PLL_RAT_MASK;
  56. sys_info->freq_ddrbus *= (gur_in32(&gur->rcwsr[0]) >>
  57. FSL_CHASSIS2_RCWSR0_MEM_PLL_RAT_SHIFT) &
  58. FSL_CHASSIS2_RCWSR0_MEM_PLL_RAT_MASK;
  59. for (i = 0; i < CONFIG_SYS_FSL_NUM_CC_PLLS; i++) {
  60. ratio[i] = (in_be32(&clk->pllcgsr[i].pllcngsr) >> 1) & 0xff;
  61. if (ratio[i] > 4)
  62. freq_c_pll[i] = sysclk * ratio[i];
  63. else
  64. freq_c_pll[i] = sys_info->freq_systembus * ratio[i];
  65. }
  66. for (cpu = 0; cpu < CONFIG_MAX_CPUS; cpu++) {
  67. u32 c_pll_sel = (in_be32(&clk->clkcsr[cpu].clkcncsr) >> 27)
  68. & 0xf;
  69. u32 cplx_pll = core_cplx_pll[c_pll_sel];
  70. sys_info->freq_processor[cpu] =
  71. freq_c_pll[cplx_pll] / core_cplx_pll_div[c_pll_sel];
  72. }
  73. #define HWA_CGA_M1_CLK_SEL 0xe0000000
  74. #define HWA_CGA_M1_CLK_SHIFT 29
  75. #ifdef CONFIG_SYS_DPAA_FMAN
  76. rcw_tmp = in_be32(&gur->rcwsr[7]);
  77. switch ((rcw_tmp & HWA_CGA_M1_CLK_SEL) >> HWA_CGA_M1_CLK_SHIFT) {
  78. case 2:
  79. sys_info->freq_fman[0] = freq_c_pll[0] / 2;
  80. break;
  81. case 3:
  82. sys_info->freq_fman[0] = freq_c_pll[0] / 3;
  83. break;
  84. case 6:
  85. sys_info->freq_fman[0] = freq_c_pll[1] / 2;
  86. break;
  87. case 7:
  88. sys_info->freq_fman[0] = freq_c_pll[1] / 3;
  89. break;
  90. default:
  91. printf("Error: Unknown FMan1 clock select!\n");
  92. break;
  93. }
  94. #endif
  95. #define HWA_CGA_M2_CLK_SEL 0x00000007
  96. #define HWA_CGA_M2_CLK_SHIFT 0
  97. #ifdef CONFIG_FSL_ESDHC
  98. #ifdef CONFIG_FSL_ESDHC_USE_PERIPHERAL_CLK
  99. rcw_tmp = in_be32(&gur->rcwsr[15]);
  100. rcw_tmp = (rcw_tmp & HWA_CGA_M2_CLK_SEL) >> HWA_CGA_M2_CLK_SHIFT;
  101. sys_info->freq_sdhc = freq_c_pll[1] / rcw_tmp;
  102. #else
  103. sys_info->freq_sdhc = sys_info->freq_systembus;
  104. #endif
  105. #endif
  106. #if defined(CONFIG_FSL_IFC)
  107. ccr = ifc_in32(&ifc_regs.gregs->ifc_ccr);
  108. ccr = ((ccr & IFC_CCR_CLK_DIV_MASK) >> IFC_CCR_CLK_DIV_SHIFT) + 1;
  109. sys_info->freq_localbus = sys_info->freq_systembus / ccr;
  110. #endif
  111. }
  112. int get_clocks(void)
  113. {
  114. struct sys_info sys_info;
  115. get_sys_info(&sys_info);
  116. gd->cpu_clk = sys_info.freq_processor[0];
  117. gd->bus_clk = sys_info.freq_systembus;
  118. gd->mem_clk = sys_info.freq_ddrbus;
  119. #ifdef CONFIG_FSL_ESDHC
  120. gd->arch.sdhc_clk = sys_info.freq_sdhc;
  121. #endif
  122. if (gd->cpu_clk != 0)
  123. return 0;
  124. else
  125. return 1;
  126. }
  127. ulong get_bus_freq(ulong dummy)
  128. {
  129. return gd->bus_clk;
  130. }
  131. ulong get_ddr_freq(ulong dummy)
  132. {
  133. return gd->mem_clk;
  134. }
  135. #ifdef CONFIG_FSL_ESDHC
  136. int get_sdhc_freq(ulong dummy)
  137. {
  138. return gd->arch.sdhc_clk;
  139. }
  140. #endif
  141. int get_serial_clock(void)
  142. {
  143. return gd->bus_clk;
  144. }
  145. unsigned int mxc_get_clock(enum mxc_clock clk)
  146. {
  147. switch (clk) {
  148. case MXC_I2C_CLK:
  149. return get_bus_freq(0);
  150. #if defined(CONFIG_FSL_ESDHC)
  151. case MXC_ESDHC_CLK:
  152. return get_sdhc_freq(0);
  153. #endif
  154. case MXC_DSPI_CLK:
  155. return get_bus_freq(0);
  156. case MXC_UART_CLK:
  157. return get_bus_freq(0);
  158. default:
  159. printf("Unsupported clock\n");
  160. }
  161. return 0;
  162. }