virtio_clk_monaco.c 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (c) 2023, Qualcomm Innovation Center, Inc. All rights reserved.
  4. */
  5. #include <linux/kernel.h>
  6. #include <linux/module.h>
  7. #include <dt-bindings/clock/qcom,gcc-monaco_auto.h>
  8. #include "virtio_clk_common.h"
  9. static const char * const monaco_gcc_parent_names_usb3_prim[] = {
  10. "usb3_phy_wrapper_gcc_usb30_prim_pipe_clk",
  11. "core_bi_pll_test_se",
  12. "bi_tcxo",
  13. };
  14. static const char * const monaco_gcc_parent_names_pcie_0[] = {
  15. "pcie_0_pipe_clk",
  16. "gcc_pcie_mbist_pll_test_se_clk_src",
  17. "bi_tcxo",
  18. };
  19. static const char * const monaco_gcc_parent_names_pcie_1[] = {
  20. "pcie_1_pipe_clk",
  21. "gcc_pcie_mbist_pll_test_se_clk_src",
  22. "bi_tcxo",
  23. };
  24. static const struct virtio_clk_init_data monaco_gcc_virtio_clocks[] = {
  25. [GCC_QUPV3_WRAP0_S0_CLK] = {.name = "gcc_qupv3_wrap0_s0_clk",},
  26. [GCC_QUPV3_WRAP0_S1_CLK] = {.name = "gcc_qupv3_wrap0_s1_clk",},
  27. [GCC_QUPV3_WRAP0_S2_CLK] = {.name = "gcc_qupv3_wrap0_s2_clk",},
  28. [GCC_QUPV3_WRAP0_S3_CLK] = {.name = "gcc_qupv3_wrap0_s3_clk",},
  29. [GCC_QUPV3_WRAP0_S4_CLK] = {.name = "gcc_qupv3_wrap0_s4_clk",},
  30. [GCC_QUPV3_WRAP0_S5_CLK] = {.name = "gcc_qupv3_wrap0_s5_clk",},
  31. [GCC_QUPV3_WRAP0_S6_CLK] = {.name = "gcc_qupv3_wrap0_s6_clk",},
  32. [GCC_QUPV3_WRAP0_S7_CLK] = {.name = "gcc_qupv3_wrap0_s7_clk",},
  33. [GCC_QUPV3_WRAP1_S0_CLK] = {.name = "gcc_qupv3_wrap1_s0_clk",},
  34. [GCC_QUPV3_WRAP1_S1_CLK] = {.name = "gcc_qupv3_wrap1_s1_clk",},
  35. [GCC_QUPV3_WRAP1_S2_CLK] = {.name = "gcc_qupv3_wrap1_s2_clk",},
  36. [GCC_QUPV3_WRAP1_S3_CLK] = {.name = "gcc_qupv3_wrap1_s3_clk",},
  37. [GCC_QUPV3_WRAP1_S4_CLK] = {.name = "gcc_qupv3_wrap1_s4_clk",},
  38. [GCC_QUPV3_WRAP1_S5_CLK] = {.name = "gcc_qupv3_wrap1_s5_clk",},
  39. [GCC_QUPV3_WRAP1_S6_CLK] = {.name = "gcc_qupv3_wrap1_s6_clk",},
  40. [GCC_QUPV3_WRAP1_S7_CLK] = {.name = "gcc_qupv3_wrap1_s7_clk",},
  41. [GCC_QUPV3_WRAP3_S0_CLK] = {.name = "gcc_qupv3_wrap3_s0_clk",},
  42. [GCC_QUPV3_WRAP_0_M_AHB_CLK] = {.name = "gcc_qupv3_wrap_0_m_ahb_clk",},
  43. [GCC_QUPV3_WRAP_0_S_AHB_CLK] = {.name = "gcc_qupv3_wrap_0_s_ahb_clk",},
  44. [GCC_QUPV3_WRAP_1_M_AHB_CLK] = {.name = "gcc_qupv3_wrap_1_m_ahb_clk",},
  45. [GCC_QUPV3_WRAP_1_S_AHB_CLK] = {.name = "gcc_qupv3_wrap_1_s_ahb_clk",},
  46. [GCC_QUPV3_WRAP_3_M_AHB_CLK] = {.name = "gcc_qupv3_wrap_3_m_ahb_clk",},
  47. [GCC_QUPV3_WRAP_3_S_AHB_CLK] = {.name = "gcc_qupv3_wrap_3_s_ahb_clk",},
  48. [GCC_AGGRE_USB2_PRIM_AXI_CLK] = {.name = "gcc_aggre_usb2_prim_axi_clk",},
  49. [GCC_AGGRE_USB3_PRIM_AXI_CLK] = {.name = "gcc_aggre_usb3_prim_axi_clk",},
  50. [GCC_CFG_NOC_USB2_PRIM_AXI_CLK] = {.name = "gcc_cfg_noc_usb2_prim_axi_clk",},
  51. [GCC_CFG_NOC_USB3_PRIM_AXI_CLK] = {.name = "gcc_cfg_noc_usb3_prim_axi_clk",},
  52. [GCC_USB20_MASTER_CLK] = {.name = "gcc_usb20_master_clk",},
  53. [GCC_USB20_MOCK_UTMI_CLK] = {.name = "gcc_usb20_mock_utmi_clk",},
  54. [GCC_USB20_SLEEP_CLK] = {.name = "gcc_usb20_sleep_clk",},
  55. [GCC_USB30_PRIM_MASTER_CLK] = {.name = "gcc_usb30_prim_master_clk",},
  56. [GCC_USB30_PRIM_MOCK_UTMI_CLK] = {.name = "gcc_usb30_prim_mock_utmi_clk",},
  57. [GCC_USB30_PRIM_SLEEP_CLK] = {.name = "gcc_usb30_prim_sleep_clk",},
  58. [GCC_USB3_PRIM_PHY_AUX_CLK] = {.name = "gcc_usb3_prim_phy_aux_clk",},
  59. [GCC_USB3_PRIM_PHY_COM_AUX_CLK] = {.name = "gcc_usb3_prim_phy_com_aux_clk",},
  60. [GCC_USB3_PRIM_PHY_PIPE_CLK] = {.name = "gcc_usb3_prim_phy_pipe_clk",},
  61. [GCC_USB3_PRIM_PHY_PIPE_CLK_SRC] = {
  62. .name = "gcc_usb3_prim_phy_pipe_clk_src",
  63. .parent_names = monaco_gcc_parent_names_usb3_prim,
  64. .num_parents = ARRAY_SIZE(monaco_gcc_parent_names_usb3_prim),
  65. },
  66. [GCC_USB_CLKREF_EN] = {.name = "gcc_usb_clkref_en",},
  67. [GCC_PCIE_0_AUX_CLK] = {.name = "gcc_pcie_0_aux_clk",},
  68. [GCC_PCIE_0_CFG_AHB_CLK] = {.name = "gcc_pcie_0_cfg_ahb_clk",},
  69. [GCC_PCIE_0_MSTR_AXI_CLK] = {.name = "gcc_pcie_0_mstr_axi_clk",},
  70. [GCC_PCIE_0_PHY_AUX_CLK] = {.name = "gcc_pcie_0_phy_aux_clk",},
  71. [GCC_PCIE_0_PHY_RCHNG_CLK] = {.name = "gcc_pcie_0_phy_rchng_clk",},
  72. [GCC_PCIE_0_PIPE_CLK] = {.name = "gcc_pcie_0_pipe_clk",},
  73. [GCC_PCIE_0_PIPE_CLK_SRC] = {
  74. .name = "gcc_pcie_0_pipe_clk_src",
  75. .parent_names = monaco_gcc_parent_names_pcie_0,
  76. .num_parents = ARRAY_SIZE(monaco_gcc_parent_names_pcie_0),
  77. },
  78. [GCC_PCIE_0_PIPEDIV2_CLK] = {.name = "gcc_pcie_0_pipediv2_clk",},
  79. [GCC_PCIE_0_SLV_AXI_CLK] = {.name = "gcc_pcie_0_slv_axi_clk",},
  80. [GCC_PCIE_0_SLV_Q2A_AXI_CLK] = {.name = "gcc_pcie_0_slv_q2a_axi_clk",},
  81. [GCC_PCIE_1_AUX_CLK] = {.name = "gcc_pcie_1_aux_clk",},
  82. [GCC_PCIE_1_CFG_AHB_CLK] = {.name = "gcc_pcie_1_cfg_ahb_clk",},
  83. [GCC_PCIE_1_MSTR_AXI_CLK] = {.name = "gcc_pcie_1_mstr_axi_clk",},
  84. [GCC_PCIE_1_PHY_AUX_CLK] = {.name = "gcc_pcie_1_phy_aux_clk",},
  85. [GCC_PCIE_1_PHY_RCHNG_CLK] = {.name = "gcc_pcie_1_phy_rchng_clk",},
  86. [GCC_PCIE_1_PIPE_CLK] = {.name = "gcc_pcie_1_pipe_clk",},
  87. [GCC_PCIE_1_PIPE_CLK_SRC] = {
  88. .name = "gcc_pcie_1_pipe_clk_src",
  89. .parent_names = monaco_gcc_parent_names_pcie_1,
  90. .num_parents = ARRAY_SIZE(monaco_gcc_parent_names_pcie_1),
  91. },
  92. [GCC_PCIE_1_PIPEDIV2_CLK] = {.name = "gcc_pcie_1_pipediv2_clk",},
  93. [GCC_PCIE_1_SLV_AXI_CLK] = {.name = "gcc_pcie_1_slv_axi_clk",},
  94. [GCC_PCIE_1_SLV_Q2A_AXI_CLK] = {.name = "gcc_pcie_1_slv_q2a_axi_clk",},
  95. [GCC_PCIE_CLKREF_EN] = {.name = "gcc_pcie_clkref_en",},
  96. };
  97. static const char * const monaco_gcc_virtio_resets[] = {
  98. [GCC_USB20_PRIM_BCR] = "gcc_usb20_master_clk",
  99. [GCC_USB2_PHY_PRIM_BCR] = "gcc_usb2_phy_prim_bcr",
  100. [GCC_USB30_PRIM_BCR] = "gcc_usb30_prim_master_clk",
  101. [GCC_USB3_PHY_PRIM_BCR] = "gcc_usb3_phy_prim_bcr",
  102. [GCC_USB3_PHY_TERT_BCR] = "gcc_usb3_phy_tert_bcr",
  103. [GCC_USB3PHY_PHY_PRIM_BCR] = "gcc_usb3phy_phy_prim_bcr",
  104. [GCC_PCIE_0_BCR] = "gcc_pcie_0_bcr",
  105. [GCC_PCIE_0_PHY_BCR] = "gcc_pcie_0_phy_bcr",
  106. [GCC_PCIE_1_BCR] = "gcc_pcie_1_bcr",
  107. [GCC_PCIE_1_PHY_BCR] = "gcc_pcie_1_phy_bcr",
  108. };
  109. const struct clk_virtio_desc clk_virtio_monaco_gcc = {
  110. .clks = monaco_gcc_virtio_clocks,
  111. .num_clks = ARRAY_SIZE(monaco_gcc_virtio_clocks),
  112. .reset_names = monaco_gcc_virtio_resets,
  113. .num_resets = ARRAY_SIZE(monaco_gcc_virtio_resets),
  114. };
  115. EXPORT_SYMBOL_GPL(clk_virtio_monaco_gcc);
  116. MODULE_LICENSE("GPL");