adpll.c 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. #include <linux/clk.h>
  3. #include <linux/clkdev.h>
  4. #include <linux/clk-provider.h>
  5. #include <linux/delay.h>
  6. #include <linux/err.h>
  7. #include <linux/io.h>
  8. #include <linux/math64.h>
  9. #include <linux/module.h>
  10. #include <linux/of.h>
  11. #include <linux/platform_device.h>
  12. #include <linux/property.h>
  13. #include <linux/string.h>
  14. #define ADPLL_PLLSS_MMR_LOCK_OFFSET 0x00 /* Managed by MPPULL */
  15. #define ADPLL_PLLSS_MMR_LOCK_ENABLED 0x1f125B64
  16. #define ADPLL_PLLSS_MMR_UNLOCK_MAGIC 0x1eda4c3d
  17. #define ADPLL_PWRCTRL_OFFSET 0x00
  18. #define ADPLL_PWRCTRL_PONIN 5
  19. #define ADPLL_PWRCTRL_PGOODIN 4
  20. #define ADPLL_PWRCTRL_RET 3
  21. #define ADPLL_PWRCTRL_ISORET 2
  22. #define ADPLL_PWRCTRL_ISOSCAN 1
  23. #define ADPLL_PWRCTRL_OFFMODE 0
  24. #define ADPLL_CLKCTRL_OFFSET 0x04
  25. #define ADPLL_CLKCTRL_CLKDCOLDOEN 29
  26. #define ADPLL_CLKCTRL_IDLE 23
  27. #define ADPLL_CLKCTRL_CLKOUTEN 20
  28. #define ADPLL_CLKINPHIFSEL_ADPLL_S 19 /* REVISIT: which bit? */
  29. #define ADPLL_CLKCTRL_CLKOUTLDOEN_ADPLL_LJ 19
  30. #define ADPLL_CLKCTRL_ULOWCLKEN 18
  31. #define ADPLL_CLKCTRL_CLKDCOLDOPWDNZ 17
  32. #define ADPLL_CLKCTRL_M2PWDNZ 16
  33. #define ADPLL_CLKCTRL_M3PWDNZ_ADPLL_S 15
  34. #define ADPLL_CLKCTRL_LOWCURRSTDBY_ADPLL_S 13
  35. #define ADPLL_CLKCTRL_LPMODE_ADPLL_S 12
  36. #define ADPLL_CLKCTRL_REGM4XEN_ADPLL_S 10
  37. #define ADPLL_CLKCTRL_SELFREQDCO_ADPLL_LJ 10
  38. #define ADPLL_CLKCTRL_TINITZ 0
  39. #define ADPLL_TENABLE_OFFSET 0x08
  40. #define ADPLL_TENABLEDIV_OFFSET 0x8c
  41. #define ADPLL_M2NDIV_OFFSET 0x10
  42. #define ADPLL_M2NDIV_M2 16
  43. #define ADPLL_M2NDIV_M2_ADPLL_S_WIDTH 5
  44. #define ADPLL_M2NDIV_M2_ADPLL_LJ_WIDTH 7
  45. #define ADPLL_MN2DIV_OFFSET 0x14
  46. #define ADPLL_MN2DIV_N2 16
  47. #define ADPLL_FRACDIV_OFFSET 0x18
  48. #define ADPLL_FRACDIV_REGSD 24
  49. #define ADPLL_FRACDIV_FRACTIONALM 0
  50. #define ADPLL_FRACDIV_FRACTIONALM_MASK 0x3ffff
  51. #define ADPLL_BWCTRL_OFFSET 0x1c
  52. #define ADPLL_BWCTRL_BWCONTROL 1
  53. #define ADPLL_BWCTRL_BW_INCR_DECRZ 0
  54. #define ADPLL_RESERVED_OFFSET 0x20
  55. #define ADPLL_STATUS_OFFSET 0x24
  56. #define ADPLL_STATUS_PONOUT 31
  57. #define ADPLL_STATUS_PGOODOUT 30
  58. #define ADPLL_STATUS_LDOPWDN 29
  59. #define ADPLL_STATUS_RECAL_BSTATUS3 28
  60. #define ADPLL_STATUS_RECAL_OPPIN 27
  61. #define ADPLL_STATUS_PHASELOCK 10
  62. #define ADPLL_STATUS_FREQLOCK 9
  63. #define ADPLL_STATUS_BYPASSACK 8
  64. #define ADPLL_STATUS_LOSSREF 6
  65. #define ADPLL_STATUS_CLKOUTENACK 5
  66. #define ADPLL_STATUS_LOCK2 4
  67. #define ADPLL_STATUS_M2CHANGEACK 3
  68. #define ADPLL_STATUS_HIGHJITTER 1
  69. #define ADPLL_STATUS_BYPASS 0
  70. #define ADPLL_STATUS_PREPARED_MASK (BIT(ADPLL_STATUS_PHASELOCK) | \
  71. BIT(ADPLL_STATUS_FREQLOCK))
  72. #define ADPLL_M3DIV_OFFSET 0x28 /* Only on MPUPLL */
  73. #define ADPLL_M3DIV_M3 0
  74. #define ADPLL_M3DIV_M3_WIDTH 5
  75. #define ADPLL_M3DIV_M3_MASK 0x1f
  76. #define ADPLL_RAMPCTRL_OFFSET 0x2c /* Only on MPUPLL */
  77. #define ADPLL_RAMPCTRL_CLKRAMPLEVEL 19
  78. #define ADPLL_RAMPCTRL_CLKRAMPRATE 16
  79. #define ADPLL_RAMPCTRL_RELOCK_RAMP_EN 0
  80. #define MAX_ADPLL_INPUTS 3
  81. #define MAX_ADPLL_OUTPUTS 4
  82. #define ADPLL_MAX_RETRIES 5
  83. #define to_dco(_hw) container_of(_hw, struct ti_adpll_dco_data, hw)
  84. #define to_adpll(_hw) container_of(_hw, struct ti_adpll_data, dco)
  85. #define to_clkout(_hw) container_of(_hw, struct ti_adpll_clkout_data, hw)
  86. enum ti_adpll_clocks {
  87. TI_ADPLL_DCO,
  88. TI_ADPLL_DCO_GATE,
  89. TI_ADPLL_N2,
  90. TI_ADPLL_M2,
  91. TI_ADPLL_M2_GATE,
  92. TI_ADPLL_BYPASS,
  93. TI_ADPLL_HIF,
  94. TI_ADPLL_DIV2,
  95. TI_ADPLL_CLKOUT,
  96. TI_ADPLL_CLKOUT2,
  97. TI_ADPLL_M3,
  98. };
  99. #define TI_ADPLL_NR_CLOCKS (TI_ADPLL_M3 + 1)
  100. enum ti_adpll_inputs {
  101. TI_ADPLL_CLKINP,
  102. TI_ADPLL_CLKINPULOW,
  103. TI_ADPLL_CLKINPHIF,
  104. };
  105. enum ti_adpll_s_outputs {
  106. TI_ADPLL_S_DCOCLKLDO,
  107. TI_ADPLL_S_CLKOUT,
  108. TI_ADPLL_S_CLKOUTX2,
  109. TI_ADPLL_S_CLKOUTHIF,
  110. };
  111. enum ti_adpll_lj_outputs {
  112. TI_ADPLL_LJ_CLKDCOLDO,
  113. TI_ADPLL_LJ_CLKOUT,
  114. TI_ADPLL_LJ_CLKOUTLDO,
  115. };
  116. struct ti_adpll_platform_data {
  117. const bool is_type_s;
  118. const int nr_max_inputs;
  119. const int nr_max_outputs;
  120. const int output_index;
  121. };
  122. struct ti_adpll_clock {
  123. struct clk *clk;
  124. struct clk_lookup *cl;
  125. void (*unregister)(struct clk *clk);
  126. };
  127. struct ti_adpll_dco_data {
  128. struct clk_hw hw;
  129. };
  130. struct ti_adpll_clkout_data {
  131. struct ti_adpll_data *adpll;
  132. struct clk_gate gate;
  133. struct clk_hw hw;
  134. };
  135. struct ti_adpll_data {
  136. struct device *dev;
  137. const struct ti_adpll_platform_data *c;
  138. struct device_node *np;
  139. unsigned long pa;
  140. void __iomem *iobase;
  141. void __iomem *regs;
  142. spinlock_t lock; /* For ADPLL shared register access */
  143. const char *parent_names[MAX_ADPLL_INPUTS];
  144. struct clk *parent_clocks[MAX_ADPLL_INPUTS];
  145. struct ti_adpll_clock *clocks;
  146. struct clk_onecell_data outputs;
  147. struct ti_adpll_dco_data dco;
  148. };
  149. static const char *ti_adpll_clk_get_name(struct ti_adpll_data *d,
  150. int output_index,
  151. const char *postfix)
  152. {
  153. const char *name;
  154. int err;
  155. if (output_index >= 0) {
  156. err = of_property_read_string_index(d->np,
  157. "clock-output-names",
  158. output_index,
  159. &name);
  160. if (err)
  161. return NULL;
  162. } else {
  163. name = devm_kasprintf(d->dev, GFP_KERNEL, "%08lx.adpll.%s",
  164. d->pa, postfix);
  165. }
  166. return name;
  167. }
  168. #define ADPLL_MAX_CON_ID 16 /* See MAX_CON_ID */
  169. static int ti_adpll_setup_clock(struct ti_adpll_data *d, struct clk *clock,
  170. int index, int output_index, const char *name,
  171. void (*unregister)(struct clk *clk))
  172. {
  173. struct clk_lookup *cl;
  174. const char *postfix = NULL;
  175. char con_id[ADPLL_MAX_CON_ID];
  176. d->clocks[index].clk = clock;
  177. d->clocks[index].unregister = unregister;
  178. /* Separate con_id in format "pll040dcoclkldo" to fit MAX_CON_ID */
  179. postfix = strrchr(name, '.');
  180. if (postfix && strlen(postfix) > 1) {
  181. if (strlen(postfix) > ADPLL_MAX_CON_ID)
  182. dev_warn(d->dev, "clock %s con_id lookup may fail\n",
  183. name);
  184. snprintf(con_id, 16, "pll%03lx%s", d->pa & 0xfff, postfix + 1);
  185. cl = clkdev_create(clock, con_id, NULL);
  186. if (!cl)
  187. return -ENOMEM;
  188. d->clocks[index].cl = cl;
  189. } else {
  190. dev_warn(d->dev, "no con_id for clock %s\n", name);
  191. }
  192. if (output_index < 0)
  193. return 0;
  194. d->outputs.clks[output_index] = clock;
  195. d->outputs.clk_num++;
  196. return 0;
  197. }
  198. static int ti_adpll_init_divider(struct ti_adpll_data *d,
  199. enum ti_adpll_clocks index,
  200. int output_index, char *name,
  201. struct clk *parent_clock,
  202. void __iomem *reg,
  203. u8 shift, u8 width,
  204. u8 clk_divider_flags)
  205. {
  206. const char *child_name;
  207. const char *parent_name;
  208. struct clk *clock;
  209. child_name = ti_adpll_clk_get_name(d, output_index, name);
  210. if (!child_name)
  211. return -EINVAL;
  212. parent_name = __clk_get_name(parent_clock);
  213. clock = clk_register_divider(d->dev, child_name, parent_name, 0,
  214. reg, shift, width, clk_divider_flags,
  215. &d->lock);
  216. if (IS_ERR(clock)) {
  217. dev_err(d->dev, "failed to register divider %s: %li\n",
  218. name, PTR_ERR(clock));
  219. return PTR_ERR(clock);
  220. }
  221. return ti_adpll_setup_clock(d, clock, index, output_index, child_name,
  222. clk_unregister_divider);
  223. }
  224. static int ti_adpll_init_mux(struct ti_adpll_data *d,
  225. enum ti_adpll_clocks index,
  226. char *name, struct clk *clk0,
  227. struct clk *clk1,
  228. void __iomem *reg,
  229. u8 shift)
  230. {
  231. const char *child_name;
  232. const char *parents[2];
  233. struct clk *clock;
  234. child_name = ti_adpll_clk_get_name(d, -ENODEV, name);
  235. if (!child_name)
  236. return -ENOMEM;
  237. parents[0] = __clk_get_name(clk0);
  238. parents[1] = __clk_get_name(clk1);
  239. clock = clk_register_mux(d->dev, child_name, parents, 2, 0,
  240. reg, shift, 1, 0, &d->lock);
  241. if (IS_ERR(clock)) {
  242. dev_err(d->dev, "failed to register mux %s: %li\n",
  243. name, PTR_ERR(clock));
  244. return PTR_ERR(clock);
  245. }
  246. return ti_adpll_setup_clock(d, clock, index, -ENODEV, child_name,
  247. clk_unregister_mux);
  248. }
  249. static int ti_adpll_init_gate(struct ti_adpll_data *d,
  250. enum ti_adpll_clocks index,
  251. int output_index, char *name,
  252. struct clk *parent_clock,
  253. void __iomem *reg,
  254. u8 bit_idx,
  255. u8 clk_gate_flags)
  256. {
  257. const char *child_name;
  258. const char *parent_name;
  259. struct clk *clock;
  260. child_name = ti_adpll_clk_get_name(d, output_index, name);
  261. if (!child_name)
  262. return -EINVAL;
  263. parent_name = __clk_get_name(parent_clock);
  264. clock = clk_register_gate(d->dev, child_name, parent_name, 0,
  265. reg, bit_idx, clk_gate_flags,
  266. &d->lock);
  267. if (IS_ERR(clock)) {
  268. dev_err(d->dev, "failed to register gate %s: %li\n",
  269. name, PTR_ERR(clock));
  270. return PTR_ERR(clock);
  271. }
  272. return ti_adpll_setup_clock(d, clock, index, output_index, child_name,
  273. clk_unregister_gate);
  274. }
  275. static int ti_adpll_init_fixed_factor(struct ti_adpll_data *d,
  276. enum ti_adpll_clocks index,
  277. char *name,
  278. struct clk *parent_clock,
  279. unsigned int mult,
  280. unsigned int div)
  281. {
  282. const char *child_name;
  283. const char *parent_name;
  284. struct clk *clock;
  285. child_name = ti_adpll_clk_get_name(d, -ENODEV, name);
  286. if (!child_name)
  287. return -ENOMEM;
  288. parent_name = __clk_get_name(parent_clock);
  289. clock = clk_register_fixed_factor(d->dev, child_name, parent_name,
  290. 0, mult, div);
  291. if (IS_ERR(clock))
  292. return PTR_ERR(clock);
  293. return ti_adpll_setup_clock(d, clock, index, -ENODEV, child_name,
  294. clk_unregister);
  295. }
  296. static void ti_adpll_set_idle_bypass(struct ti_adpll_data *d)
  297. {
  298. unsigned long flags;
  299. u32 v;
  300. spin_lock_irqsave(&d->lock, flags);
  301. v = readl_relaxed(d->regs + ADPLL_CLKCTRL_OFFSET);
  302. v |= BIT(ADPLL_CLKCTRL_IDLE);
  303. writel_relaxed(v, d->regs + ADPLL_CLKCTRL_OFFSET);
  304. spin_unlock_irqrestore(&d->lock, flags);
  305. }
  306. static void ti_adpll_clear_idle_bypass(struct ti_adpll_data *d)
  307. {
  308. unsigned long flags;
  309. u32 v;
  310. spin_lock_irqsave(&d->lock, flags);
  311. v = readl_relaxed(d->regs + ADPLL_CLKCTRL_OFFSET);
  312. v &= ~BIT(ADPLL_CLKCTRL_IDLE);
  313. writel_relaxed(v, d->regs + ADPLL_CLKCTRL_OFFSET);
  314. spin_unlock_irqrestore(&d->lock, flags);
  315. }
  316. static bool ti_adpll_clock_is_bypass(struct ti_adpll_data *d)
  317. {
  318. u32 v;
  319. v = readl_relaxed(d->regs + ADPLL_STATUS_OFFSET);
  320. return v & BIT(ADPLL_STATUS_BYPASS);
  321. }
  322. /*
  323. * Locked and bypass are not actually mutually exclusive: if you only care
  324. * about the DCO clock and not CLKOUT you can clear M2PWDNZ before enabling
  325. * the PLL, resulting in status (FREQLOCK | PHASELOCK | BYPASS) after lock.
  326. */
  327. static bool ti_adpll_is_locked(struct ti_adpll_data *d)
  328. {
  329. u32 v = readl_relaxed(d->regs + ADPLL_STATUS_OFFSET);
  330. return (v & ADPLL_STATUS_PREPARED_MASK) == ADPLL_STATUS_PREPARED_MASK;
  331. }
  332. static int ti_adpll_wait_lock(struct ti_adpll_data *d)
  333. {
  334. int retries = ADPLL_MAX_RETRIES;
  335. do {
  336. if (ti_adpll_is_locked(d))
  337. return 0;
  338. usleep_range(200, 300);
  339. } while (retries--);
  340. dev_err(d->dev, "pll failed to lock\n");
  341. return -ETIMEDOUT;
  342. }
  343. static int ti_adpll_prepare(struct clk_hw *hw)
  344. {
  345. struct ti_adpll_dco_data *dco = to_dco(hw);
  346. struct ti_adpll_data *d = to_adpll(dco);
  347. ti_adpll_clear_idle_bypass(d);
  348. ti_adpll_wait_lock(d);
  349. return 0;
  350. }
  351. static void ti_adpll_unprepare(struct clk_hw *hw)
  352. {
  353. struct ti_adpll_dco_data *dco = to_dco(hw);
  354. struct ti_adpll_data *d = to_adpll(dco);
  355. ti_adpll_set_idle_bypass(d);
  356. }
  357. static int ti_adpll_is_prepared(struct clk_hw *hw)
  358. {
  359. struct ti_adpll_dco_data *dco = to_dco(hw);
  360. struct ti_adpll_data *d = to_adpll(dco);
  361. return ti_adpll_is_locked(d);
  362. }
  363. /*
  364. * Note that the DCO clock is never subject to bypass: if the PLL is off,
  365. * dcoclk is low.
  366. */
  367. static unsigned long ti_adpll_recalc_rate(struct clk_hw *hw,
  368. unsigned long parent_rate)
  369. {
  370. struct ti_adpll_dco_data *dco = to_dco(hw);
  371. struct ti_adpll_data *d = to_adpll(dco);
  372. u32 frac_m, divider, v;
  373. u64 rate;
  374. unsigned long flags;
  375. if (ti_adpll_clock_is_bypass(d))
  376. return 0;
  377. spin_lock_irqsave(&d->lock, flags);
  378. frac_m = readl_relaxed(d->regs + ADPLL_FRACDIV_OFFSET);
  379. frac_m &= ADPLL_FRACDIV_FRACTIONALM_MASK;
  380. rate = (u64)readw_relaxed(d->regs + ADPLL_MN2DIV_OFFSET) << 18;
  381. rate += frac_m;
  382. rate *= parent_rate;
  383. divider = (readw_relaxed(d->regs + ADPLL_M2NDIV_OFFSET) + 1) << 18;
  384. spin_unlock_irqrestore(&d->lock, flags);
  385. do_div(rate, divider);
  386. if (d->c->is_type_s) {
  387. v = readl_relaxed(d->regs + ADPLL_CLKCTRL_OFFSET);
  388. if (v & BIT(ADPLL_CLKCTRL_REGM4XEN_ADPLL_S))
  389. rate *= 4;
  390. rate *= 2;
  391. }
  392. return rate;
  393. }
  394. /* PLL parent is always clkinp, bypass only affects the children */
  395. static u8 ti_adpll_get_parent(struct clk_hw *hw)
  396. {
  397. return 0;
  398. }
  399. static const struct clk_ops ti_adpll_ops = {
  400. .prepare = ti_adpll_prepare,
  401. .unprepare = ti_adpll_unprepare,
  402. .is_prepared = ti_adpll_is_prepared,
  403. .recalc_rate = ti_adpll_recalc_rate,
  404. .get_parent = ti_adpll_get_parent,
  405. };
  406. static int ti_adpll_init_dco(struct ti_adpll_data *d)
  407. {
  408. struct clk_init_data init;
  409. struct clk *clock;
  410. const char *postfix;
  411. int width, err;
  412. d->outputs.clks = devm_kcalloc(d->dev,
  413. MAX_ADPLL_OUTPUTS,
  414. sizeof(struct clk *),
  415. GFP_KERNEL);
  416. if (!d->outputs.clks)
  417. return -ENOMEM;
  418. if (d->c->output_index < 0)
  419. postfix = "dco";
  420. else
  421. postfix = NULL;
  422. init.name = ti_adpll_clk_get_name(d, d->c->output_index, postfix);
  423. if (!init.name)
  424. return -EINVAL;
  425. init.parent_names = d->parent_names;
  426. init.num_parents = d->c->nr_max_inputs;
  427. init.ops = &ti_adpll_ops;
  428. init.flags = CLK_GET_RATE_NOCACHE;
  429. d->dco.hw.init = &init;
  430. if (d->c->is_type_s)
  431. width = 5;
  432. else
  433. width = 4;
  434. /* Internal input clock divider N2 */
  435. err = ti_adpll_init_divider(d, TI_ADPLL_N2, -ENODEV, "n2",
  436. d->parent_clocks[TI_ADPLL_CLKINP],
  437. d->regs + ADPLL_MN2DIV_OFFSET,
  438. ADPLL_MN2DIV_N2, width, 0);
  439. if (err)
  440. return err;
  441. clock = devm_clk_register(d->dev, &d->dco.hw);
  442. if (IS_ERR(clock))
  443. return PTR_ERR(clock);
  444. return ti_adpll_setup_clock(d, clock, TI_ADPLL_DCO, d->c->output_index,
  445. init.name, NULL);
  446. }
  447. static int ti_adpll_clkout_enable(struct clk_hw *hw)
  448. {
  449. struct ti_adpll_clkout_data *co = to_clkout(hw);
  450. struct clk_hw *gate_hw = &co->gate.hw;
  451. __clk_hw_set_clk(gate_hw, hw);
  452. return clk_gate_ops.enable(gate_hw);
  453. }
  454. static void ti_adpll_clkout_disable(struct clk_hw *hw)
  455. {
  456. struct ti_adpll_clkout_data *co = to_clkout(hw);
  457. struct clk_hw *gate_hw = &co->gate.hw;
  458. __clk_hw_set_clk(gate_hw, hw);
  459. clk_gate_ops.disable(gate_hw);
  460. }
  461. static int ti_adpll_clkout_is_enabled(struct clk_hw *hw)
  462. {
  463. struct ti_adpll_clkout_data *co = to_clkout(hw);
  464. struct clk_hw *gate_hw = &co->gate.hw;
  465. __clk_hw_set_clk(gate_hw, hw);
  466. return clk_gate_ops.is_enabled(gate_hw);
  467. }
  468. /* Setting PLL bypass puts clkout and clkoutx2 into bypass */
  469. static u8 ti_adpll_clkout_get_parent(struct clk_hw *hw)
  470. {
  471. struct ti_adpll_clkout_data *co = to_clkout(hw);
  472. struct ti_adpll_data *d = co->adpll;
  473. return ti_adpll_clock_is_bypass(d);
  474. }
  475. static int ti_adpll_init_clkout(struct ti_adpll_data *d,
  476. enum ti_adpll_clocks index,
  477. int output_index, int gate_bit,
  478. char *name, struct clk *clk0,
  479. struct clk *clk1)
  480. {
  481. struct ti_adpll_clkout_data *co;
  482. struct clk_init_data init;
  483. struct clk_ops *ops;
  484. const char *parent_names[2];
  485. const char *child_name;
  486. struct clk *clock;
  487. int err;
  488. co = devm_kzalloc(d->dev, sizeof(*co), GFP_KERNEL);
  489. if (!co)
  490. return -ENOMEM;
  491. co->adpll = d;
  492. err = of_property_read_string_index(d->np,
  493. "clock-output-names",
  494. output_index,
  495. &child_name);
  496. if (err)
  497. return err;
  498. ops = devm_kzalloc(d->dev, sizeof(*ops), GFP_KERNEL);
  499. if (!ops)
  500. return -ENOMEM;
  501. init.name = child_name;
  502. init.ops = ops;
  503. init.flags = 0;
  504. co->hw.init = &init;
  505. parent_names[0] = __clk_get_name(clk0);
  506. parent_names[1] = __clk_get_name(clk1);
  507. init.parent_names = parent_names;
  508. init.num_parents = 2;
  509. ops->get_parent = ti_adpll_clkout_get_parent;
  510. ops->determine_rate = __clk_mux_determine_rate;
  511. if (gate_bit) {
  512. co->gate.lock = &d->lock;
  513. co->gate.reg = d->regs + ADPLL_CLKCTRL_OFFSET;
  514. co->gate.bit_idx = gate_bit;
  515. ops->enable = ti_adpll_clkout_enable;
  516. ops->disable = ti_adpll_clkout_disable;
  517. ops->is_enabled = ti_adpll_clkout_is_enabled;
  518. }
  519. clock = devm_clk_register(d->dev, &co->hw);
  520. if (IS_ERR(clock)) {
  521. dev_err(d->dev, "failed to register output %s: %li\n",
  522. name, PTR_ERR(clock));
  523. return PTR_ERR(clock);
  524. }
  525. return ti_adpll_setup_clock(d, clock, index, output_index, child_name,
  526. NULL);
  527. }
  528. static int ti_adpll_init_children_adpll_s(struct ti_adpll_data *d)
  529. {
  530. int err;
  531. if (!d->c->is_type_s)
  532. return 0;
  533. /* Internal mux, sources from divider N2 or clkinpulow */
  534. err = ti_adpll_init_mux(d, TI_ADPLL_BYPASS, "bypass",
  535. d->clocks[TI_ADPLL_N2].clk,
  536. d->parent_clocks[TI_ADPLL_CLKINPULOW],
  537. d->regs + ADPLL_CLKCTRL_OFFSET,
  538. ADPLL_CLKCTRL_ULOWCLKEN);
  539. if (err)
  540. return err;
  541. /* Internal divider M2, sources DCO */
  542. err = ti_adpll_init_divider(d, TI_ADPLL_M2, -ENODEV, "m2",
  543. d->clocks[TI_ADPLL_DCO].clk,
  544. d->regs + ADPLL_M2NDIV_OFFSET,
  545. ADPLL_M2NDIV_M2,
  546. ADPLL_M2NDIV_M2_ADPLL_S_WIDTH,
  547. CLK_DIVIDER_ONE_BASED);
  548. if (err)
  549. return err;
  550. /* Internal fixed divider, after M2 before clkout */
  551. err = ti_adpll_init_fixed_factor(d, TI_ADPLL_DIV2, "div2",
  552. d->clocks[TI_ADPLL_M2].clk,
  553. 1, 2);
  554. if (err)
  555. return err;
  556. /* Output clkout with a mux and gate, sources from div2 or bypass */
  557. err = ti_adpll_init_clkout(d, TI_ADPLL_CLKOUT, TI_ADPLL_S_CLKOUT,
  558. ADPLL_CLKCTRL_CLKOUTEN, "clkout",
  559. d->clocks[TI_ADPLL_DIV2].clk,
  560. d->clocks[TI_ADPLL_BYPASS].clk);
  561. if (err)
  562. return err;
  563. /* Output clkoutx2 with a mux and gate, sources from M2 or bypass */
  564. err = ti_adpll_init_clkout(d, TI_ADPLL_CLKOUT2, TI_ADPLL_S_CLKOUTX2, 0,
  565. "clkout2", d->clocks[TI_ADPLL_M2].clk,
  566. d->clocks[TI_ADPLL_BYPASS].clk);
  567. if (err)
  568. return err;
  569. /* Internal mux, sources from DCO and clkinphif */
  570. if (d->parent_clocks[TI_ADPLL_CLKINPHIF]) {
  571. err = ti_adpll_init_mux(d, TI_ADPLL_HIF, "hif",
  572. d->clocks[TI_ADPLL_DCO].clk,
  573. d->parent_clocks[TI_ADPLL_CLKINPHIF],
  574. d->regs + ADPLL_CLKCTRL_OFFSET,
  575. ADPLL_CLKINPHIFSEL_ADPLL_S);
  576. if (err)
  577. return err;
  578. }
  579. /* Output clkouthif with a divider M3, sources from hif */
  580. err = ti_adpll_init_divider(d, TI_ADPLL_M3, TI_ADPLL_S_CLKOUTHIF, "m3",
  581. d->clocks[TI_ADPLL_HIF].clk,
  582. d->regs + ADPLL_M3DIV_OFFSET,
  583. ADPLL_M3DIV_M3,
  584. ADPLL_M3DIV_M3_WIDTH,
  585. CLK_DIVIDER_ONE_BASED);
  586. if (err)
  587. return err;
  588. /* Output clock dcoclkldo is the DCO */
  589. return 0;
  590. }
  591. static int ti_adpll_init_children_adpll_lj(struct ti_adpll_data *d)
  592. {
  593. int err;
  594. if (d->c->is_type_s)
  595. return 0;
  596. /* Output clkdcoldo, gated output of DCO */
  597. err = ti_adpll_init_gate(d, TI_ADPLL_DCO_GATE, TI_ADPLL_LJ_CLKDCOLDO,
  598. "clkdcoldo", d->clocks[TI_ADPLL_DCO].clk,
  599. d->regs + ADPLL_CLKCTRL_OFFSET,
  600. ADPLL_CLKCTRL_CLKDCOLDOEN, 0);
  601. if (err)
  602. return err;
  603. /* Internal divider M2, sources from DCO */
  604. err = ti_adpll_init_divider(d, TI_ADPLL_M2, -ENODEV,
  605. "m2", d->clocks[TI_ADPLL_DCO].clk,
  606. d->regs + ADPLL_M2NDIV_OFFSET,
  607. ADPLL_M2NDIV_M2,
  608. ADPLL_M2NDIV_M2_ADPLL_LJ_WIDTH,
  609. CLK_DIVIDER_ONE_BASED);
  610. if (err)
  611. return err;
  612. /* Output clkoutldo, gated output of M2 */
  613. err = ti_adpll_init_gate(d, TI_ADPLL_M2_GATE, TI_ADPLL_LJ_CLKOUTLDO,
  614. "clkoutldo", d->clocks[TI_ADPLL_M2].clk,
  615. d->regs + ADPLL_CLKCTRL_OFFSET,
  616. ADPLL_CLKCTRL_CLKOUTLDOEN_ADPLL_LJ,
  617. 0);
  618. if (err)
  619. return err;
  620. /* Internal mux, sources from divider N2 or clkinpulow */
  621. err = ti_adpll_init_mux(d, TI_ADPLL_BYPASS, "bypass",
  622. d->clocks[TI_ADPLL_N2].clk,
  623. d->parent_clocks[TI_ADPLL_CLKINPULOW],
  624. d->regs + ADPLL_CLKCTRL_OFFSET,
  625. ADPLL_CLKCTRL_ULOWCLKEN);
  626. if (err)
  627. return err;
  628. /* Output clkout, sources M2 or bypass */
  629. err = ti_adpll_init_clkout(d, TI_ADPLL_CLKOUT, TI_ADPLL_S_CLKOUT,
  630. ADPLL_CLKCTRL_CLKOUTEN, "clkout",
  631. d->clocks[TI_ADPLL_M2].clk,
  632. d->clocks[TI_ADPLL_BYPASS].clk);
  633. if (err)
  634. return err;
  635. return 0;
  636. }
  637. static void ti_adpll_free_resources(struct ti_adpll_data *d)
  638. {
  639. int i;
  640. for (i = TI_ADPLL_M3; i >= 0; i--) {
  641. struct ti_adpll_clock *ac = &d->clocks[i];
  642. if (!ac || IS_ERR_OR_NULL(ac->clk))
  643. continue;
  644. if (ac->cl)
  645. clkdev_drop(ac->cl);
  646. if (ac->unregister)
  647. ac->unregister(ac->clk);
  648. }
  649. }
  650. /* MPU PLL manages the lock register for all PLLs */
  651. static void ti_adpll_unlock_all(void __iomem *reg)
  652. {
  653. u32 v;
  654. v = readl_relaxed(reg);
  655. if (v == ADPLL_PLLSS_MMR_LOCK_ENABLED)
  656. writel_relaxed(ADPLL_PLLSS_MMR_UNLOCK_MAGIC, reg);
  657. }
  658. static int ti_adpll_init_registers(struct ti_adpll_data *d)
  659. {
  660. int register_offset = 0;
  661. if (d->c->is_type_s) {
  662. register_offset = 8;
  663. ti_adpll_unlock_all(d->iobase + ADPLL_PLLSS_MMR_LOCK_OFFSET);
  664. }
  665. d->regs = d->iobase + register_offset + ADPLL_PWRCTRL_OFFSET;
  666. return 0;
  667. }
  668. static int ti_adpll_init_inputs(struct ti_adpll_data *d)
  669. {
  670. static const char error[] = "need at least %i inputs";
  671. struct clk *clock;
  672. int nr_inputs;
  673. nr_inputs = of_clk_get_parent_count(d->np);
  674. if (nr_inputs < d->c->nr_max_inputs) {
  675. dev_err(d->dev, error, nr_inputs);
  676. return -EINVAL;
  677. }
  678. of_clk_parent_fill(d->np, d->parent_names, nr_inputs);
  679. clock = devm_clk_get(d->dev, d->parent_names[0]);
  680. if (IS_ERR(clock)) {
  681. dev_err(d->dev, "could not get clkinp\n");
  682. return PTR_ERR(clock);
  683. }
  684. d->parent_clocks[TI_ADPLL_CLKINP] = clock;
  685. clock = devm_clk_get(d->dev, d->parent_names[1]);
  686. if (IS_ERR(clock)) {
  687. dev_err(d->dev, "could not get clkinpulow clock\n");
  688. return PTR_ERR(clock);
  689. }
  690. d->parent_clocks[TI_ADPLL_CLKINPULOW] = clock;
  691. if (d->c->is_type_s) {
  692. clock = devm_clk_get(d->dev, d->parent_names[2]);
  693. if (IS_ERR(clock)) {
  694. dev_err(d->dev, "could not get clkinphif clock\n");
  695. return PTR_ERR(clock);
  696. }
  697. d->parent_clocks[TI_ADPLL_CLKINPHIF] = clock;
  698. }
  699. return 0;
  700. }
  701. static const struct ti_adpll_platform_data ti_adpll_type_s = {
  702. .is_type_s = true,
  703. .nr_max_inputs = MAX_ADPLL_INPUTS,
  704. .nr_max_outputs = MAX_ADPLL_OUTPUTS,
  705. .output_index = TI_ADPLL_S_DCOCLKLDO,
  706. };
  707. static const struct ti_adpll_platform_data ti_adpll_type_lj = {
  708. .is_type_s = false,
  709. .nr_max_inputs = MAX_ADPLL_INPUTS - 1,
  710. .nr_max_outputs = MAX_ADPLL_OUTPUTS - 1,
  711. .output_index = -EINVAL,
  712. };
  713. static const struct of_device_id ti_adpll_match[] = {
  714. { .compatible = "ti,dm814-adpll-s-clock", &ti_adpll_type_s },
  715. { .compatible = "ti,dm814-adpll-lj-clock", &ti_adpll_type_lj },
  716. {},
  717. };
  718. MODULE_DEVICE_TABLE(of, ti_adpll_match);
  719. static int ti_adpll_probe(struct platform_device *pdev)
  720. {
  721. struct device_node *node = pdev->dev.of_node;
  722. struct device *dev = &pdev->dev;
  723. struct ti_adpll_data *d;
  724. struct resource *res;
  725. int err;
  726. d = devm_kzalloc(dev, sizeof(*d), GFP_KERNEL);
  727. if (!d)
  728. return -ENOMEM;
  729. d->dev = dev;
  730. d->np = node;
  731. d->c = device_get_match_data(dev);
  732. dev_set_drvdata(d->dev, d);
  733. spin_lock_init(&d->lock);
  734. d->iobase = devm_platform_get_and_ioremap_resource(pdev, 0, &res);
  735. if (IS_ERR(d->iobase))
  736. return PTR_ERR(d->iobase);
  737. d->pa = res->start;
  738. err = ti_adpll_init_registers(d);
  739. if (err)
  740. return err;
  741. err = ti_adpll_init_inputs(d);
  742. if (err)
  743. return err;
  744. d->clocks = devm_kcalloc(d->dev,
  745. TI_ADPLL_NR_CLOCKS,
  746. sizeof(struct ti_adpll_clock),
  747. GFP_KERNEL);
  748. if (!d->clocks)
  749. return -ENOMEM;
  750. err = ti_adpll_init_dco(d);
  751. if (err) {
  752. dev_err(dev, "could not register dco: %i\n", err);
  753. goto free;
  754. }
  755. err = ti_adpll_init_children_adpll_s(d);
  756. if (err)
  757. goto free;
  758. err = ti_adpll_init_children_adpll_lj(d);
  759. if (err)
  760. goto free;
  761. err = of_clk_add_provider(d->np, of_clk_src_onecell_get, &d->outputs);
  762. if (err)
  763. goto free;
  764. return 0;
  765. free:
  766. WARN_ON(1);
  767. ti_adpll_free_resources(d);
  768. return err;
  769. }
  770. static void ti_adpll_remove(struct platform_device *pdev)
  771. {
  772. struct ti_adpll_data *d = dev_get_drvdata(&pdev->dev);
  773. ti_adpll_free_resources(d);
  774. }
  775. static struct platform_driver ti_adpll_driver = {
  776. .driver = {
  777. .name = "ti-adpll",
  778. .of_match_table = ti_adpll_match,
  779. },
  780. .probe = ti_adpll_probe,
  781. .remove = ti_adpll_remove,
  782. };
  783. static int __init ti_adpll_init(void)
  784. {
  785. return platform_driver_register(&ti_adpll_driver);
  786. }
  787. core_initcall(ti_adpll_init);
  788. static void __exit ti_adpll_exit(void)
  789. {
  790. platform_driver_unregister(&ti_adpll_driver);
  791. }
  792. module_exit(ti_adpll_exit);
  793. MODULE_DESCRIPTION("Clock driver for dm814x ADPLL");
  794. MODULE_ALIAS("platform:dm814-adpll-clock");
  795. MODULE_AUTHOR("Tony LIndgren <tony@atomide.com>");
  796. MODULE_LICENSE("GPL v2");