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