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