mt8188-afe-clk.h 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * mt8188-afe-clk.h -- MediaTek 8188 afe clock ctrl definition
  4. *
  5. * Copyright (c) 2022 MediaTek Inc.
  6. * Author: Bicycle Tsai <bicycle.tsai@mediatek.com>
  7. * Trevor Wu <trevor.wu@mediatek.com>
  8. * Chun-Chia Chiu <chun-chia.chiu@mediatek.com>
  9. */
  10. #ifndef _MT8188_AFE_CLK_H_
  11. #define _MT8188_AFE_CLK_H_
  12. /* APLL */
  13. #define APLL1_W_NAME "APLL1"
  14. #define APLL2_W_NAME "APLL2"
  15. enum {
  16. /* xtal */
  17. MT8188_CLK_XTAL_26M,
  18. /* pll */
  19. MT8188_CLK_APMIXED_APLL1,
  20. MT8188_CLK_APMIXED_APLL2,
  21. /* divider */
  22. MT8188_CLK_TOP_APLL1_D4,
  23. MT8188_CLK_TOP_APLL2_D4,
  24. MT8188_CLK_TOP_APLL12_DIV0,
  25. MT8188_CLK_TOP_APLL12_DIV1,
  26. MT8188_CLK_TOP_APLL12_DIV2,
  27. MT8188_CLK_TOP_APLL12_DIV3,
  28. MT8188_CLK_TOP_APLL12_DIV4,
  29. MT8188_CLK_TOP_APLL12_DIV9,
  30. /* mux */
  31. MT8188_CLK_TOP_A1SYS_HP_SEL,
  32. MT8188_CLK_TOP_A2SYS_SEL,
  33. MT8188_CLK_TOP_AUD_IEC_SEL,
  34. MT8188_CLK_TOP_AUD_INTBUS_SEL,
  35. MT8188_CLK_TOP_AUDIO_H_SEL,
  36. MT8188_CLK_TOP_AUDIO_LOCAL_BUS_SEL,
  37. MT8188_CLK_TOP_DPTX_M_SEL,
  38. MT8188_CLK_TOP_I2SO1_M_SEL,
  39. MT8188_CLK_TOP_I2SO2_M_SEL,
  40. MT8188_CLK_TOP_I2SI1_M_SEL,
  41. MT8188_CLK_TOP_I2SI2_M_SEL,
  42. /* clock gate */
  43. MT8188_CLK_ADSP_AUDIO_26M,
  44. MT8188_CLK_AUD_AFE,
  45. MT8188_CLK_AUD_APLL1_TUNER,
  46. MT8188_CLK_AUD_APLL2_TUNER,
  47. MT8188_CLK_AUD_TOP0_SPDF,
  48. MT8188_CLK_AUD_APLL,
  49. MT8188_CLK_AUD_APLL2,
  50. MT8188_CLK_AUD_DAC,
  51. MT8188_CLK_AUD_ADC,
  52. MT8188_CLK_AUD_DAC_HIRES,
  53. MT8188_CLK_AUD_A1SYS_HP,
  54. MT8188_CLK_AUD_ADC_HIRES,
  55. MT8188_CLK_AUD_I2SIN,
  56. MT8188_CLK_AUD_TDM_IN,
  57. MT8188_CLK_AUD_I2S_OUT,
  58. MT8188_CLK_AUD_TDM_OUT,
  59. MT8188_CLK_AUD_HDMI_OUT,
  60. MT8188_CLK_AUD_ASRC11,
  61. MT8188_CLK_AUD_ASRC12,
  62. MT8188_CLK_AUD_A1SYS,
  63. MT8188_CLK_AUD_A2SYS,
  64. MT8188_CLK_AUD_PCMIF,
  65. MT8188_CLK_AUD_MEMIF_UL1,
  66. MT8188_CLK_AUD_MEMIF_UL2,
  67. MT8188_CLK_AUD_MEMIF_UL3,
  68. MT8188_CLK_AUD_MEMIF_UL4,
  69. MT8188_CLK_AUD_MEMIF_UL5,
  70. MT8188_CLK_AUD_MEMIF_UL6,
  71. MT8188_CLK_AUD_MEMIF_UL8,
  72. MT8188_CLK_AUD_MEMIF_UL9,
  73. MT8188_CLK_AUD_MEMIF_UL10,
  74. MT8188_CLK_AUD_MEMIF_DL2,
  75. MT8188_CLK_AUD_MEMIF_DL3,
  76. MT8188_CLK_AUD_MEMIF_DL6,
  77. MT8188_CLK_AUD_MEMIF_DL7,
  78. MT8188_CLK_AUD_MEMIF_DL8,
  79. MT8188_CLK_AUD_MEMIF_DL10,
  80. MT8188_CLK_AUD_MEMIF_DL11,
  81. MT8188_CLK_NUM,
  82. };
  83. enum {
  84. MT8188_AUD_PLL1,
  85. MT8188_AUD_PLL2,
  86. MT8188_AUD_PLL3,
  87. MT8188_AUD_PLL4,
  88. MT8188_AUD_PLL5,
  89. MT8188_AUD_PLL_NUM,
  90. };
  91. enum {
  92. MT8188_MCK_SEL_26M,
  93. MT8188_MCK_SEL_APLL1,
  94. MT8188_MCK_SEL_APLL2,
  95. MT8188_MCK_SEL_APLL3,
  96. MT8188_MCK_SEL_APLL4,
  97. MT8188_MCK_SEL_APLL5,
  98. MT8188_MCK_SEL_NUM,
  99. };
  100. struct mtk_base_afe;
  101. int mt8188_afe_get_mclk_source_clk_id(int sel);
  102. int mt8188_afe_get_mclk_source_rate(struct mtk_base_afe *afe, int apll);
  103. int mt8188_afe_get_default_mclk_source_by_rate(int rate);
  104. int mt8188_get_apll_by_rate(struct mtk_base_afe *afe, int rate);
  105. int mt8188_get_apll_by_name(struct mtk_base_afe *afe, const char *name);
  106. int mt8188_afe_init_clock(struct mtk_base_afe *afe);
  107. int mt8188_afe_enable_clk(struct mtk_base_afe *afe, struct clk *clk);
  108. void mt8188_afe_disable_clk(struct mtk_base_afe *afe, struct clk *clk);
  109. int mt8188_afe_set_clk_rate(struct mtk_base_afe *afe, struct clk *clk,
  110. unsigned int rate);
  111. int mt8188_afe_set_clk_parent(struct mtk_base_afe *afe, struct clk *clk,
  112. struct clk *parent);
  113. int mt8188_apll1_enable(struct mtk_base_afe *afe);
  114. int mt8188_apll1_disable(struct mtk_base_afe *afe);
  115. int mt8188_apll2_enable(struct mtk_base_afe *afe);
  116. int mt8188_apll2_disable(struct mtk_base_afe *afe);
  117. int mt8188_afe_enable_main_clock(struct mtk_base_afe *afe);
  118. int mt8188_afe_disable_main_clock(struct mtk_base_afe *afe);
  119. int mt8188_afe_enable_reg_rw_clk(struct mtk_base_afe *afe);
  120. int mt8188_afe_disable_reg_rw_clk(struct mtk_base_afe *afe);
  121. #endif