connectTheSignalSlot.c 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254
  1. /*
  2. * AM33XX Clock data
  3. *
  4. * Copyright (C) 2012 Texas Instruments Incorporated - http://www.ti.com/
  5. * Vaibhav Hiremath <hvaibhav@ti.com>
  6. *
  7. * This program is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU General Public License as
  9. * published by the Free Software Foundation version 2.
  10. *
  11. * This program is distributed "as is" WITHOUT ANY WARRANTY of any
  12. * kind, whether express or implied; without even the implied warranty
  13. * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. */
  16. #include <linux/kernel.h>
  17. #include <linux/list.h>
  18. #include <linux/clk-private.h>
  19. #include <linux/clkdev.h>
  20. #include <linux/io.h>
  21. #include "am33xx.h"
  22. #include "soc.h"
  23. #include "iomap.h"
  24. #include "clock.h"
  25. #include "control.h"
  26. #include "cm.h"
  27. #include "cm33xx.h"
  28. #include "cm-regbits-33xx.h"
  29. #include "prm.h"
  30. /* Modulemode control */
  31. #define AM33XX_MODULEMODE_HWCTRL_SHIFT 0
  32. #define AM33XX_MODULEMODE_SWCTRL_SHIFT 1
  33. /*LIST_HEAD(clocks);*/
  34. /* Root clocks */
  35. /* RTC 32k */
  36. DEFINE_CLK_FIXED_RATE(clk_32768_ck, CLK_IS_ROOT, 32768, 0x0);
  37. /* On-Chip 32KHz RC OSC */
  38. DEFINE_CLK_FIXED_RATE(clk_rc32k_ck, CLK_IS_ROOT, 32000, 0x0);
  39. /* Crystal input clks */
  40. DEFINE_CLK_FIXED_RATE(virt_19200000_ck, CLK_IS_ROOT, 19200000, 0x0);
  41. DEFINE_CLK_FIXED_RATE(virt_24000000_ck, CLK_IS_ROOT, 24000000, 0x0);
  42. DEFINE_CLK_FIXED_RATE(virt_25000000_ck, CLK_IS_ROOT, 25000000, 0x0);
  43. DEFINE_CLK_FIXED_RATE(virt_26000000_ck, CLK_IS_ROOT, 26000000, 0x0);
  44. /* Oscillator clock */
  45. /* 19.2, 24, 25 or 26 MHz */
  46. static const char *sys_clkin_ck_parents[] = {
  47. "virt_19200000_ck", "virt_24000000_ck", "virt_25000000_ck",
  48. "virt_26000000_ck",
  49. };
  50. /*
  51. * sys_clk in: input to the dpll and also used as funtional clock for,
  52. * adc_tsc, smartreflex0-1, timer1-7, mcasp0-1, dcan0-1, cefuse
  53. *
  54. */
  55. DEFINE_CLK_MUX(sys_clkin_ck, sys_clkin_ck_parents, NULL, 0x0,
  56. AM33XX_CTRL_REGADDR(AM33XX_CONTROL_STATUS),
  57. AM33XX_CONTROL_STATUS_SYSBOOT1_SHIFT,
  58. AM33XX_CONTROL_STATUS_SYSBOOT1_WIDTH,
  59. 0, NULL);
  60. /* External clock - 12 MHz */
  61. DEFINE_CLK_FIXED_RATE(tclkin_ck, CLK_IS_ROOT, 12000000, 0x0);
  62. /* Module clocks and DPLL outputs */
  63. /* DPLL_CORE */
  64. static struct dpll_data dpll_core_dd = {
  65. .mult_div1_reg = AM33XX_CM_CLKSEL_DPLL_CORE,
  66. .clk_bypass = &sys_clkin_ck,
  67. .clk_ref = &sys_clkin_ck,
  68. .control_reg = AM33XX_CM_CLKMODE_DPLL_CORE,
  69. .modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
  70. .idlest_reg = AM33XX_CM_IDLEST_DPLL_CORE,
  71. .mult_mask = AM33XX_DPLL_MULT_MASK,
  72. .div1_mask = AM33XX_DPLL_DIV_MASK,
  73. .enable_mask = AM33XX_DPLL_EN_MASK,
  74. .idlest_mask = AM33XX_ST_DPLL_CLK_MASK,
  75. .max_multiplier = 2047,
  76. .max_divider = 128,
  77. .min_divider = 1,
  78. };
  79. /* CLKDCOLDO output */
  80. static const char *dpll_core_ck_parents[] = {
  81. "sys_clkin_ck",
  82. };
  83. static struct clk dpll_core_ck;
  84. static const struct clk_ops dpll_core_ck_ops = {
  85. .recalc_rate = &omap3_dpll_recalc,
  86. .get_parent = &omap2_init_dpll_parent,
  87. };
  88. static struct clk_hw_omap dpll_core_ck_hw = {
  89. .hw = {
  90. .clk = &dpll_core_ck,
  91. },
  92. .dpll_data = &dpll_core_dd,
  93. .ops = &clkhwops_omap3_dpll,
  94. };
  95. DEFINE_STRUCT_CLK(dpll_core_ck, dpll_core_ck_parents, dpll_core_ck_ops);
  96. static const char *dpll_core_x2_ck_parents[] = {
  97. "dpll_core_ck",
  98. };
  99. static struct clk dpll_core_x2_ck;
  100. static const struct clk_ops dpll_x2_ck_ops = {
  101. .recalc_rate = &omap3_clkoutx2_recalc,
  102. };
  103. static struct clk_hw_omap dpll_core_x2_ck_hw = {
  104. .hw = {
  105. .clk = &dpll_core_x2_ck,
  106. },
  107. .flags = CLOCK_CLKOUTX2,
  108. };
  109. DEFINE_STRUCT_CLK(dpll_core_x2_ck, dpll_core_x2_ck_parents, dpll_x2_ck_ops);
  110. DEFINE_CLK_DIVIDER(dpll_core_m4_ck, "dpll_core_x2_ck", &dpll_core_x2_ck,
  111. 0x0, AM33XX_CM_DIV_M4_DPLL_CORE,
  112. AM33XX_HSDIVIDER_CLKOUT1_DIV_SHIFT,
  113. AM33XX_HSDIVIDER_CLKOUT1_DIV_WIDTH, CLK_DIVIDER_ONE_BASED,
  114. NULL);
  115. DEFINE_CLK_DIVIDER(dpll_core_m5_ck, "dpll_core_x2_ck", &dpll_core_x2_ck,
  116. 0x0, AM33XX_CM_DIV_M5_DPLL_CORE,
  117. AM33XX_HSDIVIDER_CLKOUT2_DIV_SHIFT,
  118. AM33XX_HSDIVIDER_CLKOUT2_DIV_WIDTH,
  119. CLK_DIVIDER_ONE_BASED, NULL);
  120. DEFINE_CLK_DIVIDER(dpll_core_m6_ck, "dpll_core_x2_ck", &dpll_core_x2_ck,
  121. 0x0, AM33XX_CM_DIV_M6_DPLL_CORE,
  122. AM33XX_HSDIVIDER_CLKOUT3_DIV_SHIFT,
  123. AM33XX_HSDIVIDER_CLKOUT3_DIV_WIDTH,
  124. CLK_DIVIDER_ONE_BASED, NULL);
  125. /* DPLL_MPU */
  126. static struct dpll_data dpll_mpu_dd = {
  127. .mult_div1_reg = AM33XX_CM_CLKSEL_DPLL_MPU,
  128. .clk_bypass = &sys_clkin_ck,
  129. .clk_ref = &sys_clkin_ck,
  130. .control_reg = AM33XX_CM_CLKMODE_DPLL_MPU,
  131. .modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
  132. .idlest_reg = AM33XX_CM_IDLEST_DPLL_MPU,
  133. .mult_mask = AM33XX_DPLL_MULT_MASK,
  134. .div1_mask = AM33XX_DPLL_DIV_MASK,
  135. .enable_mask = AM33XX_DPLL_EN_MASK,
  136. .idlest_mask = AM33XX_ST_DPLL_CLK_MASK,
  137. .max_multiplier = 2047,
  138. .max_divider = 128,
  139. .min_divider = 1,
  140. };
  141. /* CLKOUT: fdpll/M2 */
  142. static struct clk dpll_mpu_ck;
  143. static const struct clk_ops dpll_mpu_ck_ops = {
  144. .enable = &omap3_noncore_dpll_enable,
  145. .disable = &omap3_noncore_dpll_disable,
  146. .recalc_rate = &omap3_dpll_recalc,
  147. .round_rate = &omap2_dpll_round_rate,
  148. .set_rate = &omap3_noncore_dpll_set_rate,
  149. .get_parent = &omap2_init_dpll_parent,
  150. };
  151. static struct clk_hw_omap dpll_mpu_ck_hw = {
  152. .hw = {
  153. .clk = &dpll_mpu_ck,
  154. },
  155. .dpll_data = &dpll_mpu_dd,
  156. .ops = &clkhwops_omap3_dpll,
  157. };
  158. DEFINE_STRUCT_CLK(dpll_mpu_ck, dpll_core_ck_parents, dpll_mpu_ck_ops);
  159. /*
  160. * TODO: Add clksel here (sys_clkin, CORE_CLKOUTM6, PER_CLKOUTM2
  161. * and ALT_CLK1/2)
  162. */
  163. DEFINE_CLK_DIVIDER(dpll_mpu_m2_ck, "dpll_mpu_ck", &dpll_mpu_ck,
  164. 0x0, AM33XX_CM_DIV_M2_DPLL_MPU, AM33XX_DPLL_CLKOUT_DIV_SHIFT,
  165. AM33XX_DPLL_CLKOUT_DIV_WIDTH, CLK_DIVIDER_ONE_BASED, NULL);
  166. /* DPLL_DDR */
  167. static struct dpll_data dpll_ddr_dd = {
  168. .mult_div1_reg = AM33XX_CM_CLKSEL_DPLL_DDR,
  169. .clk_bypass = &sys_clkin_ck,
  170. .clk_ref = &sys_clkin_ck,
  171. .control_reg = AM33XX_CM_CLKMODE_DPLL_DDR,
  172. .modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED),
  173. .idlest_reg = AM33XX_CM_IDLEST_DPLL_DDR,
  174. .mult_mask = AM33XX_DPLL_MULT_MASK,
  175. .div1_mask = AM33XX_DPLL_DIV_MASK,
  176. .enable_mask = AM33XX_DPLL_EN_MASK,
  177. .idlest_mask = AM33XX_ST_DPLL_CLK_MASK,
  178. .max_multiplier = 2047,
  179. .max_divider = 128,
  180. .min_divider = 1,
  181. };
  182. /* CLKOUT: fdpll/M2 */
  183. static struct clk dpll_ddr_ck;
  184. static const struct clk_ops dpll_ddr_ck_ops = {
  185. .recalc_rate = &omap3_dpll_recalc,
  186. .get_parent = &omap2_init_dpll_parent,
  187. .round_rate = &omap2_dpll_round_rate,
  188. .set_rate = &omap3_noncore_dpll_set_rate,
  189. };
  190. static struct clk_hw_omap dpll_ddr_ck_hw = {
  191. .hw = {
  192. .clk = &dpll_ddr_ck,
  193. },
  194. .dpll_data = &dpll_ddr_dd,
  195. .ops = &clkhwops_omap3_dpll,
  196. };
  197. DEFINE_STRUCT_CLK(dpll_ddr_ck, dpll_core_ck_parents, dpll_ddr_ck_ops);
  198. /*
  199. * TODO: Add clksel here (sys_clkin, CORE_CLKOUTM6, PER_CLKOUTM2
  200. * and ALT_CLK1/2)
  201. */
  202. DEFINE_CLK_DIVIDER(dpll_ddr_m2_ck, "dpll_ddr_ck", &dpll_ddr_ck,
  203. 0x0, AM33XX_CM_DIV_M2_DPLL_DDR,
  204. AM33XX_DPLL_CLKOUT_DIV_SHIFT, AM33XX_DPLL_CLKOUT_DIV_WIDTH,
  205. CLK_DIVIDER_ONE_BASED, NULL);
  206. /* emif_fck functional clock */
  207. DEFINE_CLK_FIXED_FACTOR(dpll_ddr_m2_div2_ck, "dpll_ddr_m2_ck", &dpll_ddr_m2_ck,
  208. 0x0, 1, 2);
  209. /* DPLL_DISP */
  210. static struct dpll_data dpll_disp_dd = {