xref: /linux/drivers/clk/clk-si5351.c (revision ae64438be1923e3c1102d90fd41db7afcfaf54cc)
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3  * clk-si5351.c: Skyworks / Silicon Labs Si5351A/B/C I2C Clock Generator
4  *
5  * Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com>
6  * Rabeeh Khoury <rabeeh@solid-run.com>
7  *
8  * References:
9  * [1] "Si5351A/B/C Data Sheet"
10  *     https://www.skyworksinc.com/-/media/Skyworks/SL/documents/public/data-sheets/Si5351-B.pdf
11  * [2] "AN619: Manually Generating an Si5351 Register Map"
12  *     https://www.skyworksinc.com/-/media/Skyworks/SL/documents/public/application-notes/AN619.pdf
13  */
14 
15 #include <linux/module.h>
16 #include <linux/kernel.h>
17 #include <linux/clk.h>
18 #include <linux/clk-provider.h>
19 #include <linux/delay.h>
20 #include <linux/err.h>
21 #include <linux/errno.h>
22 #include <linux/rational.h>
23 #include <linux/i2c.h>
24 #include <linux/of_platform.h>
25 #include <linux/platform_data/si5351.h>
26 #include <linux/regmap.h>
27 #include <linux/slab.h>
28 #include <linux/string.h>
29 #include <asm/div64.h>
30 
31 #include "clk-si5351.h"
32 
33 struct si5351_driver_data;
34 
35 struct si5351_parameters {
36 	unsigned long	p1;
37 	unsigned long	p2;
38 	unsigned long	p3;
39 	int		valid;
40 };
41 
42 struct si5351_hw_data {
43 	struct clk_hw			hw;
44 	struct si5351_driver_data	*drvdata;
45 	struct si5351_parameters	params;
46 	unsigned char			num;
47 };
48 
49 struct si5351_driver_data {
50 	enum si5351_variant	variant;
51 	struct i2c_client	*client;
52 	struct regmap		*regmap;
53 
54 	struct clk		*pxtal;
55 	const char		*pxtal_name;
56 	struct clk_hw		xtal;
57 	struct clk		*pclkin;
58 	const char		*pclkin_name;
59 	struct clk_hw		clkin;
60 
61 	struct si5351_hw_data	pll[2];
62 	struct si5351_hw_data	*msynth;
63 	struct si5351_hw_data	*clkout;
64 	size_t			num_clkout;
65 };
66 
67 static const char * const si5351_input_names[] = {
68 	"xtal", "clkin"
69 };
70 static const char * const si5351_pll_names[] = {
71 	"si5351_plla", "si5351_pllb", "si5351_vxco"
72 };
73 static const char * const si5351_msynth_names[] = {
74 	"ms0", "ms1", "ms2", "ms3", "ms4", "ms5", "ms6", "ms7"
75 };
76 static const char * const si5351_clkout_names[] = {
77 	"clk0", "clk1", "clk2", "clk3", "clk4", "clk5", "clk6", "clk7"
78 };
79 
80 /*
81  * Si5351 i2c regmap
82  */
83 static inline u8 si5351_reg_read(struct si5351_driver_data *drvdata, u8 reg)
84 {
85 	u32 val;
86 	int ret;
87 
88 	ret = regmap_read(drvdata->regmap, reg, &val);
89 	if (ret) {
90 		dev_err(&drvdata->client->dev,
91 			"unable to read from reg%02x\n", reg);
92 		return 0;
93 	}
94 
95 	return (u8)val;
96 }
97 
98 static inline int si5351_bulk_read(struct si5351_driver_data *drvdata,
99 				   u8 reg, u8 count, u8 *buf)
100 {
101 	return regmap_bulk_read(drvdata->regmap, reg, buf, count);
102 }
103 
104 static inline int si5351_reg_write(struct si5351_driver_data *drvdata,
105 				   u8 reg, u8 val)
106 {
107 	return regmap_write(drvdata->regmap, reg, val);
108 }
109 
110 static inline int si5351_bulk_write(struct si5351_driver_data *drvdata,
111 				    u8 reg, u8 count, const u8 *buf)
112 {
113 	return regmap_raw_write(drvdata->regmap, reg, buf, count);
114 }
115 
116 static inline int si5351_set_bits(struct si5351_driver_data *drvdata,
117 				  u8 reg, u8 mask, u8 val)
118 {
119 	return regmap_update_bits(drvdata->regmap, reg, mask, val);
120 }
121 
122 static inline u8 si5351_msynth_params_address(int num)
123 {
124 	if (num > 5)
125 		return SI5351_CLK6_PARAMETERS + (num - 6);
126 	return SI5351_CLK0_PARAMETERS + (SI5351_PARAMETERS_LENGTH * num);
127 }
128 
129 static void si5351_read_parameters(struct si5351_driver_data *drvdata,
130 				   u8 reg, struct si5351_parameters *params)
131 {
132 	u8 buf[SI5351_PARAMETERS_LENGTH];
133 
134 	switch (reg) {
135 	case SI5351_CLK6_PARAMETERS:
136 	case SI5351_CLK7_PARAMETERS:
137 		buf[0] = si5351_reg_read(drvdata, reg);
138 		params->p1 = buf[0];
139 		params->p2 = 0;
140 		params->p3 = 1;
141 		break;
142 	default:
143 		si5351_bulk_read(drvdata, reg, SI5351_PARAMETERS_LENGTH, buf);
144 		params->p1 = ((buf[2] & 0x03) << 16) | (buf[3] << 8) | buf[4];
145 		params->p2 = ((buf[5] & 0x0f) << 16) | (buf[6] << 8) | buf[7];
146 		params->p3 = ((buf[5] & 0xf0) << 12) | (buf[0] << 8) | buf[1];
147 	}
148 	params->valid = 1;
149 }
150 
151 static void si5351_write_parameters(struct si5351_driver_data *drvdata,
152 				    u8 reg, struct si5351_parameters *params)
153 {
154 	u8 buf[SI5351_PARAMETERS_LENGTH];
155 
156 	switch (reg) {
157 	case SI5351_CLK6_PARAMETERS:
158 	case SI5351_CLK7_PARAMETERS:
159 		buf[0] = params->p1 & 0xff;
160 		si5351_reg_write(drvdata, reg, buf[0]);
161 		break;
162 	default:
163 		buf[0] = ((params->p3 & 0x0ff00) >> 8) & 0xff;
164 		buf[1] = params->p3 & 0xff;
165 		/* save rdiv and divby4 */
166 		buf[2] = si5351_reg_read(drvdata, reg + 2) & ~0x03;
167 		buf[2] |= ((params->p1 & 0x30000) >> 16) & 0x03;
168 		buf[3] = ((params->p1 & 0x0ff00) >> 8) & 0xff;
169 		buf[4] = params->p1 & 0xff;
170 		buf[5] = ((params->p3 & 0xf0000) >> 12) |
171 			((params->p2 & 0xf0000) >> 16);
172 		buf[6] = ((params->p2 & 0x0ff00) >> 8) & 0xff;
173 		buf[7] = params->p2 & 0xff;
174 		si5351_bulk_write(drvdata, reg, SI5351_PARAMETERS_LENGTH, buf);
175 	}
176 }
177 
178 static bool si5351_regmap_is_volatile(struct device *dev, unsigned int reg)
179 {
180 	switch (reg) {
181 	case SI5351_DEVICE_STATUS:
182 	case SI5351_INTERRUPT_STATUS:
183 	case SI5351_PLL_RESET:
184 		return true;
185 	}
186 	return false;
187 }
188 
189 static bool si5351_regmap_is_writeable(struct device *dev, unsigned int reg)
190 {
191 	/* reserved registers */
192 	if (reg >= 4 && reg <= 8)
193 		return false;
194 	if (reg >= 10 && reg <= 14)
195 		return false;
196 	if (reg >= 173 && reg <= 176)
197 		return false;
198 	if (reg >= 178 && reg <= 182)
199 		return false;
200 	/* read-only */
201 	if (reg == SI5351_DEVICE_STATUS)
202 		return false;
203 	return true;
204 }
205 
206 static const struct regmap_config si5351_regmap_config = {
207 	.reg_bits = 8,
208 	.val_bits = 8,
209 	.cache_type = REGCACHE_RBTREE,
210 	.max_register = 187,
211 	.writeable_reg = si5351_regmap_is_writeable,
212 	.volatile_reg = si5351_regmap_is_volatile,
213 };
214 
215 /*
216  * Si5351 xtal clock input
217  */
218 static int si5351_xtal_prepare(struct clk_hw *hw)
219 {
220 	struct si5351_driver_data *drvdata =
221 		container_of(hw, struct si5351_driver_data, xtal);
222 	si5351_set_bits(drvdata, SI5351_FANOUT_ENABLE,
223 			SI5351_XTAL_ENABLE, SI5351_XTAL_ENABLE);
224 	return 0;
225 }
226 
227 static void si5351_xtal_unprepare(struct clk_hw *hw)
228 {
229 	struct si5351_driver_data *drvdata =
230 		container_of(hw, struct si5351_driver_data, xtal);
231 	si5351_set_bits(drvdata, SI5351_FANOUT_ENABLE,
232 			SI5351_XTAL_ENABLE, 0);
233 }
234 
235 static const struct clk_ops si5351_xtal_ops = {
236 	.prepare = si5351_xtal_prepare,
237 	.unprepare = si5351_xtal_unprepare,
238 };
239 
240 /*
241  * Si5351 clkin clock input (Si5351C only)
242  */
243 static int si5351_clkin_prepare(struct clk_hw *hw)
244 {
245 	struct si5351_driver_data *drvdata =
246 		container_of(hw, struct si5351_driver_data, clkin);
247 	si5351_set_bits(drvdata, SI5351_FANOUT_ENABLE,
248 			SI5351_CLKIN_ENABLE, SI5351_CLKIN_ENABLE);
249 	return 0;
250 }
251 
252 static void si5351_clkin_unprepare(struct clk_hw *hw)
253 {
254 	struct si5351_driver_data *drvdata =
255 		container_of(hw, struct si5351_driver_data, clkin);
256 	si5351_set_bits(drvdata, SI5351_FANOUT_ENABLE,
257 			SI5351_CLKIN_ENABLE, 0);
258 }
259 
260 /*
261  * CMOS clock source constraints:
262  * The input frequency range of the PLL is 10Mhz to 40MHz.
263  * If CLKIN is >40MHz, the input divider must be used.
264  */
265 static unsigned long si5351_clkin_recalc_rate(struct clk_hw *hw,
266 					      unsigned long parent_rate)
267 {
268 	struct si5351_driver_data *drvdata =
269 		container_of(hw, struct si5351_driver_data, clkin);
270 	unsigned long rate;
271 	unsigned char idiv;
272 
273 	rate = parent_rate;
274 	if (parent_rate > 160000000) {
275 		idiv = SI5351_CLKIN_DIV_8;
276 		rate /= 8;
277 	} else if (parent_rate > 80000000) {
278 		idiv = SI5351_CLKIN_DIV_4;
279 		rate /= 4;
280 	} else if (parent_rate > 40000000) {
281 		idiv = SI5351_CLKIN_DIV_2;
282 		rate /= 2;
283 	} else {
284 		idiv = SI5351_CLKIN_DIV_1;
285 	}
286 
287 	si5351_set_bits(drvdata, SI5351_PLL_INPUT_SOURCE,
288 			SI5351_CLKIN_DIV_MASK, idiv);
289 
290 	dev_dbg(&drvdata->client->dev, "%s - clkin div = %d, rate = %lu\n",
291 		__func__, (1 << (idiv >> 6)), rate);
292 
293 	return rate;
294 }
295 
296 static const struct clk_ops si5351_clkin_ops = {
297 	.prepare = si5351_clkin_prepare,
298 	.unprepare = si5351_clkin_unprepare,
299 	.recalc_rate = si5351_clkin_recalc_rate,
300 };
301 
302 /*
303  * Si5351 vxco clock input (Si5351B only)
304  */
305 
306 static int si5351_vxco_prepare(struct clk_hw *hw)
307 {
308 	struct si5351_hw_data *hwdata =
309 		container_of(hw, struct si5351_hw_data, hw);
310 
311 	dev_warn(&hwdata->drvdata->client->dev, "VXCO currently unsupported\n");
312 
313 	return 0;
314 }
315 
316 static void si5351_vxco_unprepare(struct clk_hw *hw)
317 {
318 }
319 
320 static unsigned long si5351_vxco_recalc_rate(struct clk_hw *hw,
321 					     unsigned long parent_rate)
322 {
323 	return 0;
324 }
325 
326 static int si5351_vxco_set_rate(struct clk_hw *hw, unsigned long rate,
327 				unsigned long parent)
328 {
329 	return 0;
330 }
331 
332 static const struct clk_ops si5351_vxco_ops = {
333 	.prepare = si5351_vxco_prepare,
334 	.unprepare = si5351_vxco_unprepare,
335 	.recalc_rate = si5351_vxco_recalc_rate,
336 	.set_rate = si5351_vxco_set_rate,
337 };
338 
339 /*
340  * Si5351 pll a/b
341  *
342  * Feedback Multisynth Divider Equations [2]
343  *
344  * fVCO = fIN * (a + b/c)
345  *
346  * with 15 + 0/1048575 <= (a + b/c) <= 90 + 0/1048575 and
347  * fIN = fXTAL or fIN = fCLKIN/CLKIN_DIV
348  *
349  * Feedback Multisynth Register Equations
350  *
351  * (1) MSNx_P1[17:0] = 128 * a + floor(128 * b/c) - 512
352  * (2) MSNx_P2[19:0] = 128 * b - c * floor(128 * b/c) = (128*b) mod c
353  * (3) MSNx_P3[19:0] = c
354  *
355  * Transposing (2) yields: (4) floor(128 * b/c) = (128 * b / MSNx_P2)/c
356  *
357  * Using (4) on (1) yields:
358  * MSNx_P1 = 128 * a + (128 * b/MSNx_P2)/c - 512
359  * MSNx_P1 + 512 + MSNx_P2/c = 128 * a + 128 * b/c
360  *
361  * a + b/c = (MSNx_P1 + MSNx_P2/MSNx_P3 + 512)/128
362  *         = (MSNx_P1*MSNx_P3 + MSNx_P2 + 512*MSNx_P3)/(128*MSNx_P3)
363  *
364  */
365 static int _si5351_pll_reparent(struct si5351_driver_data *drvdata,
366 				int num, enum si5351_pll_src parent)
367 {
368 	u8 mask = (num == 0) ? SI5351_PLLA_SOURCE : SI5351_PLLB_SOURCE;
369 
370 	if (parent == SI5351_PLL_SRC_DEFAULT)
371 		return 0;
372 
373 	if (num > 2)
374 		return -EINVAL;
375 
376 	if (drvdata->variant != SI5351_VARIANT_C &&
377 	    parent != SI5351_PLL_SRC_XTAL)
378 		return -EINVAL;
379 
380 	si5351_set_bits(drvdata, SI5351_PLL_INPUT_SOURCE, mask,
381 			(parent == SI5351_PLL_SRC_XTAL) ? 0 : mask);
382 	return 0;
383 }
384 
385 static unsigned char si5351_pll_get_parent(struct clk_hw *hw)
386 {
387 	struct si5351_hw_data *hwdata =
388 		container_of(hw, struct si5351_hw_data, hw);
389 	u8 mask = (hwdata->num == 0) ? SI5351_PLLA_SOURCE : SI5351_PLLB_SOURCE;
390 	u8 val;
391 
392 	val = si5351_reg_read(hwdata->drvdata, SI5351_PLL_INPUT_SOURCE);
393 
394 	return (val & mask) ? 1 : 0;
395 }
396 
397 static int si5351_pll_set_parent(struct clk_hw *hw, u8 index)
398 {
399 	struct si5351_hw_data *hwdata =
400 		container_of(hw, struct si5351_hw_data, hw);
401 
402 	if (hwdata->drvdata->variant != SI5351_VARIANT_C &&
403 	    index > 0)
404 		return -EPERM;
405 
406 	if (index > 1)
407 		return -EINVAL;
408 
409 	return _si5351_pll_reparent(hwdata->drvdata, hwdata->num,
410 			     (index == 0) ? SI5351_PLL_SRC_XTAL :
411 			     SI5351_PLL_SRC_CLKIN);
412 }
413 
414 static unsigned long si5351_pll_recalc_rate(struct clk_hw *hw,
415 					    unsigned long parent_rate)
416 {
417 	struct si5351_hw_data *hwdata =
418 		container_of(hw, struct si5351_hw_data, hw);
419 	u8 reg = (hwdata->num == 0) ? SI5351_PLLA_PARAMETERS :
420 		SI5351_PLLB_PARAMETERS;
421 	unsigned long long rate;
422 
423 	if (!hwdata->params.valid)
424 		si5351_read_parameters(hwdata->drvdata, reg, &hwdata->params);
425 
426 	if (hwdata->params.p3 == 0)
427 		return parent_rate;
428 
429 	/* fVCO = fIN * (P1*P3 + 512*P3 + P2)/(128*P3) */
430 	rate  = hwdata->params.p1 * hwdata->params.p3;
431 	rate += 512 * hwdata->params.p3;
432 	rate += hwdata->params.p2;
433 	rate *= parent_rate;
434 	do_div(rate, 128 * hwdata->params.p3);
435 
436 	dev_dbg(&hwdata->drvdata->client->dev,
437 		"%s - %s: p1 = %lu, p2 = %lu, p3 = %lu, parent_rate = %lu, rate = %lu\n",
438 		__func__, clk_hw_get_name(hw),
439 		hwdata->params.p1, hwdata->params.p2, hwdata->params.p3,
440 		parent_rate, (unsigned long)rate);
441 
442 	return (unsigned long)rate;
443 }
444 
445 static long si5351_pll_round_rate(struct clk_hw *hw, unsigned long rate,
446 				  unsigned long *parent_rate)
447 {
448 	struct si5351_hw_data *hwdata =
449 		container_of(hw, struct si5351_hw_data, hw);
450 	unsigned long rfrac, denom, a, b, c;
451 	unsigned long long lltmp;
452 
453 	if (rate < SI5351_PLL_VCO_MIN)
454 		rate = SI5351_PLL_VCO_MIN;
455 	if (rate > SI5351_PLL_VCO_MAX)
456 		rate = SI5351_PLL_VCO_MAX;
457 
458 	/* determine integer part of feedback equation */
459 	a = rate / *parent_rate;
460 
461 	if (a < SI5351_PLL_A_MIN)
462 		rate = *parent_rate * SI5351_PLL_A_MIN;
463 	if (a > SI5351_PLL_A_MAX)
464 		rate = *parent_rate * SI5351_PLL_A_MAX;
465 
466 	/* find best approximation for b/c = fVCO mod fIN */
467 	denom = 1000 * 1000;
468 	lltmp = rate % (*parent_rate);
469 	lltmp *= denom;
470 	do_div(lltmp, *parent_rate);
471 	rfrac = (unsigned long)lltmp;
472 
473 	b = 0;
474 	c = 1;
475 	if (rfrac)
476 		rational_best_approximation(rfrac, denom,
477 				    SI5351_PLL_B_MAX, SI5351_PLL_C_MAX, &b, &c);
478 
479 	/* calculate parameters */
480 	hwdata->params.p3  = c;
481 	hwdata->params.p2  = (128 * b) % c;
482 	hwdata->params.p1  = 128 * a;
483 	hwdata->params.p1 += (128 * b / c);
484 	hwdata->params.p1 -= 512;
485 
486 	/* recalculate rate by fIN * (a + b/c) */
487 	lltmp  = *parent_rate;
488 	lltmp *= b;
489 	do_div(lltmp, c);
490 
491 	rate  = (unsigned long)lltmp;
492 	rate += *parent_rate * a;
493 
494 	dev_dbg(&hwdata->drvdata->client->dev,
495 		"%s - %s: a = %lu, b = %lu, c = %lu, parent_rate = %lu, rate = %lu\n",
496 		__func__, clk_hw_get_name(hw), a, b, c,
497 		*parent_rate, rate);
498 
499 	return rate;
500 }
501 
502 static int si5351_pll_set_rate(struct clk_hw *hw, unsigned long rate,
503 			       unsigned long parent_rate)
504 {
505 	struct si5351_hw_data *hwdata =
506 		container_of(hw, struct si5351_hw_data, hw);
507 	u8 reg = (hwdata->num == 0) ? SI5351_PLLA_PARAMETERS :
508 		SI5351_PLLB_PARAMETERS;
509 
510 	/* write multisynth parameters */
511 	si5351_write_parameters(hwdata->drvdata, reg, &hwdata->params);
512 
513 	/* plla/pllb ctrl is in clk6/clk7 ctrl registers */
514 	si5351_set_bits(hwdata->drvdata, SI5351_CLK6_CTRL + hwdata->num,
515 		SI5351_CLK_INTEGER_MODE,
516 		(hwdata->params.p2 == 0) ? SI5351_CLK_INTEGER_MODE : 0);
517 
518 	/* Do a pll soft reset on the affected pll */
519 	si5351_reg_write(hwdata->drvdata, SI5351_PLL_RESET,
520 			 hwdata->num == 0 ? SI5351_PLL_RESET_A :
521 					    SI5351_PLL_RESET_B);
522 
523 	dev_dbg(&hwdata->drvdata->client->dev,
524 		"%s - %s: p1 = %lu, p2 = %lu, p3 = %lu, parent_rate = %lu, rate = %lu\n",
525 		__func__, clk_hw_get_name(hw),
526 		hwdata->params.p1, hwdata->params.p2, hwdata->params.p3,
527 		parent_rate, rate);
528 
529 	return 0;
530 }
531 
532 static const struct clk_ops si5351_pll_ops = {
533 	.set_parent = si5351_pll_set_parent,
534 	.get_parent = si5351_pll_get_parent,
535 	.recalc_rate = si5351_pll_recalc_rate,
536 	.round_rate = si5351_pll_round_rate,
537 	.set_rate = si5351_pll_set_rate,
538 };
539 
540 /*
541  * Si5351 multisync divider
542  *
543  * for fOUT <= 150 MHz:
544  *
545  * fOUT = (fIN * (a + b/c)) / CLKOUTDIV
546  *
547  * with 6 + 0/1048575 <= (a + b/c) <= 1800 + 0/1048575 and
548  * fIN = fVCO0, fVCO1
549  *
550  * Output Clock Multisynth Register Equations
551  *
552  * MSx_P1[17:0] = 128 * a + floor(128 * b/c) - 512
553  * MSx_P2[19:0] = 128 * b - c * floor(128 * b/c) = (128*b) mod c
554  * MSx_P3[19:0] = c
555  *
556  * MS[6,7] are integer (P1) divide only, P1 = divide value,
557  * P2 and P3 are not applicable
558  *
559  * for 150MHz < fOUT <= 160MHz:
560  *
561  * MSx_P1 = 0, MSx_P2 = 0, MSx_P3 = 1, MSx_INT = 1, MSx_DIVBY4 = 11b
562  */
563 static int _si5351_msynth_reparent(struct si5351_driver_data *drvdata,
564 				   int num, enum si5351_multisynth_src parent)
565 {
566 	if (parent == SI5351_MULTISYNTH_SRC_DEFAULT)
567 		return 0;
568 
569 	if (num > 8)
570 		return -EINVAL;
571 
572 	si5351_set_bits(drvdata, SI5351_CLK0_CTRL + num, SI5351_CLK_PLL_SELECT,
573 			(parent == SI5351_MULTISYNTH_SRC_VCO0) ? 0 :
574 			SI5351_CLK_PLL_SELECT);
575 	return 0;
576 }
577 
578 static unsigned char si5351_msynth_get_parent(struct clk_hw *hw)
579 {
580 	struct si5351_hw_data *hwdata =
581 		container_of(hw, struct si5351_hw_data, hw);
582 	u8 val;
583 
584 	val = si5351_reg_read(hwdata->drvdata, SI5351_CLK0_CTRL + hwdata->num);
585 
586 	return (val & SI5351_CLK_PLL_SELECT) ? 1 : 0;
587 }
588 
589 static int si5351_msynth_set_parent(struct clk_hw *hw, u8 index)
590 {
591 	struct si5351_hw_data *hwdata =
592 		container_of(hw, struct si5351_hw_data, hw);
593 
594 	return _si5351_msynth_reparent(hwdata->drvdata, hwdata->num,
595 			       (index == 0) ? SI5351_MULTISYNTH_SRC_VCO0 :
596 			       SI5351_MULTISYNTH_SRC_VCO1);
597 }
598 
599 static unsigned long si5351_msynth_recalc_rate(struct clk_hw *hw,
600 					       unsigned long parent_rate)
601 {
602 	struct si5351_hw_data *hwdata =
603 		container_of(hw, struct si5351_hw_data, hw);
604 	u8 reg = si5351_msynth_params_address(hwdata->num);
605 	unsigned long long rate;
606 	unsigned long m;
607 
608 	if (!hwdata->params.valid)
609 		si5351_read_parameters(hwdata->drvdata, reg, &hwdata->params);
610 
611 	/*
612 	 * multisync0-5: fOUT = (128 * P3 * fIN) / (P1*P3 + P2 + 512*P3)
613 	 * multisync6-7: fOUT = fIN / P1
614 	 */
615 	rate = parent_rate;
616 	if (hwdata->num > 5) {
617 		m = hwdata->params.p1;
618 	} else if (hwdata->params.p3 == 0) {
619 		return parent_rate;
620 	} else if ((si5351_reg_read(hwdata->drvdata, reg + 2) &
621 		    SI5351_OUTPUT_CLK_DIVBY4) == SI5351_OUTPUT_CLK_DIVBY4) {
622 		m = 4;
623 	} else {
624 		rate *= 128 * hwdata->params.p3;
625 		m = hwdata->params.p1 * hwdata->params.p3;
626 		m += hwdata->params.p2;
627 		m += 512 * hwdata->params.p3;
628 	}
629 
630 	if (m == 0)
631 		return 0;
632 	do_div(rate, m);
633 
634 	dev_dbg(&hwdata->drvdata->client->dev,
635 		"%s - %s: p1 = %lu, p2 = %lu, p3 = %lu, m = %lu, parent_rate = %lu, rate = %lu\n",
636 		__func__, clk_hw_get_name(hw),
637 		hwdata->params.p1, hwdata->params.p2, hwdata->params.p3,
638 		m, parent_rate, (unsigned long)rate);
639 
640 	return (unsigned long)rate;
641 }
642 
643 static long si5351_msynth_round_rate(struct clk_hw *hw, unsigned long rate,
644 				     unsigned long *parent_rate)
645 {
646 	struct si5351_hw_data *hwdata =
647 		container_of(hw, struct si5351_hw_data, hw);
648 	unsigned long long lltmp;
649 	unsigned long a, b, c;
650 	int divby4;
651 
652 	/* multisync6-7 can only handle freqencies < 150MHz */
653 	if (hwdata->num >= 6 && rate > SI5351_MULTISYNTH67_MAX_FREQ)
654 		rate = SI5351_MULTISYNTH67_MAX_FREQ;
655 
656 	/* multisync frequency is 1MHz .. 160MHz */
657 	if (rate > SI5351_MULTISYNTH_MAX_FREQ)
658 		rate = SI5351_MULTISYNTH_MAX_FREQ;
659 	if (rate < SI5351_MULTISYNTH_MIN_FREQ)
660 		rate = SI5351_MULTISYNTH_MIN_FREQ;
661 
662 	divby4 = 0;
663 	if (rate > SI5351_MULTISYNTH_DIVBY4_FREQ)
664 		divby4 = 1;
665 
666 	/* multisync can set pll */
667 	if (clk_hw_get_flags(hw) & CLK_SET_RATE_PARENT) {
668 		/*
669 		 * find largest integer divider for max
670 		 * vco frequency and given target rate
671 		 */
672 		if (divby4 == 0) {
673 			lltmp = SI5351_PLL_VCO_MAX;
674 			do_div(lltmp, rate);
675 			a = (unsigned long)lltmp;
676 		} else
677 			a = 4;
678 
679 		b = 0;
680 		c = 1;
681 
682 		*parent_rate = a * rate;
683 	} else if (hwdata->num >= 6) {
684 		/* determine the closest integer divider */
685 		a = DIV_ROUND_CLOSEST(*parent_rate, rate);
686 		if (a < SI5351_MULTISYNTH_A_MIN)
687 			a = SI5351_MULTISYNTH_A_MIN;
688 		if (a > SI5351_MULTISYNTH67_A_MAX)
689 			a = SI5351_MULTISYNTH67_A_MAX;
690 
691 		b = 0;
692 		c = 1;
693 	} else {
694 		unsigned long rfrac, denom;
695 
696 		/* disable divby4 */
697 		if (divby4) {
698 			rate = SI5351_MULTISYNTH_DIVBY4_FREQ;
699 			divby4 = 0;
700 		}
701 
702 		/* determine integer part of divider equation */
703 		a = *parent_rate / rate;
704 		if (a < SI5351_MULTISYNTH_A_MIN)
705 			a = SI5351_MULTISYNTH_A_MIN;
706 		if (a > SI5351_MULTISYNTH_A_MAX)
707 			a = SI5351_MULTISYNTH_A_MAX;
708 
709 		/* find best approximation for b/c = fVCO mod fOUT */
710 		denom = 1000 * 1000;
711 		lltmp = (*parent_rate) % rate;
712 		lltmp *= denom;
713 		do_div(lltmp, rate);
714 		rfrac = (unsigned long)lltmp;
715 
716 		b = 0;
717 		c = 1;
718 		if (rfrac)
719 			rational_best_approximation(rfrac, denom,
720 			    SI5351_MULTISYNTH_B_MAX, SI5351_MULTISYNTH_C_MAX,
721 			    &b, &c);
722 	}
723 
724 	/* recalculate rate by fOUT = fIN / (a + b/c) */
725 	lltmp  = *parent_rate;
726 	lltmp *= c;
727 	do_div(lltmp, a * c + b);
728 	rate  = (unsigned long)lltmp;
729 
730 	/* calculate parameters */
731 	if (divby4) {
732 		hwdata->params.p3 = 1;
733 		hwdata->params.p2 = 0;
734 		hwdata->params.p1 = 0;
735 	} else if (hwdata->num >= 6) {
736 		hwdata->params.p3 = 0;
737 		hwdata->params.p2 = 0;
738 		hwdata->params.p1 = a;
739 	} else {
740 		hwdata->params.p3  = c;
741 		hwdata->params.p2  = (128 * b) % c;
742 		hwdata->params.p1  = 128 * a;
743 		hwdata->params.p1 += (128 * b / c);
744 		hwdata->params.p1 -= 512;
745 	}
746 
747 	dev_dbg(&hwdata->drvdata->client->dev,
748 		"%s - %s: a = %lu, b = %lu, c = %lu, divby4 = %d, parent_rate = %lu, rate = %lu\n",
749 		__func__, clk_hw_get_name(hw), a, b, c, divby4,
750 		*parent_rate, rate);
751 
752 	return rate;
753 }
754 
755 static int si5351_msynth_set_rate(struct clk_hw *hw, unsigned long rate,
756 				  unsigned long parent_rate)
757 {
758 	struct si5351_hw_data *hwdata =
759 		container_of(hw, struct si5351_hw_data, hw);
760 	u8 reg = si5351_msynth_params_address(hwdata->num);
761 	int divby4 = 0;
762 
763 	/* write multisynth parameters */
764 	si5351_write_parameters(hwdata->drvdata, reg, &hwdata->params);
765 
766 	if (rate > SI5351_MULTISYNTH_DIVBY4_FREQ)
767 		divby4 = 1;
768 
769 	/* enable/disable integer mode and divby4 on multisynth0-5 */
770 	if (hwdata->num < 6) {
771 		si5351_set_bits(hwdata->drvdata, reg + 2,
772 				SI5351_OUTPUT_CLK_DIVBY4,
773 				(divby4) ? SI5351_OUTPUT_CLK_DIVBY4 : 0);
774 		si5351_set_bits(hwdata->drvdata, SI5351_CLK0_CTRL + hwdata->num,
775 			SI5351_CLK_INTEGER_MODE,
776 			(hwdata->params.p2 == 0) ? SI5351_CLK_INTEGER_MODE : 0);
777 	}
778 
779 	dev_dbg(&hwdata->drvdata->client->dev,
780 		"%s - %s: p1 = %lu, p2 = %lu, p3 = %lu, divby4 = %d, parent_rate = %lu, rate = %lu\n",
781 		__func__, clk_hw_get_name(hw),
782 		hwdata->params.p1, hwdata->params.p2, hwdata->params.p3,
783 		divby4, parent_rate, rate);
784 
785 	return 0;
786 }
787 
788 static const struct clk_ops si5351_msynth_ops = {
789 	.set_parent = si5351_msynth_set_parent,
790 	.get_parent = si5351_msynth_get_parent,
791 	.recalc_rate = si5351_msynth_recalc_rate,
792 	.round_rate = si5351_msynth_round_rate,
793 	.set_rate = si5351_msynth_set_rate,
794 };
795 
796 /*
797  * Si5351 clkout divider
798  */
799 static int _si5351_clkout_reparent(struct si5351_driver_data *drvdata,
800 				   int num, enum si5351_clkout_src parent)
801 {
802 	u8 val;
803 
804 	if (num > 8)
805 		return -EINVAL;
806 
807 	switch (parent) {
808 	case SI5351_CLKOUT_SRC_MSYNTH_N:
809 		val = SI5351_CLK_INPUT_MULTISYNTH_N;
810 		break;
811 	case SI5351_CLKOUT_SRC_MSYNTH_0_4:
812 		/* clk0/clk4 can only connect to its own multisync */
813 		if (num == 0 || num == 4)
814 			val = SI5351_CLK_INPUT_MULTISYNTH_N;
815 		else
816 			val = SI5351_CLK_INPUT_MULTISYNTH_0_4;
817 		break;
818 	case SI5351_CLKOUT_SRC_XTAL:
819 		val = SI5351_CLK_INPUT_XTAL;
820 		break;
821 	case SI5351_CLKOUT_SRC_CLKIN:
822 		if (drvdata->variant != SI5351_VARIANT_C)
823 			return -EINVAL;
824 
825 		val = SI5351_CLK_INPUT_CLKIN;
826 		break;
827 	default:
828 		return 0;
829 	}
830 
831 	si5351_set_bits(drvdata, SI5351_CLK0_CTRL + num,
832 			SI5351_CLK_INPUT_MASK, val);
833 	return 0;
834 }
835 
836 static int _si5351_clkout_set_drive_strength(
837 	struct si5351_driver_data *drvdata, int num,
838 	enum si5351_drive_strength drive)
839 {
840 	u8 mask;
841 
842 	if (num > 8)
843 		return -EINVAL;
844 
845 	switch (drive) {
846 	case SI5351_DRIVE_2MA:
847 		mask = SI5351_CLK_DRIVE_STRENGTH_2MA;
848 		break;
849 	case SI5351_DRIVE_4MA:
850 		mask = SI5351_CLK_DRIVE_STRENGTH_4MA;
851 		break;
852 	case SI5351_DRIVE_6MA:
853 		mask = SI5351_CLK_DRIVE_STRENGTH_6MA;
854 		break;
855 	case SI5351_DRIVE_8MA:
856 		mask = SI5351_CLK_DRIVE_STRENGTH_8MA;
857 		break;
858 	default:
859 		return 0;
860 	}
861 
862 	si5351_set_bits(drvdata, SI5351_CLK0_CTRL + num,
863 			SI5351_CLK_DRIVE_STRENGTH_MASK, mask);
864 	return 0;
865 }
866 
867 static int _si5351_clkout_set_disable_state(
868 	struct si5351_driver_data *drvdata, int num,
869 	enum si5351_disable_state state)
870 {
871 	u8 reg = (num < 4) ? SI5351_CLK3_0_DISABLE_STATE :
872 		SI5351_CLK7_4_DISABLE_STATE;
873 	u8 shift = (num < 4) ? (2 * num) : (2 * (num-4));
874 	u8 mask = SI5351_CLK_DISABLE_STATE_MASK << shift;
875 	u8 val;
876 
877 	if (num > 8)
878 		return -EINVAL;
879 
880 	switch (state) {
881 	case SI5351_DISABLE_LOW:
882 		val = SI5351_CLK_DISABLE_STATE_LOW;
883 		break;
884 	case SI5351_DISABLE_HIGH:
885 		val = SI5351_CLK_DISABLE_STATE_HIGH;
886 		break;
887 	case SI5351_DISABLE_FLOATING:
888 		val = SI5351_CLK_DISABLE_STATE_FLOAT;
889 		break;
890 	case SI5351_DISABLE_NEVER:
891 		val = SI5351_CLK_DISABLE_STATE_NEVER;
892 		break;
893 	default:
894 		return 0;
895 	}
896 
897 	si5351_set_bits(drvdata, reg, mask, val << shift);
898 
899 	return 0;
900 }
901 
902 static void _si5351_clkout_reset_pll(struct si5351_driver_data *drvdata, int num)
903 {
904 	u8 val = si5351_reg_read(drvdata, SI5351_CLK0_CTRL + num);
905 	u8 mask = val & SI5351_CLK_PLL_SELECT ? SI5351_PLL_RESET_B :
906 						       SI5351_PLL_RESET_A;
907 	unsigned int v;
908 	int err;
909 
910 	switch (val & SI5351_CLK_INPUT_MASK) {
911 	case SI5351_CLK_INPUT_XTAL:
912 	case SI5351_CLK_INPUT_CLKIN:
913 		return;  /* pll not used, no need to reset */
914 	}
915 
916 	si5351_reg_write(drvdata, SI5351_PLL_RESET, mask);
917 
918 	err = regmap_read_poll_timeout(drvdata->regmap, SI5351_PLL_RESET, v,
919 				 !(v & mask), 0, 20000);
920 	if (err < 0)
921 		dev_err(&drvdata->client->dev, "Reset bit didn't clear\n");
922 
923 	dev_dbg(&drvdata->client->dev, "%s - %s: pll = %d\n",
924 		__func__, clk_hw_get_name(&drvdata->clkout[num].hw),
925 		(val & SI5351_CLK_PLL_SELECT) ? 1 : 0);
926 }
927 
928 static int si5351_clkout_prepare(struct clk_hw *hw)
929 {
930 	struct si5351_hw_data *hwdata =
931 		container_of(hw, struct si5351_hw_data, hw);
932 	struct si5351_platform_data *pdata =
933 		hwdata->drvdata->client->dev.platform_data;
934 
935 	si5351_set_bits(hwdata->drvdata, SI5351_CLK0_CTRL + hwdata->num,
936 			SI5351_CLK_POWERDOWN, 0);
937 
938 	/*
939 	 * Do a pll soft reset on the parent pll -- needed to get a
940 	 * deterministic phase relationship between the output clocks.
941 	 */
942 	if (pdata->clkout[hwdata->num].pll_reset)
943 		_si5351_clkout_reset_pll(hwdata->drvdata, hwdata->num);
944 
945 	si5351_set_bits(hwdata->drvdata, SI5351_OUTPUT_ENABLE_CTRL,
946 			(1 << hwdata->num), 0);
947 	return 0;
948 }
949 
950 static void si5351_clkout_unprepare(struct clk_hw *hw)
951 {
952 	struct si5351_hw_data *hwdata =
953 		container_of(hw, struct si5351_hw_data, hw);
954 
955 	si5351_set_bits(hwdata->drvdata, SI5351_CLK0_CTRL + hwdata->num,
956 			SI5351_CLK_POWERDOWN, SI5351_CLK_POWERDOWN);
957 	si5351_set_bits(hwdata->drvdata, SI5351_OUTPUT_ENABLE_CTRL,
958 			(1 << hwdata->num), (1 << hwdata->num));
959 }
960 
961 static u8 si5351_clkout_get_parent(struct clk_hw *hw)
962 {
963 	struct si5351_hw_data *hwdata =
964 		container_of(hw, struct si5351_hw_data, hw);
965 	int index = 0;
966 	unsigned char val;
967 
968 	val = si5351_reg_read(hwdata->drvdata, SI5351_CLK0_CTRL + hwdata->num);
969 	switch (val & SI5351_CLK_INPUT_MASK) {
970 	case SI5351_CLK_INPUT_MULTISYNTH_N:
971 		index = 0;
972 		break;
973 	case SI5351_CLK_INPUT_MULTISYNTH_0_4:
974 		index = 1;
975 		break;
976 	case SI5351_CLK_INPUT_XTAL:
977 		index = 2;
978 		break;
979 	case SI5351_CLK_INPUT_CLKIN:
980 		index = 3;
981 		break;
982 	}
983 
984 	return index;
985 }
986 
987 static int si5351_clkout_set_parent(struct clk_hw *hw, u8 index)
988 {
989 	struct si5351_hw_data *hwdata =
990 		container_of(hw, struct si5351_hw_data, hw);
991 	enum si5351_clkout_src parent = SI5351_CLKOUT_SRC_DEFAULT;
992 
993 	switch (index) {
994 	case 0:
995 		parent = SI5351_CLKOUT_SRC_MSYNTH_N;
996 		break;
997 	case 1:
998 		parent = SI5351_CLKOUT_SRC_MSYNTH_0_4;
999 		break;
1000 	case 2:
1001 		parent = SI5351_CLKOUT_SRC_XTAL;
1002 		break;
1003 	case 3:
1004 		parent = SI5351_CLKOUT_SRC_CLKIN;
1005 		break;
1006 	}
1007 
1008 	return _si5351_clkout_reparent(hwdata->drvdata, hwdata->num, parent);
1009 }
1010 
1011 static unsigned long si5351_clkout_recalc_rate(struct clk_hw *hw,
1012 					       unsigned long parent_rate)
1013 {
1014 	struct si5351_hw_data *hwdata =
1015 		container_of(hw, struct si5351_hw_data, hw);
1016 	unsigned char reg;
1017 	unsigned char rdiv;
1018 
1019 	if (hwdata->num <= 5)
1020 		reg = si5351_msynth_params_address(hwdata->num) + 2;
1021 	else
1022 		reg = SI5351_CLK6_7_OUTPUT_DIVIDER;
1023 
1024 	rdiv = si5351_reg_read(hwdata->drvdata, reg);
1025 	if (hwdata->num == 6) {
1026 		rdiv &= SI5351_OUTPUT_CLK6_DIV_MASK;
1027 	} else {
1028 		rdiv &= SI5351_OUTPUT_CLK_DIV_MASK;
1029 		rdiv >>= SI5351_OUTPUT_CLK_DIV_SHIFT;
1030 	}
1031 
1032 	return parent_rate >> rdiv;
1033 }
1034 
1035 static long si5351_clkout_round_rate(struct clk_hw *hw, unsigned long rate,
1036 				     unsigned long *parent_rate)
1037 {
1038 	struct si5351_hw_data *hwdata =
1039 		container_of(hw, struct si5351_hw_data, hw);
1040 	unsigned char rdiv;
1041 
1042 	/* clkout6/7 can only handle output freqencies < 150MHz */
1043 	if (hwdata->num >= 6 && rate > SI5351_CLKOUT67_MAX_FREQ)
1044 		rate = SI5351_CLKOUT67_MAX_FREQ;
1045 
1046 	/* clkout freqency is 8kHz - 160MHz */
1047 	if (rate > SI5351_CLKOUT_MAX_FREQ)
1048 		rate = SI5351_CLKOUT_MAX_FREQ;
1049 	if (rate < SI5351_CLKOUT_MIN_FREQ)
1050 		rate = SI5351_CLKOUT_MIN_FREQ;
1051 
1052 	/* request frequency if multisync master */
1053 	if (clk_hw_get_flags(hw) & CLK_SET_RATE_PARENT) {
1054 		/* use r divider for frequencies below 1MHz */
1055 		rdiv = SI5351_OUTPUT_CLK_DIV_1;
1056 		while (rate < SI5351_MULTISYNTH_MIN_FREQ &&
1057 		       rdiv < SI5351_OUTPUT_CLK_DIV_128) {
1058 			rdiv += 1;
1059 			rate *= 2;
1060 		}
1061 		*parent_rate = rate;
1062 	} else {
1063 		unsigned long new_rate, new_err, err;
1064 
1065 		/* round to closed rdiv */
1066 		rdiv = SI5351_OUTPUT_CLK_DIV_1;
1067 		new_rate = *parent_rate;
1068 		err = abs(new_rate - rate);
1069 		do {
1070 			new_rate >>= 1;
1071 			new_err = abs(new_rate - rate);
1072 			if (new_err > err || rdiv == SI5351_OUTPUT_CLK_DIV_128)
1073 				break;
1074 			rdiv++;
1075 			err = new_err;
1076 		} while (1);
1077 	}
1078 	rate = *parent_rate >> rdiv;
1079 
1080 	dev_dbg(&hwdata->drvdata->client->dev,
1081 		"%s - %s: rdiv = %u, parent_rate = %lu, rate = %lu\n",
1082 		__func__, clk_hw_get_name(hw), (1 << rdiv),
1083 		*parent_rate, rate);
1084 
1085 	return rate;
1086 }
1087 
1088 static int si5351_clkout_set_rate(struct clk_hw *hw, unsigned long rate,
1089 				  unsigned long parent_rate)
1090 {
1091 	struct si5351_hw_data *hwdata =
1092 		container_of(hw, struct si5351_hw_data, hw);
1093 	unsigned long new_rate, new_err, err;
1094 	unsigned char rdiv;
1095 
1096 	/* round to closed rdiv */
1097 	rdiv = SI5351_OUTPUT_CLK_DIV_1;
1098 	new_rate = parent_rate;
1099 	err = abs(new_rate - rate);
1100 	do {
1101 		new_rate >>= 1;
1102 		new_err = abs(new_rate - rate);
1103 		if (new_err > err || rdiv == SI5351_OUTPUT_CLK_DIV_128)
1104 			break;
1105 		rdiv++;
1106 		err = new_err;
1107 	} while (1);
1108 
1109 	/* write output divider */
1110 	switch (hwdata->num) {
1111 	case 6:
1112 		si5351_set_bits(hwdata->drvdata, SI5351_CLK6_7_OUTPUT_DIVIDER,
1113 				SI5351_OUTPUT_CLK6_DIV_MASK, rdiv);
1114 		break;
1115 	case 7:
1116 		si5351_set_bits(hwdata->drvdata, SI5351_CLK6_7_OUTPUT_DIVIDER,
1117 				SI5351_OUTPUT_CLK_DIV_MASK,
1118 				rdiv << SI5351_OUTPUT_CLK_DIV_SHIFT);
1119 		break;
1120 	default:
1121 		si5351_set_bits(hwdata->drvdata,
1122 				si5351_msynth_params_address(hwdata->num) + 2,
1123 				SI5351_OUTPUT_CLK_DIV_MASK,
1124 				rdiv << SI5351_OUTPUT_CLK_DIV_SHIFT);
1125 	}
1126 
1127 	/* powerup clkout */
1128 	si5351_set_bits(hwdata->drvdata, SI5351_CLK0_CTRL + hwdata->num,
1129 			SI5351_CLK_POWERDOWN, 0);
1130 
1131 	dev_dbg(&hwdata->drvdata->client->dev,
1132 		"%s - %s: rdiv = %u, parent_rate = %lu, rate = %lu\n",
1133 		__func__, clk_hw_get_name(hw), (1 << rdiv),
1134 		parent_rate, rate);
1135 
1136 	return 0;
1137 }
1138 
1139 static const struct clk_ops si5351_clkout_ops = {
1140 	.prepare = si5351_clkout_prepare,
1141 	.unprepare = si5351_clkout_unprepare,
1142 	.set_parent = si5351_clkout_set_parent,
1143 	.get_parent = si5351_clkout_get_parent,
1144 	.recalc_rate = si5351_clkout_recalc_rate,
1145 	.round_rate = si5351_clkout_round_rate,
1146 	.set_rate = si5351_clkout_set_rate,
1147 };
1148 
1149 /*
1150  * Si5351 i2c probe and DT
1151  */
1152 #ifdef CONFIG_OF
1153 static const struct of_device_id si5351_dt_ids[] = {
1154 	{ .compatible = "silabs,si5351a", .data = (void *)SI5351_VARIANT_A, },
1155 	{ .compatible = "silabs,si5351a-msop",
1156 					 .data = (void *)SI5351_VARIANT_A3, },
1157 	{ .compatible = "silabs,si5351b", .data = (void *)SI5351_VARIANT_B, },
1158 	{ .compatible = "silabs,si5351c", .data = (void *)SI5351_VARIANT_C, },
1159 	{ }
1160 };
1161 MODULE_DEVICE_TABLE(of, si5351_dt_ids);
1162 
1163 static int si5351_dt_parse(struct i2c_client *client,
1164 			   enum si5351_variant variant)
1165 {
1166 	struct device_node *child, *np = client->dev.of_node;
1167 	struct si5351_platform_data *pdata;
1168 	struct property *prop;
1169 	const __be32 *p;
1170 	int num = 0;
1171 	u32 val;
1172 
1173 	if (np == NULL)
1174 		return 0;
1175 
1176 	pdata = devm_kzalloc(&client->dev, sizeof(*pdata), GFP_KERNEL);
1177 	if (!pdata)
1178 		return -ENOMEM;
1179 
1180 	/*
1181 	 * property silabs,pll-source : <num src>, [<..>]
1182 	 * allow to selectively set pll source
1183 	 */
1184 	of_property_for_each_u32(np, "silabs,pll-source", prop, p, num) {
1185 		if (num >= 2) {
1186 			dev_err(&client->dev,
1187 				"invalid pll %d on pll-source prop\n", num);
1188 			return -EINVAL;
1189 		}
1190 
1191 		p = of_prop_next_u32(prop, p, &val);
1192 		if (!p) {
1193 			dev_err(&client->dev,
1194 				"missing pll-source for pll %d\n", num);
1195 			return -EINVAL;
1196 		}
1197 
1198 		switch (val) {
1199 		case 0:
1200 			pdata->pll_src[num] = SI5351_PLL_SRC_XTAL;
1201 			break;
1202 		case 1:
1203 			if (variant != SI5351_VARIANT_C) {
1204 				dev_err(&client->dev,
1205 					"invalid parent %d for pll %d\n",
1206 					val, num);
1207 				return -EINVAL;
1208 			}
1209 			pdata->pll_src[num] = SI5351_PLL_SRC_CLKIN;
1210 			break;
1211 		default:
1212 			dev_err(&client->dev,
1213 				 "invalid parent %d for pll %d\n", val, num);
1214 			return -EINVAL;
1215 		}
1216 	}
1217 
1218 	/* per clkout properties */
1219 	for_each_child_of_node(np, child) {
1220 		if (of_property_read_u32(child, "reg", &num)) {
1221 			dev_err(&client->dev, "missing reg property of %pOFn\n",
1222 				child);
1223 			goto put_child;
1224 		}
1225 
1226 		if (num >= 8 ||
1227 		    (variant == SI5351_VARIANT_A3 && num >= 3)) {
1228 			dev_err(&client->dev, "invalid clkout %d\n", num);
1229 			goto put_child;
1230 		}
1231 
1232 		if (!of_property_read_u32(child, "silabs,multisynth-source",
1233 					  &val)) {
1234 			switch (val) {
1235 			case 0:
1236 				pdata->clkout[num].multisynth_src =
1237 					SI5351_MULTISYNTH_SRC_VCO0;
1238 				break;
1239 			case 1:
1240 				pdata->clkout[num].multisynth_src =
1241 					SI5351_MULTISYNTH_SRC_VCO1;
1242 				break;
1243 			default:
1244 				dev_err(&client->dev,
1245 					"invalid parent %d for multisynth %d\n",
1246 					val, num);
1247 				goto put_child;
1248 			}
1249 		}
1250 
1251 		if (!of_property_read_u32(child, "silabs,clock-source", &val)) {
1252 			switch (val) {
1253 			case 0:
1254 				pdata->clkout[num].clkout_src =
1255 					SI5351_CLKOUT_SRC_MSYNTH_N;
1256 				break;
1257 			case 1:
1258 				pdata->clkout[num].clkout_src =
1259 					SI5351_CLKOUT_SRC_MSYNTH_0_4;
1260 				break;
1261 			case 2:
1262 				pdata->clkout[num].clkout_src =
1263 					SI5351_CLKOUT_SRC_XTAL;
1264 				break;
1265 			case 3:
1266 				if (variant != SI5351_VARIANT_C) {
1267 					dev_err(&client->dev,
1268 						"invalid parent %d for clkout %d\n",
1269 						val, num);
1270 					goto put_child;
1271 				}
1272 				pdata->clkout[num].clkout_src =
1273 					SI5351_CLKOUT_SRC_CLKIN;
1274 				break;
1275 			default:
1276 				dev_err(&client->dev,
1277 					"invalid parent %d for clkout %d\n",
1278 					val, num);
1279 				goto put_child;
1280 			}
1281 		}
1282 
1283 		if (!of_property_read_u32(child, "silabs,drive-strength",
1284 					  &val)) {
1285 			switch (val) {
1286 			case SI5351_DRIVE_2MA:
1287 			case SI5351_DRIVE_4MA:
1288 			case SI5351_DRIVE_6MA:
1289 			case SI5351_DRIVE_8MA:
1290 				pdata->clkout[num].drive = val;
1291 				break;
1292 			default:
1293 				dev_err(&client->dev,
1294 					"invalid drive strength %d for clkout %d\n",
1295 					val, num);
1296 				goto put_child;
1297 			}
1298 		}
1299 
1300 		if (!of_property_read_u32(child, "silabs,disable-state",
1301 					  &val)) {
1302 			switch (val) {
1303 			case 0:
1304 				pdata->clkout[num].disable_state =
1305 					SI5351_DISABLE_LOW;
1306 				break;
1307 			case 1:
1308 				pdata->clkout[num].disable_state =
1309 					SI5351_DISABLE_HIGH;
1310 				break;
1311 			case 2:
1312 				pdata->clkout[num].disable_state =
1313 					SI5351_DISABLE_FLOATING;
1314 				break;
1315 			case 3:
1316 				pdata->clkout[num].disable_state =
1317 					SI5351_DISABLE_NEVER;
1318 				break;
1319 			default:
1320 				dev_err(&client->dev,
1321 					"invalid disable state %d for clkout %d\n",
1322 					val, num);
1323 				goto put_child;
1324 			}
1325 		}
1326 
1327 		if (!of_property_read_u32(child, "clock-frequency", &val))
1328 			pdata->clkout[num].rate = val;
1329 
1330 		pdata->clkout[num].pll_master =
1331 			of_property_read_bool(child, "silabs,pll-master");
1332 
1333 		pdata->clkout[num].pll_reset =
1334 			of_property_read_bool(child, "silabs,pll-reset");
1335 	}
1336 	client->dev.platform_data = pdata;
1337 
1338 	return 0;
1339 put_child:
1340 	of_node_put(child);
1341 	return -EINVAL;
1342 }
1343 
1344 static struct clk_hw *
1345 si53351_of_clk_get(struct of_phandle_args *clkspec, void *data)
1346 {
1347 	struct si5351_driver_data *drvdata = data;
1348 	unsigned int idx = clkspec->args[0];
1349 
1350 	if (idx >= drvdata->num_clkout) {
1351 		pr_err("%s: invalid index %u\n", __func__, idx);
1352 		return ERR_PTR(-EINVAL);
1353 	}
1354 
1355 	return &drvdata->clkout[idx].hw;
1356 }
1357 #else
1358 static int si5351_dt_parse(struct i2c_client *client, enum si5351_variant variant)
1359 {
1360 	return 0;
1361 }
1362 
1363 static struct clk_hw *
1364 si53351_of_clk_get(struct of_phandle_args *clkspec, void *data)
1365 {
1366 	return NULL;
1367 }
1368 #endif /* CONFIG_OF */
1369 
1370 static const struct i2c_device_id si5351_i2c_ids[] = {
1371 	{ "si5351a", SI5351_VARIANT_A },
1372 	{ "si5351a-msop", SI5351_VARIANT_A3 },
1373 	{ "si5351b", SI5351_VARIANT_B },
1374 	{ "si5351c", SI5351_VARIANT_C },
1375 	{ }
1376 };
1377 MODULE_DEVICE_TABLE(i2c, si5351_i2c_ids);
1378 
1379 static int si5351_i2c_probe(struct i2c_client *client)
1380 {
1381 	const struct i2c_device_id *id = i2c_match_id(si5351_i2c_ids, client);
1382 	enum si5351_variant variant = (enum si5351_variant)id->driver_data;
1383 	struct si5351_platform_data *pdata;
1384 	struct si5351_driver_data *drvdata;
1385 	struct clk_init_data init;
1386 	const char *parent_names[4];
1387 	u8 num_parents, num_clocks;
1388 	int ret, n;
1389 
1390 	ret = si5351_dt_parse(client, variant);
1391 	if (ret)
1392 		return ret;
1393 
1394 	pdata = client->dev.platform_data;
1395 	if (!pdata)
1396 		return -EINVAL;
1397 
1398 	drvdata = devm_kzalloc(&client->dev, sizeof(*drvdata), GFP_KERNEL);
1399 	if (!drvdata)
1400 		return -ENOMEM;
1401 
1402 	i2c_set_clientdata(client, drvdata);
1403 	drvdata->client = client;
1404 	drvdata->variant = variant;
1405 	drvdata->pxtal = devm_clk_get(&client->dev, "xtal");
1406 	drvdata->pclkin = devm_clk_get(&client->dev, "clkin");
1407 
1408 	if (PTR_ERR(drvdata->pxtal) == -EPROBE_DEFER ||
1409 	    PTR_ERR(drvdata->pclkin) == -EPROBE_DEFER)
1410 		return -EPROBE_DEFER;
1411 
1412 	/*
1413 	 * Check for valid parent clock: VARIANT_A and VARIANT_B need XTAL,
1414 	 *   VARIANT_C can have CLKIN instead.
1415 	 */
1416 	if (IS_ERR(drvdata->pxtal) &&
1417 	    (drvdata->variant != SI5351_VARIANT_C || IS_ERR(drvdata->pclkin))) {
1418 		dev_err(&client->dev, "missing parent clock\n");
1419 		return -EINVAL;
1420 	}
1421 
1422 	drvdata->regmap = devm_regmap_init_i2c(client, &si5351_regmap_config);
1423 	if (IS_ERR(drvdata->regmap)) {
1424 		dev_err(&client->dev, "failed to allocate register map\n");
1425 		return PTR_ERR(drvdata->regmap);
1426 	}
1427 
1428 	/* Disable interrupts */
1429 	si5351_reg_write(drvdata, SI5351_INTERRUPT_MASK, 0xf0);
1430 	/* Ensure pll select is on XTAL for Si5351A/B */
1431 	if (drvdata->variant != SI5351_VARIANT_C)
1432 		si5351_set_bits(drvdata, SI5351_PLL_INPUT_SOURCE,
1433 				SI5351_PLLA_SOURCE | SI5351_PLLB_SOURCE, 0);
1434 
1435 	/* setup clock configuration */
1436 	for (n = 0; n < 2; n++) {
1437 		ret = _si5351_pll_reparent(drvdata, n, pdata->pll_src[n]);
1438 		if (ret) {
1439 			dev_err(&client->dev,
1440 				"failed to reparent pll %d to %d\n",
1441 				n, pdata->pll_src[n]);
1442 			return ret;
1443 		}
1444 	}
1445 
1446 	for (n = 0; n < 8; n++) {
1447 		ret = _si5351_msynth_reparent(drvdata, n,
1448 					      pdata->clkout[n].multisynth_src);
1449 		if (ret) {
1450 			dev_err(&client->dev,
1451 				"failed to reparent multisynth %d to %d\n",
1452 				n, pdata->clkout[n].multisynth_src);
1453 			return ret;
1454 		}
1455 
1456 		ret = _si5351_clkout_reparent(drvdata, n,
1457 					      pdata->clkout[n].clkout_src);
1458 		if (ret) {
1459 			dev_err(&client->dev,
1460 				"failed to reparent clkout %d to %d\n",
1461 				n, pdata->clkout[n].clkout_src);
1462 			return ret;
1463 		}
1464 
1465 		ret = _si5351_clkout_set_drive_strength(drvdata, n,
1466 							pdata->clkout[n].drive);
1467 		if (ret) {
1468 			dev_err(&client->dev,
1469 				"failed set drive strength of clkout%d to %d\n",
1470 				n, pdata->clkout[n].drive);
1471 			return ret;
1472 		}
1473 
1474 		ret = _si5351_clkout_set_disable_state(drvdata, n,
1475 						pdata->clkout[n].disable_state);
1476 		if (ret) {
1477 			dev_err(&client->dev,
1478 				"failed set disable state of clkout%d to %d\n",
1479 				n, pdata->clkout[n].disable_state);
1480 			return ret;
1481 		}
1482 	}
1483 
1484 	/* register xtal input clock gate */
1485 	memset(&init, 0, sizeof(init));
1486 	init.name = si5351_input_names[0];
1487 	init.ops = &si5351_xtal_ops;
1488 	init.flags = 0;
1489 	if (!IS_ERR(drvdata->pxtal)) {
1490 		drvdata->pxtal_name = __clk_get_name(drvdata->pxtal);
1491 		init.parent_names = &drvdata->pxtal_name;
1492 		init.num_parents = 1;
1493 	}
1494 	drvdata->xtal.init = &init;
1495 	ret = devm_clk_hw_register(&client->dev, &drvdata->xtal);
1496 	if (ret) {
1497 		dev_err(&client->dev, "unable to register %s\n", init.name);
1498 		return ret;
1499 	}
1500 
1501 	/* register clkin input clock gate */
1502 	if (drvdata->variant == SI5351_VARIANT_C) {
1503 		memset(&init, 0, sizeof(init));
1504 		init.name = si5351_input_names[1];
1505 		init.ops = &si5351_clkin_ops;
1506 		if (!IS_ERR(drvdata->pclkin)) {
1507 			drvdata->pclkin_name = __clk_get_name(drvdata->pclkin);
1508 			init.parent_names = &drvdata->pclkin_name;
1509 			init.num_parents = 1;
1510 		}
1511 		drvdata->clkin.init = &init;
1512 		ret = devm_clk_hw_register(&client->dev, &drvdata->clkin);
1513 		if (ret) {
1514 			dev_err(&client->dev, "unable to register %s\n",
1515 				init.name);
1516 			return ret;
1517 		}
1518 	}
1519 
1520 	/* Si5351C allows to mux either xtal or clkin to PLL input */
1521 	num_parents = (drvdata->variant == SI5351_VARIANT_C) ? 2 : 1;
1522 	parent_names[0] = si5351_input_names[0];
1523 	parent_names[1] = si5351_input_names[1];
1524 
1525 	/* register PLLA */
1526 	drvdata->pll[0].num = 0;
1527 	drvdata->pll[0].drvdata = drvdata;
1528 	drvdata->pll[0].hw.init = &init;
1529 	memset(&init, 0, sizeof(init));
1530 	init.name = si5351_pll_names[0];
1531 	init.ops = &si5351_pll_ops;
1532 	init.flags = 0;
1533 	init.parent_names = parent_names;
1534 	init.num_parents = num_parents;
1535 	ret = devm_clk_hw_register(&client->dev, &drvdata->pll[0].hw);
1536 	if (ret) {
1537 		dev_err(&client->dev, "unable to register %s\n", init.name);
1538 		return ret;
1539 	}
1540 
1541 	/* register PLLB or VXCO (Si5351B) */
1542 	drvdata->pll[1].num = 1;
1543 	drvdata->pll[1].drvdata = drvdata;
1544 	drvdata->pll[1].hw.init = &init;
1545 	memset(&init, 0, sizeof(init));
1546 	if (drvdata->variant == SI5351_VARIANT_B) {
1547 		init.name = si5351_pll_names[2];
1548 		init.ops = &si5351_vxco_ops;
1549 		init.flags = 0;
1550 		init.parent_names = NULL;
1551 		init.num_parents = 0;
1552 	} else {
1553 		init.name = si5351_pll_names[1];
1554 		init.ops = &si5351_pll_ops;
1555 		init.flags = 0;
1556 		init.parent_names = parent_names;
1557 		init.num_parents = num_parents;
1558 	}
1559 	ret = devm_clk_hw_register(&client->dev, &drvdata->pll[1].hw);
1560 	if (ret) {
1561 		dev_err(&client->dev, "unable to register %s\n", init.name);
1562 		return ret;
1563 	}
1564 
1565 	/* register clk multisync and clk out divider */
1566 	num_clocks = (drvdata->variant == SI5351_VARIANT_A3) ? 3 : 8;
1567 	parent_names[0] = si5351_pll_names[0];
1568 	if (drvdata->variant == SI5351_VARIANT_B)
1569 		parent_names[1] = si5351_pll_names[2];
1570 	else
1571 		parent_names[1] = si5351_pll_names[1];
1572 
1573 	drvdata->msynth = devm_kcalloc(&client->dev, num_clocks,
1574 				       sizeof(*drvdata->msynth), GFP_KERNEL);
1575 	drvdata->clkout = devm_kcalloc(&client->dev, num_clocks,
1576 				       sizeof(*drvdata->clkout), GFP_KERNEL);
1577 	drvdata->num_clkout = num_clocks;
1578 
1579 	if (WARN_ON(!drvdata->msynth || !drvdata->clkout)) {
1580 		ret = -ENOMEM;
1581 		return ret;
1582 	}
1583 
1584 	for (n = 0; n < num_clocks; n++) {
1585 		drvdata->msynth[n].num = n;
1586 		drvdata->msynth[n].drvdata = drvdata;
1587 		drvdata->msynth[n].hw.init = &init;
1588 		memset(&init, 0, sizeof(init));
1589 		init.name = si5351_msynth_names[n];
1590 		init.ops = &si5351_msynth_ops;
1591 		init.flags = 0;
1592 		if (pdata->clkout[n].pll_master)
1593 			init.flags |= CLK_SET_RATE_PARENT;
1594 		init.parent_names = parent_names;
1595 		init.num_parents = 2;
1596 		ret = devm_clk_hw_register(&client->dev,
1597 					   &drvdata->msynth[n].hw);
1598 		if (ret) {
1599 			dev_err(&client->dev, "unable to register %s\n",
1600 				init.name);
1601 			return ret;
1602 		}
1603 	}
1604 
1605 	num_parents = (drvdata->variant == SI5351_VARIANT_C) ? 4 : 3;
1606 	parent_names[2] = si5351_input_names[0];
1607 	parent_names[3] = si5351_input_names[1];
1608 	for (n = 0; n < num_clocks; n++) {
1609 		parent_names[0] = si5351_msynth_names[n];
1610 		parent_names[1] = (n < 4) ? si5351_msynth_names[0] :
1611 			si5351_msynth_names[4];
1612 
1613 		drvdata->clkout[n].num = n;
1614 		drvdata->clkout[n].drvdata = drvdata;
1615 		drvdata->clkout[n].hw.init = &init;
1616 		memset(&init, 0, sizeof(init));
1617 		init.name = si5351_clkout_names[n];
1618 		init.ops = &si5351_clkout_ops;
1619 		init.flags = 0;
1620 		if (pdata->clkout[n].clkout_src == SI5351_CLKOUT_SRC_MSYNTH_N)
1621 			init.flags |= CLK_SET_RATE_PARENT;
1622 		init.parent_names = parent_names;
1623 		init.num_parents = num_parents;
1624 		ret = devm_clk_hw_register(&client->dev,
1625 					   &drvdata->clkout[n].hw);
1626 		if (ret) {
1627 			dev_err(&client->dev, "unable to register %s\n",
1628 				init.name);
1629 			return ret;
1630 		}
1631 
1632 		/* set initial clkout rate */
1633 		if (pdata->clkout[n].rate != 0) {
1634 			int ret;
1635 			ret = clk_set_rate(drvdata->clkout[n].hw.clk,
1636 					   pdata->clkout[n].rate);
1637 			if (ret != 0) {
1638 				dev_err(&client->dev, "Cannot set rate : %d\n",
1639 					ret);
1640 			}
1641 		}
1642 	}
1643 
1644 	ret = of_clk_add_hw_provider(client->dev.of_node, si53351_of_clk_get,
1645 				     drvdata);
1646 	if (ret) {
1647 		dev_err(&client->dev, "unable to add clk provider\n");
1648 		return ret;
1649 	}
1650 
1651 	return 0;
1652 }
1653 
1654 static void si5351_i2c_remove(struct i2c_client *client)
1655 {
1656 	of_clk_del_provider(client->dev.of_node);
1657 }
1658 
1659 static struct i2c_driver si5351_driver = {
1660 	.driver = {
1661 		.name = "si5351",
1662 		.of_match_table = of_match_ptr(si5351_dt_ids),
1663 	},
1664 	.probe_new = si5351_i2c_probe,
1665 	.remove = si5351_i2c_remove,
1666 	.id_table = si5351_i2c_ids,
1667 };
1668 module_i2c_driver(si5351_driver);
1669 
1670 MODULE_AUTHOR("Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com");
1671 MODULE_DESCRIPTION("Silicon Labs Si5351A/B/C clock generator driver");
1672 MODULE_LICENSE("GPL");
1673