xref: /linux/drivers/clk/qcom/clk-alpha-pll.c (revision a4d89b11)
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * Copyright (c) 2015, 2018, The Linux Foundation. All rights reserved.
4  * Copyright (c) 2021, 2023-2024, Qualcomm Innovation Center, Inc. All rights reserved.
5  */
6 
7 #include <linux/kernel.h>
8 #include <linux/export.h>
9 #include <linux/clk-provider.h>
10 #include <linux/regmap.h>
11 #include <linux/delay.h>
12 
13 #include "clk-alpha-pll.h"
14 #include "common.h"
15 
16 #define PLL_MODE(p)		((p)->offset + 0x0)
17 # define PLL_OUTCTRL		BIT(0)
18 # define PLL_BYPASSNL		BIT(1)
19 # define PLL_RESET_N		BIT(2)
20 # define PLL_OFFLINE_REQ	BIT(7)
21 # define PLL_LOCK_COUNT_SHIFT	8
22 # define PLL_LOCK_COUNT_MASK	0x3f
23 # define PLL_BIAS_COUNT_SHIFT	14
24 # define PLL_BIAS_COUNT_MASK	0x3f
25 # define PLL_VOTE_FSM_ENA	BIT(20)
26 # define PLL_FSM_ENA		BIT(20)
27 # define PLL_VOTE_FSM_RESET	BIT(21)
28 # define PLL_UPDATE		BIT(22)
29 # define PLL_UPDATE_BYPASS	BIT(23)
30 # define PLL_FSM_LEGACY_MODE	BIT(24)
31 # define PLL_OFFLINE_ACK	BIT(28)
32 # define ALPHA_PLL_ACK_LATCH	BIT(29)
33 # define PLL_ACTIVE_FLAG	BIT(30)
34 # define PLL_LOCK_DET		BIT(31)
35 
36 #define PLL_L_VAL(p)		((p)->offset + (p)->regs[PLL_OFF_L_VAL])
37 #define PLL_CAL_L_VAL(p)	((p)->offset + (p)->regs[PLL_OFF_CAL_L_VAL])
38 #define PLL_ALPHA_VAL(p)	((p)->offset + (p)->regs[PLL_OFF_ALPHA_VAL])
39 #define PLL_ALPHA_VAL_U(p)	((p)->offset + (p)->regs[PLL_OFF_ALPHA_VAL_U])
40 
41 #define PLL_USER_CTL(p)		((p)->offset + (p)->regs[PLL_OFF_USER_CTL])
42 # define PLL_POST_DIV_SHIFT	8
43 # define PLL_POST_DIV_MASK(p)	GENMASK((p)->width - 1, 0)
44 # define PLL_ALPHA_MSB		BIT(15)
45 # define PLL_ALPHA_EN		BIT(24)
46 # define PLL_ALPHA_MODE		BIT(25)
47 # define PLL_VCO_SHIFT		20
48 # define PLL_VCO_MASK		0x3
49 
50 #define PLL_USER_CTL_U(p)	((p)->offset + (p)->regs[PLL_OFF_USER_CTL_U])
51 #define PLL_USER_CTL_U1(p)	((p)->offset + (p)->regs[PLL_OFF_USER_CTL_U1])
52 
53 #define PLL_CONFIG_CTL(p)	((p)->offset + (p)->regs[PLL_OFF_CONFIG_CTL])
54 #define PLL_CONFIG_CTL_U(p)	((p)->offset + (p)->regs[PLL_OFF_CONFIG_CTL_U])
55 #define PLL_CONFIG_CTL_U1(p)	((p)->offset + (p)->regs[PLL_OFF_CONFIG_CTL_U1])
56 #define PLL_CONFIG_CTL_U2(p)	((p)->offset + (p)->regs[PLL_OFF_CONFIG_CTL_U2])
57 #define PLL_TEST_CTL(p)		((p)->offset + (p)->regs[PLL_OFF_TEST_CTL])
58 #define PLL_TEST_CTL_U(p)	((p)->offset + (p)->regs[PLL_OFF_TEST_CTL_U])
59 #define PLL_TEST_CTL_U1(p)     ((p)->offset + (p)->regs[PLL_OFF_TEST_CTL_U1])
60 #define PLL_TEST_CTL_U2(p)     ((p)->offset + (p)->regs[PLL_OFF_TEST_CTL_U2])
61 #define PLL_STATUS(p)		((p)->offset + (p)->regs[PLL_OFF_STATUS])
62 #define PLL_OPMODE(p)		((p)->offset + (p)->regs[PLL_OFF_OPMODE])
63 #define PLL_FRAC(p)		((p)->offset + (p)->regs[PLL_OFF_FRAC])
64 
65 const u8 clk_alpha_pll_regs[][PLL_OFF_MAX_REGS] = {
66 	[CLK_ALPHA_PLL_TYPE_DEFAULT] =  {
67 		[PLL_OFF_L_VAL] = 0x04,
68 		[PLL_OFF_ALPHA_VAL] = 0x08,
69 		[PLL_OFF_ALPHA_VAL_U] = 0x0c,
70 		[PLL_OFF_USER_CTL] = 0x10,
71 		[PLL_OFF_USER_CTL_U] = 0x14,
72 		[PLL_OFF_CONFIG_CTL] = 0x18,
73 		[PLL_OFF_TEST_CTL] = 0x1c,
74 		[PLL_OFF_TEST_CTL_U] = 0x20,
75 		[PLL_OFF_STATUS] = 0x24,
76 	},
77 	[CLK_ALPHA_PLL_TYPE_HUAYRA] =  {
78 		[PLL_OFF_L_VAL] = 0x04,
79 		[PLL_OFF_ALPHA_VAL] = 0x08,
80 		[PLL_OFF_USER_CTL] = 0x10,
81 		[PLL_OFF_CONFIG_CTL] = 0x14,
82 		[PLL_OFF_CONFIG_CTL_U] = 0x18,
83 		[PLL_OFF_TEST_CTL] = 0x1c,
84 		[PLL_OFF_TEST_CTL_U] = 0x20,
85 		[PLL_OFF_STATUS] = 0x24,
86 	},
87 	[CLK_ALPHA_PLL_TYPE_HUAYRA_APSS] =  {
88 		[PLL_OFF_L_VAL] = 0x08,
89 		[PLL_OFF_ALPHA_VAL] = 0x10,
90 		[PLL_OFF_USER_CTL] = 0x18,
91 		[PLL_OFF_CONFIG_CTL] = 0x20,
92 		[PLL_OFF_CONFIG_CTL_U] = 0x24,
93 		[PLL_OFF_STATUS] = 0x28,
94 		[PLL_OFF_TEST_CTL] = 0x30,
95 		[PLL_OFF_TEST_CTL_U] = 0x34,
96 	},
97 	[CLK_ALPHA_PLL_TYPE_HUAYRA_2290] =  {
98 		[PLL_OFF_L_VAL] = 0x04,
99 		[PLL_OFF_ALPHA_VAL] = 0x08,
100 		[PLL_OFF_USER_CTL] = 0x0c,
101 		[PLL_OFF_CONFIG_CTL] = 0x10,
102 		[PLL_OFF_CONFIG_CTL_U] = 0x14,
103 		[PLL_OFF_CONFIG_CTL_U1] = 0x18,
104 		[PLL_OFF_TEST_CTL] = 0x1c,
105 		[PLL_OFF_TEST_CTL_U] = 0x20,
106 		[PLL_OFF_TEST_CTL_U1] = 0x24,
107 		[PLL_OFF_OPMODE] = 0x28,
108 		[PLL_OFF_STATUS] = 0x38,
109 	},
110 	[CLK_ALPHA_PLL_TYPE_BRAMMO] =  {
111 		[PLL_OFF_L_VAL] = 0x04,
112 		[PLL_OFF_ALPHA_VAL] = 0x08,
113 		[PLL_OFF_ALPHA_VAL_U] = 0x0c,
114 		[PLL_OFF_USER_CTL] = 0x10,
115 		[PLL_OFF_CONFIG_CTL] = 0x18,
116 		[PLL_OFF_TEST_CTL] = 0x1c,
117 		[PLL_OFF_STATUS] = 0x24,
118 	},
119 	[CLK_ALPHA_PLL_TYPE_FABIA] =  {
120 		[PLL_OFF_L_VAL] = 0x04,
121 		[PLL_OFF_USER_CTL] = 0x0c,
122 		[PLL_OFF_USER_CTL_U] = 0x10,
123 		[PLL_OFF_CONFIG_CTL] = 0x14,
124 		[PLL_OFF_CONFIG_CTL_U] = 0x18,
125 		[PLL_OFF_TEST_CTL] = 0x1c,
126 		[PLL_OFF_TEST_CTL_U] = 0x20,
127 		[PLL_OFF_STATUS] = 0x24,
128 		[PLL_OFF_OPMODE] = 0x2c,
129 		[PLL_OFF_FRAC] = 0x38,
130 	},
131 	[CLK_ALPHA_PLL_TYPE_TRION] = {
132 		[PLL_OFF_L_VAL] = 0x04,
133 		[PLL_OFF_CAL_L_VAL] = 0x08,
134 		[PLL_OFF_USER_CTL] = 0x0c,
135 		[PLL_OFF_USER_CTL_U] = 0x10,
136 		[PLL_OFF_USER_CTL_U1] = 0x14,
137 		[PLL_OFF_CONFIG_CTL] = 0x18,
138 		[PLL_OFF_CONFIG_CTL_U] = 0x1c,
139 		[PLL_OFF_CONFIG_CTL_U1] = 0x20,
140 		[PLL_OFF_TEST_CTL] = 0x24,
141 		[PLL_OFF_TEST_CTL_U] = 0x28,
142 		[PLL_OFF_TEST_CTL_U1] = 0x2c,
143 		[PLL_OFF_STATUS] = 0x30,
144 		[PLL_OFF_OPMODE] = 0x38,
145 		[PLL_OFF_ALPHA_VAL] = 0x40,
146 	},
147 	[CLK_ALPHA_PLL_TYPE_AGERA] =  {
148 		[PLL_OFF_L_VAL] = 0x04,
149 		[PLL_OFF_ALPHA_VAL] = 0x08,
150 		[PLL_OFF_USER_CTL] = 0x0c,
151 		[PLL_OFF_CONFIG_CTL] = 0x10,
152 		[PLL_OFF_CONFIG_CTL_U] = 0x14,
153 		[PLL_OFF_TEST_CTL] = 0x18,
154 		[PLL_OFF_TEST_CTL_U] = 0x1c,
155 		[PLL_OFF_STATUS] = 0x2c,
156 	},
157 	[CLK_ALPHA_PLL_TYPE_ZONDA] =  {
158 		[PLL_OFF_L_VAL] = 0x04,
159 		[PLL_OFF_ALPHA_VAL] = 0x08,
160 		[PLL_OFF_USER_CTL] = 0x0c,
161 		[PLL_OFF_CONFIG_CTL] = 0x10,
162 		[PLL_OFF_CONFIG_CTL_U] = 0x14,
163 		[PLL_OFF_CONFIG_CTL_U1] = 0x18,
164 		[PLL_OFF_TEST_CTL] = 0x1c,
165 		[PLL_OFF_TEST_CTL_U] = 0x20,
166 		[PLL_OFF_TEST_CTL_U1] = 0x24,
167 		[PLL_OFF_OPMODE] = 0x28,
168 		[PLL_OFF_STATUS] = 0x38,
169 	},
170 	[CLK_ALPHA_PLL_TYPE_LUCID_EVO] = {
171 		[PLL_OFF_OPMODE] = 0x04,
172 		[PLL_OFF_STATUS] = 0x0c,
173 		[PLL_OFF_L_VAL] = 0x10,
174 		[PLL_OFF_ALPHA_VAL] = 0x14,
175 		[PLL_OFF_USER_CTL] = 0x18,
176 		[PLL_OFF_USER_CTL_U] = 0x1c,
177 		[PLL_OFF_CONFIG_CTL] = 0x20,
178 		[PLL_OFF_CONFIG_CTL_U] = 0x24,
179 		[PLL_OFF_CONFIG_CTL_U1] = 0x28,
180 		[PLL_OFF_TEST_CTL] = 0x2c,
181 		[PLL_OFF_TEST_CTL_U] = 0x30,
182 		[PLL_OFF_TEST_CTL_U1] = 0x34,
183 	},
184 	[CLK_ALPHA_PLL_TYPE_LUCID_OLE] = {
185 		[PLL_OFF_OPMODE] = 0x04,
186 		[PLL_OFF_STATE] = 0x08,
187 		[PLL_OFF_STATUS] = 0x0c,
188 		[PLL_OFF_L_VAL] = 0x10,
189 		[PLL_OFF_ALPHA_VAL] = 0x14,
190 		[PLL_OFF_USER_CTL] = 0x18,
191 		[PLL_OFF_USER_CTL_U] = 0x1c,
192 		[PLL_OFF_CONFIG_CTL] = 0x20,
193 		[PLL_OFF_CONFIG_CTL_U] = 0x24,
194 		[PLL_OFF_CONFIG_CTL_U1] = 0x28,
195 		[PLL_OFF_TEST_CTL] = 0x2c,
196 		[PLL_OFF_TEST_CTL_U] = 0x30,
197 		[PLL_OFF_TEST_CTL_U1] = 0x34,
198 		[PLL_OFF_TEST_CTL_U2] = 0x38,
199 	},
200 	[CLK_ALPHA_PLL_TYPE_RIVIAN_EVO] = {
201 		[PLL_OFF_OPMODE] = 0x04,
202 		[PLL_OFF_STATUS] = 0x0c,
203 		[PLL_OFF_L_VAL] = 0x10,
204 		[PLL_OFF_USER_CTL] = 0x14,
205 		[PLL_OFF_USER_CTL_U] = 0x18,
206 		[PLL_OFF_CONFIG_CTL] = 0x1c,
207 		[PLL_OFF_CONFIG_CTL_U] = 0x20,
208 		[PLL_OFF_CONFIG_CTL_U1] = 0x24,
209 		[PLL_OFF_TEST_CTL] = 0x28,
210 		[PLL_OFF_TEST_CTL_U] = 0x2c,
211 	},
212 	[CLK_ALPHA_PLL_TYPE_DEFAULT_EVO] =  {
213 		[PLL_OFF_L_VAL] = 0x04,
214 		[PLL_OFF_ALPHA_VAL] = 0x08,
215 		[PLL_OFF_ALPHA_VAL_U] = 0x0c,
216 		[PLL_OFF_TEST_CTL] = 0x10,
217 		[PLL_OFF_TEST_CTL_U] = 0x14,
218 		[PLL_OFF_USER_CTL] = 0x18,
219 		[PLL_OFF_USER_CTL_U] = 0x1c,
220 		[PLL_OFF_CONFIG_CTL] = 0x20,
221 		[PLL_OFF_STATUS] = 0x24,
222 	},
223 	[CLK_ALPHA_PLL_TYPE_BRAMMO_EVO] =  {
224 		[PLL_OFF_L_VAL] = 0x04,
225 		[PLL_OFF_ALPHA_VAL] = 0x08,
226 		[PLL_OFF_ALPHA_VAL_U] = 0x0c,
227 		[PLL_OFF_TEST_CTL] = 0x10,
228 		[PLL_OFF_TEST_CTL_U] = 0x14,
229 		[PLL_OFF_USER_CTL] = 0x18,
230 		[PLL_OFF_CONFIG_CTL] = 0x1C,
231 		[PLL_OFF_STATUS] = 0x20,
232 	},
233 	[CLK_ALPHA_PLL_TYPE_STROMER] = {
234 		[PLL_OFF_L_VAL] = 0x08,
235 		[PLL_OFF_ALPHA_VAL] = 0x10,
236 		[PLL_OFF_ALPHA_VAL_U] = 0x14,
237 		[PLL_OFF_USER_CTL] = 0x18,
238 		[PLL_OFF_USER_CTL_U] = 0x1c,
239 		[PLL_OFF_CONFIG_CTL] = 0x20,
240 		[PLL_OFF_STATUS] = 0x28,
241 		[PLL_OFF_TEST_CTL] = 0x30,
242 		[PLL_OFF_TEST_CTL_U] = 0x34,
243 	},
244 	[CLK_ALPHA_PLL_TYPE_STROMER_PLUS] =  {
245 		[PLL_OFF_L_VAL] = 0x04,
246 		[PLL_OFF_USER_CTL] = 0x08,
247 		[PLL_OFF_USER_CTL_U] = 0x0c,
248 		[PLL_OFF_CONFIG_CTL] = 0x10,
249 		[PLL_OFF_TEST_CTL] = 0x14,
250 		[PLL_OFF_TEST_CTL_U] = 0x18,
251 		[PLL_OFF_STATUS] = 0x1c,
252 		[PLL_OFF_ALPHA_VAL] = 0x24,
253 		[PLL_OFF_ALPHA_VAL_U] = 0x28,
254 	},
255 	[CLK_ALPHA_PLL_TYPE_ZONDA_OLE] =  {
256 		[PLL_OFF_L_VAL] = 0x04,
257 		[PLL_OFF_ALPHA_VAL] = 0x08,
258 		[PLL_OFF_USER_CTL] = 0x0c,
259 		[PLL_OFF_USER_CTL_U] = 0x10,
260 		[PLL_OFF_CONFIG_CTL] = 0x14,
261 		[PLL_OFF_CONFIG_CTL_U] = 0x18,
262 		[PLL_OFF_CONFIG_CTL_U1] = 0x1c,
263 		[PLL_OFF_CONFIG_CTL_U2] = 0x20,
264 		[PLL_OFF_TEST_CTL] = 0x24,
265 		[PLL_OFF_TEST_CTL_U] = 0x28,
266 		[PLL_OFF_TEST_CTL_U1] = 0x2c,
267 		[PLL_OFF_OPMODE] = 0x30,
268 		[PLL_OFF_STATUS] = 0x3c,
269 	},
270 };
271 EXPORT_SYMBOL_GPL(clk_alpha_pll_regs);
272 
273 /*
274  * Even though 40 bits are present, use only 32 for ease of calculation.
275  */
276 #define ALPHA_REG_BITWIDTH	40
277 #define ALPHA_REG_16BIT_WIDTH	16
278 #define ALPHA_BITWIDTH		32U
279 #define ALPHA_SHIFT(w)		min(w, ALPHA_BITWIDTH)
280 
281 #define	ALPHA_PLL_STATUS_REG_SHIFT	8
282 
283 #define PLL_HUAYRA_M_WIDTH		8
284 #define PLL_HUAYRA_M_SHIFT		8
285 #define PLL_HUAYRA_M_MASK		0xff
286 #define PLL_HUAYRA_N_SHIFT		0
287 #define PLL_HUAYRA_N_MASK		0xff
288 #define PLL_HUAYRA_ALPHA_WIDTH		16
289 
290 #define PLL_STANDBY		0x0
291 #define PLL_RUN			0x1
292 #define PLL_OUT_MASK		0x7
293 #define PLL_RATE_MARGIN		500
294 
295 /* TRION PLL specific settings and offsets */
296 #define TRION_PLL_CAL_VAL	0x44
297 #define TRION_PCAL_DONE		BIT(26)
298 
299 /* LUCID PLL specific settings and offsets */
300 #define LUCID_PCAL_DONE		BIT(27)
301 
302 /* LUCID 5LPE PLL specific settings and offsets */
303 #define LUCID_5LPE_PCAL_DONE		BIT(11)
304 #define LUCID_5LPE_ALPHA_PLL_ACK_LATCH	BIT(13)
305 #define LUCID_5LPE_PLL_LATCH_INPUT	BIT(14)
306 #define LUCID_5LPE_ENABLE_VOTE_RUN	BIT(21)
307 
308 /* LUCID EVO PLL specific settings and offsets */
309 #define LUCID_EVO_PCAL_NOT_DONE		BIT(8)
310 #define LUCID_EVO_ENABLE_VOTE_RUN       BIT(25)
311 #define LUCID_EVO_PLL_L_VAL_MASK        GENMASK(15, 0)
312 #define LUCID_EVO_PLL_CAL_L_VAL_SHIFT	16
313 #define LUCID_OLE_PLL_RINGOSC_CAL_L_VAL_SHIFT	24
314 
315 /* ZONDA PLL specific */
316 #define ZONDA_PLL_OUT_MASK	0xf
317 #define ZONDA_STAY_IN_CFA	BIT(16)
318 #define ZONDA_PLL_FREQ_LOCK_DET	BIT(29)
319 
320 #define pll_alpha_width(p)					\
321 		((PLL_ALPHA_VAL_U(p) - PLL_ALPHA_VAL(p) == 4) ?	\
322 				 ALPHA_REG_BITWIDTH : ALPHA_REG_16BIT_WIDTH)
323 
324 #define pll_has_64bit_config(p)	((PLL_CONFIG_CTL_U(p) - PLL_CONFIG_CTL(p)) == 4)
325 
326 #define to_clk_alpha_pll(_hw) container_of(to_clk_regmap(_hw), \
327 					   struct clk_alpha_pll, clkr)
328 
329 #define to_clk_alpha_pll_postdiv(_hw) container_of(to_clk_regmap(_hw), \
330 					   struct clk_alpha_pll_postdiv, clkr)
331 
wait_for_pll(struct clk_alpha_pll * pll,u32 mask,bool inverse,const char * action)332 static int wait_for_pll(struct clk_alpha_pll *pll, u32 mask, bool inverse,
333 			const char *action)
334 {
335 	u32 val;
336 	int count;
337 	int ret;
338 	const char *name = clk_hw_get_name(&pll->clkr.hw);
339 
340 	ret = regmap_read(pll->clkr.regmap, PLL_MODE(pll), &val);
341 	if (ret)
342 		return ret;
343 
344 	for (count = 200; count > 0; count--) {
345 		ret = regmap_read(pll->clkr.regmap, PLL_MODE(pll), &val);
346 		if (ret)
347 			return ret;
348 		if (inverse && !(val & mask))
349 			return 0;
350 		else if ((val & mask) == mask)
351 			return 0;
352 
353 		udelay(1);
354 	}
355 
356 	WARN(1, "%s failed to %s!\n", name, action);
357 	return -ETIMEDOUT;
358 }
359 
360 #define wait_for_pll_enable_active(pll) \
361 	wait_for_pll(pll, PLL_ACTIVE_FLAG, 0, "enable")
362 
363 #define wait_for_pll_enable_lock(pll) \
364 	wait_for_pll(pll, PLL_LOCK_DET, 0, "enable")
365 
366 #define wait_for_zonda_pll_freq_lock(pll) \
367 	wait_for_pll(pll, ZONDA_PLL_FREQ_LOCK_DET, 0, "freq enable")
368 
369 #define wait_for_pll_disable(pll) \
370 	wait_for_pll(pll, PLL_ACTIVE_FLAG, 1, "disable")
371 
372 #define wait_for_pll_offline(pll) \
373 	wait_for_pll(pll, PLL_OFFLINE_ACK, 0, "offline")
374 
375 #define wait_for_pll_update(pll) \
376 	wait_for_pll(pll, PLL_UPDATE, 1, "update")
377 
378 #define wait_for_pll_update_ack_set(pll) \
379 	wait_for_pll(pll, ALPHA_PLL_ACK_LATCH, 0, "update_ack_set")
380 
381 #define wait_for_pll_update_ack_clear(pll) \
382 	wait_for_pll(pll, ALPHA_PLL_ACK_LATCH, 1, "update_ack_clear")
383 
clk_alpha_pll_write_config(struct regmap * regmap,unsigned int reg,unsigned int val)384 static void clk_alpha_pll_write_config(struct regmap *regmap, unsigned int reg,
385 					unsigned int val)
386 {
387 	if (val)
388 		regmap_write(regmap, reg, val);
389 }
390 
clk_alpha_pll_configure(struct clk_alpha_pll * pll,struct regmap * regmap,const struct alpha_pll_config * config)391 void clk_alpha_pll_configure(struct clk_alpha_pll *pll, struct regmap *regmap,
392 			     const struct alpha_pll_config *config)
393 {
394 	u32 val, mask;
395 
396 	regmap_write(regmap, PLL_L_VAL(pll), config->l);
397 	regmap_write(regmap, PLL_ALPHA_VAL(pll), config->alpha);
398 	regmap_write(regmap, PLL_CONFIG_CTL(pll), config->config_ctl_val);
399 
400 	if (pll_has_64bit_config(pll))
401 		regmap_write(regmap, PLL_CONFIG_CTL_U(pll),
402 			     config->config_ctl_hi_val);
403 
404 	if (pll_alpha_width(pll) > 32)
405 		regmap_write(regmap, PLL_ALPHA_VAL_U(pll), config->alpha_hi);
406 
407 	val = config->main_output_mask;
408 	val |= config->aux_output_mask;
409 	val |= config->aux2_output_mask;
410 	val |= config->early_output_mask;
411 	val |= config->pre_div_val;
412 	val |= config->post_div_val;
413 	val |= config->vco_val;
414 	val |= config->alpha_en_mask;
415 	val |= config->alpha_mode_mask;
416 
417 	mask = config->main_output_mask;
418 	mask |= config->aux_output_mask;
419 	mask |= config->aux2_output_mask;
420 	mask |= config->early_output_mask;
421 	mask |= config->pre_div_mask;
422 	mask |= config->post_div_mask;
423 	mask |= config->vco_mask;
424 
425 	regmap_update_bits(regmap, PLL_USER_CTL(pll), mask, val);
426 
427 	if (config->test_ctl_mask)
428 		regmap_update_bits(regmap, PLL_TEST_CTL(pll),
429 				   config->test_ctl_mask,
430 				   config->test_ctl_val);
431 	else
432 		clk_alpha_pll_write_config(regmap, PLL_TEST_CTL(pll),
433 					   config->test_ctl_val);
434 
435 	if (config->test_ctl_hi_mask)
436 		regmap_update_bits(regmap, PLL_TEST_CTL_U(pll),
437 				   config->test_ctl_hi_mask,
438 				   config->test_ctl_hi_val);
439 	else
440 		clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U(pll),
441 					   config->test_ctl_hi_val);
442 
443 	if (pll->flags & SUPPORTS_FSM_MODE)
444 		qcom_pll_set_fsm_mode(regmap, PLL_MODE(pll), 6, 0);
445 }
446 EXPORT_SYMBOL_GPL(clk_alpha_pll_configure);
447 
clk_alpha_pll_hwfsm_enable(struct clk_hw * hw)448 static int clk_alpha_pll_hwfsm_enable(struct clk_hw *hw)
449 {
450 	int ret;
451 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
452 	u32 val;
453 
454 	ret = regmap_read(pll->clkr.regmap, PLL_MODE(pll), &val);
455 	if (ret)
456 		return ret;
457 
458 	val |= PLL_FSM_ENA;
459 
460 	if (pll->flags & SUPPORTS_OFFLINE_REQ)
461 		val &= ~PLL_OFFLINE_REQ;
462 
463 	ret = regmap_write(pll->clkr.regmap, PLL_MODE(pll), val);
464 	if (ret)
465 		return ret;
466 
467 	/* Make sure enable request goes through before waiting for update */
468 	mb();
469 
470 	return wait_for_pll_enable_active(pll);
471 }
472 
clk_alpha_pll_hwfsm_disable(struct clk_hw * hw)473 static void clk_alpha_pll_hwfsm_disable(struct clk_hw *hw)
474 {
475 	int ret;
476 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
477 	u32 val;
478 
479 	ret = regmap_read(pll->clkr.regmap, PLL_MODE(pll), &val);
480 	if (ret)
481 		return;
482 
483 	if (pll->flags & SUPPORTS_OFFLINE_REQ) {
484 		ret = regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll),
485 					 PLL_OFFLINE_REQ, PLL_OFFLINE_REQ);
486 		if (ret)
487 			return;
488 
489 		ret = wait_for_pll_offline(pll);
490 		if (ret)
491 			return;
492 	}
493 
494 	/* Disable hwfsm */
495 	ret = regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll),
496 				 PLL_FSM_ENA, 0);
497 	if (ret)
498 		return;
499 
500 	wait_for_pll_disable(pll);
501 }
502 
pll_is_enabled(struct clk_hw * hw,u32 mask)503 static int pll_is_enabled(struct clk_hw *hw, u32 mask)
504 {
505 	int ret;
506 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
507 	u32 val;
508 
509 	ret = regmap_read(pll->clkr.regmap, PLL_MODE(pll), &val);
510 	if (ret)
511 		return ret;
512 
513 	return !!(val & mask);
514 }
515 
clk_alpha_pll_hwfsm_is_enabled(struct clk_hw * hw)516 static int clk_alpha_pll_hwfsm_is_enabled(struct clk_hw *hw)
517 {
518 	return pll_is_enabled(hw, PLL_ACTIVE_FLAG);
519 }
520 
clk_alpha_pll_is_enabled(struct clk_hw * hw)521 static int clk_alpha_pll_is_enabled(struct clk_hw *hw)
522 {
523 	return pll_is_enabled(hw, PLL_LOCK_DET);
524 }
525 
clk_alpha_pll_enable(struct clk_hw * hw)526 static int clk_alpha_pll_enable(struct clk_hw *hw)
527 {
528 	int ret;
529 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
530 	u32 val, mask;
531 
532 	mask = PLL_OUTCTRL | PLL_RESET_N | PLL_BYPASSNL;
533 	ret = regmap_read(pll->clkr.regmap, PLL_MODE(pll), &val);
534 	if (ret)
535 		return ret;
536 
537 	/* If in FSM mode, just vote for it */
538 	if (val & PLL_VOTE_FSM_ENA) {
539 		ret = clk_enable_regmap(hw);
540 		if (ret)
541 			return ret;
542 		return wait_for_pll_enable_active(pll);
543 	}
544 
545 	/* Skip if already enabled */
546 	if ((val & mask) == mask)
547 		return 0;
548 
549 	ret = regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll),
550 				 PLL_BYPASSNL, PLL_BYPASSNL);
551 	if (ret)
552 		return ret;
553 
554 	/*
555 	 * H/W requires a 5us delay between disabling the bypass and
556 	 * de-asserting the reset.
557 	 */
558 	mb();
559 	udelay(5);
560 
561 	ret = regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll),
562 				 PLL_RESET_N, PLL_RESET_N);
563 	if (ret)
564 		return ret;
565 
566 	ret = wait_for_pll_enable_lock(pll);
567 	if (ret)
568 		return ret;
569 
570 	ret = regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll),
571 				 PLL_OUTCTRL, PLL_OUTCTRL);
572 
573 	/* Ensure that the write above goes through before returning. */
574 	mb();
575 	return ret;
576 }
577 
clk_alpha_pll_disable(struct clk_hw * hw)578 static void clk_alpha_pll_disable(struct clk_hw *hw)
579 {
580 	int ret;
581 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
582 	u32 val, mask;
583 
584 	ret = regmap_read(pll->clkr.regmap, PLL_MODE(pll), &val);
585 	if (ret)
586 		return;
587 
588 	/* If in FSM mode, just unvote it */
589 	if (val & PLL_VOTE_FSM_ENA) {
590 		clk_disable_regmap(hw);
591 		return;
592 	}
593 
594 	mask = PLL_OUTCTRL;
595 	regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll), mask, 0);
596 
597 	/* Delay of 2 output clock ticks required until output is disabled */
598 	mb();
599 	udelay(1);
600 
601 	mask = PLL_RESET_N | PLL_BYPASSNL;
602 	regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll), mask, 0);
603 }
604 
605 static unsigned long
alpha_pll_calc_rate(u64 prate,u32 l,u32 a,u32 alpha_width)606 alpha_pll_calc_rate(u64 prate, u32 l, u32 a, u32 alpha_width)
607 {
608 	return (prate * l) + ((prate * a) >> ALPHA_SHIFT(alpha_width));
609 }
610 
611 static unsigned long
alpha_pll_round_rate(unsigned long rate,unsigned long prate,u32 * l,u64 * a,u32 alpha_width)612 alpha_pll_round_rate(unsigned long rate, unsigned long prate, u32 *l, u64 *a,
613 		     u32 alpha_width)
614 {
615 	u64 remainder;
616 	u64 quotient;
617 
618 	quotient = rate;
619 	remainder = do_div(quotient, prate);
620 	*l = quotient;
621 
622 	if (!remainder) {
623 		*a = 0;
624 		return rate;
625 	}
626 
627 	/* Upper ALPHA_BITWIDTH bits of Alpha */
628 	quotient = remainder << ALPHA_SHIFT(alpha_width);
629 
630 	remainder = do_div(quotient, prate);
631 
632 	if (remainder)
633 		quotient++;
634 
635 	*a = quotient;
636 	return alpha_pll_calc_rate(prate, *l, *a, alpha_width);
637 }
638 
639 static const struct pll_vco *
alpha_pll_find_vco(const struct clk_alpha_pll * pll,unsigned long rate)640 alpha_pll_find_vco(const struct clk_alpha_pll *pll, unsigned long rate)
641 {
642 	const struct pll_vco *v = pll->vco_table;
643 	const struct pll_vco *end = v + pll->num_vco;
644 
645 	for (; v < end; v++)
646 		if (rate >= v->min_freq && rate <= v->max_freq)
647 			return v;
648 
649 	return NULL;
650 }
651 
652 static unsigned long
clk_alpha_pll_recalc_rate(struct clk_hw * hw,unsigned long parent_rate)653 clk_alpha_pll_recalc_rate(struct clk_hw *hw, unsigned long parent_rate)
654 {
655 	u32 l, low, high, ctl;
656 	u64 a = 0, prate = parent_rate;
657 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
658 	u32 alpha_width = pll_alpha_width(pll);
659 
660 	regmap_read(pll->clkr.regmap, PLL_L_VAL(pll), &l);
661 
662 	regmap_read(pll->clkr.regmap, PLL_USER_CTL(pll), &ctl);
663 	if (ctl & PLL_ALPHA_EN) {
664 		regmap_read(pll->clkr.regmap, PLL_ALPHA_VAL(pll), &low);
665 		if (alpha_width > 32) {
666 			regmap_read(pll->clkr.regmap, PLL_ALPHA_VAL_U(pll),
667 				    &high);
668 			a = (u64)high << 32 | low;
669 		} else {
670 			a = low & GENMASK(alpha_width - 1, 0);
671 		}
672 
673 		if (alpha_width > ALPHA_BITWIDTH)
674 			a >>= alpha_width - ALPHA_BITWIDTH;
675 	}
676 
677 	return alpha_pll_calc_rate(prate, l, a, alpha_width);
678 }
679 
680 
__clk_alpha_pll_update_latch(struct clk_alpha_pll * pll)681 static int __clk_alpha_pll_update_latch(struct clk_alpha_pll *pll)
682 {
683 	int ret;
684 	u32 mode;
685 
686 	regmap_read(pll->clkr.regmap, PLL_MODE(pll), &mode);
687 
688 	/* Latch the input to the PLL */
689 	regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll), PLL_UPDATE,
690 			   PLL_UPDATE);
691 
692 	/* Wait for 2 reference cycle before checking ACK bit */
693 	udelay(1);
694 
695 	/*
696 	 * PLL will latch the new L, Alpha and freq control word.
697 	 * PLL will respond by raising PLL_ACK_LATCH output when new programming
698 	 * has been latched in and PLL is being updated. When
699 	 * UPDATE_LOGIC_BYPASS bit is not set, PLL_UPDATE will be cleared
700 	 * automatically by hardware when PLL_ACK_LATCH is asserted by PLL.
701 	 */
702 	if (mode & PLL_UPDATE_BYPASS) {
703 		ret = wait_for_pll_update_ack_set(pll);
704 		if (ret)
705 			return ret;
706 
707 		regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll), PLL_UPDATE, 0);
708 	} else {
709 		ret = wait_for_pll_update(pll);
710 		if (ret)
711 			return ret;
712 	}
713 
714 	ret = wait_for_pll_update_ack_clear(pll);
715 	if (ret)
716 		return ret;
717 
718 	/* Wait for PLL output to stabilize */
719 	udelay(10);
720 
721 	return 0;
722 }
723 
clk_alpha_pll_update_latch(struct clk_alpha_pll * pll,int (* is_enabled)(struct clk_hw *))724 static int clk_alpha_pll_update_latch(struct clk_alpha_pll *pll,
725 				      int (*is_enabled)(struct clk_hw *))
726 {
727 	if (!is_enabled(&pll->clkr.hw) ||
728 	    !(pll->flags & SUPPORTS_DYNAMIC_UPDATE))
729 		return 0;
730 
731 	return __clk_alpha_pll_update_latch(pll);
732 }
733 
__clk_alpha_pll_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long prate,int (* is_enabled)(struct clk_hw *))734 static int __clk_alpha_pll_set_rate(struct clk_hw *hw, unsigned long rate,
735 				    unsigned long prate,
736 				    int (*is_enabled)(struct clk_hw *))
737 {
738 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
739 	const struct pll_vco *vco;
740 	u32 l, alpha_width = pll_alpha_width(pll);
741 	u64 a;
742 
743 	rate = alpha_pll_round_rate(rate, prate, &l, &a, alpha_width);
744 	vco = alpha_pll_find_vco(pll, rate);
745 	if (pll->vco_table && !vco) {
746 		pr_err("%s: alpha pll not in a valid vco range\n",
747 		       clk_hw_get_name(hw));
748 		return -EINVAL;
749 	}
750 
751 	regmap_write(pll->clkr.regmap, PLL_L_VAL(pll), l);
752 
753 	if (alpha_width > ALPHA_BITWIDTH)
754 		a <<= alpha_width - ALPHA_BITWIDTH;
755 
756 	if (alpha_width > 32)
757 		regmap_write(pll->clkr.regmap, PLL_ALPHA_VAL_U(pll), a >> 32);
758 
759 	regmap_write(pll->clkr.regmap, PLL_ALPHA_VAL(pll), a);
760 
761 	if (vco) {
762 		regmap_update_bits(pll->clkr.regmap, PLL_USER_CTL(pll),
763 				   PLL_VCO_MASK << PLL_VCO_SHIFT,
764 				   vco->val << PLL_VCO_SHIFT);
765 	}
766 
767 	regmap_update_bits(pll->clkr.regmap, PLL_USER_CTL(pll),
768 			   PLL_ALPHA_EN, PLL_ALPHA_EN);
769 
770 	return clk_alpha_pll_update_latch(pll, is_enabled);
771 }
772 
clk_alpha_pll_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long prate)773 static int clk_alpha_pll_set_rate(struct clk_hw *hw, unsigned long rate,
774 				  unsigned long prate)
775 {
776 	return __clk_alpha_pll_set_rate(hw, rate, prate,
777 					clk_alpha_pll_is_enabled);
778 }
779 
clk_alpha_pll_hwfsm_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long prate)780 static int clk_alpha_pll_hwfsm_set_rate(struct clk_hw *hw, unsigned long rate,
781 					unsigned long prate)
782 {
783 	return __clk_alpha_pll_set_rate(hw, rate, prate,
784 					clk_alpha_pll_hwfsm_is_enabled);
785 }
786 
clk_alpha_pll_round_rate(struct clk_hw * hw,unsigned long rate,unsigned long * prate)787 static long clk_alpha_pll_round_rate(struct clk_hw *hw, unsigned long rate,
788 				     unsigned long *prate)
789 {
790 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
791 	u32 l, alpha_width = pll_alpha_width(pll);
792 	u64 a;
793 	unsigned long min_freq, max_freq;
794 
795 	rate = alpha_pll_round_rate(rate, *prate, &l, &a, alpha_width);
796 	if (!pll->vco_table || alpha_pll_find_vco(pll, rate))
797 		return rate;
798 
799 	min_freq = pll->vco_table[0].min_freq;
800 	max_freq = pll->vco_table[pll->num_vco - 1].max_freq;
801 
802 	return clamp(rate, min_freq, max_freq);
803 }
804 
clk_huayra_2290_pll_configure(struct clk_alpha_pll * pll,struct regmap * regmap,const struct alpha_pll_config * config)805 void clk_huayra_2290_pll_configure(struct clk_alpha_pll *pll, struct regmap *regmap,
806 				   const struct alpha_pll_config *config)
807 {
808 	u32 val;
809 
810 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL(pll), config->config_ctl_val);
811 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U(pll), config->config_ctl_hi_val);
812 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U1(pll), config->config_ctl_hi1_val);
813 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL(pll), config->test_ctl_val);
814 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U(pll), config->test_ctl_hi_val);
815 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U1(pll), config->test_ctl_hi1_val);
816 	clk_alpha_pll_write_config(regmap, PLL_L_VAL(pll), config->l);
817 	clk_alpha_pll_write_config(regmap, PLL_ALPHA_VAL(pll), config->alpha);
818 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL(pll), config->user_ctl_val);
819 
820 	/* Set PLL_BYPASSNL */
821 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_BYPASSNL, PLL_BYPASSNL);
822 	regmap_read(regmap, PLL_MODE(pll), &val);
823 
824 	/* Wait 5 us between setting BYPASS and deasserting reset */
825 	udelay(5);
826 
827 	/* Take PLL out from reset state */
828 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_RESET_N, PLL_RESET_N);
829 	regmap_read(regmap, PLL_MODE(pll), &val);
830 
831 	/* Wait 50us for PLL_LOCK_DET bit to go high */
832 	usleep_range(50, 55);
833 
834 	/* Enable PLL output */
835 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_OUTCTRL, PLL_OUTCTRL);
836 }
837 EXPORT_SYMBOL_GPL(clk_huayra_2290_pll_configure);
838 
839 static unsigned long
alpha_huayra_pll_calc_rate(u64 prate,u32 l,u32 a)840 alpha_huayra_pll_calc_rate(u64 prate, u32 l, u32 a)
841 {
842 	/*
843 	 * a contains 16 bit alpha_val in two’s complement number in the range
844 	 * of [-0.5, 0.5).
845 	 */
846 	if (a >= BIT(PLL_HUAYRA_ALPHA_WIDTH - 1))
847 		l -= 1;
848 
849 	return (prate * l) + (prate * a >> PLL_HUAYRA_ALPHA_WIDTH);
850 }
851 
852 static unsigned long
alpha_huayra_pll_round_rate(unsigned long rate,unsigned long prate,u32 * l,u32 * a)853 alpha_huayra_pll_round_rate(unsigned long rate, unsigned long prate,
854 			    u32 *l, u32 *a)
855 {
856 	u64 remainder;
857 	u64 quotient;
858 
859 	quotient = rate;
860 	remainder = do_div(quotient, prate);
861 	*l = quotient;
862 
863 	if (!remainder) {
864 		*a = 0;
865 		return rate;
866 	}
867 
868 	quotient = remainder << PLL_HUAYRA_ALPHA_WIDTH;
869 	remainder = do_div(quotient, prate);
870 
871 	if (remainder)
872 		quotient++;
873 
874 	/*
875 	 * alpha_val should be in two’s complement number in the range
876 	 * of [-0.5, 0.5) so if quotient >= 0.5 then increment the l value
877 	 * since alpha value will be subtracted in this case.
878 	 */
879 	if (quotient >= BIT(PLL_HUAYRA_ALPHA_WIDTH - 1))
880 		*l += 1;
881 
882 	*a = quotient;
883 	return alpha_huayra_pll_calc_rate(prate, *l, *a);
884 }
885 
886 static unsigned long
alpha_pll_huayra_recalc_rate(struct clk_hw * hw,unsigned long parent_rate)887 alpha_pll_huayra_recalc_rate(struct clk_hw *hw, unsigned long parent_rate)
888 {
889 	u64 rate = parent_rate, tmp;
890 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
891 	u32 l, alpha = 0, ctl, alpha_m, alpha_n;
892 
893 	regmap_read(pll->clkr.regmap, PLL_L_VAL(pll), &l);
894 	regmap_read(pll->clkr.regmap, PLL_USER_CTL(pll), &ctl);
895 
896 	if (ctl & PLL_ALPHA_EN) {
897 		regmap_read(pll->clkr.regmap, PLL_ALPHA_VAL(pll), &alpha);
898 		/*
899 		 * Depending upon alpha_mode, it can be treated as M/N value or
900 		 * as a two’s complement number. When alpha_mode=1,
901 		 * pll_alpha_val<15:8>=M and pll_apla_val<7:0>=N
902 		 *
903 		 *		Fout=FIN*(L+(M/N))
904 		 *
905 		 * M is a signed number (-128 to 127) and N is unsigned
906 		 * (0 to 255). M/N has to be within +/-0.5.
907 		 *
908 		 * When alpha_mode=0, it is a two’s complement number in the
909 		 * range [-0.5, 0.5).
910 		 *
911 		 *		Fout=FIN*(L+(alpha_val)/2^16)
912 		 *
913 		 * where alpha_val is two’s complement number.
914 		 */
915 		if (!(ctl & PLL_ALPHA_MODE))
916 			return alpha_huayra_pll_calc_rate(rate, l, alpha);
917 
918 		alpha_m = alpha >> PLL_HUAYRA_M_SHIFT & PLL_HUAYRA_M_MASK;
919 		alpha_n = alpha >> PLL_HUAYRA_N_SHIFT & PLL_HUAYRA_N_MASK;
920 
921 		rate *= l;
922 		tmp = parent_rate;
923 		if (alpha_m >= BIT(PLL_HUAYRA_M_WIDTH - 1)) {
924 			alpha_m = BIT(PLL_HUAYRA_M_WIDTH) - alpha_m;
925 			tmp *= alpha_m;
926 			do_div(tmp, alpha_n);
927 			rate -= tmp;
928 		} else {
929 			tmp *= alpha_m;
930 			do_div(tmp, alpha_n);
931 			rate += tmp;
932 		}
933 
934 		return rate;
935 	}
936 
937 	return alpha_huayra_pll_calc_rate(rate, l, alpha);
938 }
939 
alpha_pll_huayra_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long prate)940 static int alpha_pll_huayra_set_rate(struct clk_hw *hw, unsigned long rate,
941 				     unsigned long prate)
942 {
943 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
944 	u32 l, a, ctl, cur_alpha = 0;
945 
946 	rate = alpha_huayra_pll_round_rate(rate, prate, &l, &a);
947 
948 	regmap_read(pll->clkr.regmap, PLL_USER_CTL(pll), &ctl);
949 
950 	if (ctl & PLL_ALPHA_EN)
951 		regmap_read(pll->clkr.regmap, PLL_ALPHA_VAL(pll), &cur_alpha);
952 
953 	/*
954 	 * Huayra PLL supports PLL dynamic programming. User can change L_VAL,
955 	 * without having to go through the power on sequence.
956 	 */
957 	if (clk_alpha_pll_is_enabled(hw)) {
958 		if (cur_alpha != a) {
959 			pr_err("%s: clock needs to be gated\n",
960 			       clk_hw_get_name(hw));
961 			return -EBUSY;
962 		}
963 
964 		regmap_write(pll->clkr.regmap, PLL_L_VAL(pll), l);
965 		/* Ensure that the write above goes to detect L val change. */
966 		mb();
967 		return wait_for_pll_enable_lock(pll);
968 	}
969 
970 	regmap_write(pll->clkr.regmap, PLL_L_VAL(pll), l);
971 	regmap_write(pll->clkr.regmap, PLL_ALPHA_VAL(pll), a);
972 
973 	if (a == 0)
974 		regmap_update_bits(pll->clkr.regmap, PLL_USER_CTL(pll),
975 				   PLL_ALPHA_EN, 0x0);
976 	else
977 		regmap_update_bits(pll->clkr.regmap, PLL_USER_CTL(pll),
978 				   PLL_ALPHA_EN | PLL_ALPHA_MODE, PLL_ALPHA_EN);
979 
980 	return 0;
981 }
982 
alpha_pll_huayra_round_rate(struct clk_hw * hw,unsigned long rate,unsigned long * prate)983 static long alpha_pll_huayra_round_rate(struct clk_hw *hw, unsigned long rate,
984 					unsigned long *prate)
985 {
986 	u32 l, a;
987 
988 	return alpha_huayra_pll_round_rate(rate, *prate, &l, &a);
989 }
990 
trion_pll_is_enabled(struct clk_alpha_pll * pll,struct regmap * regmap)991 static int trion_pll_is_enabled(struct clk_alpha_pll *pll,
992 				struct regmap *regmap)
993 {
994 	u32 mode_val, opmode_val;
995 	int ret;
996 
997 	ret = regmap_read(regmap, PLL_MODE(pll), &mode_val);
998 	ret |= regmap_read(regmap, PLL_OPMODE(pll), &opmode_val);
999 	if (ret)
1000 		return 0;
1001 
1002 	return ((opmode_val & PLL_RUN) && (mode_val & PLL_OUTCTRL));
1003 }
1004 
clk_trion_pll_is_enabled(struct clk_hw * hw)1005 static int clk_trion_pll_is_enabled(struct clk_hw *hw)
1006 {
1007 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
1008 
1009 	return trion_pll_is_enabled(pll, pll->clkr.regmap);
1010 }
1011 
clk_trion_pll_enable(struct clk_hw * hw)1012 static int clk_trion_pll_enable(struct clk_hw *hw)
1013 {
1014 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
1015 	struct regmap *regmap = pll->clkr.regmap;
1016 	u32 val;
1017 	int ret;
1018 
1019 	ret = regmap_read(regmap, PLL_MODE(pll), &val);
1020 	if (ret)
1021 		return ret;
1022 
1023 	/* If in FSM mode, just vote for it */
1024 	if (val & PLL_VOTE_FSM_ENA) {
1025 		ret = clk_enable_regmap(hw);
1026 		if (ret)
1027 			return ret;
1028 		return wait_for_pll_enable_active(pll);
1029 	}
1030 
1031 	/* Set operation mode to RUN */
1032 	regmap_write(regmap, PLL_OPMODE(pll), PLL_RUN);
1033 
1034 	ret = wait_for_pll_enable_lock(pll);
1035 	if (ret)
1036 		return ret;
1037 
1038 	/* Enable the PLL outputs */
1039 	ret = regmap_update_bits(regmap, PLL_USER_CTL(pll),
1040 				 PLL_OUT_MASK, PLL_OUT_MASK);
1041 	if (ret)
1042 		return ret;
1043 
1044 	/* Enable the global PLL outputs */
1045 	return regmap_update_bits(regmap, PLL_MODE(pll),
1046 				 PLL_OUTCTRL, PLL_OUTCTRL);
1047 }
1048 
clk_trion_pll_disable(struct clk_hw * hw)1049 static void clk_trion_pll_disable(struct clk_hw *hw)
1050 {
1051 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
1052 	struct regmap *regmap = pll->clkr.regmap;
1053 	u32 val;
1054 	int ret;
1055 
1056 	ret = regmap_read(regmap, PLL_MODE(pll), &val);
1057 	if (ret)
1058 		return;
1059 
1060 	/* If in FSM mode, just unvote it */
1061 	if (val & PLL_VOTE_FSM_ENA) {
1062 		clk_disable_regmap(hw);
1063 		return;
1064 	}
1065 
1066 	/* Disable the global PLL output */
1067 	ret = regmap_update_bits(regmap, PLL_MODE(pll), PLL_OUTCTRL, 0);
1068 	if (ret)
1069 		return;
1070 
1071 	/* Disable the PLL outputs */
1072 	ret = regmap_update_bits(regmap, PLL_USER_CTL(pll),
1073 				 PLL_OUT_MASK, 0);
1074 	if (ret)
1075 		return;
1076 
1077 	/* Place the PLL mode in STANDBY */
1078 	regmap_write(regmap, PLL_OPMODE(pll), PLL_STANDBY);
1079 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_RESET_N, PLL_RESET_N);
1080 }
1081 
1082 static unsigned long
clk_trion_pll_recalc_rate(struct clk_hw * hw,unsigned long parent_rate)1083 clk_trion_pll_recalc_rate(struct clk_hw *hw, unsigned long parent_rate)
1084 {
1085 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
1086 	u32 l, frac, alpha_width = pll_alpha_width(pll);
1087 
1088 	regmap_read(pll->clkr.regmap, PLL_L_VAL(pll), &l);
1089 	regmap_read(pll->clkr.regmap, PLL_ALPHA_VAL(pll), &frac);
1090 
1091 	return alpha_pll_calc_rate(parent_rate, l, frac, alpha_width);
1092 }
1093 
1094 const struct clk_ops clk_alpha_pll_fixed_ops = {
1095 	.enable = clk_alpha_pll_enable,
1096 	.disable = clk_alpha_pll_disable,
1097 	.is_enabled = clk_alpha_pll_is_enabled,
1098 	.recalc_rate = clk_alpha_pll_recalc_rate,
1099 };
1100 EXPORT_SYMBOL_GPL(clk_alpha_pll_fixed_ops);
1101 
1102 const struct clk_ops clk_alpha_pll_ops = {
1103 	.enable = clk_alpha_pll_enable,
1104 	.disable = clk_alpha_pll_disable,
1105 	.is_enabled = clk_alpha_pll_is_enabled,
1106 	.recalc_rate = clk_alpha_pll_recalc_rate,
1107 	.round_rate = clk_alpha_pll_round_rate,
1108 	.set_rate = clk_alpha_pll_set_rate,
1109 };
1110 EXPORT_SYMBOL_GPL(clk_alpha_pll_ops);
1111 
1112 const struct clk_ops clk_alpha_pll_huayra_ops = {
1113 	.enable = clk_alpha_pll_enable,
1114 	.disable = clk_alpha_pll_disable,
1115 	.is_enabled = clk_alpha_pll_is_enabled,
1116 	.recalc_rate = alpha_pll_huayra_recalc_rate,
1117 	.round_rate = alpha_pll_huayra_round_rate,
1118 	.set_rate = alpha_pll_huayra_set_rate,
1119 };
1120 EXPORT_SYMBOL_GPL(clk_alpha_pll_huayra_ops);
1121 
1122 const struct clk_ops clk_alpha_pll_hwfsm_ops = {
1123 	.enable = clk_alpha_pll_hwfsm_enable,
1124 	.disable = clk_alpha_pll_hwfsm_disable,
1125 	.is_enabled = clk_alpha_pll_hwfsm_is_enabled,
1126 	.recalc_rate = clk_alpha_pll_recalc_rate,
1127 	.round_rate = clk_alpha_pll_round_rate,
1128 	.set_rate = clk_alpha_pll_hwfsm_set_rate,
1129 };
1130 EXPORT_SYMBOL_GPL(clk_alpha_pll_hwfsm_ops);
1131 
1132 const struct clk_ops clk_alpha_pll_fixed_trion_ops = {
1133 	.enable = clk_trion_pll_enable,
1134 	.disable = clk_trion_pll_disable,
1135 	.is_enabled = clk_trion_pll_is_enabled,
1136 	.recalc_rate = clk_trion_pll_recalc_rate,
1137 	.round_rate = clk_alpha_pll_round_rate,
1138 };
1139 EXPORT_SYMBOL_GPL(clk_alpha_pll_fixed_trion_ops);
1140 
1141 static unsigned long
clk_alpha_pll_postdiv_recalc_rate(struct clk_hw * hw,unsigned long parent_rate)1142 clk_alpha_pll_postdiv_recalc_rate(struct clk_hw *hw, unsigned long parent_rate)
1143 {
1144 	struct clk_alpha_pll_postdiv *pll = to_clk_alpha_pll_postdiv(hw);
1145 	u32 ctl;
1146 
1147 	regmap_read(pll->clkr.regmap, PLL_USER_CTL(pll), &ctl);
1148 
1149 	ctl >>= PLL_POST_DIV_SHIFT;
1150 	ctl &= PLL_POST_DIV_MASK(pll);
1151 
1152 	return parent_rate >> fls(ctl);
1153 }
1154 
1155 static const struct clk_div_table clk_alpha_div_table[] = {
1156 	{ 0x0, 1 },
1157 	{ 0x1, 2 },
1158 	{ 0x3, 4 },
1159 	{ 0x7, 8 },
1160 	{ 0xf, 16 },
1161 	{ }
1162 };
1163 
1164 static const struct clk_div_table clk_alpha_2bit_div_table[] = {
1165 	{ 0x0, 1 },
1166 	{ 0x1, 2 },
1167 	{ 0x3, 4 },
1168 	{ }
1169 };
1170 
1171 static long
clk_alpha_pll_postdiv_round_rate(struct clk_hw * hw,unsigned long rate,unsigned long * prate)1172 clk_alpha_pll_postdiv_round_rate(struct clk_hw *hw, unsigned long rate,
1173 				 unsigned long *prate)
1174 {
1175 	struct clk_alpha_pll_postdiv *pll = to_clk_alpha_pll_postdiv(hw);
1176 	const struct clk_div_table *table;
1177 
1178 	if (pll->width == 2)
1179 		table = clk_alpha_2bit_div_table;
1180 	else
1181 		table = clk_alpha_div_table;
1182 
1183 	return divider_round_rate(hw, rate, prate, table,
1184 				  pll->width, CLK_DIVIDER_POWER_OF_TWO);
1185 }
1186 
1187 static long
clk_alpha_pll_postdiv_round_ro_rate(struct clk_hw * hw,unsigned long rate,unsigned long * prate)1188 clk_alpha_pll_postdiv_round_ro_rate(struct clk_hw *hw, unsigned long rate,
1189 				    unsigned long *prate)
1190 {
1191 	struct clk_alpha_pll_postdiv *pll = to_clk_alpha_pll_postdiv(hw);
1192 	u32 ctl, div;
1193 
1194 	regmap_read(pll->clkr.regmap, PLL_USER_CTL(pll), &ctl);
1195 
1196 	ctl >>= PLL_POST_DIV_SHIFT;
1197 	ctl &= BIT(pll->width) - 1;
1198 	div = 1 << fls(ctl);
1199 
1200 	if (clk_hw_get_flags(hw) & CLK_SET_RATE_PARENT)
1201 		*prate = clk_hw_round_rate(clk_hw_get_parent(hw), div * rate);
1202 
1203 	return DIV_ROUND_UP_ULL((u64)*prate, div);
1204 }
1205 
clk_alpha_pll_postdiv_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long parent_rate)1206 static int clk_alpha_pll_postdiv_set_rate(struct clk_hw *hw, unsigned long rate,
1207 					  unsigned long parent_rate)
1208 {
1209 	struct clk_alpha_pll_postdiv *pll = to_clk_alpha_pll_postdiv(hw);
1210 	int div;
1211 
1212 	/* 16 -> 0xf, 8 -> 0x7, 4 -> 0x3, 2 -> 0x1, 1 -> 0x0 */
1213 	div = DIV_ROUND_UP_ULL(parent_rate, rate) - 1;
1214 
1215 	return regmap_update_bits(pll->clkr.regmap, PLL_USER_CTL(pll),
1216 				  PLL_POST_DIV_MASK(pll) << PLL_POST_DIV_SHIFT,
1217 				  div << PLL_POST_DIV_SHIFT);
1218 }
1219 
1220 const struct clk_ops clk_alpha_pll_postdiv_ops = {
1221 	.recalc_rate = clk_alpha_pll_postdiv_recalc_rate,
1222 	.round_rate = clk_alpha_pll_postdiv_round_rate,
1223 	.set_rate = clk_alpha_pll_postdiv_set_rate,
1224 };
1225 EXPORT_SYMBOL_GPL(clk_alpha_pll_postdiv_ops);
1226 
1227 const struct clk_ops clk_alpha_pll_postdiv_ro_ops = {
1228 	.round_rate = clk_alpha_pll_postdiv_round_ro_rate,
1229 	.recalc_rate = clk_alpha_pll_postdiv_recalc_rate,
1230 };
1231 EXPORT_SYMBOL_GPL(clk_alpha_pll_postdiv_ro_ops);
1232 
clk_fabia_pll_configure(struct clk_alpha_pll * pll,struct regmap * regmap,const struct alpha_pll_config * config)1233 void clk_fabia_pll_configure(struct clk_alpha_pll *pll, struct regmap *regmap,
1234 			     const struct alpha_pll_config *config)
1235 {
1236 	u32 val, mask;
1237 
1238 	clk_alpha_pll_write_config(regmap, PLL_L_VAL(pll), config->l);
1239 	clk_alpha_pll_write_config(regmap, PLL_FRAC(pll), config->alpha);
1240 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL(pll),
1241 						config->config_ctl_val);
1242 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U(pll),
1243 						config->config_ctl_hi_val);
1244 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL(pll),
1245 						config->user_ctl_val);
1246 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL_U(pll),
1247 						config->user_ctl_hi_val);
1248 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL(pll),
1249 						config->test_ctl_val);
1250 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U(pll),
1251 						config->test_ctl_hi_val);
1252 
1253 	if (config->post_div_mask) {
1254 		mask = config->post_div_mask;
1255 		val = config->post_div_val;
1256 		regmap_update_bits(regmap, PLL_USER_CTL(pll), mask, val);
1257 	}
1258 
1259 	if (pll->flags & SUPPORTS_FSM_LEGACY_MODE)
1260 		regmap_update_bits(regmap, PLL_MODE(pll), PLL_FSM_LEGACY_MODE,
1261 							PLL_FSM_LEGACY_MODE);
1262 
1263 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_UPDATE_BYPASS,
1264 							PLL_UPDATE_BYPASS);
1265 
1266 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_RESET_N, PLL_RESET_N);
1267 }
1268 EXPORT_SYMBOL_GPL(clk_fabia_pll_configure);
1269 
alpha_pll_fabia_enable(struct clk_hw * hw)1270 static int alpha_pll_fabia_enable(struct clk_hw *hw)
1271 {
1272 	int ret;
1273 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
1274 	u32 val, opmode_val;
1275 	struct regmap *regmap = pll->clkr.regmap;
1276 
1277 	ret = regmap_read(regmap, PLL_MODE(pll), &val);
1278 	if (ret)
1279 		return ret;
1280 
1281 	/* If in FSM mode, just vote for it */
1282 	if (val & PLL_VOTE_FSM_ENA) {
1283 		ret = clk_enable_regmap(hw);
1284 		if (ret)
1285 			return ret;
1286 		return wait_for_pll_enable_active(pll);
1287 	}
1288 
1289 	ret = regmap_read(regmap, PLL_OPMODE(pll), &opmode_val);
1290 	if (ret)
1291 		return ret;
1292 
1293 	/* Skip If PLL is already running */
1294 	if ((opmode_val & PLL_RUN) && (val & PLL_OUTCTRL))
1295 		return 0;
1296 
1297 	ret = regmap_update_bits(regmap, PLL_MODE(pll), PLL_OUTCTRL, 0);
1298 	if (ret)
1299 		return ret;
1300 
1301 	ret = regmap_write(regmap, PLL_OPMODE(pll), PLL_STANDBY);
1302 	if (ret)
1303 		return ret;
1304 
1305 	ret = regmap_update_bits(regmap, PLL_MODE(pll), PLL_RESET_N,
1306 				 PLL_RESET_N);
1307 	if (ret)
1308 		return ret;
1309 
1310 	ret = regmap_write(regmap, PLL_OPMODE(pll), PLL_RUN);
1311 	if (ret)
1312 		return ret;
1313 
1314 	ret = wait_for_pll_enable_lock(pll);
1315 	if (ret)
1316 		return ret;
1317 
1318 	ret = regmap_update_bits(regmap, PLL_USER_CTL(pll),
1319 				 PLL_OUT_MASK, PLL_OUT_MASK);
1320 	if (ret)
1321 		return ret;
1322 
1323 	return regmap_update_bits(regmap, PLL_MODE(pll), PLL_OUTCTRL,
1324 				 PLL_OUTCTRL);
1325 }
1326 
alpha_pll_fabia_disable(struct clk_hw * hw)1327 static void alpha_pll_fabia_disable(struct clk_hw *hw)
1328 {
1329 	int ret;
1330 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
1331 	u32 val;
1332 	struct regmap *regmap = pll->clkr.regmap;
1333 
1334 	ret = regmap_read(regmap, PLL_MODE(pll), &val);
1335 	if (ret)
1336 		return;
1337 
1338 	/* If in FSM mode, just unvote it */
1339 	if (val & PLL_FSM_ENA) {
1340 		clk_disable_regmap(hw);
1341 		return;
1342 	}
1343 
1344 	ret = regmap_update_bits(regmap, PLL_MODE(pll), PLL_OUTCTRL, 0);
1345 	if (ret)
1346 		return;
1347 
1348 	/* Disable main outputs */
1349 	ret = regmap_update_bits(regmap, PLL_USER_CTL(pll), PLL_OUT_MASK, 0);
1350 	if (ret)
1351 		return;
1352 
1353 	/* Place the PLL in STANDBY */
1354 	regmap_write(regmap, PLL_OPMODE(pll), PLL_STANDBY);
1355 }
1356 
alpha_pll_fabia_recalc_rate(struct clk_hw * hw,unsigned long parent_rate)1357 static unsigned long alpha_pll_fabia_recalc_rate(struct clk_hw *hw,
1358 						unsigned long parent_rate)
1359 {
1360 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
1361 	u32 l, frac, alpha_width = pll_alpha_width(pll);
1362 
1363 	regmap_read(pll->clkr.regmap, PLL_L_VAL(pll), &l);
1364 	regmap_read(pll->clkr.regmap, PLL_FRAC(pll), &frac);
1365 
1366 	return alpha_pll_calc_rate(parent_rate, l, frac, alpha_width);
1367 }
1368 
1369 /*
1370  * Due to limited number of bits for fractional rate programming, the
1371  * rounded up rate could be marginally higher than the requested rate.
1372  */
alpha_pll_check_rate_margin(struct clk_hw * hw,unsigned long rrate,unsigned long rate)1373 static int alpha_pll_check_rate_margin(struct clk_hw *hw,
1374 			unsigned long rrate, unsigned long rate)
1375 {
1376 	unsigned long rate_margin = rate + PLL_RATE_MARGIN;
1377 
1378 	if (rrate > rate_margin || rrate < rate) {
1379 		pr_err("%s: Rounded rate %lu not within range [%lu, %lu)\n",
1380 		       clk_hw_get_name(hw), rrate, rate, rate_margin);
1381 		return -EINVAL;
1382 	}
1383 
1384 	return 0;
1385 }
1386 
alpha_pll_fabia_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long prate)1387 static int alpha_pll_fabia_set_rate(struct clk_hw *hw, unsigned long rate,
1388 						unsigned long prate)
1389 {
1390 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
1391 	u32 l, alpha_width = pll_alpha_width(pll);
1392 	unsigned long rrate;
1393 	int ret;
1394 	u64 a;
1395 
1396 	rrate = alpha_pll_round_rate(rate, prate, &l, &a, alpha_width);
1397 
1398 	ret = alpha_pll_check_rate_margin(hw, rrate, rate);
1399 	if (ret < 0)
1400 		return ret;
1401 
1402 	regmap_write(pll->clkr.regmap, PLL_L_VAL(pll), l);
1403 	regmap_write(pll->clkr.regmap, PLL_FRAC(pll), a);
1404 
1405 	return __clk_alpha_pll_update_latch(pll);
1406 }
1407 
alpha_pll_fabia_prepare(struct clk_hw * hw)1408 static int alpha_pll_fabia_prepare(struct clk_hw *hw)
1409 {
1410 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
1411 	const struct pll_vco *vco;
1412 	struct clk_hw *parent_hw;
1413 	unsigned long cal_freq, rrate;
1414 	u32 cal_l, val, alpha_width = pll_alpha_width(pll);
1415 	const char *name = clk_hw_get_name(hw);
1416 	u64 a;
1417 	int ret;
1418 
1419 	/* Check if calibration needs to be done i.e. PLL is in reset */
1420 	ret = regmap_read(pll->clkr.regmap, PLL_MODE(pll), &val);
1421 	if (ret)
1422 		return ret;
1423 
1424 	/* Return early if calibration is not needed. */
1425 	if (val & PLL_RESET_N)
1426 		return 0;
1427 
1428 	vco = alpha_pll_find_vco(pll, clk_hw_get_rate(hw));
1429 	if (!vco) {
1430 		pr_err("%s: alpha pll not in a valid vco range\n", name);
1431 		return -EINVAL;
1432 	}
1433 
1434 	cal_freq = DIV_ROUND_CLOSEST((pll->vco_table[0].min_freq +
1435 				pll->vco_table[0].max_freq) * 54, 100);
1436 
1437 	parent_hw = clk_hw_get_parent(hw);
1438 	if (!parent_hw)
1439 		return -EINVAL;
1440 
1441 	rrate = alpha_pll_round_rate(cal_freq, clk_hw_get_rate(parent_hw),
1442 					&cal_l, &a, alpha_width);
1443 
1444 	ret = alpha_pll_check_rate_margin(hw, rrate, cal_freq);
1445 	if (ret < 0)
1446 		return ret;
1447 
1448 	/* Setup PLL for calibration frequency */
1449 	regmap_write(pll->clkr.regmap, PLL_CAL_L_VAL(pll), cal_l);
1450 
1451 	/* Bringup the PLL at calibration frequency */
1452 	ret = clk_alpha_pll_enable(hw);
1453 	if (ret) {
1454 		pr_err("%s: alpha pll calibration failed\n", name);
1455 		return ret;
1456 	}
1457 
1458 	clk_alpha_pll_disable(hw);
1459 
1460 	return 0;
1461 }
1462 
1463 const struct clk_ops clk_alpha_pll_fabia_ops = {
1464 	.prepare = alpha_pll_fabia_prepare,
1465 	.enable = alpha_pll_fabia_enable,
1466 	.disable = alpha_pll_fabia_disable,
1467 	.is_enabled = clk_alpha_pll_is_enabled,
1468 	.set_rate = alpha_pll_fabia_set_rate,
1469 	.recalc_rate = alpha_pll_fabia_recalc_rate,
1470 	.round_rate = clk_alpha_pll_round_rate,
1471 };
1472 EXPORT_SYMBOL_GPL(clk_alpha_pll_fabia_ops);
1473 
1474 const struct clk_ops clk_alpha_pll_fixed_fabia_ops = {
1475 	.enable = alpha_pll_fabia_enable,
1476 	.disable = alpha_pll_fabia_disable,
1477 	.is_enabled = clk_alpha_pll_is_enabled,
1478 	.recalc_rate = alpha_pll_fabia_recalc_rate,
1479 	.round_rate = clk_alpha_pll_round_rate,
1480 };
1481 EXPORT_SYMBOL_GPL(clk_alpha_pll_fixed_fabia_ops);
1482 
clk_alpha_pll_postdiv_fabia_recalc_rate(struct clk_hw * hw,unsigned long parent_rate)1483 static unsigned long clk_alpha_pll_postdiv_fabia_recalc_rate(struct clk_hw *hw,
1484 					unsigned long parent_rate)
1485 {
1486 	struct clk_alpha_pll_postdiv *pll = to_clk_alpha_pll_postdiv(hw);
1487 	u32 i, div = 1, val;
1488 	int ret;
1489 
1490 	ret = regmap_read(pll->clkr.regmap, PLL_USER_CTL(pll), &val);
1491 	if (ret)
1492 		return ret;
1493 
1494 	val >>= pll->post_div_shift;
1495 	val &= BIT(pll->width) - 1;
1496 
1497 	for (i = 0; i < pll->num_post_div; i++) {
1498 		if (pll->post_div_table[i].val == val) {
1499 			div = pll->post_div_table[i].div;
1500 			break;
1501 		}
1502 	}
1503 
1504 	return (parent_rate / div);
1505 }
1506 
1507 static unsigned long
clk_trion_pll_postdiv_recalc_rate(struct clk_hw * hw,unsigned long parent_rate)1508 clk_trion_pll_postdiv_recalc_rate(struct clk_hw *hw, unsigned long parent_rate)
1509 {
1510 	struct clk_alpha_pll_postdiv *pll = to_clk_alpha_pll_postdiv(hw);
1511 	struct regmap *regmap = pll->clkr.regmap;
1512 	u32 i, div = 1, val;
1513 
1514 	regmap_read(regmap, PLL_USER_CTL(pll), &val);
1515 
1516 	val >>= pll->post_div_shift;
1517 	val &= PLL_POST_DIV_MASK(pll);
1518 
1519 	for (i = 0; i < pll->num_post_div; i++) {
1520 		if (pll->post_div_table[i].val == val) {
1521 			div = pll->post_div_table[i].div;
1522 			break;
1523 		}
1524 	}
1525 
1526 	return (parent_rate / div);
1527 }
1528 
1529 static long
clk_trion_pll_postdiv_round_rate(struct clk_hw * hw,unsigned long rate,unsigned long * prate)1530 clk_trion_pll_postdiv_round_rate(struct clk_hw *hw, unsigned long rate,
1531 				 unsigned long *prate)
1532 {
1533 	struct clk_alpha_pll_postdiv *pll = to_clk_alpha_pll_postdiv(hw);
1534 
1535 	return divider_round_rate(hw, rate, prate, pll->post_div_table,
1536 				  pll->width, CLK_DIVIDER_ROUND_CLOSEST);
1537 };
1538 
1539 static int
clk_trion_pll_postdiv_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long parent_rate)1540 clk_trion_pll_postdiv_set_rate(struct clk_hw *hw, unsigned long rate,
1541 			       unsigned long parent_rate)
1542 {
1543 	struct clk_alpha_pll_postdiv *pll = to_clk_alpha_pll_postdiv(hw);
1544 	struct regmap *regmap = pll->clkr.regmap;
1545 	int i, val = 0, div;
1546 
1547 	div = DIV_ROUND_UP_ULL(parent_rate, rate);
1548 	for (i = 0; i < pll->num_post_div; i++) {
1549 		if (pll->post_div_table[i].div == div) {
1550 			val = pll->post_div_table[i].val;
1551 			break;
1552 		}
1553 	}
1554 
1555 	return regmap_update_bits(regmap, PLL_USER_CTL(pll),
1556 				  PLL_POST_DIV_MASK(pll) << pll->post_div_shift,
1557 				  val << pll->post_div_shift);
1558 }
1559 
1560 const struct clk_ops clk_alpha_pll_postdiv_trion_ops = {
1561 	.recalc_rate = clk_trion_pll_postdiv_recalc_rate,
1562 	.round_rate = clk_trion_pll_postdiv_round_rate,
1563 	.set_rate = clk_trion_pll_postdiv_set_rate,
1564 };
1565 EXPORT_SYMBOL_GPL(clk_alpha_pll_postdiv_trion_ops);
1566 
clk_alpha_pll_postdiv_fabia_round_rate(struct clk_hw * hw,unsigned long rate,unsigned long * prate)1567 static long clk_alpha_pll_postdiv_fabia_round_rate(struct clk_hw *hw,
1568 				unsigned long rate, unsigned long *prate)
1569 {
1570 	struct clk_alpha_pll_postdiv *pll = to_clk_alpha_pll_postdiv(hw);
1571 
1572 	return divider_round_rate(hw, rate, prate, pll->post_div_table,
1573 				pll->width, CLK_DIVIDER_ROUND_CLOSEST);
1574 }
1575 
clk_alpha_pll_postdiv_fabia_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long parent_rate)1576 static int clk_alpha_pll_postdiv_fabia_set_rate(struct clk_hw *hw,
1577 				unsigned long rate, unsigned long parent_rate)
1578 {
1579 	struct clk_alpha_pll_postdiv *pll = to_clk_alpha_pll_postdiv(hw);
1580 	int i, val = 0, div, ret;
1581 
1582 	/*
1583 	 * If the PLL is in FSM mode, then treat set_rate callback as a
1584 	 * no-operation.
1585 	 */
1586 	ret = regmap_read(pll->clkr.regmap, PLL_MODE(pll), &val);
1587 	if (ret)
1588 		return ret;
1589 
1590 	if (val & PLL_VOTE_FSM_ENA)
1591 		return 0;
1592 
1593 	div = DIV_ROUND_UP_ULL(parent_rate, rate);
1594 	for (i = 0; i < pll->num_post_div; i++) {
1595 		if (pll->post_div_table[i].div == div) {
1596 			val = pll->post_div_table[i].val;
1597 			break;
1598 		}
1599 	}
1600 
1601 	return regmap_update_bits(pll->clkr.regmap, PLL_USER_CTL(pll),
1602 				(BIT(pll->width) - 1) << pll->post_div_shift,
1603 				val << pll->post_div_shift);
1604 }
1605 
1606 const struct clk_ops clk_alpha_pll_postdiv_fabia_ops = {
1607 	.recalc_rate = clk_alpha_pll_postdiv_fabia_recalc_rate,
1608 	.round_rate = clk_alpha_pll_postdiv_fabia_round_rate,
1609 	.set_rate = clk_alpha_pll_postdiv_fabia_set_rate,
1610 };
1611 EXPORT_SYMBOL_GPL(clk_alpha_pll_postdiv_fabia_ops);
1612 
1613 /**
1614  * clk_trion_pll_configure - configure the trion pll
1615  *
1616  * @pll: clk alpha pll
1617  * @regmap: register map
1618  * @config: configuration to apply for pll
1619  */
clk_trion_pll_configure(struct clk_alpha_pll * pll,struct regmap * regmap,const struct alpha_pll_config * config)1620 void clk_trion_pll_configure(struct clk_alpha_pll *pll, struct regmap *regmap,
1621 			     const struct alpha_pll_config *config)
1622 {
1623 	/*
1624 	 * If the bootloader left the PLL enabled it's likely that there are
1625 	 * RCGs that will lock up if we disable the PLL below.
1626 	 */
1627 	if (trion_pll_is_enabled(pll, regmap)) {
1628 		pr_debug("Trion PLL is already enabled, skipping configuration\n");
1629 		return;
1630 	}
1631 
1632 	clk_alpha_pll_write_config(regmap, PLL_L_VAL(pll), config->l);
1633 	regmap_write(regmap, PLL_CAL_L_VAL(pll), TRION_PLL_CAL_VAL);
1634 	clk_alpha_pll_write_config(regmap, PLL_ALPHA_VAL(pll), config->alpha);
1635 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL(pll),
1636 				     config->config_ctl_val);
1637 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U(pll),
1638 				     config->config_ctl_hi_val);
1639 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U1(pll),
1640 				     config->config_ctl_hi1_val);
1641 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL(pll),
1642 					config->user_ctl_val);
1643 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL_U(pll),
1644 					config->user_ctl_hi_val);
1645 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL_U1(pll),
1646 					config->user_ctl_hi1_val);
1647 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL(pll),
1648 					config->test_ctl_val);
1649 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U(pll),
1650 					config->test_ctl_hi_val);
1651 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U1(pll),
1652 					config->test_ctl_hi1_val);
1653 
1654 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_UPDATE_BYPASS,
1655 			   PLL_UPDATE_BYPASS);
1656 
1657 	/* Disable PLL output */
1658 	regmap_update_bits(regmap, PLL_MODE(pll),  PLL_OUTCTRL, 0);
1659 
1660 	/* Set operation mode to OFF */
1661 	regmap_write(regmap, PLL_OPMODE(pll), PLL_STANDBY);
1662 
1663 	/* Place the PLL in STANDBY mode */
1664 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_RESET_N, PLL_RESET_N);
1665 }
1666 EXPORT_SYMBOL_GPL(clk_trion_pll_configure);
1667 
1668 /*
1669  * The TRION PLL requires a power-on self-calibration which happens when the
1670  * PLL comes out of reset. Calibrate in case it is not completed.
1671  */
__alpha_pll_trion_prepare(struct clk_hw * hw,u32 pcal_done)1672 static int __alpha_pll_trion_prepare(struct clk_hw *hw, u32 pcal_done)
1673 {
1674 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
1675 	u32 val;
1676 	int ret;
1677 
1678 	/* Return early if calibration is not needed. */
1679 	regmap_read(pll->clkr.regmap, PLL_STATUS(pll), &val);
1680 	if (val & pcal_done)
1681 		return 0;
1682 
1683 	/* On/off to calibrate */
1684 	ret = clk_trion_pll_enable(hw);
1685 	if (!ret)
1686 		clk_trion_pll_disable(hw);
1687 
1688 	return ret;
1689 }
1690 
alpha_pll_trion_prepare(struct clk_hw * hw)1691 static int alpha_pll_trion_prepare(struct clk_hw *hw)
1692 {
1693 	return __alpha_pll_trion_prepare(hw, TRION_PCAL_DONE);
1694 }
1695 
alpha_pll_lucid_prepare(struct clk_hw * hw)1696 static int alpha_pll_lucid_prepare(struct clk_hw *hw)
1697 {
1698 	return __alpha_pll_trion_prepare(hw, LUCID_PCAL_DONE);
1699 }
1700 
__alpha_pll_trion_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long prate,u32 latch_bit,u32 latch_ack)1701 static int __alpha_pll_trion_set_rate(struct clk_hw *hw, unsigned long rate,
1702 				      unsigned long prate, u32 latch_bit, u32 latch_ack)
1703 {
1704 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
1705 	unsigned long rrate;
1706 	u32 val, l, alpha_width = pll_alpha_width(pll);
1707 	u64 a;
1708 	int ret;
1709 
1710 	rrate = alpha_pll_round_rate(rate, prate, &l, &a, alpha_width);
1711 
1712 	ret = alpha_pll_check_rate_margin(hw, rrate, rate);
1713 	if (ret < 0)
1714 		return ret;
1715 
1716 	regmap_update_bits(pll->clkr.regmap, PLL_L_VAL(pll), LUCID_EVO_PLL_L_VAL_MASK,  l);
1717 	regmap_write(pll->clkr.regmap, PLL_ALPHA_VAL(pll), a);
1718 
1719 	/* Latch the PLL input */
1720 	ret = regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll), latch_bit, latch_bit);
1721 	if (ret)
1722 		return ret;
1723 
1724 	/* Wait for 2 reference cycles before checking the ACK bit. */
1725 	udelay(1);
1726 	regmap_read(pll->clkr.regmap, PLL_MODE(pll), &val);
1727 	if (!(val & latch_ack)) {
1728 		pr_err("Lucid PLL latch failed. Output may be unstable!\n");
1729 		return -EINVAL;
1730 	}
1731 
1732 	/* Return the latch input to 0 */
1733 	ret = regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll), latch_bit, 0);
1734 	if (ret)
1735 		return ret;
1736 
1737 	if (clk_hw_is_enabled(hw)) {
1738 		ret = wait_for_pll_enable_lock(pll);
1739 		if (ret)
1740 			return ret;
1741 	}
1742 
1743 	/* Wait for PLL output to stabilize */
1744 	udelay(100);
1745 	return 0;
1746 }
1747 
alpha_pll_trion_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long prate)1748 static int alpha_pll_trion_set_rate(struct clk_hw *hw, unsigned long rate,
1749 				    unsigned long prate)
1750 {
1751 	return __alpha_pll_trion_set_rate(hw, rate, prate, PLL_UPDATE, ALPHA_PLL_ACK_LATCH);
1752 }
1753 
1754 const struct clk_ops clk_alpha_pll_trion_ops = {
1755 	.prepare = alpha_pll_trion_prepare,
1756 	.enable = clk_trion_pll_enable,
1757 	.disable = clk_trion_pll_disable,
1758 	.is_enabled = clk_trion_pll_is_enabled,
1759 	.recalc_rate = clk_trion_pll_recalc_rate,
1760 	.round_rate = clk_alpha_pll_round_rate,
1761 	.set_rate = alpha_pll_trion_set_rate,
1762 };
1763 EXPORT_SYMBOL_GPL(clk_alpha_pll_trion_ops);
1764 
1765 const struct clk_ops clk_alpha_pll_lucid_ops = {
1766 	.prepare = alpha_pll_lucid_prepare,
1767 	.enable = clk_trion_pll_enable,
1768 	.disable = clk_trion_pll_disable,
1769 	.is_enabled = clk_trion_pll_is_enabled,
1770 	.recalc_rate = clk_trion_pll_recalc_rate,
1771 	.round_rate = clk_alpha_pll_round_rate,
1772 	.set_rate = alpha_pll_trion_set_rate,
1773 };
1774 EXPORT_SYMBOL_GPL(clk_alpha_pll_lucid_ops);
1775 
1776 const struct clk_ops clk_alpha_pll_postdiv_lucid_ops = {
1777 	.recalc_rate = clk_alpha_pll_postdiv_fabia_recalc_rate,
1778 	.round_rate = clk_alpha_pll_postdiv_fabia_round_rate,
1779 	.set_rate = clk_alpha_pll_postdiv_fabia_set_rate,
1780 };
1781 EXPORT_SYMBOL_GPL(clk_alpha_pll_postdiv_lucid_ops);
1782 
clk_agera_pll_configure(struct clk_alpha_pll * pll,struct regmap * regmap,const struct alpha_pll_config * config)1783 void clk_agera_pll_configure(struct clk_alpha_pll *pll, struct regmap *regmap,
1784 			const struct alpha_pll_config *config)
1785 {
1786 	clk_alpha_pll_write_config(regmap, PLL_L_VAL(pll), config->l);
1787 	clk_alpha_pll_write_config(regmap, PLL_ALPHA_VAL(pll), config->alpha);
1788 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL(pll),
1789 							config->user_ctl_val);
1790 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL(pll),
1791 						config->config_ctl_val);
1792 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U(pll),
1793 						config->config_ctl_hi_val);
1794 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL(pll),
1795 						config->test_ctl_val);
1796 	clk_alpha_pll_write_config(regmap,  PLL_TEST_CTL_U(pll),
1797 						config->test_ctl_hi_val);
1798 }
1799 EXPORT_SYMBOL_GPL(clk_agera_pll_configure);
1800 
clk_alpha_pll_agera_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long prate)1801 static int clk_alpha_pll_agera_set_rate(struct clk_hw *hw, unsigned long rate,
1802 							unsigned long prate)
1803 {
1804 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
1805 	u32 l, alpha_width = pll_alpha_width(pll);
1806 	int ret;
1807 	unsigned long rrate;
1808 	u64 a;
1809 
1810 	rrate = alpha_pll_round_rate(rate, prate, &l, &a, alpha_width);
1811 	ret = alpha_pll_check_rate_margin(hw, rrate, rate);
1812 	if (ret < 0)
1813 		return ret;
1814 
1815 	/* change L_VAL without having to go through the power on sequence */
1816 	regmap_write(pll->clkr.regmap, PLL_L_VAL(pll), l);
1817 	regmap_write(pll->clkr.regmap, PLL_ALPHA_VAL(pll), a);
1818 
1819 	if (clk_hw_is_enabled(hw))
1820 		return wait_for_pll_enable_lock(pll);
1821 
1822 	return 0;
1823 }
1824 
1825 const struct clk_ops clk_alpha_pll_agera_ops = {
1826 	.enable = clk_alpha_pll_enable,
1827 	.disable = clk_alpha_pll_disable,
1828 	.is_enabled = clk_alpha_pll_is_enabled,
1829 	.recalc_rate = alpha_pll_fabia_recalc_rate,
1830 	.round_rate = clk_alpha_pll_round_rate,
1831 	.set_rate = clk_alpha_pll_agera_set_rate,
1832 };
1833 EXPORT_SYMBOL_GPL(clk_alpha_pll_agera_ops);
1834 
1835 /**
1836  * clk_lucid_5lpe_pll_configure - configure the lucid 5lpe pll
1837  *
1838  * @pll: clk alpha pll
1839  * @regmap: register map
1840  * @config: configuration to apply for pll
1841  */
clk_lucid_5lpe_pll_configure(struct clk_alpha_pll * pll,struct regmap * regmap,const struct alpha_pll_config * config)1842 void clk_lucid_5lpe_pll_configure(struct clk_alpha_pll *pll, struct regmap *regmap,
1843 				  const struct alpha_pll_config *config)
1844 {
1845 	/*
1846 	 * If the bootloader left the PLL enabled it's likely that there are
1847 	 * RCGs that will lock up if we disable the PLL below.
1848 	 */
1849 	if (trion_pll_is_enabled(pll, regmap)) {
1850 		pr_debug("Lucid 5LPE PLL is already enabled, skipping configuration\n");
1851 		return;
1852 	}
1853 
1854 	clk_alpha_pll_write_config(regmap, PLL_L_VAL(pll), config->l);
1855 	regmap_write(regmap, PLL_CAL_L_VAL(pll), TRION_PLL_CAL_VAL);
1856 	clk_alpha_pll_write_config(regmap, PLL_ALPHA_VAL(pll), config->alpha);
1857 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL(pll),
1858 				     config->config_ctl_val);
1859 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U(pll),
1860 				     config->config_ctl_hi_val);
1861 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U1(pll),
1862 				     config->config_ctl_hi1_val);
1863 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL(pll),
1864 					config->user_ctl_val);
1865 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL_U(pll),
1866 					config->user_ctl_hi_val);
1867 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL_U1(pll),
1868 					config->user_ctl_hi1_val);
1869 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL(pll),
1870 					config->test_ctl_val);
1871 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U(pll),
1872 					config->test_ctl_hi_val);
1873 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U1(pll),
1874 					config->test_ctl_hi1_val);
1875 
1876 	/* Disable PLL output */
1877 	regmap_update_bits(regmap, PLL_MODE(pll),  PLL_OUTCTRL, 0);
1878 
1879 	/* Set operation mode to OFF */
1880 	regmap_write(regmap, PLL_OPMODE(pll), PLL_STANDBY);
1881 
1882 	/* Place the PLL in STANDBY mode */
1883 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_RESET_N, PLL_RESET_N);
1884 }
1885 EXPORT_SYMBOL_GPL(clk_lucid_5lpe_pll_configure);
1886 
alpha_pll_lucid_5lpe_enable(struct clk_hw * hw)1887 static int alpha_pll_lucid_5lpe_enable(struct clk_hw *hw)
1888 {
1889 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
1890 	u32 val;
1891 	int ret;
1892 
1893 	ret = regmap_read(pll->clkr.regmap, PLL_USER_CTL(pll), &val);
1894 	if (ret)
1895 		return ret;
1896 
1897 	/* If in FSM mode, just vote for it */
1898 	if (val & LUCID_5LPE_ENABLE_VOTE_RUN) {
1899 		ret = clk_enable_regmap(hw);
1900 		if (ret)
1901 			return ret;
1902 		return wait_for_pll_enable_lock(pll);
1903 	}
1904 
1905 	/* Check if PLL is already enabled, return if enabled */
1906 	ret = trion_pll_is_enabled(pll, pll->clkr.regmap);
1907 	if (ret < 0)
1908 		return ret;
1909 
1910 	ret = regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll), PLL_RESET_N, PLL_RESET_N);
1911 	if (ret)
1912 		return ret;
1913 
1914 	regmap_write(pll->clkr.regmap, PLL_OPMODE(pll), PLL_RUN);
1915 
1916 	ret = wait_for_pll_enable_lock(pll);
1917 	if (ret)
1918 		return ret;
1919 
1920 	/* Enable the PLL outputs */
1921 	ret = regmap_update_bits(pll->clkr.regmap, PLL_USER_CTL(pll), PLL_OUT_MASK, PLL_OUT_MASK);
1922 	if (ret)
1923 		return ret;
1924 
1925 	/* Enable the global PLL outputs */
1926 	return regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll), PLL_OUTCTRL, PLL_OUTCTRL);
1927 }
1928 
alpha_pll_lucid_5lpe_disable(struct clk_hw * hw)1929 static void alpha_pll_lucid_5lpe_disable(struct clk_hw *hw)
1930 {
1931 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
1932 	u32 val;
1933 	int ret;
1934 
1935 	ret = regmap_read(pll->clkr.regmap, PLL_USER_CTL(pll), &val);
1936 	if (ret)
1937 		return;
1938 
1939 	/* If in FSM mode, just unvote it */
1940 	if (val & LUCID_5LPE_ENABLE_VOTE_RUN) {
1941 		clk_disable_regmap(hw);
1942 		return;
1943 	}
1944 
1945 	/* Disable the global PLL output */
1946 	ret = regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll), PLL_OUTCTRL, 0);
1947 	if (ret)
1948 		return;
1949 
1950 	/* Disable the PLL outputs */
1951 	ret = regmap_update_bits(pll->clkr.regmap, PLL_USER_CTL(pll), PLL_OUT_MASK, 0);
1952 	if (ret)
1953 		return;
1954 
1955 	/* Place the PLL mode in STANDBY */
1956 	regmap_write(pll->clkr.regmap, PLL_OPMODE(pll), PLL_STANDBY);
1957 }
1958 
1959 /*
1960  * The Lucid 5LPE PLL requires a power-on self-calibration which happens
1961  * when the PLL comes out of reset. Calibrate in case it is not completed.
1962  */
alpha_pll_lucid_5lpe_prepare(struct clk_hw * hw)1963 static int alpha_pll_lucid_5lpe_prepare(struct clk_hw *hw)
1964 {
1965 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
1966 	struct clk_hw *p;
1967 	u32 val = 0;
1968 	int ret;
1969 
1970 	/* Return early if calibration is not needed. */
1971 	regmap_read(pll->clkr.regmap, PLL_MODE(pll), &val);
1972 	if (val & LUCID_5LPE_PCAL_DONE)
1973 		return 0;
1974 
1975 	p = clk_hw_get_parent(hw);
1976 	if (!p)
1977 		return -EINVAL;
1978 
1979 	ret = alpha_pll_lucid_5lpe_enable(hw);
1980 	if (ret)
1981 		return ret;
1982 
1983 	alpha_pll_lucid_5lpe_disable(hw);
1984 
1985 	return 0;
1986 }
1987 
alpha_pll_lucid_5lpe_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long prate)1988 static int alpha_pll_lucid_5lpe_set_rate(struct clk_hw *hw, unsigned long rate,
1989 					 unsigned long prate)
1990 {
1991 	return __alpha_pll_trion_set_rate(hw, rate, prate,
1992 					  LUCID_5LPE_PLL_LATCH_INPUT,
1993 					  LUCID_5LPE_ALPHA_PLL_ACK_LATCH);
1994 }
1995 
__clk_lucid_pll_postdiv_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long parent_rate,unsigned long enable_vote_run)1996 static int __clk_lucid_pll_postdiv_set_rate(struct clk_hw *hw, unsigned long rate,
1997 					    unsigned long parent_rate,
1998 					    unsigned long enable_vote_run)
1999 {
2000 	struct clk_alpha_pll_postdiv *pll = to_clk_alpha_pll_postdiv(hw);
2001 	struct regmap *regmap = pll->clkr.regmap;
2002 	int i, val, div, ret;
2003 	u32 mask;
2004 
2005 	/*
2006 	 * If the PLL is in FSM mode, then treat set_rate callback as a
2007 	 * no-operation.
2008 	 */
2009 	ret = regmap_read(regmap, PLL_USER_CTL(pll), &val);
2010 	if (ret)
2011 		return ret;
2012 
2013 	if (val & enable_vote_run)
2014 		return 0;
2015 
2016 	if (!pll->post_div_table) {
2017 		pr_err("Missing the post_div_table for the %s PLL\n",
2018 		       clk_hw_get_name(&pll->clkr.hw));
2019 		return -EINVAL;
2020 	}
2021 
2022 	div = DIV_ROUND_UP_ULL((u64)parent_rate, rate);
2023 	for (i = 0; i < pll->num_post_div; i++) {
2024 		if (pll->post_div_table[i].div == div) {
2025 			val = pll->post_div_table[i].val;
2026 			break;
2027 		}
2028 	}
2029 
2030 	mask = GENMASK(pll->width + pll->post_div_shift - 1, pll->post_div_shift);
2031 	return regmap_update_bits(pll->clkr.regmap, PLL_USER_CTL(pll),
2032 				  mask, val << pll->post_div_shift);
2033 }
2034 
clk_lucid_5lpe_pll_postdiv_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long parent_rate)2035 static int clk_lucid_5lpe_pll_postdiv_set_rate(struct clk_hw *hw, unsigned long rate,
2036 					       unsigned long parent_rate)
2037 {
2038 	return __clk_lucid_pll_postdiv_set_rate(hw, rate, parent_rate, LUCID_5LPE_ENABLE_VOTE_RUN);
2039 }
2040 
2041 const struct clk_ops clk_alpha_pll_lucid_5lpe_ops = {
2042 	.prepare = alpha_pll_lucid_5lpe_prepare,
2043 	.enable = alpha_pll_lucid_5lpe_enable,
2044 	.disable = alpha_pll_lucid_5lpe_disable,
2045 	.is_enabled = clk_trion_pll_is_enabled,
2046 	.recalc_rate = clk_trion_pll_recalc_rate,
2047 	.round_rate = clk_alpha_pll_round_rate,
2048 	.set_rate = alpha_pll_lucid_5lpe_set_rate,
2049 };
2050 EXPORT_SYMBOL_GPL(clk_alpha_pll_lucid_5lpe_ops);
2051 
2052 const struct clk_ops clk_alpha_pll_fixed_lucid_5lpe_ops = {
2053 	.enable = alpha_pll_lucid_5lpe_enable,
2054 	.disable = alpha_pll_lucid_5lpe_disable,
2055 	.is_enabled = clk_trion_pll_is_enabled,
2056 	.recalc_rate = clk_trion_pll_recalc_rate,
2057 	.round_rate = clk_alpha_pll_round_rate,
2058 };
2059 EXPORT_SYMBOL_GPL(clk_alpha_pll_fixed_lucid_5lpe_ops);
2060 
2061 const struct clk_ops clk_alpha_pll_postdiv_lucid_5lpe_ops = {
2062 	.recalc_rate = clk_alpha_pll_postdiv_fabia_recalc_rate,
2063 	.round_rate = clk_alpha_pll_postdiv_fabia_round_rate,
2064 	.set_rate = clk_lucid_5lpe_pll_postdiv_set_rate,
2065 };
2066 EXPORT_SYMBOL_GPL(clk_alpha_pll_postdiv_lucid_5lpe_ops);
2067 
clk_zonda_pll_configure(struct clk_alpha_pll * pll,struct regmap * regmap,const struct alpha_pll_config * config)2068 void clk_zonda_pll_configure(struct clk_alpha_pll *pll, struct regmap *regmap,
2069 			     const struct alpha_pll_config *config)
2070 {
2071 	clk_alpha_pll_write_config(regmap, PLL_L_VAL(pll), config->l);
2072 	clk_alpha_pll_write_config(regmap, PLL_ALPHA_VAL(pll), config->alpha);
2073 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL(pll), config->config_ctl_val);
2074 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U(pll), config->config_ctl_hi_val);
2075 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U1(pll), config->config_ctl_hi1_val);
2076 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL(pll), config->user_ctl_val);
2077 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL_U(pll), config->user_ctl_hi_val);
2078 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL_U1(pll), config->user_ctl_hi1_val);
2079 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL(pll), config->test_ctl_val);
2080 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U(pll), config->test_ctl_hi_val);
2081 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U1(pll), config->test_ctl_hi1_val);
2082 
2083 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_BYPASSNL, 0);
2084 
2085 	/* Disable PLL output */
2086 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_OUTCTRL, 0);
2087 
2088 	/* Set operation mode to OFF */
2089 	regmap_write(regmap, PLL_OPMODE(pll), PLL_STANDBY);
2090 
2091 	/* Place the PLL in STANDBY mode */
2092 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_RESET_N, PLL_RESET_N);
2093 }
2094 EXPORT_SYMBOL_GPL(clk_zonda_pll_configure);
2095 
clk_zonda_pll_enable(struct clk_hw * hw)2096 static int clk_zonda_pll_enable(struct clk_hw *hw)
2097 {
2098 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
2099 	struct regmap *regmap = pll->clkr.regmap;
2100 	u32 val;
2101 	int ret;
2102 
2103 	regmap_read(regmap, PLL_MODE(pll), &val);
2104 
2105 	/* If in FSM mode, just vote for it */
2106 	if (val & PLL_VOTE_FSM_ENA) {
2107 		ret = clk_enable_regmap(hw);
2108 		if (ret)
2109 			return ret;
2110 		return wait_for_pll_enable_active(pll);
2111 	}
2112 
2113 	/* Get the PLL out of bypass mode */
2114 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_BYPASSNL, PLL_BYPASSNL);
2115 
2116 	/*
2117 	 * H/W requires a 1us delay between disabling the bypass and
2118 	 * de-asserting the reset.
2119 	 */
2120 	udelay(1);
2121 
2122 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_RESET_N, PLL_RESET_N);
2123 
2124 	/* Set operation mode to RUN */
2125 	regmap_write(regmap, PLL_OPMODE(pll), PLL_RUN);
2126 
2127 	regmap_read(regmap, PLL_TEST_CTL(pll), &val);
2128 
2129 	/* If cfa mode then poll for freq lock */
2130 	if (val & ZONDA_STAY_IN_CFA)
2131 		ret = wait_for_zonda_pll_freq_lock(pll);
2132 	else
2133 		ret = wait_for_pll_enable_lock(pll);
2134 	if (ret)
2135 		return ret;
2136 
2137 	/* Enable the PLL outputs */
2138 	regmap_update_bits(regmap, PLL_USER_CTL(pll), ZONDA_PLL_OUT_MASK, ZONDA_PLL_OUT_MASK);
2139 
2140 	/* Enable the global PLL outputs */
2141 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_OUTCTRL, PLL_OUTCTRL);
2142 
2143 	return 0;
2144 }
2145 
clk_zonda_pll_disable(struct clk_hw * hw)2146 static void clk_zonda_pll_disable(struct clk_hw *hw)
2147 {
2148 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
2149 	struct regmap *regmap = pll->clkr.regmap;
2150 	u32 val;
2151 
2152 	regmap_read(regmap, PLL_MODE(pll), &val);
2153 
2154 	/* If in FSM mode, just unvote it */
2155 	if (val & PLL_VOTE_FSM_ENA) {
2156 		clk_disable_regmap(hw);
2157 		return;
2158 	}
2159 
2160 	/* Disable the global PLL output */
2161 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_OUTCTRL, 0);
2162 
2163 	/* Disable the PLL outputs */
2164 	regmap_update_bits(regmap, PLL_USER_CTL(pll), ZONDA_PLL_OUT_MASK, 0);
2165 
2166 	/* Put the PLL in bypass and reset */
2167 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_RESET_N | PLL_BYPASSNL, 0);
2168 
2169 	/* Place the PLL mode in OFF state */
2170 	regmap_write(regmap, PLL_OPMODE(pll), 0x0);
2171 }
2172 
zonda_pll_adjust_l_val(unsigned long rate,unsigned long prate,u32 * l)2173 static void zonda_pll_adjust_l_val(unsigned long rate, unsigned long prate, u32 *l)
2174 {
2175 	u64 remainder, quotient;
2176 
2177 	quotient = rate;
2178 	remainder = do_div(quotient, prate);
2179 
2180 	*l = rate + (u32)(remainder * 2 >= prate);
2181 }
2182 
clk_zonda_pll_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long prate)2183 static int clk_zonda_pll_set_rate(struct clk_hw *hw, unsigned long rate,
2184 				  unsigned long prate)
2185 {
2186 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
2187 	unsigned long rrate;
2188 	u32 test_ctl_val;
2189 	u32 l, alpha_width = pll_alpha_width(pll);
2190 	u64 a;
2191 	int ret;
2192 
2193 	rrate = alpha_pll_round_rate(rate, prate, &l, &a, alpha_width);
2194 
2195 	ret = alpha_pll_check_rate_margin(hw, rrate, rate);
2196 	if (ret < 0)
2197 		return ret;
2198 
2199 	if (a & PLL_ALPHA_MSB)
2200 		zonda_pll_adjust_l_val(rate, prate, &l);
2201 
2202 	regmap_write(pll->clkr.regmap, PLL_ALPHA_VAL(pll), a);
2203 	regmap_write(pll->clkr.regmap, PLL_L_VAL(pll), l);
2204 
2205 	if (!clk_hw_is_enabled(hw))
2206 		return 0;
2207 
2208 	/* Wait before polling for the frequency latch */
2209 	udelay(5);
2210 
2211 	/* Read stay in cfa mode */
2212 	regmap_read(pll->clkr.regmap, PLL_TEST_CTL(pll), &test_ctl_val);
2213 
2214 	/* If cfa mode then poll for freq lock */
2215 	if (test_ctl_val & ZONDA_STAY_IN_CFA)
2216 		ret = wait_for_zonda_pll_freq_lock(pll);
2217 	else
2218 		ret = wait_for_pll_enable_lock(pll);
2219 	if (ret)
2220 		return ret;
2221 
2222 	/* Wait for PLL output to stabilize */
2223 	udelay(100);
2224 	return 0;
2225 }
2226 
2227 const struct clk_ops clk_alpha_pll_zonda_ops = {
2228 	.enable = clk_zonda_pll_enable,
2229 	.disable = clk_zonda_pll_disable,
2230 	.is_enabled = clk_trion_pll_is_enabled,
2231 	.recalc_rate = clk_trion_pll_recalc_rate,
2232 	.round_rate = clk_alpha_pll_round_rate,
2233 	.set_rate = clk_zonda_pll_set_rate,
2234 };
2235 EXPORT_SYMBOL_GPL(clk_alpha_pll_zonda_ops);
2236 
clk_lucid_evo_pll_configure(struct clk_alpha_pll * pll,struct regmap * regmap,const struct alpha_pll_config * config)2237 void clk_lucid_evo_pll_configure(struct clk_alpha_pll *pll, struct regmap *regmap,
2238 				 const struct alpha_pll_config *config)
2239 {
2240 	u32 lval = config->l;
2241 
2242 	/*
2243 	 * If the bootloader left the PLL enabled it's likely that there are
2244 	 * RCGs that will lock up if we disable the PLL below.
2245 	 */
2246 	if (trion_pll_is_enabled(pll, regmap)) {
2247 		pr_debug("Lucid Evo PLL is already enabled, skipping configuration\n");
2248 		return;
2249 	}
2250 
2251 	lval |= TRION_PLL_CAL_VAL << LUCID_EVO_PLL_CAL_L_VAL_SHIFT;
2252 	clk_alpha_pll_write_config(regmap, PLL_L_VAL(pll), lval);
2253 	clk_alpha_pll_write_config(regmap, PLL_ALPHA_VAL(pll), config->alpha);
2254 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL(pll), config->config_ctl_val);
2255 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U(pll), config->config_ctl_hi_val);
2256 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U1(pll), config->config_ctl_hi1_val);
2257 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL(pll), config->user_ctl_val);
2258 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL_U(pll), config->user_ctl_hi_val);
2259 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL(pll), config->test_ctl_val);
2260 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U(pll), config->test_ctl_hi_val);
2261 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U1(pll), config->test_ctl_hi1_val);
2262 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U2(pll), config->test_ctl_hi2_val);
2263 
2264 	/* Disable PLL output */
2265 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_OUTCTRL, 0);
2266 
2267 	/* Set operation mode to STANDBY and de-assert the reset */
2268 	regmap_write(regmap, PLL_OPMODE(pll), PLL_STANDBY);
2269 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_RESET_N, PLL_RESET_N);
2270 }
2271 EXPORT_SYMBOL_GPL(clk_lucid_evo_pll_configure);
2272 
clk_lucid_ole_pll_configure(struct clk_alpha_pll * pll,struct regmap * regmap,const struct alpha_pll_config * config)2273 void clk_lucid_ole_pll_configure(struct clk_alpha_pll *pll, struct regmap *regmap,
2274 				 const struct alpha_pll_config *config)
2275 {
2276 	u32 lval = config->l;
2277 
2278 	lval |= TRION_PLL_CAL_VAL << LUCID_EVO_PLL_CAL_L_VAL_SHIFT;
2279 	lval |= TRION_PLL_CAL_VAL << LUCID_OLE_PLL_RINGOSC_CAL_L_VAL_SHIFT;
2280 	clk_alpha_pll_write_config(regmap, PLL_L_VAL(pll), lval);
2281 	clk_alpha_pll_write_config(regmap, PLL_ALPHA_VAL(pll), config->alpha);
2282 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL(pll), config->config_ctl_val);
2283 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U(pll), config->config_ctl_hi_val);
2284 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U1(pll), config->config_ctl_hi1_val);
2285 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL(pll), config->user_ctl_val);
2286 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL_U(pll), config->user_ctl_hi_val);
2287 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL(pll), config->test_ctl_val);
2288 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U(pll), config->test_ctl_hi_val);
2289 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U1(pll), config->test_ctl_hi1_val);
2290 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U2(pll), config->test_ctl_hi2_val);
2291 
2292 	/* Disable PLL output */
2293 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_OUTCTRL, 0);
2294 
2295 	/* Set operation mode to STANDBY and de-assert the reset */
2296 	regmap_write(regmap, PLL_OPMODE(pll), PLL_STANDBY);
2297 	regmap_update_bits(regmap, PLL_MODE(pll), PLL_RESET_N, PLL_RESET_N);
2298 }
2299 EXPORT_SYMBOL_GPL(clk_lucid_ole_pll_configure);
2300 
alpha_pll_lucid_evo_enable(struct clk_hw * hw)2301 static int alpha_pll_lucid_evo_enable(struct clk_hw *hw)
2302 {
2303 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
2304 	struct regmap *regmap = pll->clkr.regmap;
2305 	u32 val;
2306 	int ret;
2307 
2308 	ret = regmap_read(regmap, PLL_USER_CTL(pll), &val);
2309 	if (ret)
2310 		return ret;
2311 
2312 	/* If in FSM mode, just vote for it */
2313 	if (val & LUCID_EVO_ENABLE_VOTE_RUN) {
2314 		ret = clk_enable_regmap(hw);
2315 		if (ret)
2316 			return ret;
2317 		return wait_for_pll_enable_lock(pll);
2318 	}
2319 
2320 	/* Check if PLL is already enabled */
2321 	ret = trion_pll_is_enabled(pll, regmap);
2322 	if (ret < 0) {
2323 		return ret;
2324 	} else if (ret) {
2325 		pr_warn("%s PLL is already enabled\n", clk_hw_get_name(&pll->clkr.hw));
2326 		return 0;
2327 	}
2328 
2329 	ret = regmap_update_bits(regmap, PLL_MODE(pll), PLL_RESET_N, PLL_RESET_N);
2330 	if (ret)
2331 		return ret;
2332 
2333 	/* Set operation mode to RUN */
2334 	regmap_write(regmap, PLL_OPMODE(pll), PLL_RUN);
2335 
2336 	ret = wait_for_pll_enable_lock(pll);
2337 	if (ret)
2338 		return ret;
2339 
2340 	/* Enable the PLL outputs */
2341 	ret = regmap_update_bits(regmap, PLL_USER_CTL(pll), PLL_OUT_MASK, PLL_OUT_MASK);
2342 	if (ret)
2343 		return ret;
2344 
2345 	/* Enable the global PLL outputs */
2346 	ret = regmap_update_bits(regmap, PLL_MODE(pll), PLL_OUTCTRL, PLL_OUTCTRL);
2347 	if (ret)
2348 		return ret;
2349 
2350 	/* Ensure that the write above goes through before returning. */
2351 	mb();
2352 	return ret;
2353 }
2354 
_alpha_pll_lucid_evo_disable(struct clk_hw * hw,bool reset)2355 static void _alpha_pll_lucid_evo_disable(struct clk_hw *hw, bool reset)
2356 {
2357 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
2358 	struct regmap *regmap = pll->clkr.regmap;
2359 	u32 val;
2360 	int ret;
2361 
2362 	ret = regmap_read(regmap, PLL_USER_CTL(pll), &val);
2363 	if (ret)
2364 		return;
2365 
2366 	/* If in FSM mode, just unvote it */
2367 	if (val & LUCID_EVO_ENABLE_VOTE_RUN) {
2368 		clk_disable_regmap(hw);
2369 		return;
2370 	}
2371 
2372 	/* Disable the global PLL output */
2373 	ret = regmap_update_bits(regmap, PLL_MODE(pll), PLL_OUTCTRL, 0);
2374 	if (ret)
2375 		return;
2376 
2377 	/* Disable the PLL outputs */
2378 	ret = regmap_update_bits(regmap, PLL_USER_CTL(pll), PLL_OUT_MASK, 0);
2379 	if (ret)
2380 		return;
2381 
2382 	/* Place the PLL mode in STANDBY */
2383 	regmap_write(regmap, PLL_OPMODE(pll), PLL_STANDBY);
2384 
2385 	if (reset)
2386 		regmap_update_bits(regmap, PLL_MODE(pll), PLL_RESET_N, 0);
2387 }
2388 
_alpha_pll_lucid_evo_prepare(struct clk_hw * hw,bool reset)2389 static int _alpha_pll_lucid_evo_prepare(struct clk_hw *hw, bool reset)
2390 {
2391 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
2392 	struct clk_hw *p;
2393 	u32 val = 0;
2394 	int ret;
2395 
2396 	/* Return early if calibration is not needed. */
2397 	regmap_read(pll->clkr.regmap, PLL_MODE(pll), &val);
2398 	if (!(val & LUCID_EVO_PCAL_NOT_DONE))
2399 		return 0;
2400 
2401 	p = clk_hw_get_parent(hw);
2402 	if (!p)
2403 		return -EINVAL;
2404 
2405 	ret = alpha_pll_lucid_evo_enable(hw);
2406 	if (ret)
2407 		return ret;
2408 
2409 	_alpha_pll_lucid_evo_disable(hw, reset);
2410 
2411 	return 0;
2412 }
2413 
alpha_pll_lucid_evo_disable(struct clk_hw * hw)2414 static void alpha_pll_lucid_evo_disable(struct clk_hw *hw)
2415 {
2416 	_alpha_pll_lucid_evo_disable(hw, false);
2417 }
2418 
alpha_pll_lucid_evo_prepare(struct clk_hw * hw)2419 static int alpha_pll_lucid_evo_prepare(struct clk_hw *hw)
2420 {
2421 	return _alpha_pll_lucid_evo_prepare(hw, false);
2422 }
2423 
alpha_pll_reset_lucid_evo_disable(struct clk_hw * hw)2424 static void alpha_pll_reset_lucid_evo_disable(struct clk_hw *hw)
2425 {
2426 	_alpha_pll_lucid_evo_disable(hw, true);
2427 }
2428 
alpha_pll_reset_lucid_evo_prepare(struct clk_hw * hw)2429 static int alpha_pll_reset_lucid_evo_prepare(struct clk_hw *hw)
2430 {
2431 	return _alpha_pll_lucid_evo_prepare(hw, true);
2432 }
2433 
alpha_pll_lucid_evo_recalc_rate(struct clk_hw * hw,unsigned long parent_rate)2434 static unsigned long alpha_pll_lucid_evo_recalc_rate(struct clk_hw *hw,
2435 						     unsigned long parent_rate)
2436 {
2437 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
2438 	struct regmap *regmap = pll->clkr.regmap;
2439 	u32 l, frac;
2440 
2441 	regmap_read(regmap, PLL_L_VAL(pll), &l);
2442 	l &= LUCID_EVO_PLL_L_VAL_MASK;
2443 	regmap_read(regmap, PLL_ALPHA_VAL(pll), &frac);
2444 
2445 	return alpha_pll_calc_rate(parent_rate, l, frac, pll_alpha_width(pll));
2446 }
2447 
clk_lucid_evo_pll_postdiv_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long parent_rate)2448 static int clk_lucid_evo_pll_postdiv_set_rate(struct clk_hw *hw, unsigned long rate,
2449 					      unsigned long parent_rate)
2450 {
2451 	return __clk_lucid_pll_postdiv_set_rate(hw, rate, parent_rate, LUCID_EVO_ENABLE_VOTE_RUN);
2452 }
2453 
2454 const struct clk_ops clk_alpha_pll_fixed_lucid_evo_ops = {
2455 	.enable = alpha_pll_lucid_evo_enable,
2456 	.disable = alpha_pll_lucid_evo_disable,
2457 	.is_enabled = clk_trion_pll_is_enabled,
2458 	.recalc_rate = alpha_pll_lucid_evo_recalc_rate,
2459 	.round_rate = clk_alpha_pll_round_rate,
2460 };
2461 EXPORT_SYMBOL_GPL(clk_alpha_pll_fixed_lucid_evo_ops);
2462 
2463 const struct clk_ops clk_alpha_pll_postdiv_lucid_evo_ops = {
2464 	.recalc_rate = clk_alpha_pll_postdiv_fabia_recalc_rate,
2465 	.round_rate = clk_alpha_pll_postdiv_fabia_round_rate,
2466 	.set_rate = clk_lucid_evo_pll_postdiv_set_rate,
2467 };
2468 EXPORT_SYMBOL_GPL(clk_alpha_pll_postdiv_lucid_evo_ops);
2469 
2470 const struct clk_ops clk_alpha_pll_lucid_evo_ops = {
2471 	.prepare = alpha_pll_lucid_evo_prepare,
2472 	.enable = alpha_pll_lucid_evo_enable,
2473 	.disable = alpha_pll_lucid_evo_disable,
2474 	.is_enabled = clk_trion_pll_is_enabled,
2475 	.recalc_rate = alpha_pll_lucid_evo_recalc_rate,
2476 	.round_rate = clk_alpha_pll_round_rate,
2477 	.set_rate = alpha_pll_lucid_5lpe_set_rate,
2478 };
2479 EXPORT_SYMBOL_GPL(clk_alpha_pll_lucid_evo_ops);
2480 
2481 const struct clk_ops clk_alpha_pll_reset_lucid_evo_ops = {
2482 	.prepare = alpha_pll_reset_lucid_evo_prepare,
2483 	.enable = alpha_pll_lucid_evo_enable,
2484 	.disable = alpha_pll_reset_lucid_evo_disable,
2485 	.is_enabled = clk_trion_pll_is_enabled,
2486 	.recalc_rate = alpha_pll_lucid_evo_recalc_rate,
2487 	.round_rate = clk_alpha_pll_round_rate,
2488 	.set_rate = alpha_pll_lucid_5lpe_set_rate,
2489 };
2490 EXPORT_SYMBOL_GPL(clk_alpha_pll_reset_lucid_evo_ops);
2491 
clk_rivian_evo_pll_configure(struct clk_alpha_pll * pll,struct regmap * regmap,const struct alpha_pll_config * config)2492 void clk_rivian_evo_pll_configure(struct clk_alpha_pll *pll, struct regmap *regmap,
2493 				  const struct alpha_pll_config *config)
2494 {
2495 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL(pll), config->config_ctl_val);
2496 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U(pll), config->config_ctl_hi_val);
2497 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U1(pll), config->config_ctl_hi1_val);
2498 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL(pll), config->test_ctl_val);
2499 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U(pll), config->test_ctl_hi_val);
2500 	clk_alpha_pll_write_config(regmap, PLL_L_VAL(pll), config->l);
2501 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL(pll), config->user_ctl_val);
2502 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL_U(pll), config->user_ctl_hi_val);
2503 
2504 	regmap_write(regmap, PLL_OPMODE(pll), PLL_STANDBY);
2505 
2506 	regmap_update_bits(regmap, PLL_MODE(pll),
2507 			   PLL_RESET_N | PLL_BYPASSNL | PLL_OUTCTRL,
2508 			   PLL_RESET_N | PLL_BYPASSNL);
2509 }
2510 EXPORT_SYMBOL_GPL(clk_rivian_evo_pll_configure);
2511 
clk_rivian_evo_pll_recalc_rate(struct clk_hw * hw,unsigned long parent_rate)2512 static unsigned long clk_rivian_evo_pll_recalc_rate(struct clk_hw *hw,
2513 						    unsigned long parent_rate)
2514 {
2515 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
2516 	u32 l;
2517 
2518 	regmap_read(pll->clkr.regmap, PLL_L_VAL(pll), &l);
2519 
2520 	return parent_rate * l;
2521 }
2522 
clk_rivian_evo_pll_round_rate(struct clk_hw * hw,unsigned long rate,unsigned long * prate)2523 static long clk_rivian_evo_pll_round_rate(struct clk_hw *hw, unsigned long rate,
2524 					  unsigned long *prate)
2525 {
2526 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
2527 	unsigned long min_freq, max_freq;
2528 	u32 l;
2529 	u64 a;
2530 
2531 	rate = alpha_pll_round_rate(rate, *prate, &l, &a, 0);
2532 	if (!pll->vco_table || alpha_pll_find_vco(pll, rate))
2533 		return rate;
2534 
2535 	min_freq = pll->vco_table[0].min_freq;
2536 	max_freq = pll->vco_table[pll->num_vco - 1].max_freq;
2537 
2538 	return clamp(rate, min_freq, max_freq);
2539 }
2540 
2541 const struct clk_ops clk_alpha_pll_rivian_evo_ops = {
2542 	.enable = alpha_pll_lucid_5lpe_enable,
2543 	.disable = alpha_pll_lucid_5lpe_disable,
2544 	.is_enabled = clk_trion_pll_is_enabled,
2545 	.recalc_rate = clk_rivian_evo_pll_recalc_rate,
2546 	.round_rate = clk_rivian_evo_pll_round_rate,
2547 };
2548 EXPORT_SYMBOL_GPL(clk_alpha_pll_rivian_evo_ops);
2549 
clk_stromer_pll_configure(struct clk_alpha_pll * pll,struct regmap * regmap,const struct alpha_pll_config * config)2550 void clk_stromer_pll_configure(struct clk_alpha_pll *pll, struct regmap *regmap,
2551 			       const struct alpha_pll_config *config)
2552 {
2553 	u32 val, val_u, mask, mask_u;
2554 
2555 	regmap_write(regmap, PLL_L_VAL(pll), config->l);
2556 	regmap_write(regmap, PLL_ALPHA_VAL(pll), config->alpha);
2557 	regmap_write(regmap, PLL_CONFIG_CTL(pll), config->config_ctl_val);
2558 
2559 	if (pll_has_64bit_config(pll))
2560 		regmap_write(regmap, PLL_CONFIG_CTL_U(pll),
2561 			     config->config_ctl_hi_val);
2562 
2563 	if (pll_alpha_width(pll) > 32)
2564 		regmap_write(regmap, PLL_ALPHA_VAL_U(pll), config->alpha_hi);
2565 
2566 	val = config->main_output_mask;
2567 	val |= config->aux_output_mask;
2568 	val |= config->aux2_output_mask;
2569 	val |= config->early_output_mask;
2570 	val |= config->pre_div_val;
2571 	val |= config->post_div_val;
2572 	val |= config->vco_val;
2573 	val |= config->alpha_en_mask;
2574 	val |= config->alpha_mode_mask;
2575 
2576 	mask = config->main_output_mask;
2577 	mask |= config->aux_output_mask;
2578 	mask |= config->aux2_output_mask;
2579 	mask |= config->early_output_mask;
2580 	mask |= config->pre_div_mask;
2581 	mask |= config->post_div_mask;
2582 	mask |= config->vco_mask;
2583 	mask |= config->alpha_en_mask;
2584 	mask |= config->alpha_mode_mask;
2585 
2586 	regmap_update_bits(regmap, PLL_USER_CTL(pll), mask, val);
2587 
2588 	/* Stromer APSS PLL does not enable LOCK_DET by default, so enable it */
2589 	val_u = config->status_val << ALPHA_PLL_STATUS_REG_SHIFT;
2590 	val_u |= config->lock_det;
2591 
2592 	mask_u = config->status_mask;
2593 	mask_u |= config->lock_det;
2594 
2595 	regmap_update_bits(regmap, PLL_USER_CTL_U(pll), mask_u, val_u);
2596 	regmap_write(regmap, PLL_TEST_CTL(pll), config->test_ctl_val);
2597 	regmap_write(regmap, PLL_TEST_CTL_U(pll), config->test_ctl_hi_val);
2598 
2599 	if (pll->flags & SUPPORTS_FSM_MODE)
2600 		qcom_pll_set_fsm_mode(regmap, PLL_MODE(pll), 6, 0);
2601 }
2602 EXPORT_SYMBOL_GPL(clk_stromer_pll_configure);
2603 
clk_alpha_pll_stromer_determine_rate(struct clk_hw * hw,struct clk_rate_request * req)2604 static int clk_alpha_pll_stromer_determine_rate(struct clk_hw *hw,
2605 						struct clk_rate_request *req)
2606 {
2607 	u32 l;
2608 	u64 a;
2609 
2610 	req->rate = alpha_pll_round_rate(req->rate, req->best_parent_rate,
2611 					 &l, &a, ALPHA_REG_BITWIDTH);
2612 
2613 	return 0;
2614 }
2615 
clk_alpha_pll_stromer_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long prate)2616 static int clk_alpha_pll_stromer_set_rate(struct clk_hw *hw, unsigned long rate,
2617 					  unsigned long prate)
2618 {
2619 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
2620 	int ret;
2621 	u32 l;
2622 	u64 a;
2623 
2624 	rate = alpha_pll_round_rate(rate, prate, &l, &a, ALPHA_REG_BITWIDTH);
2625 
2626 	regmap_write(pll->clkr.regmap, PLL_L_VAL(pll), l);
2627 
2628 	a <<= ALPHA_REG_BITWIDTH - ALPHA_BITWIDTH;
2629 	regmap_write(pll->clkr.regmap, PLL_ALPHA_VAL(pll), a);
2630 	regmap_write(pll->clkr.regmap, PLL_ALPHA_VAL_U(pll),
2631 		     a >> ALPHA_BITWIDTH);
2632 
2633 	regmap_update_bits(pll->clkr.regmap, PLL_USER_CTL(pll),
2634 			   PLL_ALPHA_EN, PLL_ALPHA_EN);
2635 
2636 	if (!clk_hw_is_enabled(hw))
2637 		return 0;
2638 
2639 	/*
2640 	 * Stromer PLL supports Dynamic programming.
2641 	 * It allows the PLL frequency to be changed on-the-fly without first
2642 	 * execution of a shutdown procedure followed by a bring up procedure.
2643 	 */
2644 	regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll), PLL_UPDATE,
2645 			   PLL_UPDATE);
2646 
2647 	ret = wait_for_pll_update(pll);
2648 	if (ret)
2649 		return ret;
2650 
2651 	return wait_for_pll_enable_lock(pll);
2652 }
2653 
2654 const struct clk_ops clk_alpha_pll_stromer_ops = {
2655 	.enable = clk_alpha_pll_enable,
2656 	.disable = clk_alpha_pll_disable,
2657 	.is_enabled = clk_alpha_pll_is_enabled,
2658 	.recalc_rate = clk_alpha_pll_recalc_rate,
2659 	.determine_rate = clk_alpha_pll_stromer_determine_rate,
2660 	.set_rate = clk_alpha_pll_stromer_set_rate,
2661 };
2662 EXPORT_SYMBOL_GPL(clk_alpha_pll_stromer_ops);
2663 
clk_alpha_pll_stromer_plus_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long prate)2664 static int clk_alpha_pll_stromer_plus_set_rate(struct clk_hw *hw,
2665 					       unsigned long rate,
2666 					       unsigned long prate)
2667 {
2668 	struct clk_alpha_pll *pll = to_clk_alpha_pll(hw);
2669 	u32 l, alpha_width = pll_alpha_width(pll);
2670 	int ret, pll_mode;
2671 	u64 a;
2672 
2673 	rate = alpha_pll_round_rate(rate, prate, &l, &a, alpha_width);
2674 
2675 	ret = regmap_read(pll->clkr.regmap, PLL_MODE(pll), &pll_mode);
2676 	if (ret)
2677 		return ret;
2678 
2679 	regmap_write(pll->clkr.regmap, PLL_MODE(pll), 0);
2680 
2681 	/* Delay of 2 output clock ticks required until output is disabled */
2682 	udelay(1);
2683 
2684 	regmap_write(pll->clkr.regmap, PLL_L_VAL(pll), l);
2685 
2686 	if (alpha_width > ALPHA_BITWIDTH)
2687 		a <<= alpha_width - ALPHA_BITWIDTH;
2688 
2689 	regmap_write(pll->clkr.regmap, PLL_ALPHA_VAL(pll), a);
2690 	regmap_write(pll->clkr.regmap, PLL_ALPHA_VAL_U(pll),
2691 					a >> ALPHA_BITWIDTH);
2692 
2693 	regmap_update_bits(pll->clkr.regmap, PLL_USER_CTL(pll),
2694 			   PLL_ALPHA_EN, PLL_ALPHA_EN);
2695 
2696 	regmap_write(pll->clkr.regmap, PLL_MODE(pll), PLL_BYPASSNL);
2697 
2698 	/* Wait five micro seconds or more */
2699 	udelay(5);
2700 	regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll), PLL_RESET_N,
2701 			   PLL_RESET_N);
2702 
2703 	/* The lock time should be less than 50 micro seconds worst case */
2704 	usleep_range(50, 60);
2705 
2706 	ret = wait_for_pll_enable_lock(pll);
2707 	if (ret) {
2708 		pr_err("Wait for PLL enable lock failed [%s] %d\n",
2709 		       clk_hw_get_name(hw), ret);
2710 		return ret;
2711 	}
2712 
2713 	if (pll_mode & PLL_OUTCTRL)
2714 		regmap_update_bits(pll->clkr.regmap, PLL_MODE(pll), PLL_OUTCTRL,
2715 				   PLL_OUTCTRL);
2716 
2717 	return 0;
2718 }
2719 
2720 const struct clk_ops clk_alpha_pll_stromer_plus_ops = {
2721 	.prepare = clk_alpha_pll_enable,
2722 	.unprepare = clk_alpha_pll_disable,
2723 	.is_enabled = clk_alpha_pll_is_enabled,
2724 	.recalc_rate = clk_alpha_pll_recalc_rate,
2725 	.determine_rate = clk_alpha_pll_stromer_determine_rate,
2726 	.set_rate = clk_alpha_pll_stromer_plus_set_rate,
2727 };
2728 EXPORT_SYMBOL_GPL(clk_alpha_pll_stromer_plus_ops);
2729 
clk_regera_pll_configure(struct clk_alpha_pll * pll,struct regmap * regmap,const struct alpha_pll_config * config)2730 void clk_regera_pll_configure(struct clk_alpha_pll *pll, struct regmap *regmap,
2731 			     const struct alpha_pll_config *config)
2732 {
2733 	clk_alpha_pll_write_config(regmap, PLL_L_VAL(pll), config->l);
2734 	clk_alpha_pll_write_config(regmap, PLL_ALPHA_VAL(pll), config->alpha);
2735 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL(pll), config->config_ctl_val);
2736 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U(pll), config->config_ctl_hi_val);
2737 	clk_alpha_pll_write_config(regmap, PLL_CONFIG_CTL_U1(pll), config->config_ctl_hi1_val);
2738 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL(pll), config->user_ctl_val);
2739 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL_U(pll), config->user_ctl_hi_val);
2740 	clk_alpha_pll_write_config(regmap, PLL_USER_CTL_U1(pll), config->user_ctl_hi1_val);
2741 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL(pll), config->test_ctl_val);
2742 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U(pll), config->test_ctl_hi_val);
2743 	clk_alpha_pll_write_config(regmap, PLL_TEST_CTL_U1(pll), config->test_ctl_hi1_val);
2744 
2745 	/* Set operation mode to STANDBY */
2746 	regmap_write(regmap, PLL_OPMODE(pll), PLL_STANDBY);
2747 }
2748 EXPORT_SYMBOL_GPL(clk_regera_pll_configure);
2749 
2750 const struct clk_ops clk_alpha_pll_regera_ops = {
2751 	.enable = clk_zonda_pll_enable,
2752 	.disable = clk_zonda_pll_disable,
2753 	.is_enabled = clk_alpha_pll_is_enabled,
2754 	.recalc_rate = clk_trion_pll_recalc_rate,
2755 	.round_rate = clk_alpha_pll_round_rate,
2756 	.set_rate = clk_zonda_pll_set_rate,
2757 };
2758 EXPORT_SYMBOL_GPL(clk_alpha_pll_regera_ops);
2759