fu740-prci.h 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * Copyright (C) 2020-2021 SiFive, Inc.
  4. * Copyright (C) 2020-2021 Zong Li
  5. */
  6. #ifndef __SIFIVE_CLK_FU740_PRCI_H
  7. #define __SIFIVE_CLK_FU740_PRCI_H
  8. #include <linux/module.h>
  9. #include <dt-bindings/clock/sifive-fu740-prci.h>
  10. #include "sifive-prci.h"
  11. /* PRCI integration data for each WRPLL instance */
  12. static struct __prci_wrpll_data sifive_fu740_prci_corepll_data = {
  13. .cfg0_offs = PRCI_COREPLLCFG0_OFFSET,
  14. .cfg1_offs = PRCI_COREPLLCFG1_OFFSET,
  15. .enable_bypass = sifive_prci_coreclksel_use_hfclk,
  16. .disable_bypass = sifive_prci_coreclksel_use_final_corepll,
  17. };
  18. static struct __prci_wrpll_data sifive_fu740_prci_ddrpll_data = {
  19. .cfg0_offs = PRCI_DDRPLLCFG0_OFFSET,
  20. .cfg1_offs = PRCI_DDRPLLCFG1_OFFSET,
  21. };
  22. static struct __prci_wrpll_data sifive_fu740_prci_gemgxlpll_data = {
  23. .cfg0_offs = PRCI_GEMGXLPLLCFG0_OFFSET,
  24. .cfg1_offs = PRCI_GEMGXLPLLCFG1_OFFSET,
  25. };
  26. static struct __prci_wrpll_data sifive_fu740_prci_dvfscorepll_data = {
  27. .cfg0_offs = PRCI_DVFSCOREPLLCFG0_OFFSET,
  28. .cfg1_offs = PRCI_DVFSCOREPLLCFG1_OFFSET,
  29. .enable_bypass = sifive_prci_corepllsel_use_corepll,
  30. .disable_bypass = sifive_prci_corepllsel_use_dvfscorepll,
  31. };
  32. static struct __prci_wrpll_data sifive_fu740_prci_hfpclkpll_data = {
  33. .cfg0_offs = PRCI_HFPCLKPLLCFG0_OFFSET,
  34. .cfg1_offs = PRCI_HFPCLKPLLCFG1_OFFSET,
  35. .enable_bypass = sifive_prci_hfpclkpllsel_use_hfclk,
  36. .disable_bypass = sifive_prci_hfpclkpllsel_use_hfpclkpll,
  37. };
  38. static struct __prci_wrpll_data sifive_fu740_prci_cltxpll_data = {
  39. .cfg0_offs = PRCI_CLTXPLLCFG0_OFFSET,
  40. .cfg1_offs = PRCI_CLTXPLLCFG1_OFFSET,
  41. };
  42. /* Linux clock framework integration */
  43. static const struct clk_ops sifive_fu740_prci_wrpll_clk_ops = {
  44. .set_rate = sifive_prci_wrpll_set_rate,
  45. .round_rate = sifive_prci_wrpll_round_rate,
  46. .recalc_rate = sifive_prci_wrpll_recalc_rate,
  47. .enable = sifive_prci_clock_enable,
  48. .disable = sifive_prci_clock_disable,
  49. .is_enabled = sifive_clk_is_enabled,
  50. };
  51. static const struct clk_ops sifive_fu740_prci_wrpll_ro_clk_ops = {
  52. .recalc_rate = sifive_prci_wrpll_recalc_rate,
  53. };
  54. static const struct clk_ops sifive_fu740_prci_tlclksel_clk_ops = {
  55. .recalc_rate = sifive_prci_tlclksel_recalc_rate,
  56. };
  57. static const struct clk_ops sifive_fu740_prci_hfpclkplldiv_clk_ops = {
  58. .recalc_rate = sifive_prci_hfpclkplldiv_recalc_rate,
  59. };
  60. static const struct clk_ops sifive_fu740_prci_pcie_aux_clk_ops = {
  61. .enable = sifive_prci_pcie_aux_clock_enable,
  62. .disable = sifive_prci_pcie_aux_clock_disable,
  63. .is_enabled = sifive_prci_pcie_aux_clock_is_enabled,
  64. };
  65. /* List of clock controls provided by the PRCI */
  66. static struct __prci_clock __prci_init_clocks_fu740[] = {
  67. [FU740_PRCI_CLK_COREPLL] = {
  68. .name = "corepll",
  69. .parent_name = "hfclk",
  70. .ops = &sifive_fu740_prci_wrpll_clk_ops,
  71. .pwd = &sifive_fu740_prci_corepll_data,
  72. },
  73. [FU740_PRCI_CLK_DDRPLL] = {
  74. .name = "ddrpll",
  75. .parent_name = "hfclk",
  76. .ops = &sifive_fu740_prci_wrpll_ro_clk_ops,
  77. .pwd = &sifive_fu740_prci_ddrpll_data,
  78. },
  79. [FU740_PRCI_CLK_GEMGXLPLL] = {
  80. .name = "gemgxlpll",
  81. .parent_name = "hfclk",
  82. .ops = &sifive_fu740_prci_wrpll_clk_ops,
  83. .pwd = &sifive_fu740_prci_gemgxlpll_data,
  84. },
  85. [FU740_PRCI_CLK_DVFSCOREPLL] = {
  86. .name = "dvfscorepll",
  87. .parent_name = "hfclk",
  88. .ops = &sifive_fu740_prci_wrpll_clk_ops,
  89. .pwd = &sifive_fu740_prci_dvfscorepll_data,
  90. },
  91. [FU740_PRCI_CLK_HFPCLKPLL] = {
  92. .name = "hfpclkpll",
  93. .parent_name = "hfclk",
  94. .ops = &sifive_fu740_prci_wrpll_clk_ops,
  95. .pwd = &sifive_fu740_prci_hfpclkpll_data,
  96. },
  97. [FU740_PRCI_CLK_CLTXPLL] = {
  98. .name = "cltxpll",
  99. .parent_name = "hfclk",
  100. .ops = &sifive_fu740_prci_wrpll_clk_ops,
  101. .pwd = &sifive_fu740_prci_cltxpll_data,
  102. },
  103. [FU740_PRCI_CLK_TLCLK] = {
  104. .name = "tlclk",
  105. .parent_name = "corepll",
  106. .ops = &sifive_fu740_prci_tlclksel_clk_ops,
  107. },
  108. [FU740_PRCI_CLK_PCLK] = {
  109. .name = "pclk",
  110. .parent_name = "hfpclkpll",
  111. .ops = &sifive_fu740_prci_hfpclkplldiv_clk_ops,
  112. },
  113. [FU740_PRCI_CLK_PCIE_AUX] = {
  114. .name = "pcie_aux",
  115. .parent_name = "hfclk",
  116. .ops = &sifive_fu740_prci_pcie_aux_clk_ops,
  117. },
  118. };
  119. static const struct prci_clk_desc prci_clk_fu740 = {
  120. .clks = __prci_init_clocks_fu740,
  121. .num_clks = ARRAY_SIZE(__prci_init_clocks_fu740),
  122. };
  123. #endif /* __SIFIVE_CLK_FU740_PRCI_H */