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