clk-sp7021.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708
  1. // SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
  2. /*
  3. * Copyright (C) Sunplus Technology Co., Ltd.
  4. * All rights reserved.
  5. */
  6. #include <linux/module.h>
  7. #include <linux/clk-provider.h>
  8. #include <linux/of.h>
  9. #include <linux/bitfield.h>
  10. #include <linux/hw_bitfield.h>
  11. #include <linux/slab.h>
  12. #include <linux/io.h>
  13. #include <linux/err.h>
  14. #include <linux/platform_device.h>
  15. #include <dt-bindings/clock/sunplus,sp7021-clkc.h>
  16. /* special div_width values for PLLTV/PLLA */
  17. #define DIV_TV 33
  18. #define DIV_A 34
  19. /* PLLTV parameters */
  20. enum {
  21. SEL_FRA,
  22. SDM_MOD,
  23. PH_SEL,
  24. NFRA,
  25. DIVR,
  26. DIVN,
  27. DIVM,
  28. P_MAX
  29. };
  30. #define MASK_SEL_FRA GENMASK(1, 1)
  31. #define MASK_SDM_MOD GENMASK(2, 2)
  32. #define MASK_PH_SEL GENMASK(4, 4)
  33. #define MASK_NFRA GENMASK(12, 6)
  34. #define MASK_DIVR GENMASK(8, 7)
  35. #define MASK_DIVN GENMASK(7, 0)
  36. #define MASK_DIVM GENMASK(14, 8)
  37. struct sp_pll {
  38. struct clk_hw hw;
  39. void __iomem *reg;
  40. spinlock_t lock; /* lock for reg */
  41. int div_shift;
  42. int div_width;
  43. int pd_bit; /* power down bit idx */
  44. int bp_bit; /* bypass bit idx */
  45. unsigned long brate; /* base rate, TODO: replace brate with muldiv */
  46. u32 p[P_MAX]; /* for hold PLLTV/PLLA parameters */
  47. };
  48. #define to_sp_pll(_hw) container_of(_hw, struct sp_pll, hw)
  49. struct sp_clk_gate_info {
  50. u16 reg; /* reg_index_shift */
  51. u16 ext_parent; /* parent is extclk */
  52. };
  53. static const struct sp_clk_gate_info sp_clk_gates[] = {
  54. { 0x02 },
  55. { 0x05 },
  56. { 0x06 },
  57. { 0x07 },
  58. { 0x09 },
  59. { 0x0b, 1 },
  60. { 0x0f, 1 },
  61. { 0x14 },
  62. { 0x15 },
  63. { 0x16 },
  64. { 0x17 },
  65. { 0x18, 1 },
  66. { 0x19, 1 },
  67. { 0x1a, 1 },
  68. { 0x1b, 1 },
  69. { 0x1c, 1 },
  70. { 0x1d, 1 },
  71. { 0x1e },
  72. { 0x1f, 1 },
  73. { 0x20 },
  74. { 0x21 },
  75. { 0x22 },
  76. { 0x23 },
  77. { 0x24 },
  78. { 0x25 },
  79. { 0x26 },
  80. { 0x2a },
  81. { 0x2b },
  82. { 0x2d },
  83. { 0x2e },
  84. { 0x30 },
  85. { 0x31 },
  86. { 0x32 },
  87. { 0x33 },
  88. { 0x3d },
  89. { 0x3e },
  90. { 0x3f },
  91. { 0x42 },
  92. { 0x44 },
  93. { 0x4b },
  94. { 0x4c },
  95. { 0x4d },
  96. { 0x4e },
  97. { 0x4f },
  98. { 0x50 },
  99. { 0x55 },
  100. { 0x60 },
  101. { 0x61 },
  102. { 0x6a },
  103. { 0x73 },
  104. { 0x86 },
  105. { 0x8a },
  106. { 0x8b },
  107. { 0x8d },
  108. { 0x8e },
  109. { 0x8f },
  110. { 0x90 },
  111. { 0x92 },
  112. { 0x93 },
  113. { 0x95 },
  114. { 0x96 },
  115. { 0x97 },
  116. { 0x98 },
  117. { 0x99 },
  118. };
  119. #define _M 1000000UL
  120. #define F_27M (27 * _M)
  121. /*********************************** PLL_TV **********************************/
  122. /* TODO: set proper FVCO range */
  123. #define FVCO_MIN (100 * _M)
  124. #define FVCO_MAX (200 * _M)
  125. #define F_MIN (FVCO_MIN / 8)
  126. #define F_MAX (FVCO_MAX)
  127. static long plltv_integer_div(struct sp_pll *clk, unsigned long freq)
  128. {
  129. /* valid m values: 27M must be divisible by m */
  130. static const u32 m_table[] = {
  131. 1, 2, 3, 4, 5, 6, 8, 9, 10, 12, 15, 16, 18, 20, 24, 25, 27, 30, 32
  132. };
  133. u32 m, n, r;
  134. unsigned long fvco, nf;
  135. long ret;
  136. freq = clamp(freq, F_MIN, F_MAX);
  137. /* DIVR 0~3 */
  138. for (r = 0; r <= 3; r++) {
  139. fvco = freq << r;
  140. if (fvco <= FVCO_MAX)
  141. break;
  142. }
  143. /* DIVM */
  144. for (m = 0; m < ARRAY_SIZE(m_table); m++) {
  145. nf = fvco * m_table[m];
  146. n = nf / F_27M;
  147. if ((n * F_27M) == nf)
  148. break;
  149. }
  150. if (m >= ARRAY_SIZE(m_table)) {
  151. ret = -EINVAL;
  152. goto err_not_found;
  153. }
  154. /* save parameters */
  155. clk->p[SEL_FRA] = 0;
  156. clk->p[DIVR] = r;
  157. clk->p[DIVN] = n;
  158. clk->p[DIVM] = m_table[m];
  159. return freq;
  160. err_not_found:
  161. pr_err("%s: %s freq:%lu not found a valid setting\n",
  162. __func__, clk_hw_get_name(&clk->hw), freq);
  163. return ret;
  164. }
  165. /* parameters for PLLTV fractional divider */
  166. static const u32 pt[][5] = {
  167. /* conventional fractional */
  168. {
  169. 1, /* factor */
  170. 5, /* 5 * p0 (nint) */
  171. 1, /* 1 * p0 */
  172. F_27M, /* F_27M / p0 */
  173. 1, /* p0 / p2 */
  174. },
  175. /* phase rotation */
  176. {
  177. 10, /* factor */
  178. 54, /* 5.4 * p0 (nint) */
  179. 2, /* 0.2 * p0 */
  180. F_27M / 10, /* F_27M / p0 */
  181. 5, /* p0 / p2 */
  182. },
  183. };
  184. static const u32 sdm_mod_vals[] = { 91, 55 };
  185. static long plltv_fractional_div(struct sp_pll *clk, unsigned long freq)
  186. {
  187. u32 m, r;
  188. u32 nint, nfra;
  189. u32 df_quotient_min = 210000000;
  190. u32 df_remainder_min = 0;
  191. unsigned long fvco, nf, f, fout = 0;
  192. int sdm, ph;
  193. freq = clamp(freq, F_MIN, F_MAX);
  194. /* DIVR 0~3 */
  195. for (r = 0; r <= 3; r++) {
  196. fvco = freq << r;
  197. if (fvco <= FVCO_MAX)
  198. break;
  199. }
  200. f = F_27M >> r;
  201. /* PH_SEL */
  202. for (ph = ARRAY_SIZE(pt) - 1; ph >= 0; ph--) {
  203. const u32 *pp = pt[ph];
  204. /* SDM_MOD */
  205. for (sdm = 0; sdm < ARRAY_SIZE(sdm_mod_vals); sdm++) {
  206. u32 mod = sdm_mod_vals[sdm];
  207. /* DIVM 1~32 */
  208. for (m = 1; m <= 32; m++) {
  209. u32 df; /* diff freq */
  210. u32 df_quotient, df_remainder;
  211. nf = fvco * m;
  212. nint = nf / pp[3];
  213. if (nint < pp[1])
  214. continue;
  215. if (nint > pp[1])
  216. break;
  217. nfra = (((nf % pp[3]) * mod * pp[4]) + (F_27M / 2)) / F_27M;
  218. if (nfra) {
  219. u32 df0 = f * (nint + pp[2]) / pp[0];
  220. u32 df1 = f * (mod - nfra) / mod / pp[4];
  221. df = df0 - df1;
  222. } else {
  223. df = f * (nint) / pp[0];
  224. }
  225. df_quotient = df / m;
  226. df_remainder = ((df % m) * 1000) / m;
  227. if (freq > df_quotient) {
  228. df_quotient = freq - df_quotient - 1;
  229. df_remainder = 1000 - df_remainder;
  230. } else {
  231. df_quotient = df_quotient - freq;
  232. }
  233. if (df_quotient_min > df_quotient ||
  234. (df_quotient_min == df_quotient &&
  235. df_remainder_min > df_remainder)) {
  236. /* found a closer freq, save parameters */
  237. clk->p[SEL_FRA] = 1;
  238. clk->p[SDM_MOD] = sdm;
  239. clk->p[PH_SEL] = ph;
  240. clk->p[NFRA] = nfra;
  241. clk->p[DIVR] = r;
  242. clk->p[DIVM] = m;
  243. fout = df / m;
  244. df_quotient_min = df_quotient;
  245. df_remainder_min = df_remainder;
  246. }
  247. }
  248. }
  249. }
  250. if (!fout) {
  251. pr_err("%s: %s freq:%lu not found a valid setting\n",
  252. __func__, clk_hw_get_name(&clk->hw), freq);
  253. return -EINVAL;
  254. }
  255. return fout;
  256. }
  257. static long plltv_div(struct sp_pll *clk, unsigned long freq)
  258. {
  259. if (freq % 100)
  260. return plltv_fractional_div(clk, freq);
  261. return plltv_integer_div(clk, freq);
  262. }
  263. static int plltv_set_rate(struct sp_pll *clk)
  264. {
  265. unsigned long flags;
  266. u32 r0, r1, r2;
  267. r0 = BIT(clk->bp_bit + 16);
  268. r0 |= FIELD_PREP_WM16(MASK_SEL_FRA, clk->p[SEL_FRA]);
  269. r0 |= FIELD_PREP_WM16(MASK_SDM_MOD, clk->p[SDM_MOD]);
  270. r0 |= FIELD_PREP_WM16(MASK_PH_SEL, clk->p[PH_SEL]);
  271. r0 |= FIELD_PREP_WM16(MASK_NFRA, clk->p[NFRA]);
  272. r1 = FIELD_PREP_WM16(MASK_DIVR, clk->p[DIVR]);
  273. r2 = FIELD_PREP_WM16(MASK_DIVN, clk->p[DIVN] - 1);
  274. r2 |= FIELD_PREP_WM16(MASK_DIVM, clk->p[DIVM] - 1);
  275. spin_lock_irqsave(&clk->lock, flags);
  276. writel(r0, clk->reg);
  277. writel(r1, clk->reg + 4);
  278. writel(r2, clk->reg + 8);
  279. spin_unlock_irqrestore(&clk->lock, flags);
  280. return 0;
  281. }
  282. /*********************************** PLL_A ***********************************/
  283. /* from Q628_PLLs_REG_setting.xlsx */
  284. static const struct {
  285. u32 rate;
  286. u32 regs[5];
  287. } pa[] = {
  288. {
  289. .rate = 135475200,
  290. .regs = {
  291. 0x4801,
  292. 0x02df,
  293. 0x248f,
  294. 0x0211,
  295. 0x33e9
  296. }
  297. },
  298. {
  299. .rate = 147456000,
  300. .regs = {
  301. 0x4801,
  302. 0x1adf,
  303. 0x2490,
  304. 0x0349,
  305. 0x33e9
  306. }
  307. },
  308. {
  309. .rate = 196608000,
  310. .regs = {
  311. 0x4801,
  312. 0x42ef,
  313. 0x2495,
  314. 0x01c6,
  315. 0x33e9
  316. }
  317. },
  318. };
  319. static int plla_set_rate(struct sp_pll *clk)
  320. {
  321. const u32 *pp = pa[clk->p[0]].regs;
  322. unsigned long flags;
  323. int i;
  324. spin_lock_irqsave(&clk->lock, flags);
  325. for (i = 0; i < ARRAY_SIZE(pa->regs); i++)
  326. writel(0xffff0000 | pp[i], clk->reg + (i * 4));
  327. spin_unlock_irqrestore(&clk->lock, flags);
  328. return 0;
  329. }
  330. static long plla_round_rate(struct sp_pll *clk, unsigned long rate)
  331. {
  332. int i = ARRAY_SIZE(pa);
  333. while (--i) {
  334. if (rate >= pa[i].rate)
  335. break;
  336. }
  337. clk->p[0] = i;
  338. return pa[i].rate;
  339. }
  340. /********************************** SP_PLL ***********************************/
  341. static long sp_pll_calc_div(struct sp_pll *clk, unsigned long rate)
  342. {
  343. u32 fbdiv;
  344. u32 max = 1 << clk->div_width;
  345. fbdiv = DIV_ROUND_CLOSEST(rate, clk->brate);
  346. if (fbdiv > max)
  347. fbdiv = max;
  348. return fbdiv;
  349. }
  350. static int sp_pll_determine_rate(struct clk_hw *hw,
  351. struct clk_rate_request *req)
  352. {
  353. struct sp_pll *clk = to_sp_pll(hw);
  354. long ret;
  355. if (req->rate == req->best_parent_rate) {
  356. ret = req->best_parent_rate; /* bypass */
  357. } else if (clk->div_width == DIV_A) {
  358. ret = plla_round_rate(clk, req->rate);
  359. } else if (clk->div_width == DIV_TV) {
  360. ret = plltv_div(clk, req->rate);
  361. if (ret < 0)
  362. ret = req->best_parent_rate;
  363. } else {
  364. ret = sp_pll_calc_div(clk, req->rate) * clk->brate;
  365. }
  366. req->rate = ret;
  367. return 0;
  368. }
  369. static unsigned long sp_pll_recalc_rate(struct clk_hw *hw,
  370. unsigned long prate)
  371. {
  372. struct sp_pll *clk = to_sp_pll(hw);
  373. u32 reg = readl(clk->reg);
  374. unsigned long ret;
  375. if (reg & BIT(clk->bp_bit)) {
  376. ret = prate; /* bypass */
  377. } else if (clk->div_width == DIV_A) {
  378. ret = pa[clk->p[0]].rate;
  379. } else if (clk->div_width == DIV_TV) {
  380. u32 m, r, reg2;
  381. r = FIELD_GET(MASK_DIVR, readl(clk->reg + 4));
  382. reg2 = readl(clk->reg + 8);
  383. m = FIELD_GET(MASK_DIVM, reg2) + 1;
  384. if (reg & MASK_SEL_FRA) {
  385. /* fractional divider */
  386. u32 sdm = FIELD_GET(MASK_SDM_MOD, reg);
  387. u32 ph = FIELD_GET(MASK_PH_SEL, reg);
  388. u32 nfra = FIELD_GET(MASK_NFRA, reg);
  389. const u32 *pp = pt[ph];
  390. unsigned long r0, r1;
  391. ret = prate >> r;
  392. r0 = ret * (pp[1] + pp[2]) / pp[0];
  393. r1 = ret * (sdm_mod_vals[sdm] - nfra) / sdm_mod_vals[sdm] / pp[4];
  394. ret = (r0 - r1) / m;
  395. } else {
  396. /* integer divider */
  397. u32 n = FIELD_GET(MASK_DIVN, reg2) + 1;
  398. ret = (prate / m * n) >> r;
  399. }
  400. } else {
  401. u32 fbdiv = ((reg >> clk->div_shift) & ((1 << clk->div_width) - 1)) + 1;
  402. ret = clk->brate * fbdiv;
  403. }
  404. return ret;
  405. }
  406. static int sp_pll_set_rate(struct clk_hw *hw, unsigned long rate,
  407. unsigned long prate)
  408. {
  409. struct sp_pll *clk = to_sp_pll(hw);
  410. unsigned long flags;
  411. u32 reg;
  412. reg = BIT(clk->bp_bit + 16); /* HIWORD_MASK */
  413. if (rate == prate) {
  414. reg |= BIT(clk->bp_bit); /* bypass */
  415. } else if (clk->div_width == DIV_A) {
  416. return plla_set_rate(clk);
  417. } else if (clk->div_width == DIV_TV) {
  418. return plltv_set_rate(clk);
  419. } else if (clk->div_width) {
  420. u32 fbdiv = sp_pll_calc_div(clk, rate);
  421. u32 mask = GENMASK(clk->div_shift + clk->div_width - 1, clk->div_shift);
  422. reg |= mask << 16;
  423. reg |= ((fbdiv - 1) << clk->div_shift) & mask;
  424. }
  425. spin_lock_irqsave(&clk->lock, flags);
  426. writel(reg, clk->reg);
  427. spin_unlock_irqrestore(&clk->lock, flags);
  428. return 0;
  429. }
  430. static int sp_pll_enable(struct clk_hw *hw)
  431. {
  432. struct sp_pll *clk = to_sp_pll(hw);
  433. writel(BIT(clk->pd_bit + 16) | BIT(clk->pd_bit), clk->reg);
  434. return 0;
  435. }
  436. static void sp_pll_disable(struct clk_hw *hw)
  437. {
  438. struct sp_pll *clk = to_sp_pll(hw);
  439. writel(BIT(clk->pd_bit + 16), clk->reg);
  440. }
  441. static int sp_pll_is_enabled(struct clk_hw *hw)
  442. {
  443. struct sp_pll *clk = to_sp_pll(hw);
  444. return readl(clk->reg) & BIT(clk->pd_bit);
  445. }
  446. static const struct clk_ops sp_pll_ops = {
  447. .enable = sp_pll_enable,
  448. .disable = sp_pll_disable,
  449. .is_enabled = sp_pll_is_enabled,
  450. .determine_rate = sp_pll_determine_rate,
  451. .recalc_rate = sp_pll_recalc_rate,
  452. .set_rate = sp_pll_set_rate
  453. };
  454. static const struct clk_ops sp_pll_sub_ops = {
  455. .enable = sp_pll_enable,
  456. .disable = sp_pll_disable,
  457. .is_enabled = sp_pll_is_enabled,
  458. .recalc_rate = sp_pll_recalc_rate,
  459. };
  460. static struct clk_hw *sp_pll_register(struct device *dev, const char *name,
  461. const struct clk_parent_data *parent_data,
  462. void __iomem *reg, int pd_bit, int bp_bit,
  463. unsigned long brate, int shift, int width,
  464. unsigned long flags)
  465. {
  466. struct sp_pll *pll;
  467. struct clk_hw *hw;
  468. struct clk_init_data initd = {
  469. .name = name,
  470. .parent_data = parent_data,
  471. .ops = (bp_bit >= 0) ? &sp_pll_ops : &sp_pll_sub_ops,
  472. .num_parents = 1,
  473. .flags = flags,
  474. };
  475. int ret;
  476. pll = devm_kzalloc(dev, sizeof(*pll), GFP_KERNEL);
  477. if (!pll)
  478. return ERR_PTR(-ENOMEM);
  479. pll->hw.init = &initd;
  480. pll->reg = reg;
  481. pll->pd_bit = pd_bit;
  482. pll->bp_bit = bp_bit;
  483. pll->brate = brate;
  484. pll->div_shift = shift;
  485. pll->div_width = width;
  486. spin_lock_init(&pll->lock);
  487. hw = &pll->hw;
  488. ret = devm_clk_hw_register(dev, hw);
  489. if (ret)
  490. return ERR_PTR(ret);
  491. return hw;
  492. }
  493. #define PLLA_CTL (pll_base + 0x1c)
  494. #define PLLE_CTL (pll_base + 0x30)
  495. #define PLLF_CTL (pll_base + 0x34)
  496. #define PLLTV_CTL (pll_base + 0x38)
  497. static int sp7021_clk_probe(struct platform_device *pdev)
  498. {
  499. static const u32 sp_clken[] = {
  500. 0x67ef, 0x03ff, 0xff03, 0xfff0, 0x0004, /* G0.1~5 */
  501. 0x0000, 0x8000, 0xffff, 0x0040, 0x0000, /* G0.6~10 */
  502. };
  503. static struct clk_parent_data pd_ext, pd_sys, pd_e;
  504. struct device *dev = &pdev->dev;
  505. void __iomem *clk_base, *pll_base, *sys_base;
  506. struct clk_hw_onecell_data *clk_data;
  507. struct clk_hw **hws;
  508. int i;
  509. clk_base = devm_platform_ioremap_resource(pdev, 0);
  510. if (IS_ERR(clk_base))
  511. return PTR_ERR(clk_base);
  512. pll_base = devm_platform_ioremap_resource(pdev, 1);
  513. if (IS_ERR(pll_base))
  514. return PTR_ERR(pll_base);
  515. sys_base = devm_platform_ioremap_resource(pdev, 2);
  516. if (IS_ERR(sys_base))
  517. return PTR_ERR(sys_base);
  518. /* enable default clks */
  519. for (i = 0; i < ARRAY_SIZE(sp_clken); i++)
  520. writel((sp_clken[i] << 16) | sp_clken[i], clk_base + i * 4);
  521. clk_data = devm_kzalloc(dev, struct_size(clk_data, hws, CLK_MAX),
  522. GFP_KERNEL);
  523. if (!clk_data)
  524. return -ENOMEM;
  525. clk_data->num = CLK_MAX;
  526. hws = clk_data->hws;
  527. pd_ext.index = 0;
  528. /* PLLs */
  529. hws[PLL_A] = sp_pll_register(dev, "plla", &pd_ext, PLLA_CTL,
  530. 11, 12, 27000000, 0, DIV_A, 0);
  531. if (IS_ERR(hws[PLL_A]))
  532. return PTR_ERR(hws[PLL_A]);
  533. hws[PLL_E] = sp_pll_register(dev, "plle", &pd_ext, PLLE_CTL,
  534. 6, 2, 50000000, 0, 0, 0);
  535. if (IS_ERR(hws[PLL_E]))
  536. return PTR_ERR(hws[PLL_E]);
  537. pd_e.hw = hws[PLL_E];
  538. hws[PLL_E_2P5] = sp_pll_register(dev, "plle_2p5", &pd_e, PLLE_CTL,
  539. 13, -1, 2500000, 0, 0, 0);
  540. if (IS_ERR(hws[PLL_E_2P5]))
  541. return PTR_ERR(hws[PLL_E_2P5]);
  542. hws[PLL_E_25] = sp_pll_register(dev, "plle_25", &pd_e, PLLE_CTL,
  543. 12, -1, 25000000, 0, 0, 0);
  544. if (IS_ERR(hws[PLL_E_25]))
  545. return PTR_ERR(hws[PLL_E_25]);
  546. hws[PLL_E_112P5] = sp_pll_register(dev, "plle_112p5", &pd_e, PLLE_CTL,
  547. 11, -1, 112500000, 0, 0, 0);
  548. if (IS_ERR(hws[PLL_E_112P5]))
  549. return PTR_ERR(hws[PLL_E_112P5]);
  550. hws[PLL_F] = sp_pll_register(dev, "pllf", &pd_ext, PLLF_CTL,
  551. 0, 10, 13500000, 1, 4, 0);
  552. if (IS_ERR(hws[PLL_F]))
  553. return PTR_ERR(hws[PLL_F]);
  554. hws[PLL_TV] = sp_pll_register(dev, "plltv", &pd_ext, PLLTV_CTL,
  555. 0, 15, 27000000, 0, DIV_TV, 0);
  556. if (IS_ERR(hws[PLL_TV]))
  557. return PTR_ERR(hws[PLL_TV]);
  558. hws[PLL_TV_A] = devm_clk_hw_register_divider(dev, "plltv_a", "plltv", 0,
  559. PLLTV_CTL + 4, 5, 1,
  560. CLK_DIVIDER_POWER_OF_TWO,
  561. &to_sp_pll(hws[PLL_TV])->lock);
  562. if (IS_ERR(hws[PLL_TV_A]))
  563. return PTR_ERR(hws[PLL_TV_A]);
  564. /* system clock, should not be disabled */
  565. hws[PLL_SYS] = sp_pll_register(dev, "pllsys", &pd_ext, sys_base,
  566. 10, 9, 13500000, 0, 4, CLK_IS_CRITICAL);
  567. if (IS_ERR(hws[PLL_SYS]))
  568. return PTR_ERR(hws[PLL_SYS]);
  569. pd_sys.hw = hws[PLL_SYS];
  570. /* gates */
  571. for (i = 0; i < ARRAY_SIZE(sp_clk_gates); i++) {
  572. char name[10];
  573. u32 j = sp_clk_gates[i].reg;
  574. struct clk_parent_data *pd = sp_clk_gates[i].ext_parent ? &pd_ext : &pd_sys;
  575. sprintf(name, "%02d_0x%02x", i, j);
  576. hws[i] = devm_clk_hw_register_gate_parent_data(dev, name, pd, 0,
  577. clk_base + (j >> 4) * 4,
  578. j & 0x0f,
  579. CLK_GATE_HIWORD_MASK,
  580. NULL);
  581. if (IS_ERR(hws[i]))
  582. return PTR_ERR(hws[i]);
  583. }
  584. return devm_of_clk_add_hw_provider(dev, of_clk_hw_onecell_get, clk_data);
  585. }
  586. static const struct of_device_id sp7021_clk_dt_ids[] = {
  587. { .compatible = "sunplus,sp7021-clkc" },
  588. { }
  589. };
  590. MODULE_DEVICE_TABLE(of, sp7021_clk_dt_ids);
  591. static struct platform_driver sp7021_clk_driver = {
  592. .probe = sp7021_clk_probe,
  593. .driver = {
  594. .name = "sp7021-clk",
  595. .of_match_table = sp7021_clk_dt_ids,
  596. },
  597. };
  598. module_platform_driver(sp7021_clk_driver);
  599. MODULE_AUTHOR("Sunplus Technology");
  600. MODULE_LICENSE("GPL");
  601. MODULE_DESCRIPTION("Clock driver for Sunplus SP7021 SoC");