tcsrcc-niobe.c 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (c) 2023, Qualcomm Innovation Center, Inc. All rights reserved.
  4. */
  5. #include <linux/clk-provider.h>
  6. #include <linux/kernel.h>
  7. #include <linux/module.h>
  8. #include <linux/of_device.h>
  9. #include <linux/of.h>
  10. #include <linux/regmap.h>
  11. #include <dt-bindings/clock/qcom,tcsrcc-niobe.h>
  12. #include "clk-branch.h"
  13. #include "common.h"
  14. static struct clk_branch tcsr_edp1_clkref_en = {
  15. .halt_reg = 0xb1128,
  16. .halt_check = BRANCH_HALT_DELAY,
  17. .clkr = {
  18. .enable_reg = 0xb1128,
  19. .enable_mask = BIT(0),
  20. .hw.init = &(const struct clk_init_data) {
  21. .name = "tcsr_edp1_clkref_en",
  22. .ops = &clk_branch2_ops,
  23. },
  24. },
  25. };
  26. static struct clk_branch tcsr_edp2_clkref_en = {
  27. .halt_reg = 0xb112c,
  28. .halt_check = BRANCH_HALT_DELAY,
  29. .clkr = {
  30. .enable_reg = 0xb112c,
  31. .enable_mask = BIT(0),
  32. .hw.init = &(const struct clk_init_data) {
  33. .name = "tcsr_edp2_clkref_en",
  34. .ops = &clk_branch2_ops,
  35. },
  36. },
  37. };
  38. static struct clk_branch tcsr_pcie_0_clkref_en = {
  39. .halt_reg = 0xb1100,
  40. .halt_check = BRANCH_HALT_DELAY,
  41. .clkr = {
  42. .enable_reg = 0xb1100,
  43. .enable_mask = BIT(0),
  44. .hw.init = &(const struct clk_init_data) {
  45. .name = "tcsr_pcie_0_clkref_en",
  46. .ops = &clk_branch2_ops,
  47. },
  48. },
  49. };
  50. static struct clk_branch tcsr_pcie_1_clkref_en = {
  51. .halt_reg = 0xb1114,
  52. .halt_check = BRANCH_HALT_DELAY,
  53. .clkr = {
  54. .enable_reg = 0xb1114,
  55. .enable_mask = BIT(0),
  56. .hw.init = &(const struct clk_init_data) {
  57. .name = "tcsr_pcie_1_clkref_en",
  58. .ops = &clk_branch2_ops,
  59. },
  60. },
  61. };
  62. static struct clk_branch tcsr_pcie_2_clkref_en = {
  63. .halt_reg = 0xb111c,
  64. .halt_check = BRANCH_HALT_DELAY,
  65. .clkr = {
  66. .enable_reg = 0xb111c,
  67. .enable_mask = BIT(0),
  68. .hw.init = &(const struct clk_init_data) {
  69. .name = "tcsr_pcie_2_clkref_en",
  70. .ops = &clk_branch2_ops,
  71. },
  72. },
  73. };
  74. static struct clk_branch tcsr_ufs_clkref_en = {
  75. .halt_reg = 0xb1110,
  76. .halt_check = BRANCH_HALT_DELAY,
  77. .clkr = {
  78. .enable_reg = 0xb1110,
  79. .enable_mask = BIT(0),
  80. .hw.init = &(const struct clk_init_data) {
  81. .name = "tcsr_ufs_clkref_en",
  82. .ops = &clk_branch2_ops,
  83. },
  84. },
  85. };
  86. static struct clk_branch tcsr_usb2_2_clkref_en = {
  87. .halt_reg = 0xb1124,
  88. .halt_check = BRANCH_HALT_DELAY,
  89. .clkr = {
  90. .enable_reg = 0xb1124,
  91. .enable_mask = BIT(0),
  92. .hw.init = &(const struct clk_init_data) {
  93. .name = "tcsr_usb2_2_clkref_en",
  94. .ops = &clk_branch2_ops,
  95. },
  96. },
  97. };
  98. static struct clk_branch tcsr_usb2_clkref_en = {
  99. .halt_reg = 0xb1118,
  100. .halt_check = BRANCH_HALT_DELAY,
  101. .clkr = {
  102. .enable_reg = 0xb1118,
  103. .enable_mask = BIT(0),
  104. .hw.init = &(const struct clk_init_data) {
  105. .name = "tcsr_usb2_clkref_en",
  106. .ops = &clk_branch2_ops,
  107. },
  108. },
  109. };
  110. static struct clk_branch tcsr_usb3_2_clkref_en = {
  111. .halt_reg = 0xb1120,
  112. .halt_check = BRANCH_HALT_DELAY,
  113. .clkr = {
  114. .enable_reg = 0xb1120,
  115. .enable_mask = BIT(0),
  116. .hw.init = &(const struct clk_init_data) {
  117. .name = "tcsr_usb3_2_clkref_en",
  118. .ops = &clk_branch2_ops,
  119. },
  120. },
  121. };
  122. static struct clk_branch tcsr_usb3_clkref_en = {
  123. .halt_reg = 0xb1108,
  124. .halt_check = BRANCH_HALT_DELAY,
  125. .clkr = {
  126. .enable_reg = 0xb1108,
  127. .enable_mask = BIT(0),
  128. .hw.init = &(const struct clk_init_data) {
  129. .name = "tcsr_usb3_clkref_en",
  130. .ops = &clk_branch2_ops,
  131. },
  132. },
  133. };
  134. static struct clk_regmap *tcsr_cc_niobe_clocks[] = {
  135. [TCSR_EDP1_CLKREF_EN] = &tcsr_edp1_clkref_en.clkr,
  136. [TCSR_EDP2_CLKREF_EN] = &tcsr_edp2_clkref_en.clkr,
  137. [TCSR_PCIE_0_CLKREF_EN] = &tcsr_pcie_0_clkref_en.clkr,
  138. [TCSR_PCIE_1_CLKREF_EN] = &tcsr_pcie_1_clkref_en.clkr,
  139. [TCSR_PCIE_2_CLKREF_EN] = &tcsr_pcie_2_clkref_en.clkr,
  140. [TCSR_UFS_CLKREF_EN] = &tcsr_ufs_clkref_en.clkr,
  141. [TCSR_USB2_2_CLKREF_EN] = &tcsr_usb2_2_clkref_en.clkr,
  142. [TCSR_USB2_CLKREF_EN] = &tcsr_usb2_clkref_en.clkr,
  143. [TCSR_USB3_2_CLKREF_EN] = &tcsr_usb3_2_clkref_en.clkr,
  144. [TCSR_USB3_CLKREF_EN] = &tcsr_usb3_clkref_en.clkr,
  145. };
  146. static const struct regmap_config tcsr_cc_niobe_regmap_config = {
  147. .reg_bits = 32,
  148. .reg_stride = 4,
  149. .val_bits = 32,
  150. .max_register = 0xbb000,
  151. .fast_io = true,
  152. };
  153. static const struct qcom_cc_desc tcsr_cc_niobe_desc = {
  154. .config = &tcsr_cc_niobe_regmap_config,
  155. .clks = tcsr_cc_niobe_clocks,
  156. .num_clks = ARRAY_SIZE(tcsr_cc_niobe_clocks),
  157. };
  158. static const struct of_device_id tcsr_cc_niobe_match_table[] = {
  159. { .compatible = "qcom,niobe-tcsrcc" },
  160. { }
  161. };
  162. MODULE_DEVICE_TABLE(of, tcsr_cc_niobe_match_table);
  163. static int tcsr_cc_niobe_probe(struct platform_device *pdev)
  164. {
  165. struct regmap *regmap;
  166. int ret;
  167. regmap = qcom_cc_map(pdev, &tcsr_cc_niobe_desc);
  168. if (IS_ERR(regmap))
  169. return PTR_ERR(regmap);
  170. ret = qcom_cc_really_probe(pdev, &tcsr_cc_niobe_desc, regmap);
  171. if (ret) {
  172. dev_err(&pdev->dev, "Failed to register TCSR CC clocks\n");
  173. return ret;
  174. }
  175. dev_info(&pdev->dev, "Registered TCSR CC clocks\n");
  176. return ret;
  177. }
  178. static void tcsr_cc_niobe_sync_state(struct device *dev)
  179. {
  180. qcom_cc_sync_state(dev, &tcsr_cc_niobe_desc);
  181. }
  182. static struct platform_driver tcsr_cc_niobe_driver = {
  183. .probe = tcsr_cc_niobe_probe,
  184. .driver = {
  185. .name = "tcsr_cc-niobe",
  186. .of_match_table = tcsr_cc_niobe_match_table,
  187. .sync_state = tcsr_cc_niobe_sync_state,
  188. },
  189. };
  190. static int __init tcsr_cc_niobe_init(void)
  191. {
  192. return platform_driver_register(&tcsr_cc_niobe_driver);
  193. }
  194. subsys_initcall(tcsr_cc_niobe_init);
  195. static void __exit tcsr_cc_niobe_exit(void)
  196. {
  197. platform_driver_unregister(&tcsr_cc_niobe_driver);
  198. }
  199. module_exit(tcsr_cc_niobe_exit);
  200. MODULE_DESCRIPTION("QTI TCSR_CC NIOBE Driver");
  201. MODULE_LICENSE("GPL");