xref: /linux/drivers/gpu/drm/i915/display/intel_dpll_mgr.c (revision 7255fcc80d4b525cc10cfaaf7f485830d4ed2000)
1 /*
2  * Copyright © 2006-2016 Intel Corporation
3  *
4  * Permission is hereby granted, free of charge, to any person obtaining a
5  * copy of this software and associated documentation files (the "Software"),
6  * to deal in the Software without restriction, including without limitation
7  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8  * and/or sell copies of the Software, and to permit persons to whom the
9  * Software is furnished to do so, subject to the following conditions:
10  *
11  * The above copyright notice and this permission notice (including the next
12  * paragraph) shall be included in all copies or substantial portions of the
13  * Software.
14  *
15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21  * DEALINGS IN THE SOFTWARE.
22  */
23 
24 #include <linux/math.h>
25 #include <linux/string_helpers.h>
26 
27 #include "i915_reg.h"
28 #include "intel_de.h"
29 #include "intel_display_types.h"
30 #include "intel_dkl_phy.h"
31 #include "intel_dkl_phy_regs.h"
32 #include "intel_dpio_phy.h"
33 #include "intel_dpll.h"
34 #include "intel_dpll_mgr.h"
35 #include "intel_hti.h"
36 #include "intel_mg_phy_regs.h"
37 #include "intel_pch_refclk.h"
38 #include "intel_tc.h"
39 
40 /**
41  * DOC: Display PLLs
42  *
43  * Display PLLs used for driving outputs vary by platform. While some have
44  * per-pipe or per-encoder dedicated PLLs, others allow the use of any PLL
45  * from a pool. In the latter scenario, it is possible that multiple pipes
46  * share a PLL if their configurations match.
47  *
48  * This file provides an abstraction over display PLLs. The function
49  * intel_shared_dpll_init() initializes the PLLs for the given platform.  The
50  * users of a PLL are tracked and that tracking is integrated with the atomic
51  * modset interface. During an atomic operation, required PLLs can be reserved
52  * for a given CRTC and encoder configuration by calling
53  * intel_reserve_shared_dplls() and previously reserved PLLs can be released
54  * with intel_release_shared_dplls().
55  * Changes to the users are first staged in the atomic state, and then made
56  * effective by calling intel_shared_dpll_swap_state() during the atomic
57  * commit phase.
58  */
59 
60 /* platform specific hooks for managing DPLLs */
61 struct intel_shared_dpll_funcs {
62 	/*
63 	 * Hook for enabling the pll, called from intel_enable_shared_dpll() if
64 	 * the pll is not already enabled.
65 	 */
66 	void (*enable)(struct drm_i915_private *i915,
67 		       struct intel_shared_dpll *pll);
68 
69 	/*
70 	 * Hook for disabling the pll, called from intel_disable_shared_dpll()
71 	 * only when it is safe to disable the pll, i.e., there are no more
72 	 * tracked users for it.
73 	 */
74 	void (*disable)(struct drm_i915_private *i915,
75 			struct intel_shared_dpll *pll);
76 
77 	/*
78 	 * Hook for reading the values currently programmed to the DPLL
79 	 * registers. This is used for initial hw state readout and state
80 	 * verification after a mode set.
81 	 */
82 	bool (*get_hw_state)(struct drm_i915_private *i915,
83 			     struct intel_shared_dpll *pll,
84 			     struct intel_dpll_hw_state *hw_state);
85 
86 	/*
87 	 * Hook for calculating the pll's output frequency based on its passed
88 	 * in state.
89 	 */
90 	int (*get_freq)(struct drm_i915_private *i915,
91 			const struct intel_shared_dpll *pll,
92 			const struct intel_dpll_hw_state *pll_state);
93 };
94 
95 struct intel_dpll_mgr {
96 	const struct dpll_info *dpll_info;
97 
98 	int (*compute_dplls)(struct intel_atomic_state *state,
99 			     struct intel_crtc *crtc,
100 			     struct intel_encoder *encoder);
101 	int (*get_dplls)(struct intel_atomic_state *state,
102 			 struct intel_crtc *crtc,
103 			 struct intel_encoder *encoder);
104 	void (*put_dplls)(struct intel_atomic_state *state,
105 			  struct intel_crtc *crtc);
106 	void (*update_active_dpll)(struct intel_atomic_state *state,
107 				   struct intel_crtc *crtc,
108 				   struct intel_encoder *encoder);
109 	void (*update_ref_clks)(struct drm_i915_private *i915);
110 	void (*dump_hw_state)(struct drm_i915_private *i915,
111 			      const struct intel_dpll_hw_state *hw_state);
112 	bool (*compare_hw_state)(const struct intel_dpll_hw_state *a,
113 				 const struct intel_dpll_hw_state *b);
114 };
115 
116 static void
117 intel_atomic_duplicate_dpll_state(struct drm_i915_private *i915,
118 				  struct intel_shared_dpll_state *shared_dpll)
119 {
120 	struct intel_shared_dpll *pll;
121 	int i;
122 
123 	/* Copy shared dpll state */
124 	for_each_shared_dpll(i915, pll, i)
125 		shared_dpll[pll->index] = pll->state;
126 }
127 
128 static struct intel_shared_dpll_state *
129 intel_atomic_get_shared_dpll_state(struct drm_atomic_state *s)
130 {
131 	struct intel_atomic_state *state = to_intel_atomic_state(s);
132 
133 	drm_WARN_ON(s->dev, !drm_modeset_is_locked(&s->dev->mode_config.connection_mutex));
134 
135 	if (!state->dpll_set) {
136 		state->dpll_set = true;
137 
138 		intel_atomic_duplicate_dpll_state(to_i915(s->dev),
139 						  state->shared_dpll);
140 	}
141 
142 	return state->shared_dpll;
143 }
144 
145 /**
146  * intel_get_shared_dpll_by_id - get a DPLL given its id
147  * @i915: i915 device instance
148  * @id: pll id
149  *
150  * Returns:
151  * A pointer to the DPLL with @id
152  */
153 struct intel_shared_dpll *
154 intel_get_shared_dpll_by_id(struct drm_i915_private *i915,
155 			    enum intel_dpll_id id)
156 {
157 	struct intel_shared_dpll *pll;
158 	int i;
159 
160 	for_each_shared_dpll(i915, pll, i) {
161 		if (pll->info->id == id)
162 			return pll;
163 	}
164 
165 	MISSING_CASE(id);
166 	return NULL;
167 }
168 
169 /* For ILK+ */
170 void assert_shared_dpll(struct drm_i915_private *i915,
171 			struct intel_shared_dpll *pll,
172 			bool state)
173 {
174 	bool cur_state;
175 	struct intel_dpll_hw_state hw_state;
176 
177 	if (drm_WARN(&i915->drm, !pll,
178 		     "asserting DPLL %s with no DPLL\n", str_on_off(state)))
179 		return;
180 
181 	cur_state = intel_dpll_get_hw_state(i915, pll, &hw_state);
182 	I915_STATE_WARN(i915, cur_state != state,
183 			"%s assertion failure (expected %s, current %s)\n",
184 			pll->info->name, str_on_off(state),
185 			str_on_off(cur_state));
186 }
187 
188 static enum tc_port icl_pll_id_to_tc_port(enum intel_dpll_id id)
189 {
190 	return TC_PORT_1 + id - DPLL_ID_ICL_MGPLL1;
191 }
192 
193 enum intel_dpll_id icl_tc_port_to_pll_id(enum tc_port tc_port)
194 {
195 	return tc_port - TC_PORT_1 + DPLL_ID_ICL_MGPLL1;
196 }
197 
198 static i915_reg_t
199 intel_combo_pll_enable_reg(struct drm_i915_private *i915,
200 			   struct intel_shared_dpll *pll)
201 {
202 	if (IS_DG1(i915))
203 		return DG1_DPLL_ENABLE(pll->info->id);
204 	else if ((IS_JASPERLAKE(i915) || IS_ELKHARTLAKE(i915)) &&
205 		 (pll->info->id == DPLL_ID_EHL_DPLL4))
206 		return MG_PLL_ENABLE(0);
207 
208 	return ICL_DPLL_ENABLE(pll->info->id);
209 }
210 
211 static i915_reg_t
212 intel_tc_pll_enable_reg(struct drm_i915_private *i915,
213 			struct intel_shared_dpll *pll)
214 {
215 	const enum intel_dpll_id id = pll->info->id;
216 	enum tc_port tc_port = icl_pll_id_to_tc_port(id);
217 
218 	if (IS_ALDERLAKE_P(i915))
219 		return ADLP_PORTTC_PLL_ENABLE(tc_port);
220 
221 	return MG_PLL_ENABLE(tc_port);
222 }
223 
224 static void _intel_enable_shared_dpll(struct drm_i915_private *i915,
225 				      struct intel_shared_dpll *pll)
226 {
227 	if (pll->info->power_domain)
228 		pll->wakeref = intel_display_power_get(i915, pll->info->power_domain);
229 
230 	pll->info->funcs->enable(i915, pll);
231 	pll->on = true;
232 }
233 
234 static void _intel_disable_shared_dpll(struct drm_i915_private *i915,
235 				       struct intel_shared_dpll *pll)
236 {
237 	pll->info->funcs->disable(i915, pll);
238 	pll->on = false;
239 
240 	if (pll->info->power_domain)
241 		intel_display_power_put(i915, pll->info->power_domain, pll->wakeref);
242 }
243 
244 /**
245  * intel_enable_shared_dpll - enable a CRTC's shared DPLL
246  * @crtc_state: CRTC, and its state, which has a shared DPLL
247  *
248  * Enable the shared DPLL used by @crtc.
249  */
250 void intel_enable_shared_dpll(const struct intel_crtc_state *crtc_state)
251 {
252 	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
253 	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
254 	struct intel_shared_dpll *pll = crtc_state->shared_dpll;
255 	unsigned int pipe_mask = BIT(crtc->pipe);
256 	unsigned int old_mask;
257 
258 	if (drm_WARN_ON(&i915->drm, pll == NULL))
259 		return;
260 
261 	mutex_lock(&i915->display.dpll.lock);
262 	old_mask = pll->active_mask;
263 
264 	if (drm_WARN_ON(&i915->drm, !(pll->state.pipe_mask & pipe_mask)) ||
265 	    drm_WARN_ON(&i915->drm, pll->active_mask & pipe_mask))
266 		goto out;
267 
268 	pll->active_mask |= pipe_mask;
269 
270 	drm_dbg_kms(&i915->drm,
271 		    "enable %s (active 0x%x, on? %d) for [CRTC:%d:%s]\n",
272 		    pll->info->name, pll->active_mask, pll->on,
273 		    crtc->base.base.id, crtc->base.name);
274 
275 	if (old_mask) {
276 		drm_WARN_ON(&i915->drm, !pll->on);
277 		assert_shared_dpll_enabled(i915, pll);
278 		goto out;
279 	}
280 	drm_WARN_ON(&i915->drm, pll->on);
281 
282 	drm_dbg_kms(&i915->drm, "enabling %s\n", pll->info->name);
283 
284 	_intel_enable_shared_dpll(i915, pll);
285 
286 out:
287 	mutex_unlock(&i915->display.dpll.lock);
288 }
289 
290 /**
291  * intel_disable_shared_dpll - disable a CRTC's shared DPLL
292  * @crtc_state: CRTC, and its state, which has a shared DPLL
293  *
294  * Disable the shared DPLL used by @crtc.
295  */
296 void intel_disable_shared_dpll(const struct intel_crtc_state *crtc_state)
297 {
298 	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
299 	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
300 	struct intel_shared_dpll *pll = crtc_state->shared_dpll;
301 	unsigned int pipe_mask = BIT(crtc->pipe);
302 
303 	/* PCH only available on ILK+ */
304 	if (DISPLAY_VER(i915) < 5)
305 		return;
306 
307 	if (pll == NULL)
308 		return;
309 
310 	mutex_lock(&i915->display.dpll.lock);
311 	if (drm_WARN(&i915->drm, !(pll->active_mask & pipe_mask),
312 		     "%s not used by [CRTC:%d:%s]\n", pll->info->name,
313 		     crtc->base.base.id, crtc->base.name))
314 		goto out;
315 
316 	drm_dbg_kms(&i915->drm,
317 		    "disable %s (active 0x%x, on? %d) for [CRTC:%d:%s]\n",
318 		    pll->info->name, pll->active_mask, pll->on,
319 		    crtc->base.base.id, crtc->base.name);
320 
321 	assert_shared_dpll_enabled(i915, pll);
322 	drm_WARN_ON(&i915->drm, !pll->on);
323 
324 	pll->active_mask &= ~pipe_mask;
325 	if (pll->active_mask)
326 		goto out;
327 
328 	drm_dbg_kms(&i915->drm, "disabling %s\n", pll->info->name);
329 
330 	_intel_disable_shared_dpll(i915, pll);
331 
332 out:
333 	mutex_unlock(&i915->display.dpll.lock);
334 }
335 
336 static unsigned long
337 intel_dpll_mask_all(struct drm_i915_private *i915)
338 {
339 	struct intel_shared_dpll *pll;
340 	unsigned long dpll_mask = 0;
341 	int i;
342 
343 	for_each_shared_dpll(i915, pll, i) {
344 		drm_WARN_ON(&i915->drm, dpll_mask & BIT(pll->info->id));
345 
346 		dpll_mask |= BIT(pll->info->id);
347 	}
348 
349 	return dpll_mask;
350 }
351 
352 static struct intel_shared_dpll *
353 intel_find_shared_dpll(struct intel_atomic_state *state,
354 		       const struct intel_crtc *crtc,
355 		       const struct intel_dpll_hw_state *pll_state,
356 		       unsigned long dpll_mask)
357 {
358 	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
359 	unsigned long dpll_mask_all = intel_dpll_mask_all(i915);
360 	struct intel_shared_dpll_state *shared_dpll;
361 	struct intel_shared_dpll *unused_pll = NULL;
362 	enum intel_dpll_id id;
363 
364 	shared_dpll = intel_atomic_get_shared_dpll_state(&state->base);
365 
366 	drm_WARN_ON(&i915->drm, dpll_mask & ~dpll_mask_all);
367 
368 	for_each_set_bit(id, &dpll_mask, fls(dpll_mask_all)) {
369 		struct intel_shared_dpll *pll;
370 
371 		pll = intel_get_shared_dpll_by_id(i915, id);
372 		if (!pll)
373 			continue;
374 
375 		/* Only want to check enabled timings first */
376 		if (shared_dpll[pll->index].pipe_mask == 0) {
377 			if (!unused_pll)
378 				unused_pll = pll;
379 			continue;
380 		}
381 
382 		if (memcmp(pll_state,
383 			   &shared_dpll[pll->index].hw_state,
384 			   sizeof(*pll_state)) == 0) {
385 			drm_dbg_kms(&i915->drm,
386 				    "[CRTC:%d:%s] sharing existing %s (pipe mask 0x%x, active 0x%x)\n",
387 				    crtc->base.base.id, crtc->base.name,
388 				    pll->info->name,
389 				    shared_dpll[pll->index].pipe_mask,
390 				    pll->active_mask);
391 			return pll;
392 		}
393 	}
394 
395 	/* Ok no matching timings, maybe there's a free one? */
396 	if (unused_pll) {
397 		drm_dbg_kms(&i915->drm, "[CRTC:%d:%s] allocated %s\n",
398 			    crtc->base.base.id, crtc->base.name,
399 			    unused_pll->info->name);
400 		return unused_pll;
401 	}
402 
403 	return NULL;
404 }
405 
406 /**
407  * intel_reference_shared_dpll_crtc - Get a DPLL reference for a CRTC
408  * @crtc: CRTC on which behalf the reference is taken
409  * @pll: DPLL for which the reference is taken
410  * @shared_dpll_state: the DPLL atomic state in which the reference is tracked
411  *
412  * Take a reference for @pll tracking the use of it by @crtc.
413  */
414 static void
415 intel_reference_shared_dpll_crtc(const struct intel_crtc *crtc,
416 				 const struct intel_shared_dpll *pll,
417 				 struct intel_shared_dpll_state *shared_dpll_state)
418 {
419 	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
420 
421 	drm_WARN_ON(&i915->drm, (shared_dpll_state->pipe_mask & BIT(crtc->pipe)) != 0);
422 
423 	shared_dpll_state->pipe_mask |= BIT(crtc->pipe);
424 
425 	drm_dbg_kms(&i915->drm, "[CRTC:%d:%s] reserving %s\n",
426 		    crtc->base.base.id, crtc->base.name, pll->info->name);
427 }
428 
429 static void
430 intel_reference_shared_dpll(struct intel_atomic_state *state,
431 			    const struct intel_crtc *crtc,
432 			    const struct intel_shared_dpll *pll,
433 			    const struct intel_dpll_hw_state *pll_state)
434 {
435 	struct intel_shared_dpll_state *shared_dpll;
436 
437 	shared_dpll = intel_atomic_get_shared_dpll_state(&state->base);
438 
439 	if (shared_dpll[pll->index].pipe_mask == 0)
440 		shared_dpll[pll->index].hw_state = *pll_state;
441 
442 	intel_reference_shared_dpll_crtc(crtc, pll, &shared_dpll[pll->index]);
443 }
444 
445 /**
446  * intel_unreference_shared_dpll_crtc - Drop a DPLL reference for a CRTC
447  * @crtc: CRTC on which behalf the reference is dropped
448  * @pll: DPLL for which the reference is dropped
449  * @shared_dpll_state: the DPLL atomic state in which the reference is tracked
450  *
451  * Drop a reference for @pll tracking the end of use of it by @crtc.
452  */
453 void
454 intel_unreference_shared_dpll_crtc(const struct intel_crtc *crtc,
455 				   const struct intel_shared_dpll *pll,
456 				   struct intel_shared_dpll_state *shared_dpll_state)
457 {
458 	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
459 
460 	drm_WARN_ON(&i915->drm, (shared_dpll_state->pipe_mask & BIT(crtc->pipe)) == 0);
461 
462 	shared_dpll_state->pipe_mask &= ~BIT(crtc->pipe);
463 
464 	drm_dbg_kms(&i915->drm, "[CRTC:%d:%s] releasing %s\n",
465 		    crtc->base.base.id, crtc->base.name, pll->info->name);
466 }
467 
468 static void intel_unreference_shared_dpll(struct intel_atomic_state *state,
469 					  const struct intel_crtc *crtc,
470 					  const struct intel_shared_dpll *pll)
471 {
472 	struct intel_shared_dpll_state *shared_dpll;
473 
474 	shared_dpll = intel_atomic_get_shared_dpll_state(&state->base);
475 
476 	intel_unreference_shared_dpll_crtc(crtc, pll, &shared_dpll[pll->index]);
477 }
478 
479 static void intel_put_dpll(struct intel_atomic_state *state,
480 			   struct intel_crtc *crtc)
481 {
482 	const struct intel_crtc_state *old_crtc_state =
483 		intel_atomic_get_old_crtc_state(state, crtc);
484 	struct intel_crtc_state *new_crtc_state =
485 		intel_atomic_get_new_crtc_state(state, crtc);
486 
487 	new_crtc_state->shared_dpll = NULL;
488 
489 	if (!old_crtc_state->shared_dpll)
490 		return;
491 
492 	intel_unreference_shared_dpll(state, crtc, old_crtc_state->shared_dpll);
493 }
494 
495 /**
496  * intel_shared_dpll_swap_state - make atomic DPLL configuration effective
497  * @state: atomic state
498  *
499  * This is the dpll version of drm_atomic_helper_swap_state() since the
500  * helper does not handle driver-specific global state.
501  *
502  * For consistency with atomic helpers this function does a complete swap,
503  * i.e. it also puts the current state into @state, even though there is no
504  * need for that at this moment.
505  */
506 void intel_shared_dpll_swap_state(struct intel_atomic_state *state)
507 {
508 	struct drm_i915_private *i915 = to_i915(state->base.dev);
509 	struct intel_shared_dpll_state *shared_dpll = state->shared_dpll;
510 	struct intel_shared_dpll *pll;
511 	int i;
512 
513 	if (!state->dpll_set)
514 		return;
515 
516 	for_each_shared_dpll(i915, pll, i)
517 		swap(pll->state, shared_dpll[pll->index]);
518 }
519 
520 static bool ibx_pch_dpll_get_hw_state(struct drm_i915_private *i915,
521 				      struct intel_shared_dpll *pll,
522 				      struct intel_dpll_hw_state *hw_state)
523 {
524 	const enum intel_dpll_id id = pll->info->id;
525 	intel_wakeref_t wakeref;
526 	u32 val;
527 
528 	wakeref = intel_display_power_get_if_enabled(i915,
529 						     POWER_DOMAIN_DISPLAY_CORE);
530 	if (!wakeref)
531 		return false;
532 
533 	val = intel_de_read(i915, PCH_DPLL(id));
534 	hw_state->dpll = val;
535 	hw_state->fp0 = intel_de_read(i915, PCH_FP0(id));
536 	hw_state->fp1 = intel_de_read(i915, PCH_FP1(id));
537 
538 	intel_display_power_put(i915, POWER_DOMAIN_DISPLAY_CORE, wakeref);
539 
540 	return val & DPLL_VCO_ENABLE;
541 }
542 
543 static void ibx_assert_pch_refclk_enabled(struct drm_i915_private *i915)
544 {
545 	u32 val;
546 	bool enabled;
547 
548 	val = intel_de_read(i915, PCH_DREF_CONTROL);
549 	enabled = !!(val & (DREF_SSC_SOURCE_MASK | DREF_NONSPREAD_SOURCE_MASK |
550 			    DREF_SUPERSPREAD_SOURCE_MASK));
551 	I915_STATE_WARN(i915, !enabled,
552 			"PCH refclk assertion failure, should be active but is disabled\n");
553 }
554 
555 static void ibx_pch_dpll_enable(struct drm_i915_private *i915,
556 				struct intel_shared_dpll *pll)
557 {
558 	const enum intel_dpll_id id = pll->info->id;
559 
560 	/* PCH refclock must be enabled first */
561 	ibx_assert_pch_refclk_enabled(i915);
562 
563 	intel_de_write(i915, PCH_FP0(id), pll->state.hw_state.fp0);
564 	intel_de_write(i915, PCH_FP1(id), pll->state.hw_state.fp1);
565 
566 	intel_de_write(i915, PCH_DPLL(id), pll->state.hw_state.dpll);
567 
568 	/* Wait for the clocks to stabilize. */
569 	intel_de_posting_read(i915, PCH_DPLL(id));
570 	udelay(150);
571 
572 	/* The pixel multiplier can only be updated once the
573 	 * DPLL is enabled and the clocks are stable.
574 	 *
575 	 * So write it again.
576 	 */
577 	intel_de_write(i915, PCH_DPLL(id), pll->state.hw_state.dpll);
578 	intel_de_posting_read(i915, PCH_DPLL(id));
579 	udelay(200);
580 }
581 
582 static void ibx_pch_dpll_disable(struct drm_i915_private *i915,
583 				 struct intel_shared_dpll *pll)
584 {
585 	const enum intel_dpll_id id = pll->info->id;
586 
587 	intel_de_write(i915, PCH_DPLL(id), 0);
588 	intel_de_posting_read(i915, PCH_DPLL(id));
589 	udelay(200);
590 }
591 
592 static int ibx_compute_dpll(struct intel_atomic_state *state,
593 			    struct intel_crtc *crtc,
594 			    struct intel_encoder *encoder)
595 {
596 	return 0;
597 }
598 
599 static int ibx_get_dpll(struct intel_atomic_state *state,
600 			struct intel_crtc *crtc,
601 			struct intel_encoder *encoder)
602 {
603 	struct intel_crtc_state *crtc_state =
604 		intel_atomic_get_new_crtc_state(state, crtc);
605 	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
606 	struct intel_shared_dpll *pll;
607 	enum intel_dpll_id id;
608 
609 	if (HAS_PCH_IBX(i915)) {
610 		/* Ironlake PCH has a fixed PLL->PCH pipe mapping. */
611 		id = (enum intel_dpll_id) crtc->pipe;
612 		pll = intel_get_shared_dpll_by_id(i915, id);
613 
614 		drm_dbg_kms(&i915->drm,
615 			    "[CRTC:%d:%s] using pre-allocated %s\n",
616 			    crtc->base.base.id, crtc->base.name,
617 			    pll->info->name);
618 	} else {
619 		pll = intel_find_shared_dpll(state, crtc,
620 					     &crtc_state->dpll_hw_state,
621 					     BIT(DPLL_ID_PCH_PLL_B) |
622 					     BIT(DPLL_ID_PCH_PLL_A));
623 	}
624 
625 	if (!pll)
626 		return -EINVAL;
627 
628 	/* reference the pll */
629 	intel_reference_shared_dpll(state, crtc,
630 				    pll, &crtc_state->dpll_hw_state);
631 
632 	crtc_state->shared_dpll = pll;
633 
634 	return 0;
635 }
636 
637 static void ibx_dump_hw_state(struct drm_i915_private *i915,
638 			      const struct intel_dpll_hw_state *hw_state)
639 {
640 	drm_dbg_kms(&i915->drm,
641 		    "dpll_hw_state: dpll: 0x%x, dpll_md: 0x%x, "
642 		    "fp0: 0x%x, fp1: 0x%x\n",
643 		    hw_state->dpll,
644 		    hw_state->dpll_md,
645 		    hw_state->fp0,
646 		    hw_state->fp1);
647 }
648 
649 static bool ibx_compare_hw_state(const struct intel_dpll_hw_state *a,
650 				 const struct intel_dpll_hw_state *b)
651 {
652 	return a->dpll == b->dpll &&
653 		a->dpll_md == b->dpll_md &&
654 		a->fp0 == b->fp0 &&
655 		a->fp1 == b->fp1;
656 }
657 
658 static const struct intel_shared_dpll_funcs ibx_pch_dpll_funcs = {
659 	.enable = ibx_pch_dpll_enable,
660 	.disable = ibx_pch_dpll_disable,
661 	.get_hw_state = ibx_pch_dpll_get_hw_state,
662 };
663 
664 static const struct dpll_info pch_plls[] = {
665 	{ .name = "PCH DPLL A", .funcs = &ibx_pch_dpll_funcs, .id = DPLL_ID_PCH_PLL_A, },
666 	{ .name = "PCH DPLL B", .funcs = &ibx_pch_dpll_funcs, .id = DPLL_ID_PCH_PLL_B, },
667 	{}
668 };
669 
670 static const struct intel_dpll_mgr pch_pll_mgr = {
671 	.dpll_info = pch_plls,
672 	.compute_dplls = ibx_compute_dpll,
673 	.get_dplls = ibx_get_dpll,
674 	.put_dplls = intel_put_dpll,
675 	.dump_hw_state = ibx_dump_hw_state,
676 	.compare_hw_state = ibx_compare_hw_state,
677 };
678 
679 static void hsw_ddi_wrpll_enable(struct drm_i915_private *i915,
680 				 struct intel_shared_dpll *pll)
681 {
682 	const enum intel_dpll_id id = pll->info->id;
683 
684 	intel_de_write(i915, WRPLL_CTL(id), pll->state.hw_state.wrpll);
685 	intel_de_posting_read(i915, WRPLL_CTL(id));
686 	udelay(20);
687 }
688 
689 static void hsw_ddi_spll_enable(struct drm_i915_private *i915,
690 				struct intel_shared_dpll *pll)
691 {
692 	intel_de_write(i915, SPLL_CTL, pll->state.hw_state.spll);
693 	intel_de_posting_read(i915, SPLL_CTL);
694 	udelay(20);
695 }
696 
697 static void hsw_ddi_wrpll_disable(struct drm_i915_private *i915,
698 				  struct intel_shared_dpll *pll)
699 {
700 	const enum intel_dpll_id id = pll->info->id;
701 
702 	intel_de_rmw(i915, WRPLL_CTL(id), WRPLL_PLL_ENABLE, 0);
703 	intel_de_posting_read(i915, WRPLL_CTL(id));
704 
705 	/*
706 	 * Try to set up the PCH reference clock once all DPLLs
707 	 * that depend on it have been shut down.
708 	 */
709 	if (i915->display.dpll.pch_ssc_use & BIT(id))
710 		intel_init_pch_refclk(i915);
711 }
712 
713 static void hsw_ddi_spll_disable(struct drm_i915_private *i915,
714 				 struct intel_shared_dpll *pll)
715 {
716 	enum intel_dpll_id id = pll->info->id;
717 
718 	intel_de_rmw(i915, SPLL_CTL, SPLL_PLL_ENABLE, 0);
719 	intel_de_posting_read(i915, SPLL_CTL);
720 
721 	/*
722 	 * Try to set up the PCH reference clock once all DPLLs
723 	 * that depend on it have been shut down.
724 	 */
725 	if (i915->display.dpll.pch_ssc_use & BIT(id))
726 		intel_init_pch_refclk(i915);
727 }
728 
729 static bool hsw_ddi_wrpll_get_hw_state(struct drm_i915_private *i915,
730 				       struct intel_shared_dpll *pll,
731 				       struct intel_dpll_hw_state *hw_state)
732 {
733 	const enum intel_dpll_id id = pll->info->id;
734 	intel_wakeref_t wakeref;
735 	u32 val;
736 
737 	wakeref = intel_display_power_get_if_enabled(i915,
738 						     POWER_DOMAIN_DISPLAY_CORE);
739 	if (!wakeref)
740 		return false;
741 
742 	val = intel_de_read(i915, WRPLL_CTL(id));
743 	hw_state->wrpll = val;
744 
745 	intel_display_power_put(i915, POWER_DOMAIN_DISPLAY_CORE, wakeref);
746 
747 	return val & WRPLL_PLL_ENABLE;
748 }
749 
750 static bool hsw_ddi_spll_get_hw_state(struct drm_i915_private *i915,
751 				      struct intel_shared_dpll *pll,
752 				      struct intel_dpll_hw_state *hw_state)
753 {
754 	intel_wakeref_t wakeref;
755 	u32 val;
756 
757 	wakeref = intel_display_power_get_if_enabled(i915,
758 						     POWER_DOMAIN_DISPLAY_CORE);
759 	if (!wakeref)
760 		return false;
761 
762 	val = intel_de_read(i915, SPLL_CTL);
763 	hw_state->spll = val;
764 
765 	intel_display_power_put(i915, POWER_DOMAIN_DISPLAY_CORE, wakeref);
766 
767 	return val & SPLL_PLL_ENABLE;
768 }
769 
770 #define LC_FREQ 2700
771 #define LC_FREQ_2K U64_C(LC_FREQ * 2000)
772 
773 #define P_MIN 2
774 #define P_MAX 64
775 #define P_INC 2
776 
777 /* Constraints for PLL good behavior */
778 #define REF_MIN 48
779 #define REF_MAX 400
780 #define VCO_MIN 2400
781 #define VCO_MAX 4800
782 
783 struct hsw_wrpll_rnp {
784 	unsigned p, n2, r2;
785 };
786 
787 static unsigned hsw_wrpll_get_budget_for_freq(int clock)
788 {
789 	switch (clock) {
790 	case 25175000:
791 	case 25200000:
792 	case 27000000:
793 	case 27027000:
794 	case 37762500:
795 	case 37800000:
796 	case 40500000:
797 	case 40541000:
798 	case 54000000:
799 	case 54054000:
800 	case 59341000:
801 	case 59400000:
802 	case 72000000:
803 	case 74176000:
804 	case 74250000:
805 	case 81000000:
806 	case 81081000:
807 	case 89012000:
808 	case 89100000:
809 	case 108000000:
810 	case 108108000:
811 	case 111264000:
812 	case 111375000:
813 	case 148352000:
814 	case 148500000:
815 	case 162000000:
816 	case 162162000:
817 	case 222525000:
818 	case 222750000:
819 	case 296703000:
820 	case 297000000:
821 		return 0;
822 	case 233500000:
823 	case 245250000:
824 	case 247750000:
825 	case 253250000:
826 	case 298000000:
827 		return 1500;
828 	case 169128000:
829 	case 169500000:
830 	case 179500000:
831 	case 202000000:
832 		return 2000;
833 	case 256250000:
834 	case 262500000:
835 	case 270000000:
836 	case 272500000:
837 	case 273750000:
838 	case 280750000:
839 	case 281250000:
840 	case 286000000:
841 	case 291750000:
842 		return 4000;
843 	case 267250000:
844 	case 268500000:
845 		return 5000;
846 	default:
847 		return 1000;
848 	}
849 }
850 
851 static void hsw_wrpll_update_rnp(u64 freq2k, unsigned int budget,
852 				 unsigned int r2, unsigned int n2,
853 				 unsigned int p,
854 				 struct hsw_wrpll_rnp *best)
855 {
856 	u64 a, b, c, d, diff, diff_best;
857 
858 	/* No best (r,n,p) yet */
859 	if (best->p == 0) {
860 		best->p = p;
861 		best->n2 = n2;
862 		best->r2 = r2;
863 		return;
864 	}
865 
866 	/*
867 	 * Output clock is (LC_FREQ_2K / 2000) * N / (P * R), which compares to
868 	 * freq2k.
869 	 *
870 	 * delta = 1e6 *
871 	 *	   abs(freq2k - (LC_FREQ_2K * n2/(p * r2))) /
872 	 *	   freq2k;
873 	 *
874 	 * and we would like delta <= budget.
875 	 *
876 	 * If the discrepancy is above the PPM-based budget, always prefer to
877 	 * improve upon the previous solution.  However, if you're within the
878 	 * budget, try to maximize Ref * VCO, that is N / (P * R^2).
879 	 */
880 	a = freq2k * budget * p * r2;
881 	b = freq2k * budget * best->p * best->r2;
882 	diff = abs_diff(freq2k * p * r2, LC_FREQ_2K * n2);
883 	diff_best = abs_diff(freq2k * best->p * best->r2,
884 			     LC_FREQ_2K * best->n2);
885 	c = 1000000 * diff;
886 	d = 1000000 * diff_best;
887 
888 	if (a < c && b < d) {
889 		/* If both are above the budget, pick the closer */
890 		if (best->p * best->r2 * diff < p * r2 * diff_best) {
891 			best->p = p;
892 			best->n2 = n2;
893 			best->r2 = r2;
894 		}
895 	} else if (a >= c && b < d) {
896 		/* If A is below the threshold but B is above it?  Update. */
897 		best->p = p;
898 		best->n2 = n2;
899 		best->r2 = r2;
900 	} else if (a >= c && b >= d) {
901 		/* Both are below the limit, so pick the higher n2/(r2*r2) */
902 		if (n2 * best->r2 * best->r2 > best->n2 * r2 * r2) {
903 			best->p = p;
904 			best->n2 = n2;
905 			best->r2 = r2;
906 		}
907 	}
908 	/* Otherwise a < c && b >= d, do nothing */
909 }
910 
911 static void
912 hsw_ddi_calculate_wrpll(int clock /* in Hz */,
913 			unsigned *r2_out, unsigned *n2_out, unsigned *p_out)
914 {
915 	u64 freq2k;
916 	unsigned p, n2, r2;
917 	struct hsw_wrpll_rnp best = {};
918 	unsigned budget;
919 
920 	freq2k = clock / 100;
921 
922 	budget = hsw_wrpll_get_budget_for_freq(clock);
923 
924 	/* Special case handling for 540 pixel clock: bypass WR PLL entirely
925 	 * and directly pass the LC PLL to it. */
926 	if (freq2k == 5400000) {
927 		*n2_out = 2;
928 		*p_out = 1;
929 		*r2_out = 2;
930 		return;
931 	}
932 
933 	/*
934 	 * Ref = LC_FREQ / R, where Ref is the actual reference input seen by
935 	 * the WR PLL.
936 	 *
937 	 * We want R so that REF_MIN <= Ref <= REF_MAX.
938 	 * Injecting R2 = 2 * R gives:
939 	 *   REF_MAX * r2 > LC_FREQ * 2 and
940 	 *   REF_MIN * r2 < LC_FREQ * 2
941 	 *
942 	 * Which means the desired boundaries for r2 are:
943 	 *  LC_FREQ * 2 / REF_MAX < r2 < LC_FREQ * 2 / REF_MIN
944 	 *
945 	 */
946 	for (r2 = LC_FREQ * 2 / REF_MAX + 1;
947 	     r2 <= LC_FREQ * 2 / REF_MIN;
948 	     r2++) {
949 
950 		/*
951 		 * VCO = N * Ref, that is: VCO = N * LC_FREQ / R
952 		 *
953 		 * Once again we want VCO_MIN <= VCO <= VCO_MAX.
954 		 * Injecting R2 = 2 * R and N2 = 2 * N, we get:
955 		 *   VCO_MAX * r2 > n2 * LC_FREQ and
956 		 *   VCO_MIN * r2 < n2 * LC_FREQ)
957 		 *
958 		 * Which means the desired boundaries for n2 are:
959 		 * VCO_MIN * r2 / LC_FREQ < n2 < VCO_MAX * r2 / LC_FREQ
960 		 */
961 		for (n2 = VCO_MIN * r2 / LC_FREQ + 1;
962 		     n2 <= VCO_MAX * r2 / LC_FREQ;
963 		     n2++) {
964 
965 			for (p = P_MIN; p <= P_MAX; p += P_INC)
966 				hsw_wrpll_update_rnp(freq2k, budget,
967 						     r2, n2, p, &best);
968 		}
969 	}
970 
971 	*n2_out = best.n2;
972 	*p_out = best.p;
973 	*r2_out = best.r2;
974 }
975 
976 static int hsw_ddi_wrpll_get_freq(struct drm_i915_private *i915,
977 				  const struct intel_shared_dpll *pll,
978 				  const struct intel_dpll_hw_state *pll_state)
979 {
980 	int refclk;
981 	int n, p, r;
982 	u32 wrpll = pll_state->wrpll;
983 
984 	switch (wrpll & WRPLL_REF_MASK) {
985 	case WRPLL_REF_SPECIAL_HSW:
986 		/* Muxed-SSC for BDW, non-SSC for non-ULT HSW. */
987 		if (IS_HASWELL(i915) && !IS_HASWELL_ULT(i915)) {
988 			refclk = i915->display.dpll.ref_clks.nssc;
989 			break;
990 		}
991 		fallthrough;
992 	case WRPLL_REF_PCH_SSC:
993 		/*
994 		 * We could calculate spread here, but our checking
995 		 * code only cares about 5% accuracy, and spread is a max of
996 		 * 0.5% downspread.
997 		 */
998 		refclk = i915->display.dpll.ref_clks.ssc;
999 		break;
1000 	case WRPLL_REF_LCPLL:
1001 		refclk = 2700000;
1002 		break;
1003 	default:
1004 		MISSING_CASE(wrpll);
1005 		return 0;
1006 	}
1007 
1008 	r = wrpll & WRPLL_DIVIDER_REF_MASK;
1009 	p = (wrpll & WRPLL_DIVIDER_POST_MASK) >> WRPLL_DIVIDER_POST_SHIFT;
1010 	n = (wrpll & WRPLL_DIVIDER_FB_MASK) >> WRPLL_DIVIDER_FB_SHIFT;
1011 
1012 	/* Convert to KHz, p & r have a fixed point portion */
1013 	return (refclk * n / 10) / (p * r) * 2;
1014 }
1015 
1016 static int
1017 hsw_ddi_wrpll_compute_dpll(struct intel_atomic_state *state,
1018 			   struct intel_crtc *crtc)
1019 {
1020 	struct drm_i915_private *i915 = to_i915(state->base.dev);
1021 	struct intel_crtc_state *crtc_state =
1022 		intel_atomic_get_new_crtc_state(state, crtc);
1023 	unsigned int p, n2, r2;
1024 
1025 	hsw_ddi_calculate_wrpll(crtc_state->port_clock * 1000, &r2, &n2, &p);
1026 
1027 	crtc_state->dpll_hw_state.wrpll =
1028 		WRPLL_PLL_ENABLE | WRPLL_REF_LCPLL |
1029 		WRPLL_DIVIDER_REFERENCE(r2) | WRPLL_DIVIDER_FEEDBACK(n2) |
1030 		WRPLL_DIVIDER_POST(p);
1031 
1032 	crtc_state->port_clock = hsw_ddi_wrpll_get_freq(i915, NULL,
1033 							&crtc_state->dpll_hw_state);
1034 
1035 	return 0;
1036 }
1037 
1038 static struct intel_shared_dpll *
1039 hsw_ddi_wrpll_get_dpll(struct intel_atomic_state *state,
1040 		       struct intel_crtc *crtc)
1041 {
1042 	struct intel_crtc_state *crtc_state =
1043 		intel_atomic_get_new_crtc_state(state, crtc);
1044 
1045 	return intel_find_shared_dpll(state, crtc,
1046 				      &crtc_state->dpll_hw_state,
1047 				      BIT(DPLL_ID_WRPLL2) |
1048 				      BIT(DPLL_ID_WRPLL1));
1049 }
1050 
1051 static int
1052 hsw_ddi_lcpll_compute_dpll(struct intel_crtc_state *crtc_state)
1053 {
1054 	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
1055 	int clock = crtc_state->port_clock;
1056 
1057 	switch (clock / 2) {
1058 	case 81000:
1059 	case 135000:
1060 	case 270000:
1061 		return 0;
1062 	default:
1063 		drm_dbg_kms(&i915->drm, "Invalid clock for DP: %d\n",
1064 			    clock);
1065 		return -EINVAL;
1066 	}
1067 }
1068 
1069 static struct intel_shared_dpll *
1070 hsw_ddi_lcpll_get_dpll(struct intel_crtc_state *crtc_state)
1071 {
1072 	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
1073 	struct intel_shared_dpll *pll;
1074 	enum intel_dpll_id pll_id;
1075 	int clock = crtc_state->port_clock;
1076 
1077 	switch (clock / 2) {
1078 	case 81000:
1079 		pll_id = DPLL_ID_LCPLL_810;
1080 		break;
1081 	case 135000:
1082 		pll_id = DPLL_ID_LCPLL_1350;
1083 		break;
1084 	case 270000:
1085 		pll_id = DPLL_ID_LCPLL_2700;
1086 		break;
1087 	default:
1088 		MISSING_CASE(clock / 2);
1089 		return NULL;
1090 	}
1091 
1092 	pll = intel_get_shared_dpll_by_id(i915, pll_id);
1093 
1094 	if (!pll)
1095 		return NULL;
1096 
1097 	return pll;
1098 }
1099 
1100 static int hsw_ddi_lcpll_get_freq(struct drm_i915_private *i915,
1101 				  const struct intel_shared_dpll *pll,
1102 				  const struct intel_dpll_hw_state *pll_state)
1103 {
1104 	int link_clock = 0;
1105 
1106 	switch (pll->info->id) {
1107 	case DPLL_ID_LCPLL_810:
1108 		link_clock = 81000;
1109 		break;
1110 	case DPLL_ID_LCPLL_1350:
1111 		link_clock = 135000;
1112 		break;
1113 	case DPLL_ID_LCPLL_2700:
1114 		link_clock = 270000;
1115 		break;
1116 	default:
1117 		drm_WARN(&i915->drm, 1, "bad port clock sel\n");
1118 		break;
1119 	}
1120 
1121 	return link_clock * 2;
1122 }
1123 
1124 static int
1125 hsw_ddi_spll_compute_dpll(struct intel_atomic_state *state,
1126 			  struct intel_crtc *crtc)
1127 {
1128 	struct intel_crtc_state *crtc_state =
1129 		intel_atomic_get_new_crtc_state(state, crtc);
1130 
1131 	if (drm_WARN_ON(crtc->base.dev, crtc_state->port_clock / 2 != 135000))
1132 		return -EINVAL;
1133 
1134 	crtc_state->dpll_hw_state.spll =
1135 		SPLL_PLL_ENABLE | SPLL_FREQ_1350MHz | SPLL_REF_MUXED_SSC;
1136 
1137 	return 0;
1138 }
1139 
1140 static struct intel_shared_dpll *
1141 hsw_ddi_spll_get_dpll(struct intel_atomic_state *state,
1142 		      struct intel_crtc *crtc)
1143 {
1144 	struct intel_crtc_state *crtc_state =
1145 		intel_atomic_get_new_crtc_state(state, crtc);
1146 
1147 	return intel_find_shared_dpll(state, crtc, &crtc_state->dpll_hw_state,
1148 				      BIT(DPLL_ID_SPLL));
1149 }
1150 
1151 static int hsw_ddi_spll_get_freq(struct drm_i915_private *i915,
1152 				 const struct intel_shared_dpll *pll,
1153 				 const struct intel_dpll_hw_state *pll_state)
1154 {
1155 	int link_clock = 0;
1156 
1157 	switch (pll_state->spll & SPLL_FREQ_MASK) {
1158 	case SPLL_FREQ_810MHz:
1159 		link_clock = 81000;
1160 		break;
1161 	case SPLL_FREQ_1350MHz:
1162 		link_clock = 135000;
1163 		break;
1164 	case SPLL_FREQ_2700MHz:
1165 		link_clock = 270000;
1166 		break;
1167 	default:
1168 		drm_WARN(&i915->drm, 1, "bad spll freq\n");
1169 		break;
1170 	}
1171 
1172 	return link_clock * 2;
1173 }
1174 
1175 static int hsw_compute_dpll(struct intel_atomic_state *state,
1176 			    struct intel_crtc *crtc,
1177 			    struct intel_encoder *encoder)
1178 {
1179 	struct intel_crtc_state *crtc_state =
1180 		intel_atomic_get_new_crtc_state(state, crtc);
1181 
1182 	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI))
1183 		return hsw_ddi_wrpll_compute_dpll(state, crtc);
1184 	else if (intel_crtc_has_dp_encoder(crtc_state))
1185 		return hsw_ddi_lcpll_compute_dpll(crtc_state);
1186 	else if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_ANALOG))
1187 		return hsw_ddi_spll_compute_dpll(state, crtc);
1188 	else
1189 		return -EINVAL;
1190 }
1191 
1192 static int hsw_get_dpll(struct intel_atomic_state *state,
1193 			struct intel_crtc *crtc,
1194 			struct intel_encoder *encoder)
1195 {
1196 	struct intel_crtc_state *crtc_state =
1197 		intel_atomic_get_new_crtc_state(state, crtc);
1198 	struct intel_shared_dpll *pll = NULL;
1199 
1200 	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI))
1201 		pll = hsw_ddi_wrpll_get_dpll(state, crtc);
1202 	else if (intel_crtc_has_dp_encoder(crtc_state))
1203 		pll = hsw_ddi_lcpll_get_dpll(crtc_state);
1204 	else if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_ANALOG))
1205 		pll = hsw_ddi_spll_get_dpll(state, crtc);
1206 
1207 	if (!pll)
1208 		return -EINVAL;
1209 
1210 	intel_reference_shared_dpll(state, crtc,
1211 				    pll, &crtc_state->dpll_hw_state);
1212 
1213 	crtc_state->shared_dpll = pll;
1214 
1215 	return 0;
1216 }
1217 
1218 static void hsw_update_dpll_ref_clks(struct drm_i915_private *i915)
1219 {
1220 	i915->display.dpll.ref_clks.ssc = 135000;
1221 	/* Non-SSC is only used on non-ULT HSW. */
1222 	if (intel_de_read(i915, FUSE_STRAP3) & HSW_REF_CLK_SELECT)
1223 		i915->display.dpll.ref_clks.nssc = 24000;
1224 	else
1225 		i915->display.dpll.ref_clks.nssc = 135000;
1226 }
1227 
1228 static void hsw_dump_hw_state(struct drm_i915_private *i915,
1229 			      const struct intel_dpll_hw_state *hw_state)
1230 {
1231 	drm_dbg_kms(&i915->drm, "dpll_hw_state: wrpll: 0x%x spll: 0x%x\n",
1232 		    hw_state->wrpll, hw_state->spll);
1233 }
1234 
1235 static bool hsw_compare_hw_state(const struct intel_dpll_hw_state *a,
1236 				 const struct intel_dpll_hw_state *b)
1237 {
1238 	return a->wrpll == b->wrpll &&
1239 		a->spll == b->spll;
1240 }
1241 
1242 static const struct intel_shared_dpll_funcs hsw_ddi_wrpll_funcs = {
1243 	.enable = hsw_ddi_wrpll_enable,
1244 	.disable = hsw_ddi_wrpll_disable,
1245 	.get_hw_state = hsw_ddi_wrpll_get_hw_state,
1246 	.get_freq = hsw_ddi_wrpll_get_freq,
1247 };
1248 
1249 static const struct intel_shared_dpll_funcs hsw_ddi_spll_funcs = {
1250 	.enable = hsw_ddi_spll_enable,
1251 	.disable = hsw_ddi_spll_disable,
1252 	.get_hw_state = hsw_ddi_spll_get_hw_state,
1253 	.get_freq = hsw_ddi_spll_get_freq,
1254 };
1255 
1256 static void hsw_ddi_lcpll_enable(struct drm_i915_private *i915,
1257 				 struct intel_shared_dpll *pll)
1258 {
1259 }
1260 
1261 static void hsw_ddi_lcpll_disable(struct drm_i915_private *i915,
1262 				  struct intel_shared_dpll *pll)
1263 {
1264 }
1265 
1266 static bool hsw_ddi_lcpll_get_hw_state(struct drm_i915_private *i915,
1267 				       struct intel_shared_dpll *pll,
1268 				       struct intel_dpll_hw_state *hw_state)
1269 {
1270 	return true;
1271 }
1272 
1273 static const struct intel_shared_dpll_funcs hsw_ddi_lcpll_funcs = {
1274 	.enable = hsw_ddi_lcpll_enable,
1275 	.disable = hsw_ddi_lcpll_disable,
1276 	.get_hw_state = hsw_ddi_lcpll_get_hw_state,
1277 	.get_freq = hsw_ddi_lcpll_get_freq,
1278 };
1279 
1280 static const struct dpll_info hsw_plls[] = {
1281 	{ .name = "WRPLL 1", .funcs = &hsw_ddi_wrpll_funcs, .id = DPLL_ID_WRPLL1, },
1282 	{ .name = "WRPLL 2", .funcs = &hsw_ddi_wrpll_funcs, .id = DPLL_ID_WRPLL2, },
1283 	{ .name = "SPLL", .funcs = &hsw_ddi_spll_funcs, .id = DPLL_ID_SPLL, },
1284 	{ .name = "LCPLL 810", .funcs = &hsw_ddi_lcpll_funcs, .id = DPLL_ID_LCPLL_810,
1285 	  .always_on = true, },
1286 	{ .name = "LCPLL 1350", .funcs = &hsw_ddi_lcpll_funcs, .id = DPLL_ID_LCPLL_1350,
1287 	  .always_on = true, },
1288 	{ .name = "LCPLL 2700", .funcs = &hsw_ddi_lcpll_funcs, .id = DPLL_ID_LCPLL_2700,
1289 	  .always_on = true, },
1290 	{}
1291 };
1292 
1293 static const struct intel_dpll_mgr hsw_pll_mgr = {
1294 	.dpll_info = hsw_plls,
1295 	.compute_dplls = hsw_compute_dpll,
1296 	.get_dplls = hsw_get_dpll,
1297 	.put_dplls = intel_put_dpll,
1298 	.update_ref_clks = hsw_update_dpll_ref_clks,
1299 	.dump_hw_state = hsw_dump_hw_state,
1300 	.compare_hw_state = hsw_compare_hw_state,
1301 };
1302 
1303 struct skl_dpll_regs {
1304 	i915_reg_t ctl, cfgcr1, cfgcr2;
1305 };
1306 
1307 /* this array is indexed by the *shared* pll id */
1308 static const struct skl_dpll_regs skl_dpll_regs[4] = {
1309 	{
1310 		/* DPLL 0 */
1311 		.ctl = LCPLL1_CTL,
1312 		/* DPLL 0 doesn't support HDMI mode */
1313 	},
1314 	{
1315 		/* DPLL 1 */
1316 		.ctl = LCPLL2_CTL,
1317 		.cfgcr1 = DPLL_CFGCR1(SKL_DPLL1),
1318 		.cfgcr2 = DPLL_CFGCR2(SKL_DPLL1),
1319 	},
1320 	{
1321 		/* DPLL 2 */
1322 		.ctl = WRPLL_CTL(0),
1323 		.cfgcr1 = DPLL_CFGCR1(SKL_DPLL2),
1324 		.cfgcr2 = DPLL_CFGCR2(SKL_DPLL2),
1325 	},
1326 	{
1327 		/* DPLL 3 */
1328 		.ctl = WRPLL_CTL(1),
1329 		.cfgcr1 = DPLL_CFGCR1(SKL_DPLL3),
1330 		.cfgcr2 = DPLL_CFGCR2(SKL_DPLL3),
1331 	},
1332 };
1333 
1334 static void skl_ddi_pll_write_ctrl1(struct drm_i915_private *i915,
1335 				    struct intel_shared_dpll *pll)
1336 {
1337 	const enum intel_dpll_id id = pll->info->id;
1338 
1339 	intel_de_rmw(i915, DPLL_CTRL1,
1340 		     DPLL_CTRL1_HDMI_MODE(id) | DPLL_CTRL1_SSC(id) | DPLL_CTRL1_LINK_RATE_MASK(id),
1341 		     pll->state.hw_state.ctrl1 << (id * 6));
1342 	intel_de_posting_read(i915, DPLL_CTRL1);
1343 }
1344 
1345 static void skl_ddi_pll_enable(struct drm_i915_private *i915,
1346 			       struct intel_shared_dpll *pll)
1347 {
1348 	const struct skl_dpll_regs *regs = skl_dpll_regs;
1349 	const enum intel_dpll_id id = pll->info->id;
1350 
1351 	skl_ddi_pll_write_ctrl1(i915, pll);
1352 
1353 	intel_de_write(i915, regs[id].cfgcr1, pll->state.hw_state.cfgcr1);
1354 	intel_de_write(i915, regs[id].cfgcr2, pll->state.hw_state.cfgcr2);
1355 	intel_de_posting_read(i915, regs[id].cfgcr1);
1356 	intel_de_posting_read(i915, regs[id].cfgcr2);
1357 
1358 	/* the enable bit is always bit 31 */
1359 	intel_de_rmw(i915, regs[id].ctl, 0, LCPLL_PLL_ENABLE);
1360 
1361 	if (intel_de_wait_for_set(i915, DPLL_STATUS, DPLL_LOCK(id), 5))
1362 		drm_err(&i915->drm, "DPLL %d not locked\n", id);
1363 }
1364 
1365 static void skl_ddi_dpll0_enable(struct drm_i915_private *i915,
1366 				 struct intel_shared_dpll *pll)
1367 {
1368 	skl_ddi_pll_write_ctrl1(i915, pll);
1369 }
1370 
1371 static void skl_ddi_pll_disable(struct drm_i915_private *i915,
1372 				struct intel_shared_dpll *pll)
1373 {
1374 	const struct skl_dpll_regs *regs = skl_dpll_regs;
1375 	const enum intel_dpll_id id = pll->info->id;
1376 
1377 	/* the enable bit is always bit 31 */
1378 	intel_de_rmw(i915, regs[id].ctl, LCPLL_PLL_ENABLE, 0);
1379 	intel_de_posting_read(i915, regs[id].ctl);
1380 }
1381 
1382 static void skl_ddi_dpll0_disable(struct drm_i915_private *i915,
1383 				  struct intel_shared_dpll *pll)
1384 {
1385 }
1386 
1387 static bool skl_ddi_pll_get_hw_state(struct drm_i915_private *i915,
1388 				     struct intel_shared_dpll *pll,
1389 				     struct intel_dpll_hw_state *hw_state)
1390 {
1391 	u32 val;
1392 	const struct skl_dpll_regs *regs = skl_dpll_regs;
1393 	const enum intel_dpll_id id = pll->info->id;
1394 	intel_wakeref_t wakeref;
1395 	bool ret;
1396 
1397 	wakeref = intel_display_power_get_if_enabled(i915,
1398 						     POWER_DOMAIN_DISPLAY_CORE);
1399 	if (!wakeref)
1400 		return false;
1401 
1402 	ret = false;
1403 
1404 	val = intel_de_read(i915, regs[id].ctl);
1405 	if (!(val & LCPLL_PLL_ENABLE))
1406 		goto out;
1407 
1408 	val = intel_de_read(i915, DPLL_CTRL1);
1409 	hw_state->ctrl1 = (val >> (id * 6)) & 0x3f;
1410 
1411 	/* avoid reading back stale values if HDMI mode is not enabled */
1412 	if (val & DPLL_CTRL1_HDMI_MODE(id)) {
1413 		hw_state->cfgcr1 = intel_de_read(i915, regs[id].cfgcr1);
1414 		hw_state->cfgcr2 = intel_de_read(i915, regs[id].cfgcr2);
1415 	}
1416 	ret = true;
1417 
1418 out:
1419 	intel_display_power_put(i915, POWER_DOMAIN_DISPLAY_CORE, wakeref);
1420 
1421 	return ret;
1422 }
1423 
1424 static bool skl_ddi_dpll0_get_hw_state(struct drm_i915_private *i915,
1425 				       struct intel_shared_dpll *pll,
1426 				       struct intel_dpll_hw_state *hw_state)
1427 {
1428 	const struct skl_dpll_regs *regs = skl_dpll_regs;
1429 	const enum intel_dpll_id id = pll->info->id;
1430 	intel_wakeref_t wakeref;
1431 	u32 val;
1432 	bool ret;
1433 
1434 	wakeref = intel_display_power_get_if_enabled(i915,
1435 						     POWER_DOMAIN_DISPLAY_CORE);
1436 	if (!wakeref)
1437 		return false;
1438 
1439 	ret = false;
1440 
1441 	/* DPLL0 is always enabled since it drives CDCLK */
1442 	val = intel_de_read(i915, regs[id].ctl);
1443 	if (drm_WARN_ON(&i915->drm, !(val & LCPLL_PLL_ENABLE)))
1444 		goto out;
1445 
1446 	val = intel_de_read(i915, DPLL_CTRL1);
1447 	hw_state->ctrl1 = (val >> (id * 6)) & 0x3f;
1448 
1449 	ret = true;
1450 
1451 out:
1452 	intel_display_power_put(i915, POWER_DOMAIN_DISPLAY_CORE, wakeref);
1453 
1454 	return ret;
1455 }
1456 
1457 struct skl_wrpll_context {
1458 	u64 min_deviation;		/* current minimal deviation */
1459 	u64 central_freq;		/* chosen central freq */
1460 	u64 dco_freq;			/* chosen dco freq */
1461 	unsigned int p;			/* chosen divider */
1462 };
1463 
1464 /* DCO freq must be within +1%/-6%  of the DCO central freq */
1465 #define SKL_DCO_MAX_PDEVIATION	100
1466 #define SKL_DCO_MAX_NDEVIATION	600
1467 
1468 static void skl_wrpll_try_divider(struct skl_wrpll_context *ctx,
1469 				  u64 central_freq,
1470 				  u64 dco_freq,
1471 				  unsigned int divider)
1472 {
1473 	u64 deviation;
1474 
1475 	deviation = div64_u64(10000 * abs_diff(dco_freq, central_freq),
1476 			      central_freq);
1477 
1478 	/* positive deviation */
1479 	if (dco_freq >= central_freq) {
1480 		if (deviation < SKL_DCO_MAX_PDEVIATION &&
1481 		    deviation < ctx->min_deviation) {
1482 			ctx->min_deviation = deviation;
1483 			ctx->central_freq = central_freq;
1484 			ctx->dco_freq = dco_freq;
1485 			ctx->p = divider;
1486 		}
1487 	/* negative deviation */
1488 	} else if (deviation < SKL_DCO_MAX_NDEVIATION &&
1489 		   deviation < ctx->min_deviation) {
1490 		ctx->min_deviation = deviation;
1491 		ctx->central_freq = central_freq;
1492 		ctx->dco_freq = dco_freq;
1493 		ctx->p = divider;
1494 	}
1495 }
1496 
1497 static void skl_wrpll_get_multipliers(unsigned int p,
1498 				      unsigned int *p0 /* out */,
1499 				      unsigned int *p1 /* out */,
1500 				      unsigned int *p2 /* out */)
1501 {
1502 	/* even dividers */
1503 	if (p % 2 == 0) {
1504 		unsigned int half = p / 2;
1505 
1506 		if (half == 1 || half == 2 || half == 3 || half == 5) {
1507 			*p0 = 2;
1508 			*p1 = 1;
1509 			*p2 = half;
1510 		} else if (half % 2 == 0) {
1511 			*p0 = 2;
1512 			*p1 = half / 2;
1513 			*p2 = 2;
1514 		} else if (half % 3 == 0) {
1515 			*p0 = 3;
1516 			*p1 = half / 3;
1517 			*p2 = 2;
1518 		} else if (half % 7 == 0) {
1519 			*p0 = 7;
1520 			*p1 = half / 7;
1521 			*p2 = 2;
1522 		}
1523 	} else if (p == 3 || p == 9) {  /* 3, 5, 7, 9, 15, 21, 35 */
1524 		*p0 = 3;
1525 		*p1 = 1;
1526 		*p2 = p / 3;
1527 	} else if (p == 5 || p == 7) {
1528 		*p0 = p;
1529 		*p1 = 1;
1530 		*p2 = 1;
1531 	} else if (p == 15) {
1532 		*p0 = 3;
1533 		*p1 = 1;
1534 		*p2 = 5;
1535 	} else if (p == 21) {
1536 		*p0 = 7;
1537 		*p1 = 1;
1538 		*p2 = 3;
1539 	} else if (p == 35) {
1540 		*p0 = 7;
1541 		*p1 = 1;
1542 		*p2 = 5;
1543 	}
1544 }
1545 
1546 struct skl_wrpll_params {
1547 	u32 dco_fraction;
1548 	u32 dco_integer;
1549 	u32 qdiv_ratio;
1550 	u32 qdiv_mode;
1551 	u32 kdiv;
1552 	u32 pdiv;
1553 	u32 central_freq;
1554 };
1555 
1556 static void skl_wrpll_params_populate(struct skl_wrpll_params *params,
1557 				      u64 afe_clock,
1558 				      int ref_clock,
1559 				      u64 central_freq,
1560 				      u32 p0, u32 p1, u32 p2)
1561 {
1562 	u64 dco_freq;
1563 
1564 	switch (central_freq) {
1565 	case 9600000000ULL:
1566 		params->central_freq = 0;
1567 		break;
1568 	case 9000000000ULL:
1569 		params->central_freq = 1;
1570 		break;
1571 	case 8400000000ULL:
1572 		params->central_freq = 3;
1573 	}
1574 
1575 	switch (p0) {
1576 	case 1:
1577 		params->pdiv = 0;
1578 		break;
1579 	case 2:
1580 		params->pdiv = 1;
1581 		break;
1582 	case 3:
1583 		params->pdiv = 2;
1584 		break;
1585 	case 7:
1586 		params->pdiv = 4;
1587 		break;
1588 	default:
1589 		WARN(1, "Incorrect PDiv\n");
1590 	}
1591 
1592 	switch (p2) {
1593 	case 5:
1594 		params->kdiv = 0;
1595 		break;
1596 	case 2:
1597 		params->kdiv = 1;
1598 		break;
1599 	case 3:
1600 		params->kdiv = 2;
1601 		break;
1602 	case 1:
1603 		params->kdiv = 3;
1604 		break;
1605 	default:
1606 		WARN(1, "Incorrect KDiv\n");
1607 	}
1608 
1609 	params->qdiv_ratio = p1;
1610 	params->qdiv_mode = (params->qdiv_ratio == 1) ? 0 : 1;
1611 
1612 	dco_freq = p0 * p1 * p2 * afe_clock;
1613 
1614 	/*
1615 	 * Intermediate values are in Hz.
1616 	 * Divide by MHz to match bsepc
1617 	 */
1618 	params->dco_integer = div_u64(dco_freq, ref_clock * KHz(1));
1619 	params->dco_fraction =
1620 		div_u64((div_u64(dco_freq, ref_clock / KHz(1)) -
1621 			 params->dco_integer * MHz(1)) * 0x8000, MHz(1));
1622 }
1623 
1624 static int
1625 skl_ddi_calculate_wrpll(int clock /* in Hz */,
1626 			int ref_clock,
1627 			struct skl_wrpll_params *wrpll_params)
1628 {
1629 	static const u64 dco_central_freq[3] = { 8400000000ULL,
1630 						 9000000000ULL,
1631 						 9600000000ULL };
1632 	static const u8 even_dividers[] = {  4,  6,  8, 10, 12, 14, 16, 18, 20,
1633 					    24, 28, 30, 32, 36, 40, 42, 44,
1634 					    48, 52, 54, 56, 60, 64, 66, 68,
1635 					    70, 72, 76, 78, 80, 84, 88, 90,
1636 					    92, 96, 98 };
1637 	static const u8 odd_dividers[] = { 3, 5, 7, 9, 15, 21, 35 };
1638 	static const struct {
1639 		const u8 *list;
1640 		int n_dividers;
1641 	} dividers[] = {
1642 		{ even_dividers, ARRAY_SIZE(even_dividers) },
1643 		{ odd_dividers, ARRAY_SIZE(odd_dividers) },
1644 	};
1645 	struct skl_wrpll_context ctx = {
1646 		.min_deviation = U64_MAX,
1647 	};
1648 	unsigned int dco, d, i;
1649 	unsigned int p0, p1, p2;
1650 	u64 afe_clock = clock * 5; /* AFE Clock is 5x Pixel clock */
1651 
1652 	for (d = 0; d < ARRAY_SIZE(dividers); d++) {
1653 		for (dco = 0; dco < ARRAY_SIZE(dco_central_freq); dco++) {
1654 			for (i = 0; i < dividers[d].n_dividers; i++) {
1655 				unsigned int p = dividers[d].list[i];
1656 				u64 dco_freq = p * afe_clock;
1657 
1658 				skl_wrpll_try_divider(&ctx,
1659 						      dco_central_freq[dco],
1660 						      dco_freq,
1661 						      p);
1662 				/*
1663 				 * Skip the remaining dividers if we're sure to
1664 				 * have found the definitive divider, we can't
1665 				 * improve a 0 deviation.
1666 				 */
1667 				if (ctx.min_deviation == 0)
1668 					goto skip_remaining_dividers;
1669 			}
1670 		}
1671 
1672 skip_remaining_dividers:
1673 		/*
1674 		 * If a solution is found with an even divider, prefer
1675 		 * this one.
1676 		 */
1677 		if (d == 0 && ctx.p)
1678 			break;
1679 	}
1680 
1681 	if (!ctx.p)
1682 		return -EINVAL;
1683 
1684 	/*
1685 	 * gcc incorrectly analyses that these can be used without being
1686 	 * initialized. To be fair, it's hard to guess.
1687 	 */
1688 	p0 = p1 = p2 = 0;
1689 	skl_wrpll_get_multipliers(ctx.p, &p0, &p1, &p2);
1690 	skl_wrpll_params_populate(wrpll_params, afe_clock, ref_clock,
1691 				  ctx.central_freq, p0, p1, p2);
1692 
1693 	return 0;
1694 }
1695 
1696 static int skl_ddi_wrpll_get_freq(struct drm_i915_private *i915,
1697 				  const struct intel_shared_dpll *pll,
1698 				  const struct intel_dpll_hw_state *pll_state)
1699 {
1700 	int ref_clock = i915->display.dpll.ref_clks.nssc;
1701 	u32 p0, p1, p2, dco_freq;
1702 
1703 	p0 = pll_state->cfgcr2 & DPLL_CFGCR2_PDIV_MASK;
1704 	p2 = pll_state->cfgcr2 & DPLL_CFGCR2_KDIV_MASK;
1705 
1706 	if (pll_state->cfgcr2 &  DPLL_CFGCR2_QDIV_MODE(1))
1707 		p1 = (pll_state->cfgcr2 & DPLL_CFGCR2_QDIV_RATIO_MASK) >> 8;
1708 	else
1709 		p1 = 1;
1710 
1711 
1712 	switch (p0) {
1713 	case DPLL_CFGCR2_PDIV_1:
1714 		p0 = 1;
1715 		break;
1716 	case DPLL_CFGCR2_PDIV_2:
1717 		p0 = 2;
1718 		break;
1719 	case DPLL_CFGCR2_PDIV_3:
1720 		p0 = 3;
1721 		break;
1722 	case DPLL_CFGCR2_PDIV_7_INVALID:
1723 		/*
1724 		 * Incorrect ASUS-Z170M BIOS setting, the HW seems to ignore bit#0,
1725 		 * handling it the same way as PDIV_7.
1726 		 */
1727 		drm_dbg_kms(&i915->drm, "Invalid WRPLL PDIV divider value, fixing it.\n");
1728 		fallthrough;
1729 	case DPLL_CFGCR2_PDIV_7:
1730 		p0 = 7;
1731 		break;
1732 	default:
1733 		MISSING_CASE(p0);
1734 		return 0;
1735 	}
1736 
1737 	switch (p2) {
1738 	case DPLL_CFGCR2_KDIV_5:
1739 		p2 = 5;
1740 		break;
1741 	case DPLL_CFGCR2_KDIV_2:
1742 		p2 = 2;
1743 		break;
1744 	case DPLL_CFGCR2_KDIV_3:
1745 		p2 = 3;
1746 		break;
1747 	case DPLL_CFGCR2_KDIV_1:
1748 		p2 = 1;
1749 		break;
1750 	default:
1751 		MISSING_CASE(p2);
1752 		return 0;
1753 	}
1754 
1755 	dco_freq = (pll_state->cfgcr1 & DPLL_CFGCR1_DCO_INTEGER_MASK) *
1756 		   ref_clock;
1757 
1758 	dco_freq += ((pll_state->cfgcr1 & DPLL_CFGCR1_DCO_FRACTION_MASK) >> 9) *
1759 		    ref_clock / 0x8000;
1760 
1761 	if (drm_WARN_ON(&i915->drm, p0 == 0 || p1 == 0 || p2 == 0))
1762 		return 0;
1763 
1764 	return dco_freq / (p0 * p1 * p2 * 5);
1765 }
1766 
1767 static int skl_ddi_hdmi_pll_dividers(struct intel_crtc_state *crtc_state)
1768 {
1769 	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
1770 	struct skl_wrpll_params wrpll_params = {};
1771 	u32 ctrl1, cfgcr1, cfgcr2;
1772 	int ret;
1773 
1774 	/*
1775 	 * See comment in intel_dpll_hw_state to understand why we always use 0
1776 	 * as the DPLL id in this function.
1777 	 */
1778 	ctrl1 = DPLL_CTRL1_OVERRIDE(0);
1779 
1780 	ctrl1 |= DPLL_CTRL1_HDMI_MODE(0);
1781 
1782 	ret = skl_ddi_calculate_wrpll(crtc_state->port_clock * 1000,
1783 				      i915->display.dpll.ref_clks.nssc, &wrpll_params);
1784 	if (ret)
1785 		return ret;
1786 
1787 	cfgcr1 = DPLL_CFGCR1_FREQ_ENABLE |
1788 		DPLL_CFGCR1_DCO_FRACTION(wrpll_params.dco_fraction) |
1789 		wrpll_params.dco_integer;
1790 
1791 	cfgcr2 = DPLL_CFGCR2_QDIV_RATIO(wrpll_params.qdiv_ratio) |
1792 		DPLL_CFGCR2_QDIV_MODE(wrpll_params.qdiv_mode) |
1793 		DPLL_CFGCR2_KDIV(wrpll_params.kdiv) |
1794 		DPLL_CFGCR2_PDIV(wrpll_params.pdiv) |
1795 		wrpll_params.central_freq;
1796 
1797 	crtc_state->dpll_hw_state.ctrl1 = ctrl1;
1798 	crtc_state->dpll_hw_state.cfgcr1 = cfgcr1;
1799 	crtc_state->dpll_hw_state.cfgcr2 = cfgcr2;
1800 
1801 	crtc_state->port_clock = skl_ddi_wrpll_get_freq(i915, NULL,
1802 							&crtc_state->dpll_hw_state);
1803 
1804 	return 0;
1805 }
1806 
1807 static int
1808 skl_ddi_dp_set_dpll_hw_state(struct intel_crtc_state *crtc_state)
1809 {
1810 	u32 ctrl1;
1811 
1812 	/*
1813 	 * See comment in intel_dpll_hw_state to understand why we always use 0
1814 	 * as the DPLL id in this function.
1815 	 */
1816 	ctrl1 = DPLL_CTRL1_OVERRIDE(0);
1817 	switch (crtc_state->port_clock / 2) {
1818 	case 81000:
1819 		ctrl1 |= DPLL_CTRL1_LINK_RATE(DPLL_CTRL1_LINK_RATE_810, 0);
1820 		break;
1821 	case 135000:
1822 		ctrl1 |= DPLL_CTRL1_LINK_RATE(DPLL_CTRL1_LINK_RATE_1350, 0);
1823 		break;
1824 	case 270000:
1825 		ctrl1 |= DPLL_CTRL1_LINK_RATE(DPLL_CTRL1_LINK_RATE_2700, 0);
1826 		break;
1827 		/* eDP 1.4 rates */
1828 	case 162000:
1829 		ctrl1 |= DPLL_CTRL1_LINK_RATE(DPLL_CTRL1_LINK_RATE_1620, 0);
1830 		break;
1831 	case 108000:
1832 		ctrl1 |= DPLL_CTRL1_LINK_RATE(DPLL_CTRL1_LINK_RATE_1080, 0);
1833 		break;
1834 	case 216000:
1835 		ctrl1 |= DPLL_CTRL1_LINK_RATE(DPLL_CTRL1_LINK_RATE_2160, 0);
1836 		break;
1837 	}
1838 
1839 	crtc_state->dpll_hw_state.ctrl1 = ctrl1;
1840 
1841 	return 0;
1842 }
1843 
1844 static int skl_ddi_lcpll_get_freq(struct drm_i915_private *i915,
1845 				  const struct intel_shared_dpll *pll,
1846 				  const struct intel_dpll_hw_state *pll_state)
1847 {
1848 	int link_clock = 0;
1849 
1850 	switch ((pll_state->ctrl1 & DPLL_CTRL1_LINK_RATE_MASK(0)) >>
1851 		DPLL_CTRL1_LINK_RATE_SHIFT(0)) {
1852 	case DPLL_CTRL1_LINK_RATE_810:
1853 		link_clock = 81000;
1854 		break;
1855 	case DPLL_CTRL1_LINK_RATE_1080:
1856 		link_clock = 108000;
1857 		break;
1858 	case DPLL_CTRL1_LINK_RATE_1350:
1859 		link_clock = 135000;
1860 		break;
1861 	case DPLL_CTRL1_LINK_RATE_1620:
1862 		link_clock = 162000;
1863 		break;
1864 	case DPLL_CTRL1_LINK_RATE_2160:
1865 		link_clock = 216000;
1866 		break;
1867 	case DPLL_CTRL1_LINK_RATE_2700:
1868 		link_clock = 270000;
1869 		break;
1870 	default:
1871 		drm_WARN(&i915->drm, 1, "Unsupported link rate\n");
1872 		break;
1873 	}
1874 
1875 	return link_clock * 2;
1876 }
1877 
1878 static int skl_compute_dpll(struct intel_atomic_state *state,
1879 			    struct intel_crtc *crtc,
1880 			    struct intel_encoder *encoder)
1881 {
1882 	struct intel_crtc_state *crtc_state =
1883 		intel_atomic_get_new_crtc_state(state, crtc);
1884 
1885 	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI))
1886 		return skl_ddi_hdmi_pll_dividers(crtc_state);
1887 	else if (intel_crtc_has_dp_encoder(crtc_state))
1888 		return skl_ddi_dp_set_dpll_hw_state(crtc_state);
1889 	else
1890 		return -EINVAL;
1891 }
1892 
1893 static int skl_get_dpll(struct intel_atomic_state *state,
1894 			struct intel_crtc *crtc,
1895 			struct intel_encoder *encoder)
1896 {
1897 	struct intel_crtc_state *crtc_state =
1898 		intel_atomic_get_new_crtc_state(state, crtc);
1899 	struct intel_shared_dpll *pll;
1900 
1901 	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_EDP))
1902 		pll = intel_find_shared_dpll(state, crtc,
1903 					     &crtc_state->dpll_hw_state,
1904 					     BIT(DPLL_ID_SKL_DPLL0));
1905 	else
1906 		pll = intel_find_shared_dpll(state, crtc,
1907 					     &crtc_state->dpll_hw_state,
1908 					     BIT(DPLL_ID_SKL_DPLL3) |
1909 					     BIT(DPLL_ID_SKL_DPLL2) |
1910 					     BIT(DPLL_ID_SKL_DPLL1));
1911 	if (!pll)
1912 		return -EINVAL;
1913 
1914 	intel_reference_shared_dpll(state, crtc,
1915 				    pll, &crtc_state->dpll_hw_state);
1916 
1917 	crtc_state->shared_dpll = pll;
1918 
1919 	return 0;
1920 }
1921 
1922 static int skl_ddi_pll_get_freq(struct drm_i915_private *i915,
1923 				const struct intel_shared_dpll *pll,
1924 				const struct intel_dpll_hw_state *pll_state)
1925 {
1926 	/*
1927 	 * ctrl1 register is already shifted for each pll, just use 0 to get
1928 	 * the internal shift for each field
1929 	 */
1930 	if (pll_state->ctrl1 & DPLL_CTRL1_HDMI_MODE(0))
1931 		return skl_ddi_wrpll_get_freq(i915, pll, pll_state);
1932 	else
1933 		return skl_ddi_lcpll_get_freq(i915, pll, pll_state);
1934 }
1935 
1936 static void skl_update_dpll_ref_clks(struct drm_i915_private *i915)
1937 {
1938 	/* No SSC ref */
1939 	i915->display.dpll.ref_clks.nssc = i915->display.cdclk.hw.ref;
1940 }
1941 
1942 static void skl_dump_hw_state(struct drm_i915_private *i915,
1943 			      const struct intel_dpll_hw_state *hw_state)
1944 {
1945 	drm_dbg_kms(&i915->drm, "dpll_hw_state: "
1946 		      "ctrl1: 0x%x, cfgcr1: 0x%x, cfgcr2: 0x%x\n",
1947 		      hw_state->ctrl1,
1948 		      hw_state->cfgcr1,
1949 		      hw_state->cfgcr2);
1950 }
1951 
1952 static bool skl_compare_hw_state(const struct intel_dpll_hw_state *a,
1953 				 const struct intel_dpll_hw_state *b)
1954 {
1955 	return a->ctrl1 == b->ctrl1 &&
1956 		a->cfgcr1 == b->cfgcr1 &&
1957 		a->cfgcr2 == b->cfgcr2;
1958 }
1959 
1960 static const struct intel_shared_dpll_funcs skl_ddi_pll_funcs = {
1961 	.enable = skl_ddi_pll_enable,
1962 	.disable = skl_ddi_pll_disable,
1963 	.get_hw_state = skl_ddi_pll_get_hw_state,
1964 	.get_freq = skl_ddi_pll_get_freq,
1965 };
1966 
1967 static const struct intel_shared_dpll_funcs skl_ddi_dpll0_funcs = {
1968 	.enable = skl_ddi_dpll0_enable,
1969 	.disable = skl_ddi_dpll0_disable,
1970 	.get_hw_state = skl_ddi_dpll0_get_hw_state,
1971 	.get_freq = skl_ddi_pll_get_freq,
1972 };
1973 
1974 static const struct dpll_info skl_plls[] = {
1975 	{ .name = "DPLL 0", .funcs = &skl_ddi_dpll0_funcs, .id = DPLL_ID_SKL_DPLL0,
1976 	  .always_on = true, },
1977 	{ .name = "DPLL 1", .funcs = &skl_ddi_pll_funcs, .id = DPLL_ID_SKL_DPLL1, },
1978 	{ .name = "DPLL 2", .funcs = &skl_ddi_pll_funcs, .id = DPLL_ID_SKL_DPLL2, },
1979 	{ .name = "DPLL 3", .funcs = &skl_ddi_pll_funcs, .id = DPLL_ID_SKL_DPLL3, },
1980 	{}
1981 };
1982 
1983 static const struct intel_dpll_mgr skl_pll_mgr = {
1984 	.dpll_info = skl_plls,
1985 	.compute_dplls = skl_compute_dpll,
1986 	.get_dplls = skl_get_dpll,
1987 	.put_dplls = intel_put_dpll,
1988 	.update_ref_clks = skl_update_dpll_ref_clks,
1989 	.dump_hw_state = skl_dump_hw_state,
1990 	.compare_hw_state = skl_compare_hw_state,
1991 };
1992 
1993 static void bxt_ddi_pll_enable(struct drm_i915_private *i915,
1994 			       struct intel_shared_dpll *pll)
1995 {
1996 	u32 temp;
1997 	enum port port = (enum port)pll->info->id; /* 1:1 port->PLL mapping */
1998 	enum dpio_phy phy;
1999 	enum dpio_channel ch;
2000 
2001 	bxt_port_to_phy_channel(i915, port, &phy, &ch);
2002 
2003 	/* Non-SSC reference */
2004 	intel_de_rmw(i915, BXT_PORT_PLL_ENABLE(port), 0, PORT_PLL_REF_SEL);
2005 
2006 	if (IS_GEMINILAKE(i915)) {
2007 		intel_de_rmw(i915, BXT_PORT_PLL_ENABLE(port),
2008 			     0, PORT_PLL_POWER_ENABLE);
2009 
2010 		if (wait_for_us((intel_de_read(i915, BXT_PORT_PLL_ENABLE(port)) &
2011 				 PORT_PLL_POWER_STATE), 200))
2012 			drm_err(&i915->drm,
2013 				"Power state not set for PLL:%d\n", port);
2014 	}
2015 
2016 	/* Disable 10 bit clock */
2017 	intel_de_rmw(i915, BXT_PORT_PLL_EBB_4(phy, ch),
2018 		     PORT_PLL_10BIT_CLK_ENABLE, 0);
2019 
2020 	/* Write P1 & P2 */
2021 	intel_de_rmw(i915, BXT_PORT_PLL_EBB_0(phy, ch),
2022 		     PORT_PLL_P1_MASK | PORT_PLL_P2_MASK, pll->state.hw_state.ebb0);
2023 
2024 	/* Write M2 integer */
2025 	intel_de_rmw(i915, BXT_PORT_PLL(phy, ch, 0),
2026 		     PORT_PLL_M2_INT_MASK, pll->state.hw_state.pll0);
2027 
2028 	/* Write N */
2029 	intel_de_rmw(i915, BXT_PORT_PLL(phy, ch, 1),
2030 		     PORT_PLL_N_MASK, pll->state.hw_state.pll1);
2031 
2032 	/* Write M2 fraction */
2033 	intel_de_rmw(i915, BXT_PORT_PLL(phy, ch, 2),
2034 		     PORT_PLL_M2_FRAC_MASK, pll->state.hw_state.pll2);
2035 
2036 	/* Write M2 fraction enable */
2037 	intel_de_rmw(i915, BXT_PORT_PLL(phy, ch, 3),
2038 		     PORT_PLL_M2_FRAC_ENABLE, pll->state.hw_state.pll3);
2039 
2040 	/* Write coeff */
2041 	temp = intel_de_read(i915, BXT_PORT_PLL(phy, ch, 6));
2042 	temp &= ~PORT_PLL_PROP_COEFF_MASK;
2043 	temp &= ~PORT_PLL_INT_COEFF_MASK;
2044 	temp &= ~PORT_PLL_GAIN_CTL_MASK;
2045 	temp |= pll->state.hw_state.pll6;
2046 	intel_de_write(i915, BXT_PORT_PLL(phy, ch, 6), temp);
2047 
2048 	/* Write calibration val */
2049 	intel_de_rmw(i915, BXT_PORT_PLL(phy, ch, 8),
2050 		     PORT_PLL_TARGET_CNT_MASK, pll->state.hw_state.pll8);
2051 
2052 	intel_de_rmw(i915, BXT_PORT_PLL(phy, ch, 9),
2053 		     PORT_PLL_LOCK_THRESHOLD_MASK, pll->state.hw_state.pll9);
2054 
2055 	temp = intel_de_read(i915, BXT_PORT_PLL(phy, ch, 10));
2056 	temp &= ~PORT_PLL_DCO_AMP_OVR_EN_H;
2057 	temp &= ~PORT_PLL_DCO_AMP_MASK;
2058 	temp |= pll->state.hw_state.pll10;
2059 	intel_de_write(i915, BXT_PORT_PLL(phy, ch, 10), temp);
2060 
2061 	/* Recalibrate with new settings */
2062 	temp = intel_de_read(i915, BXT_PORT_PLL_EBB_4(phy, ch));
2063 	temp |= PORT_PLL_RECALIBRATE;
2064 	intel_de_write(i915, BXT_PORT_PLL_EBB_4(phy, ch), temp);
2065 	temp &= ~PORT_PLL_10BIT_CLK_ENABLE;
2066 	temp |= pll->state.hw_state.ebb4;
2067 	intel_de_write(i915, BXT_PORT_PLL_EBB_4(phy, ch), temp);
2068 
2069 	/* Enable PLL */
2070 	intel_de_rmw(i915, BXT_PORT_PLL_ENABLE(port), 0, PORT_PLL_ENABLE);
2071 	intel_de_posting_read(i915, BXT_PORT_PLL_ENABLE(port));
2072 
2073 	if (wait_for_us((intel_de_read(i915, BXT_PORT_PLL_ENABLE(port)) & PORT_PLL_LOCK),
2074 			200))
2075 		drm_err(&i915->drm, "PLL %d not locked\n", port);
2076 
2077 	if (IS_GEMINILAKE(i915)) {
2078 		temp = intel_de_read(i915, BXT_PORT_TX_DW5_LN0(phy, ch));
2079 		temp |= DCC_DELAY_RANGE_2;
2080 		intel_de_write(i915, BXT_PORT_TX_DW5_GRP(phy, ch), temp);
2081 	}
2082 
2083 	/*
2084 	 * While we write to the group register to program all lanes at once we
2085 	 * can read only lane registers and we pick lanes 0/1 for that.
2086 	 */
2087 	temp = intel_de_read(i915, BXT_PORT_PCS_DW12_LN01(phy, ch));
2088 	temp &= ~LANE_STAGGER_MASK;
2089 	temp &= ~LANESTAGGER_STRAP_OVRD;
2090 	temp |= pll->state.hw_state.pcsdw12;
2091 	intel_de_write(i915, BXT_PORT_PCS_DW12_GRP(phy, ch), temp);
2092 }
2093 
2094 static void bxt_ddi_pll_disable(struct drm_i915_private *i915,
2095 				struct intel_shared_dpll *pll)
2096 {
2097 	enum port port = (enum port)pll->info->id; /* 1:1 port->PLL mapping */
2098 
2099 	intel_de_rmw(i915, BXT_PORT_PLL_ENABLE(port), PORT_PLL_ENABLE, 0);
2100 	intel_de_posting_read(i915, BXT_PORT_PLL_ENABLE(port));
2101 
2102 	if (IS_GEMINILAKE(i915)) {
2103 		intel_de_rmw(i915, BXT_PORT_PLL_ENABLE(port),
2104 			     PORT_PLL_POWER_ENABLE, 0);
2105 
2106 		if (wait_for_us(!(intel_de_read(i915, BXT_PORT_PLL_ENABLE(port)) &
2107 				  PORT_PLL_POWER_STATE), 200))
2108 			drm_err(&i915->drm,
2109 				"Power state not reset for PLL:%d\n", port);
2110 	}
2111 }
2112 
2113 static bool bxt_ddi_pll_get_hw_state(struct drm_i915_private *i915,
2114 				     struct intel_shared_dpll *pll,
2115 				     struct intel_dpll_hw_state *hw_state)
2116 {
2117 	enum port port = (enum port)pll->info->id; /* 1:1 port->PLL mapping */
2118 	intel_wakeref_t wakeref;
2119 	enum dpio_phy phy;
2120 	enum dpio_channel ch;
2121 	u32 val;
2122 	bool ret;
2123 
2124 	bxt_port_to_phy_channel(i915, port, &phy, &ch);
2125 
2126 	wakeref = intel_display_power_get_if_enabled(i915,
2127 						     POWER_DOMAIN_DISPLAY_CORE);
2128 	if (!wakeref)
2129 		return false;
2130 
2131 	ret = false;
2132 
2133 	val = intel_de_read(i915, BXT_PORT_PLL_ENABLE(port));
2134 	if (!(val & PORT_PLL_ENABLE))
2135 		goto out;
2136 
2137 	hw_state->ebb0 = intel_de_read(i915, BXT_PORT_PLL_EBB_0(phy, ch));
2138 	hw_state->ebb0 &= PORT_PLL_P1_MASK | PORT_PLL_P2_MASK;
2139 
2140 	hw_state->ebb4 = intel_de_read(i915, BXT_PORT_PLL_EBB_4(phy, ch));
2141 	hw_state->ebb4 &= PORT_PLL_10BIT_CLK_ENABLE;
2142 
2143 	hw_state->pll0 = intel_de_read(i915, BXT_PORT_PLL(phy, ch, 0));
2144 	hw_state->pll0 &= PORT_PLL_M2_INT_MASK;
2145 
2146 	hw_state->pll1 = intel_de_read(i915, BXT_PORT_PLL(phy, ch, 1));
2147 	hw_state->pll1 &= PORT_PLL_N_MASK;
2148 
2149 	hw_state->pll2 = intel_de_read(i915, BXT_PORT_PLL(phy, ch, 2));
2150 	hw_state->pll2 &= PORT_PLL_M2_FRAC_MASK;
2151 
2152 	hw_state->pll3 = intel_de_read(i915, BXT_PORT_PLL(phy, ch, 3));
2153 	hw_state->pll3 &= PORT_PLL_M2_FRAC_ENABLE;
2154 
2155 	hw_state->pll6 = intel_de_read(i915, BXT_PORT_PLL(phy, ch, 6));
2156 	hw_state->pll6 &= PORT_PLL_PROP_COEFF_MASK |
2157 			  PORT_PLL_INT_COEFF_MASK |
2158 			  PORT_PLL_GAIN_CTL_MASK;
2159 
2160 	hw_state->pll8 = intel_de_read(i915, BXT_PORT_PLL(phy, ch, 8));
2161 	hw_state->pll8 &= PORT_PLL_TARGET_CNT_MASK;
2162 
2163 	hw_state->pll9 = intel_de_read(i915, BXT_PORT_PLL(phy, ch, 9));
2164 	hw_state->pll9 &= PORT_PLL_LOCK_THRESHOLD_MASK;
2165 
2166 	hw_state->pll10 = intel_de_read(i915, BXT_PORT_PLL(phy, ch, 10));
2167 	hw_state->pll10 &= PORT_PLL_DCO_AMP_OVR_EN_H |
2168 			   PORT_PLL_DCO_AMP_MASK;
2169 
2170 	/*
2171 	 * While we write to the group register to program all lanes at once we
2172 	 * can read only lane registers. We configure all lanes the same way, so
2173 	 * here just read out lanes 0/1 and output a note if lanes 2/3 differ.
2174 	 */
2175 	hw_state->pcsdw12 = intel_de_read(i915,
2176 					  BXT_PORT_PCS_DW12_LN01(phy, ch));
2177 	if (intel_de_read(i915, BXT_PORT_PCS_DW12_LN23(phy, ch)) != hw_state->pcsdw12)
2178 		drm_dbg(&i915->drm,
2179 			"lane stagger config different for lane 01 (%08x) and 23 (%08x)\n",
2180 			hw_state->pcsdw12,
2181 			intel_de_read(i915,
2182 				      BXT_PORT_PCS_DW12_LN23(phy, ch)));
2183 	hw_state->pcsdw12 &= LANE_STAGGER_MASK | LANESTAGGER_STRAP_OVRD;
2184 
2185 	ret = true;
2186 
2187 out:
2188 	intel_display_power_put(i915, POWER_DOMAIN_DISPLAY_CORE, wakeref);
2189 
2190 	return ret;
2191 }
2192 
2193 /* pre-calculated values for DP linkrates */
2194 static const struct dpll bxt_dp_clk_val[] = {
2195 	/* m2 is .22 binary fixed point */
2196 	{ .dot = 162000, .p1 = 4, .p2 = 2, .n = 1, .m1 = 2, .m2 = 0x819999a /* 32.4 */ },
2197 	{ .dot = 270000, .p1 = 4, .p2 = 1, .n = 1, .m1 = 2, .m2 = 0x6c00000 /* 27.0 */ },
2198 	{ .dot = 540000, .p1 = 2, .p2 = 1, .n = 1, .m1 = 2, .m2 = 0x6c00000 /* 27.0 */ },
2199 	{ .dot = 216000, .p1 = 3, .p2 = 2, .n = 1, .m1 = 2, .m2 = 0x819999a /* 32.4 */ },
2200 	{ .dot = 243000, .p1 = 4, .p2 = 1, .n = 1, .m1 = 2, .m2 = 0x6133333 /* 24.3 */ },
2201 	{ .dot = 324000, .p1 = 4, .p2 = 1, .n = 1, .m1 = 2, .m2 = 0x819999a /* 32.4 */ },
2202 	{ .dot = 432000, .p1 = 3, .p2 = 1, .n = 1, .m1 = 2, .m2 = 0x819999a /* 32.4 */ },
2203 };
2204 
2205 static int
2206 bxt_ddi_hdmi_pll_dividers(struct intel_crtc_state *crtc_state,
2207 			  struct dpll *clk_div)
2208 {
2209 	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2210 
2211 	/* Calculate HDMI div */
2212 	/*
2213 	 * FIXME: tie the following calculation into
2214 	 * i9xx_crtc_compute_clock
2215 	 */
2216 	if (!bxt_find_best_dpll(crtc_state, clk_div))
2217 		return -EINVAL;
2218 
2219 	drm_WARN_ON(&i915->drm, clk_div->m1 != 2);
2220 
2221 	return 0;
2222 }
2223 
2224 static void bxt_ddi_dp_pll_dividers(struct intel_crtc_state *crtc_state,
2225 				    struct dpll *clk_div)
2226 {
2227 	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2228 	int i;
2229 
2230 	*clk_div = bxt_dp_clk_val[0];
2231 	for (i = 0; i < ARRAY_SIZE(bxt_dp_clk_val); ++i) {
2232 		if (crtc_state->port_clock == bxt_dp_clk_val[i].dot) {
2233 			*clk_div = bxt_dp_clk_val[i];
2234 			break;
2235 		}
2236 	}
2237 
2238 	chv_calc_dpll_params(i915->display.dpll.ref_clks.nssc, clk_div);
2239 
2240 	drm_WARN_ON(&i915->drm, clk_div->vco == 0 ||
2241 		    clk_div->dot != crtc_state->port_clock);
2242 }
2243 
2244 static int bxt_ddi_set_dpll_hw_state(struct intel_crtc_state *crtc_state,
2245 				     const struct dpll *clk_div)
2246 {
2247 	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2248 	struct intel_dpll_hw_state *dpll_hw_state = &crtc_state->dpll_hw_state;
2249 	int clock = crtc_state->port_clock;
2250 	int vco = clk_div->vco;
2251 	u32 prop_coef, int_coef, gain_ctl, targ_cnt;
2252 	u32 lanestagger;
2253 
2254 	if (vco >= 6200000 && vco <= 6700000) {
2255 		prop_coef = 4;
2256 		int_coef = 9;
2257 		gain_ctl = 3;
2258 		targ_cnt = 8;
2259 	} else if ((vco > 5400000 && vco < 6200000) ||
2260 			(vco >= 4800000 && vco < 5400000)) {
2261 		prop_coef = 5;
2262 		int_coef = 11;
2263 		gain_ctl = 3;
2264 		targ_cnt = 9;
2265 	} else if (vco == 5400000) {
2266 		prop_coef = 3;
2267 		int_coef = 8;
2268 		gain_ctl = 1;
2269 		targ_cnt = 9;
2270 	} else {
2271 		drm_err(&i915->drm, "Invalid VCO\n");
2272 		return -EINVAL;
2273 	}
2274 
2275 	if (clock > 270000)
2276 		lanestagger = 0x18;
2277 	else if (clock > 135000)
2278 		lanestagger = 0x0d;
2279 	else if (clock > 67000)
2280 		lanestagger = 0x07;
2281 	else if (clock > 33000)
2282 		lanestagger = 0x04;
2283 	else
2284 		lanestagger = 0x02;
2285 
2286 	dpll_hw_state->ebb0 = PORT_PLL_P1(clk_div->p1) | PORT_PLL_P2(clk_div->p2);
2287 	dpll_hw_state->pll0 = PORT_PLL_M2_INT(clk_div->m2 >> 22);
2288 	dpll_hw_state->pll1 = PORT_PLL_N(clk_div->n);
2289 	dpll_hw_state->pll2 = PORT_PLL_M2_FRAC(clk_div->m2 & 0x3fffff);
2290 
2291 	if (clk_div->m2 & 0x3fffff)
2292 		dpll_hw_state->pll3 = PORT_PLL_M2_FRAC_ENABLE;
2293 
2294 	dpll_hw_state->pll6 = PORT_PLL_PROP_COEFF(prop_coef) |
2295 		PORT_PLL_INT_COEFF(int_coef) |
2296 		PORT_PLL_GAIN_CTL(gain_ctl);
2297 
2298 	dpll_hw_state->pll8 = PORT_PLL_TARGET_CNT(targ_cnt);
2299 
2300 	dpll_hw_state->pll9 = PORT_PLL_LOCK_THRESHOLD(5);
2301 
2302 	dpll_hw_state->pll10 = PORT_PLL_DCO_AMP(15) |
2303 		PORT_PLL_DCO_AMP_OVR_EN_H;
2304 
2305 	dpll_hw_state->ebb4 = PORT_PLL_10BIT_CLK_ENABLE;
2306 
2307 	dpll_hw_state->pcsdw12 = LANESTAGGER_STRAP_OVRD | lanestagger;
2308 
2309 	return 0;
2310 }
2311 
2312 static int bxt_ddi_pll_get_freq(struct drm_i915_private *i915,
2313 				const struct intel_shared_dpll *pll,
2314 				const struct intel_dpll_hw_state *pll_state)
2315 {
2316 	struct dpll clock;
2317 
2318 	clock.m1 = 2;
2319 	clock.m2 = REG_FIELD_GET(PORT_PLL_M2_INT_MASK, pll_state->pll0) << 22;
2320 	if (pll_state->pll3 & PORT_PLL_M2_FRAC_ENABLE)
2321 		clock.m2 |= REG_FIELD_GET(PORT_PLL_M2_FRAC_MASK, pll_state->pll2);
2322 	clock.n = REG_FIELD_GET(PORT_PLL_N_MASK, pll_state->pll1);
2323 	clock.p1 = REG_FIELD_GET(PORT_PLL_P1_MASK, pll_state->ebb0);
2324 	clock.p2 = REG_FIELD_GET(PORT_PLL_P2_MASK, pll_state->ebb0);
2325 
2326 	return chv_calc_dpll_params(i915->display.dpll.ref_clks.nssc, &clock);
2327 }
2328 
2329 static int
2330 bxt_ddi_dp_set_dpll_hw_state(struct intel_crtc_state *crtc_state)
2331 {
2332 	struct dpll clk_div = {};
2333 
2334 	bxt_ddi_dp_pll_dividers(crtc_state, &clk_div);
2335 
2336 	return bxt_ddi_set_dpll_hw_state(crtc_state, &clk_div);
2337 }
2338 
2339 static int
2340 bxt_ddi_hdmi_set_dpll_hw_state(struct intel_crtc_state *crtc_state)
2341 {
2342 	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2343 	struct dpll clk_div = {};
2344 	int ret;
2345 
2346 	bxt_ddi_hdmi_pll_dividers(crtc_state, &clk_div);
2347 
2348 	ret = bxt_ddi_set_dpll_hw_state(crtc_state, &clk_div);
2349 	if (ret)
2350 		return ret;
2351 
2352 	crtc_state->port_clock = bxt_ddi_pll_get_freq(i915, NULL,
2353 						      &crtc_state->dpll_hw_state);
2354 
2355 	return 0;
2356 }
2357 
2358 static int bxt_compute_dpll(struct intel_atomic_state *state,
2359 			    struct intel_crtc *crtc,
2360 			    struct intel_encoder *encoder)
2361 {
2362 	struct intel_crtc_state *crtc_state =
2363 		intel_atomic_get_new_crtc_state(state, crtc);
2364 
2365 	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI))
2366 		return bxt_ddi_hdmi_set_dpll_hw_state(crtc_state);
2367 	else if (intel_crtc_has_dp_encoder(crtc_state))
2368 		return bxt_ddi_dp_set_dpll_hw_state(crtc_state);
2369 	else
2370 		return -EINVAL;
2371 }
2372 
2373 static int bxt_get_dpll(struct intel_atomic_state *state,
2374 			struct intel_crtc *crtc,
2375 			struct intel_encoder *encoder)
2376 {
2377 	struct intel_crtc_state *crtc_state =
2378 		intel_atomic_get_new_crtc_state(state, crtc);
2379 	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
2380 	struct intel_shared_dpll *pll;
2381 	enum intel_dpll_id id;
2382 
2383 	/* 1:1 mapping between ports and PLLs */
2384 	id = (enum intel_dpll_id) encoder->port;
2385 	pll = intel_get_shared_dpll_by_id(i915, id);
2386 
2387 	drm_dbg_kms(&i915->drm, "[CRTC:%d:%s] using pre-allocated %s\n",
2388 		    crtc->base.base.id, crtc->base.name, pll->info->name);
2389 
2390 	intel_reference_shared_dpll(state, crtc,
2391 				    pll, &crtc_state->dpll_hw_state);
2392 
2393 	crtc_state->shared_dpll = pll;
2394 
2395 	return 0;
2396 }
2397 
2398 static void bxt_update_dpll_ref_clks(struct drm_i915_private *i915)
2399 {
2400 	i915->display.dpll.ref_clks.ssc = 100000;
2401 	i915->display.dpll.ref_clks.nssc = 100000;
2402 	/* DSI non-SSC ref 19.2MHz */
2403 }
2404 
2405 static void bxt_dump_hw_state(struct drm_i915_private *i915,
2406 			      const struct intel_dpll_hw_state *hw_state)
2407 {
2408 	drm_dbg_kms(&i915->drm, "dpll_hw_state: ebb0: 0x%x, ebb4: 0x%x,"
2409 		    "pll0: 0x%x, pll1: 0x%x, pll2: 0x%x, pll3: 0x%x, "
2410 		    "pll6: 0x%x, pll8: 0x%x, pll9: 0x%x, pll10: 0x%x, pcsdw12: 0x%x\n",
2411 		    hw_state->ebb0,
2412 		    hw_state->ebb4,
2413 		    hw_state->pll0,
2414 		    hw_state->pll1,
2415 		    hw_state->pll2,
2416 		    hw_state->pll3,
2417 		    hw_state->pll6,
2418 		    hw_state->pll8,
2419 		    hw_state->pll9,
2420 		    hw_state->pll10,
2421 		    hw_state->pcsdw12);
2422 }
2423 
2424 static bool bxt_compare_hw_state(const struct intel_dpll_hw_state *a,
2425 				 const struct intel_dpll_hw_state *b)
2426 {
2427 	return a->ebb0 == b->ebb0 &&
2428 		a->ebb4 == b->ebb4 &&
2429 		a->pll0 == b->pll0 &&
2430 		a->pll1 == b->pll1 &&
2431 		a->pll2 == b->pll2 &&
2432 		a->pll3 == b->pll3 &&
2433 		a->pll6 == b->pll6 &&
2434 		a->pll8 == b->pll8 &&
2435 		a->pll10 == b->pll10 &&
2436 		a->pcsdw12 == b->pcsdw12;
2437 }
2438 
2439 static const struct intel_shared_dpll_funcs bxt_ddi_pll_funcs = {
2440 	.enable = bxt_ddi_pll_enable,
2441 	.disable = bxt_ddi_pll_disable,
2442 	.get_hw_state = bxt_ddi_pll_get_hw_state,
2443 	.get_freq = bxt_ddi_pll_get_freq,
2444 };
2445 
2446 static const struct dpll_info bxt_plls[] = {
2447 	{ .name = "PORT PLL A", .funcs = &bxt_ddi_pll_funcs, .id = DPLL_ID_SKL_DPLL0, },
2448 	{ .name = "PORT PLL B", .funcs = &bxt_ddi_pll_funcs, .id = DPLL_ID_SKL_DPLL1, },
2449 	{ .name = "PORT PLL C", .funcs = &bxt_ddi_pll_funcs, .id = DPLL_ID_SKL_DPLL2, },
2450 	{}
2451 };
2452 
2453 static const struct intel_dpll_mgr bxt_pll_mgr = {
2454 	.dpll_info = bxt_plls,
2455 	.compute_dplls = bxt_compute_dpll,
2456 	.get_dplls = bxt_get_dpll,
2457 	.put_dplls = intel_put_dpll,
2458 	.update_ref_clks = bxt_update_dpll_ref_clks,
2459 	.dump_hw_state = bxt_dump_hw_state,
2460 	.compare_hw_state = bxt_compare_hw_state,
2461 };
2462 
2463 static void icl_wrpll_get_multipliers(int bestdiv, int *pdiv,
2464 				      int *qdiv, int *kdiv)
2465 {
2466 	/* even dividers */
2467 	if (bestdiv % 2 == 0) {
2468 		if (bestdiv == 2) {
2469 			*pdiv = 2;
2470 			*qdiv = 1;
2471 			*kdiv = 1;
2472 		} else if (bestdiv % 4 == 0) {
2473 			*pdiv = 2;
2474 			*qdiv = bestdiv / 4;
2475 			*kdiv = 2;
2476 		} else if (bestdiv % 6 == 0) {
2477 			*pdiv = 3;
2478 			*qdiv = bestdiv / 6;
2479 			*kdiv = 2;
2480 		} else if (bestdiv % 5 == 0) {
2481 			*pdiv = 5;
2482 			*qdiv = bestdiv / 10;
2483 			*kdiv = 2;
2484 		} else if (bestdiv % 14 == 0) {
2485 			*pdiv = 7;
2486 			*qdiv = bestdiv / 14;
2487 			*kdiv = 2;
2488 		}
2489 	} else {
2490 		if (bestdiv == 3 || bestdiv == 5 || bestdiv == 7) {
2491 			*pdiv = bestdiv;
2492 			*qdiv = 1;
2493 			*kdiv = 1;
2494 		} else { /* 9, 15, 21 */
2495 			*pdiv = bestdiv / 3;
2496 			*qdiv = 1;
2497 			*kdiv = 3;
2498 		}
2499 	}
2500 }
2501 
2502 static void icl_wrpll_params_populate(struct skl_wrpll_params *params,
2503 				      u32 dco_freq, u32 ref_freq,
2504 				      int pdiv, int qdiv, int kdiv)
2505 {
2506 	u32 dco;
2507 
2508 	switch (kdiv) {
2509 	case 1:
2510 		params->kdiv = 1;
2511 		break;
2512 	case 2:
2513 		params->kdiv = 2;
2514 		break;
2515 	case 3:
2516 		params->kdiv = 4;
2517 		break;
2518 	default:
2519 		WARN(1, "Incorrect KDiv\n");
2520 	}
2521 
2522 	switch (pdiv) {
2523 	case 2:
2524 		params->pdiv = 1;
2525 		break;
2526 	case 3:
2527 		params->pdiv = 2;
2528 		break;
2529 	case 5:
2530 		params->pdiv = 4;
2531 		break;
2532 	case 7:
2533 		params->pdiv = 8;
2534 		break;
2535 	default:
2536 		WARN(1, "Incorrect PDiv\n");
2537 	}
2538 
2539 	WARN_ON(kdiv != 2 && qdiv != 1);
2540 
2541 	params->qdiv_ratio = qdiv;
2542 	params->qdiv_mode = (qdiv == 1) ? 0 : 1;
2543 
2544 	dco = div_u64((u64)dco_freq << 15, ref_freq);
2545 
2546 	params->dco_integer = dco >> 15;
2547 	params->dco_fraction = dco & 0x7fff;
2548 }
2549 
2550 /*
2551  * Display WA #22010492432: ehl, tgl, adl-s, adl-p
2552  * Program half of the nominal DCO divider fraction value.
2553  */
2554 static bool
2555 ehl_combo_pll_div_frac_wa_needed(struct drm_i915_private *i915)
2556 {
2557 	return ((IS_ELKHARTLAKE(i915) &&
2558 		 IS_DISPLAY_STEP(i915, STEP_B0, STEP_FOREVER)) ||
2559 		 IS_TIGERLAKE(i915) || IS_ALDERLAKE_S(i915) || IS_ALDERLAKE_P(i915)) &&
2560 		 i915->display.dpll.ref_clks.nssc == 38400;
2561 }
2562 
2563 struct icl_combo_pll_params {
2564 	int clock;
2565 	struct skl_wrpll_params wrpll;
2566 };
2567 
2568 /*
2569  * These values alrea already adjusted: they're the bits we write to the
2570  * registers, not the logical values.
2571  */
2572 static const struct icl_combo_pll_params icl_dp_combo_pll_24MHz_values[] = {
2573 	{ 540000,
2574 	  { .dco_integer = 0x151, .dco_fraction = 0x4000,		/* [0]: 5.4 */
2575 	    .pdiv = 0x2 /* 3 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2576 	{ 270000,
2577 	  { .dco_integer = 0x151, .dco_fraction = 0x4000,		/* [1]: 2.7 */
2578 	    .pdiv = 0x2 /* 3 */, .kdiv = 2, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2579 	{ 162000,
2580 	  { .dco_integer = 0x151, .dco_fraction = 0x4000,		/* [2]: 1.62 */
2581 	    .pdiv = 0x4 /* 5 */, .kdiv = 2, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2582 	{ 324000,
2583 	  { .dco_integer = 0x151, .dco_fraction = 0x4000,		/* [3]: 3.24 */
2584 	    .pdiv = 0x4 /* 5 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2585 	{ 216000,
2586 	  { .dco_integer = 0x168, .dco_fraction = 0x0000,		/* [4]: 2.16 */
2587 	    .pdiv = 0x1 /* 2 */, .kdiv = 2, .qdiv_mode = 1, .qdiv_ratio = 2, }, },
2588 	{ 432000,
2589 	  { .dco_integer = 0x168, .dco_fraction = 0x0000,		/* [5]: 4.32 */
2590 	    .pdiv = 0x1 /* 2 */, .kdiv = 2, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2591 	{ 648000,
2592 	  { .dco_integer = 0x195, .dco_fraction = 0x0000,		/* [6]: 6.48 */
2593 	    .pdiv = 0x2 /* 3 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2594 	{ 810000,
2595 	  { .dco_integer = 0x151, .dco_fraction = 0x4000,		/* [7]: 8.1 */
2596 	    .pdiv = 0x1 /* 2 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2597 };
2598 
2599 
2600 /* Also used for 38.4 MHz values. */
2601 static const struct icl_combo_pll_params icl_dp_combo_pll_19_2MHz_values[] = {
2602 	{ 540000,
2603 	  { .dco_integer = 0x1A5, .dco_fraction = 0x7000,		/* [0]: 5.4 */
2604 	    .pdiv = 0x2 /* 3 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2605 	{ 270000,
2606 	  { .dco_integer = 0x1A5, .dco_fraction = 0x7000,		/* [1]: 2.7 */
2607 	    .pdiv = 0x2 /* 3 */, .kdiv = 2, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2608 	{ 162000,
2609 	  { .dco_integer = 0x1A5, .dco_fraction = 0x7000,		/* [2]: 1.62 */
2610 	    .pdiv = 0x4 /* 5 */, .kdiv = 2, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2611 	{ 324000,
2612 	  { .dco_integer = 0x1A5, .dco_fraction = 0x7000,		/* [3]: 3.24 */
2613 	    .pdiv = 0x4 /* 5 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2614 	{ 216000,
2615 	  { .dco_integer = 0x1C2, .dco_fraction = 0x0000,		/* [4]: 2.16 */
2616 	    .pdiv = 0x1 /* 2 */, .kdiv = 2, .qdiv_mode = 1, .qdiv_ratio = 2, }, },
2617 	{ 432000,
2618 	  { .dco_integer = 0x1C2, .dco_fraction = 0x0000,		/* [5]: 4.32 */
2619 	    .pdiv = 0x1 /* 2 */, .kdiv = 2, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2620 	{ 648000,
2621 	  { .dco_integer = 0x1FA, .dco_fraction = 0x2000,		/* [6]: 6.48 */
2622 	    .pdiv = 0x2 /* 3 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2623 	{ 810000,
2624 	  { .dco_integer = 0x1A5, .dco_fraction = 0x7000,		/* [7]: 8.1 */
2625 	    .pdiv = 0x1 /* 2 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2626 };
2627 
2628 static const struct skl_wrpll_params icl_tbt_pll_24MHz_values = {
2629 	.dco_integer = 0x151, .dco_fraction = 0x4000,
2630 	.pdiv = 0x4 /* 5 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0,
2631 };
2632 
2633 static const struct skl_wrpll_params icl_tbt_pll_19_2MHz_values = {
2634 	.dco_integer = 0x1A5, .dco_fraction = 0x7000,
2635 	.pdiv = 0x4 /* 5 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0,
2636 };
2637 
2638 static const struct skl_wrpll_params tgl_tbt_pll_19_2MHz_values = {
2639 	.dco_integer = 0x54, .dco_fraction = 0x3000,
2640 	/* the following params are unused */
2641 	.pdiv = 0, .kdiv = 0, .qdiv_mode = 0, .qdiv_ratio = 0,
2642 };
2643 
2644 static const struct skl_wrpll_params tgl_tbt_pll_24MHz_values = {
2645 	.dco_integer = 0x43, .dco_fraction = 0x4000,
2646 	/* the following params are unused */
2647 };
2648 
2649 static int icl_calc_dp_combo_pll(struct intel_crtc_state *crtc_state,
2650 				 struct skl_wrpll_params *pll_params)
2651 {
2652 	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2653 	const struct icl_combo_pll_params *params =
2654 		i915->display.dpll.ref_clks.nssc == 24000 ?
2655 		icl_dp_combo_pll_24MHz_values :
2656 		icl_dp_combo_pll_19_2MHz_values;
2657 	int clock = crtc_state->port_clock;
2658 	int i;
2659 
2660 	for (i = 0; i < ARRAY_SIZE(icl_dp_combo_pll_24MHz_values); i++) {
2661 		if (clock == params[i].clock) {
2662 			*pll_params = params[i].wrpll;
2663 			return 0;
2664 		}
2665 	}
2666 
2667 	MISSING_CASE(clock);
2668 	return -EINVAL;
2669 }
2670 
2671 static int icl_calc_tbt_pll(struct intel_crtc_state *crtc_state,
2672 			    struct skl_wrpll_params *pll_params)
2673 {
2674 	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2675 
2676 	if (DISPLAY_VER(i915) >= 12) {
2677 		switch (i915->display.dpll.ref_clks.nssc) {
2678 		default:
2679 			MISSING_CASE(i915->display.dpll.ref_clks.nssc);
2680 			fallthrough;
2681 		case 19200:
2682 		case 38400:
2683 			*pll_params = tgl_tbt_pll_19_2MHz_values;
2684 			break;
2685 		case 24000:
2686 			*pll_params = tgl_tbt_pll_24MHz_values;
2687 			break;
2688 		}
2689 	} else {
2690 		switch (i915->display.dpll.ref_clks.nssc) {
2691 		default:
2692 			MISSING_CASE(i915->display.dpll.ref_clks.nssc);
2693 			fallthrough;
2694 		case 19200:
2695 		case 38400:
2696 			*pll_params = icl_tbt_pll_19_2MHz_values;
2697 			break;
2698 		case 24000:
2699 			*pll_params = icl_tbt_pll_24MHz_values;
2700 			break;
2701 		}
2702 	}
2703 
2704 	return 0;
2705 }
2706 
2707 static int icl_ddi_tbt_pll_get_freq(struct drm_i915_private *i915,
2708 				    const struct intel_shared_dpll *pll,
2709 				    const struct intel_dpll_hw_state *pll_state)
2710 {
2711 	/*
2712 	 * The PLL outputs multiple frequencies at the same time, selection is
2713 	 * made at DDI clock mux level.
2714 	 */
2715 	drm_WARN_ON(&i915->drm, 1);
2716 
2717 	return 0;
2718 }
2719 
2720 static int icl_wrpll_ref_clock(struct drm_i915_private *i915)
2721 {
2722 	int ref_clock = i915->display.dpll.ref_clks.nssc;
2723 
2724 	/*
2725 	 * For ICL+, the spec states: if reference frequency is 38.4,
2726 	 * use 19.2 because the DPLL automatically divides that by 2.
2727 	 */
2728 	if (ref_clock == 38400)
2729 		ref_clock = 19200;
2730 
2731 	return ref_clock;
2732 }
2733 
2734 static int
2735 icl_calc_wrpll(struct intel_crtc_state *crtc_state,
2736 	       struct skl_wrpll_params *wrpll_params)
2737 {
2738 	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2739 	int ref_clock = icl_wrpll_ref_clock(i915);
2740 	u32 afe_clock = crtc_state->port_clock * 5;
2741 	u32 dco_min = 7998000;
2742 	u32 dco_max = 10000000;
2743 	u32 dco_mid = (dco_min + dco_max) / 2;
2744 	static const int dividers[] = {  2,  4,  6,  8, 10, 12,  14,  16,
2745 					 18, 20, 24, 28, 30, 32,  36,  40,
2746 					 42, 44, 48, 50, 52, 54,  56,  60,
2747 					 64, 66, 68, 70, 72, 76,  78,  80,
2748 					 84, 88, 90, 92, 96, 98, 100, 102,
2749 					  3,  5,  7,  9, 15, 21 };
2750 	u32 dco, best_dco = 0, dco_centrality = 0;
2751 	u32 best_dco_centrality = U32_MAX; /* Spec meaning of 999999 MHz */
2752 	int d, best_div = 0, pdiv = 0, qdiv = 0, kdiv = 0;
2753 
2754 	for (d = 0; d < ARRAY_SIZE(dividers); d++) {
2755 		dco = afe_clock * dividers[d];
2756 
2757 		if (dco <= dco_max && dco >= dco_min) {
2758 			dco_centrality = abs(dco - dco_mid);
2759 
2760 			if (dco_centrality < best_dco_centrality) {
2761 				best_dco_centrality = dco_centrality;
2762 				best_div = dividers[d];
2763 				best_dco = dco;
2764 			}
2765 		}
2766 	}
2767 
2768 	if (best_div == 0)
2769 		return -EINVAL;
2770 
2771 	icl_wrpll_get_multipliers(best_div, &pdiv, &qdiv, &kdiv);
2772 	icl_wrpll_params_populate(wrpll_params, best_dco, ref_clock,
2773 				  pdiv, qdiv, kdiv);
2774 
2775 	return 0;
2776 }
2777 
2778 static int icl_ddi_combo_pll_get_freq(struct drm_i915_private *i915,
2779 				      const struct intel_shared_dpll *pll,
2780 				      const struct intel_dpll_hw_state *pll_state)
2781 {
2782 	int ref_clock = icl_wrpll_ref_clock(i915);
2783 	u32 dco_fraction;
2784 	u32 p0, p1, p2, dco_freq;
2785 
2786 	p0 = pll_state->cfgcr1 & DPLL_CFGCR1_PDIV_MASK;
2787 	p2 = pll_state->cfgcr1 & DPLL_CFGCR1_KDIV_MASK;
2788 
2789 	if (pll_state->cfgcr1 & DPLL_CFGCR1_QDIV_MODE(1))
2790 		p1 = (pll_state->cfgcr1 & DPLL_CFGCR1_QDIV_RATIO_MASK) >>
2791 			DPLL_CFGCR1_QDIV_RATIO_SHIFT;
2792 	else
2793 		p1 = 1;
2794 
2795 	switch (p0) {
2796 	case DPLL_CFGCR1_PDIV_2:
2797 		p0 = 2;
2798 		break;
2799 	case DPLL_CFGCR1_PDIV_3:
2800 		p0 = 3;
2801 		break;
2802 	case DPLL_CFGCR1_PDIV_5:
2803 		p0 = 5;
2804 		break;
2805 	case DPLL_CFGCR1_PDIV_7:
2806 		p0 = 7;
2807 		break;
2808 	}
2809 
2810 	switch (p2) {
2811 	case DPLL_CFGCR1_KDIV_1:
2812 		p2 = 1;
2813 		break;
2814 	case DPLL_CFGCR1_KDIV_2:
2815 		p2 = 2;
2816 		break;
2817 	case DPLL_CFGCR1_KDIV_3:
2818 		p2 = 3;
2819 		break;
2820 	}
2821 
2822 	dco_freq = (pll_state->cfgcr0 & DPLL_CFGCR0_DCO_INTEGER_MASK) *
2823 		   ref_clock;
2824 
2825 	dco_fraction = (pll_state->cfgcr0 & DPLL_CFGCR0_DCO_FRACTION_MASK) >>
2826 		       DPLL_CFGCR0_DCO_FRACTION_SHIFT;
2827 
2828 	if (ehl_combo_pll_div_frac_wa_needed(i915))
2829 		dco_fraction *= 2;
2830 
2831 	dco_freq += (dco_fraction * ref_clock) / 0x8000;
2832 
2833 	if (drm_WARN_ON(&i915->drm, p0 == 0 || p1 == 0 || p2 == 0))
2834 		return 0;
2835 
2836 	return dco_freq / (p0 * p1 * p2 * 5);
2837 }
2838 
2839 static void icl_calc_dpll_state(struct drm_i915_private *i915,
2840 				const struct skl_wrpll_params *pll_params,
2841 				struct intel_dpll_hw_state *pll_state)
2842 {
2843 	u32 dco_fraction = pll_params->dco_fraction;
2844 
2845 	if (ehl_combo_pll_div_frac_wa_needed(i915))
2846 		dco_fraction = DIV_ROUND_CLOSEST(dco_fraction, 2);
2847 
2848 	pll_state->cfgcr0 = DPLL_CFGCR0_DCO_FRACTION(dco_fraction) |
2849 			    pll_params->dco_integer;
2850 
2851 	pll_state->cfgcr1 = DPLL_CFGCR1_QDIV_RATIO(pll_params->qdiv_ratio) |
2852 			    DPLL_CFGCR1_QDIV_MODE(pll_params->qdiv_mode) |
2853 			    DPLL_CFGCR1_KDIV(pll_params->kdiv) |
2854 			    DPLL_CFGCR1_PDIV(pll_params->pdiv);
2855 
2856 	if (DISPLAY_VER(i915) >= 12)
2857 		pll_state->cfgcr1 |= TGL_DPLL_CFGCR1_CFSELOVRD_NORMAL_XTAL;
2858 	else
2859 		pll_state->cfgcr1 |= DPLL_CFGCR1_CENTRAL_FREQ_8400;
2860 
2861 	if (i915->display.vbt.override_afc_startup)
2862 		pll_state->div0 = TGL_DPLL0_DIV0_AFC_STARTUP(i915->display.vbt.override_afc_startup_val);
2863 }
2864 
2865 static int icl_mg_pll_find_divisors(int clock_khz, bool is_dp, bool use_ssc,
2866 				    u32 *target_dco_khz,
2867 				    struct intel_dpll_hw_state *state,
2868 				    bool is_dkl)
2869 {
2870 	static const u8 div1_vals[] = { 7, 5, 3, 2 };
2871 	u32 dco_min_freq, dco_max_freq;
2872 	unsigned int i;
2873 	int div2;
2874 
2875 	dco_min_freq = is_dp ? 8100000 : use_ssc ? 8000000 : 7992000;
2876 	dco_max_freq = is_dp ? 8100000 : 10000000;
2877 
2878 	for (i = 0; i < ARRAY_SIZE(div1_vals); i++) {
2879 		int div1 = div1_vals[i];
2880 
2881 		for (div2 = 10; div2 > 0; div2--) {
2882 			int dco = div1 * div2 * clock_khz * 5;
2883 			int a_divratio, tlinedrv, inputsel;
2884 			u32 hsdiv;
2885 
2886 			if (dco < dco_min_freq || dco > dco_max_freq)
2887 				continue;
2888 
2889 			if (div2 >= 2) {
2890 				/*
2891 				 * Note: a_divratio not matching TGL BSpec
2892 				 * algorithm but matching hardcoded values and
2893 				 * working on HW for DP alt-mode at least
2894 				 */
2895 				a_divratio = is_dp ? 10 : 5;
2896 				tlinedrv = is_dkl ? 1 : 2;
2897 			} else {
2898 				a_divratio = 5;
2899 				tlinedrv = 0;
2900 			}
2901 			inputsel = is_dp ? 0 : 1;
2902 
2903 			switch (div1) {
2904 			default:
2905 				MISSING_CASE(div1);
2906 				fallthrough;
2907 			case 2:
2908 				hsdiv = MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_2;
2909 				break;
2910 			case 3:
2911 				hsdiv = MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_3;
2912 				break;
2913 			case 5:
2914 				hsdiv = MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_5;
2915 				break;
2916 			case 7:
2917 				hsdiv = MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_7;
2918 				break;
2919 			}
2920 
2921 			*target_dco_khz = dco;
2922 
2923 			state->mg_refclkin_ctl = MG_REFCLKIN_CTL_OD_2_MUX(1);
2924 
2925 			state->mg_clktop2_coreclkctl1 =
2926 				MG_CLKTOP2_CORECLKCTL1_A_DIVRATIO(a_divratio);
2927 
2928 			state->mg_clktop2_hsclkctl =
2929 				MG_CLKTOP2_HSCLKCTL_TLINEDRV_CLKSEL(tlinedrv) |
2930 				MG_CLKTOP2_HSCLKCTL_CORE_INPUTSEL(inputsel) |
2931 				hsdiv |
2932 				MG_CLKTOP2_HSCLKCTL_DSDIV_RATIO(div2);
2933 
2934 			return 0;
2935 		}
2936 	}
2937 
2938 	return -EINVAL;
2939 }
2940 
2941 /*
2942  * The specification for this function uses real numbers, so the math had to be
2943  * adapted to integer-only calculation, that's why it looks so different.
2944  */
2945 static int icl_calc_mg_pll_state(struct intel_crtc_state *crtc_state,
2946 				 struct intel_dpll_hw_state *pll_state)
2947 {
2948 	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2949 	int refclk_khz = i915->display.dpll.ref_clks.nssc;
2950 	int clock = crtc_state->port_clock;
2951 	u32 dco_khz, m1div, m2div_int, m2div_rem, m2div_frac;
2952 	u32 iref_ndiv, iref_trim, iref_pulse_w;
2953 	u32 prop_coeff, int_coeff;
2954 	u32 tdc_targetcnt, feedfwgain;
2955 	u64 ssc_stepsize, ssc_steplen, ssc_steplog;
2956 	u64 tmp;
2957 	bool use_ssc = false;
2958 	bool is_dp = !intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI);
2959 	bool is_dkl = DISPLAY_VER(i915) >= 12;
2960 	int ret;
2961 
2962 	ret = icl_mg_pll_find_divisors(clock, is_dp, use_ssc, &dco_khz,
2963 				       pll_state, is_dkl);
2964 	if (ret)
2965 		return ret;
2966 
2967 	m1div = 2;
2968 	m2div_int = dco_khz / (refclk_khz * m1div);
2969 	if (m2div_int > 255) {
2970 		if (!is_dkl) {
2971 			m1div = 4;
2972 			m2div_int = dco_khz / (refclk_khz * m1div);
2973 		}
2974 
2975 		if (m2div_int > 255)
2976 			return -EINVAL;
2977 	}
2978 	m2div_rem = dco_khz % (refclk_khz * m1div);
2979 
2980 	tmp = (u64)m2div_rem * (1 << 22);
2981 	do_div(tmp, refclk_khz * m1div);
2982 	m2div_frac = tmp;
2983 
2984 	switch (refclk_khz) {
2985 	case 19200:
2986 		iref_ndiv = 1;
2987 		iref_trim = 28;
2988 		iref_pulse_w = 1;
2989 		break;
2990 	case 24000:
2991 		iref_ndiv = 1;
2992 		iref_trim = 25;
2993 		iref_pulse_w = 2;
2994 		break;
2995 	case 38400:
2996 		iref_ndiv = 2;
2997 		iref_trim = 28;
2998 		iref_pulse_w = 1;
2999 		break;
3000 	default:
3001 		MISSING_CASE(refclk_khz);
3002 		return -EINVAL;
3003 	}
3004 
3005 	/*
3006 	 * tdc_res = 0.000003
3007 	 * tdc_targetcnt = int(2 / (tdc_res * 8 * 50 * 1.1) / refclk_mhz + 0.5)
3008 	 *
3009 	 * The multiplication by 1000 is due to refclk MHz to KHz conversion. It
3010 	 * was supposed to be a division, but we rearranged the operations of
3011 	 * the formula to avoid early divisions so we don't multiply the
3012 	 * rounding errors.
3013 	 *
3014 	 * 0.000003 * 8 * 50 * 1.1 = 0.00132, also known as 132 / 100000, which
3015 	 * we also rearrange to work with integers.
3016 	 *
3017 	 * The 0.5 transformed to 5 results in a multiplication by 10 and the
3018 	 * last division by 10.
3019 	 */
3020 	tdc_targetcnt = (2 * 1000 * 100000 * 10 / (132 * refclk_khz) + 5) / 10;
3021 
3022 	/*
3023 	 * Here we divide dco_khz by 10 in order to allow the dividend to fit in
3024 	 * 32 bits. That's not a problem since we round the division down
3025 	 * anyway.
3026 	 */
3027 	feedfwgain = (use_ssc || m2div_rem > 0) ?
3028 		m1div * 1000000 * 100 / (dco_khz * 3 / 10) : 0;
3029 
3030 	if (dco_khz >= 9000000) {
3031 		prop_coeff = 5;
3032 		int_coeff = 10;
3033 	} else {
3034 		prop_coeff = 4;
3035 		int_coeff = 8;
3036 	}
3037 
3038 	if (use_ssc) {
3039 		tmp = mul_u32_u32(dco_khz, 47 * 32);
3040 		do_div(tmp, refclk_khz * m1div * 10000);
3041 		ssc_stepsize = tmp;
3042 
3043 		tmp = mul_u32_u32(dco_khz, 1000);
3044 		ssc_steplen = DIV_ROUND_UP_ULL(tmp, 32 * 2 * 32);
3045 	} else {
3046 		ssc_stepsize = 0;
3047 		ssc_steplen = 0;
3048 	}
3049 	ssc_steplog = 4;
3050 
3051 	/* write pll_state calculations */
3052 	if (is_dkl) {
3053 		pll_state->mg_pll_div0 = DKL_PLL_DIV0_INTEG_COEFF(int_coeff) |
3054 					 DKL_PLL_DIV0_PROP_COEFF(prop_coeff) |
3055 					 DKL_PLL_DIV0_FBPREDIV(m1div) |
3056 					 DKL_PLL_DIV0_FBDIV_INT(m2div_int);
3057 		if (i915->display.vbt.override_afc_startup) {
3058 			u8 val = i915->display.vbt.override_afc_startup_val;
3059 
3060 			pll_state->mg_pll_div0 |= DKL_PLL_DIV0_AFC_STARTUP(val);
3061 		}
3062 
3063 		pll_state->mg_pll_div1 = DKL_PLL_DIV1_IREF_TRIM(iref_trim) |
3064 					 DKL_PLL_DIV1_TDC_TARGET_CNT(tdc_targetcnt);
3065 
3066 		pll_state->mg_pll_ssc = DKL_PLL_SSC_IREF_NDIV_RATIO(iref_ndiv) |
3067 					DKL_PLL_SSC_STEP_LEN(ssc_steplen) |
3068 					DKL_PLL_SSC_STEP_NUM(ssc_steplog) |
3069 					(use_ssc ? DKL_PLL_SSC_EN : 0);
3070 
3071 		pll_state->mg_pll_bias = (m2div_frac ? DKL_PLL_BIAS_FRAC_EN_H : 0) |
3072 					  DKL_PLL_BIAS_FBDIV_FRAC(m2div_frac);
3073 
3074 		pll_state->mg_pll_tdc_coldst_bias =
3075 				DKL_PLL_TDC_SSC_STEP_SIZE(ssc_stepsize) |
3076 				DKL_PLL_TDC_FEED_FWD_GAIN(feedfwgain);
3077 
3078 	} else {
3079 		pll_state->mg_pll_div0 =
3080 			(m2div_rem > 0 ? MG_PLL_DIV0_FRACNEN_H : 0) |
3081 			MG_PLL_DIV0_FBDIV_FRAC(m2div_frac) |
3082 			MG_PLL_DIV0_FBDIV_INT(m2div_int);
3083 
3084 		pll_state->mg_pll_div1 =
3085 			MG_PLL_DIV1_IREF_NDIVRATIO(iref_ndiv) |
3086 			MG_PLL_DIV1_DITHER_DIV_2 |
3087 			MG_PLL_DIV1_NDIVRATIO(1) |
3088 			MG_PLL_DIV1_FBPREDIV(m1div);
3089 
3090 		pll_state->mg_pll_lf =
3091 			MG_PLL_LF_TDCTARGETCNT(tdc_targetcnt) |
3092 			MG_PLL_LF_AFCCNTSEL_512 |
3093 			MG_PLL_LF_GAINCTRL(1) |
3094 			MG_PLL_LF_INT_COEFF(int_coeff) |
3095 			MG_PLL_LF_PROP_COEFF(prop_coeff);
3096 
3097 		pll_state->mg_pll_frac_lock =
3098 			MG_PLL_FRAC_LOCK_TRUELOCK_CRIT_32 |
3099 			MG_PLL_FRAC_LOCK_EARLYLOCK_CRIT_32 |
3100 			MG_PLL_FRAC_LOCK_LOCKTHRESH(10) |
3101 			MG_PLL_FRAC_LOCK_DCODITHEREN |
3102 			MG_PLL_FRAC_LOCK_FEEDFWRDGAIN(feedfwgain);
3103 		if (use_ssc || m2div_rem > 0)
3104 			pll_state->mg_pll_frac_lock |=
3105 				MG_PLL_FRAC_LOCK_FEEDFWRDCAL_EN;
3106 
3107 		pll_state->mg_pll_ssc =
3108 			(use_ssc ? MG_PLL_SSC_EN : 0) |
3109 			MG_PLL_SSC_TYPE(2) |
3110 			MG_PLL_SSC_STEPLENGTH(ssc_steplen) |
3111 			MG_PLL_SSC_STEPNUM(ssc_steplog) |
3112 			MG_PLL_SSC_FLLEN |
3113 			MG_PLL_SSC_STEPSIZE(ssc_stepsize);
3114 
3115 		pll_state->mg_pll_tdc_coldst_bias =
3116 			MG_PLL_TDC_COLDST_COLDSTART |
3117 			MG_PLL_TDC_COLDST_IREFINT_EN |
3118 			MG_PLL_TDC_COLDST_REFBIAS_START_PULSE_W(iref_pulse_w) |
3119 			MG_PLL_TDC_TDCOVCCORR_EN |
3120 			MG_PLL_TDC_TDCSEL(3);
3121 
3122 		pll_state->mg_pll_bias =
3123 			MG_PLL_BIAS_BIAS_GB_SEL(3) |
3124 			MG_PLL_BIAS_INIT_DCOAMP(0x3F) |
3125 			MG_PLL_BIAS_BIAS_BONUS(10) |
3126 			MG_PLL_BIAS_BIASCAL_EN |
3127 			MG_PLL_BIAS_CTRIM(12) |
3128 			MG_PLL_BIAS_VREF_RDAC(4) |
3129 			MG_PLL_BIAS_IREFTRIM(iref_trim);
3130 
3131 		if (refclk_khz == 38400) {
3132 			pll_state->mg_pll_tdc_coldst_bias_mask =
3133 				MG_PLL_TDC_COLDST_COLDSTART;
3134 			pll_state->mg_pll_bias_mask = 0;
3135 		} else {
3136 			pll_state->mg_pll_tdc_coldst_bias_mask = -1U;
3137 			pll_state->mg_pll_bias_mask = -1U;
3138 		}
3139 
3140 		pll_state->mg_pll_tdc_coldst_bias &=
3141 			pll_state->mg_pll_tdc_coldst_bias_mask;
3142 		pll_state->mg_pll_bias &= pll_state->mg_pll_bias_mask;
3143 	}
3144 
3145 	return 0;
3146 }
3147 
3148 static int icl_ddi_mg_pll_get_freq(struct drm_i915_private *i915,
3149 				   const struct intel_shared_dpll *pll,
3150 				   const struct intel_dpll_hw_state *pll_state)
3151 {
3152 	u32 m1, m2_int, m2_frac, div1, div2, ref_clock;
3153 	u64 tmp;
3154 
3155 	ref_clock = i915->display.dpll.ref_clks.nssc;
3156 
3157 	if (DISPLAY_VER(i915) >= 12) {
3158 		m1 = pll_state->mg_pll_div0 & DKL_PLL_DIV0_FBPREDIV_MASK;
3159 		m1 = m1 >> DKL_PLL_DIV0_FBPREDIV_SHIFT;
3160 		m2_int = pll_state->mg_pll_div0 & DKL_PLL_DIV0_FBDIV_INT_MASK;
3161 
3162 		if (pll_state->mg_pll_bias & DKL_PLL_BIAS_FRAC_EN_H) {
3163 			m2_frac = pll_state->mg_pll_bias &
3164 				  DKL_PLL_BIAS_FBDIV_FRAC_MASK;
3165 			m2_frac = m2_frac >> DKL_PLL_BIAS_FBDIV_SHIFT;
3166 		} else {
3167 			m2_frac = 0;
3168 		}
3169 	} else {
3170 		m1 = pll_state->mg_pll_div1 & MG_PLL_DIV1_FBPREDIV_MASK;
3171 		m2_int = pll_state->mg_pll_div0 & MG_PLL_DIV0_FBDIV_INT_MASK;
3172 
3173 		if (pll_state->mg_pll_div0 & MG_PLL_DIV0_FRACNEN_H) {
3174 			m2_frac = pll_state->mg_pll_div0 &
3175 				  MG_PLL_DIV0_FBDIV_FRAC_MASK;
3176 			m2_frac = m2_frac >> MG_PLL_DIV0_FBDIV_FRAC_SHIFT;
3177 		} else {
3178 			m2_frac = 0;
3179 		}
3180 	}
3181 
3182 	switch (pll_state->mg_clktop2_hsclkctl &
3183 		MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_MASK) {
3184 	case MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_2:
3185 		div1 = 2;
3186 		break;
3187 	case MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_3:
3188 		div1 = 3;
3189 		break;
3190 	case MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_5:
3191 		div1 = 5;
3192 		break;
3193 	case MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_7:
3194 		div1 = 7;
3195 		break;
3196 	default:
3197 		MISSING_CASE(pll_state->mg_clktop2_hsclkctl);
3198 		return 0;
3199 	}
3200 
3201 	div2 = (pll_state->mg_clktop2_hsclkctl &
3202 		MG_CLKTOP2_HSCLKCTL_DSDIV_RATIO_MASK) >>
3203 		MG_CLKTOP2_HSCLKCTL_DSDIV_RATIO_SHIFT;
3204 
3205 	/* div2 value of 0 is same as 1 means no div */
3206 	if (div2 == 0)
3207 		div2 = 1;
3208 
3209 	/*
3210 	 * Adjust the original formula to delay the division by 2^22 in order to
3211 	 * minimize possible rounding errors.
3212 	 */
3213 	tmp = (u64)m1 * m2_int * ref_clock +
3214 	      (((u64)m1 * m2_frac * ref_clock) >> 22);
3215 	tmp = div_u64(tmp, 5 * div1 * div2);
3216 
3217 	return tmp;
3218 }
3219 
3220 /**
3221  * icl_set_active_port_dpll - select the active port DPLL for a given CRTC
3222  * @crtc_state: state for the CRTC to select the DPLL for
3223  * @port_dpll_id: the active @port_dpll_id to select
3224  *
3225  * Select the given @port_dpll_id instance from the DPLLs reserved for the
3226  * CRTC.
3227  */
3228 void icl_set_active_port_dpll(struct intel_crtc_state *crtc_state,
3229 			      enum icl_port_dpll_id port_dpll_id)
3230 {
3231 	struct icl_port_dpll *port_dpll =
3232 		&crtc_state->icl_port_dplls[port_dpll_id];
3233 
3234 	crtc_state->shared_dpll = port_dpll->pll;
3235 	crtc_state->dpll_hw_state = port_dpll->hw_state;
3236 }
3237 
3238 static void icl_update_active_dpll(struct intel_atomic_state *state,
3239 				   struct intel_crtc *crtc,
3240 				   struct intel_encoder *encoder)
3241 {
3242 	struct intel_crtc_state *crtc_state =
3243 		intel_atomic_get_new_crtc_state(state, crtc);
3244 	struct intel_digital_port *primary_port;
3245 	enum icl_port_dpll_id port_dpll_id = ICL_PORT_DPLL_DEFAULT;
3246 
3247 	primary_port = encoder->type == INTEL_OUTPUT_DP_MST ?
3248 		enc_to_mst(encoder)->primary :
3249 		enc_to_dig_port(encoder);
3250 
3251 	if (primary_port &&
3252 	    (intel_tc_port_in_dp_alt_mode(primary_port) ||
3253 	     intel_tc_port_in_legacy_mode(primary_port)))
3254 		port_dpll_id = ICL_PORT_DPLL_MG_PHY;
3255 
3256 	icl_set_active_port_dpll(crtc_state, port_dpll_id);
3257 }
3258 
3259 static int icl_compute_combo_phy_dpll(struct intel_atomic_state *state,
3260 				      struct intel_crtc *crtc)
3261 {
3262 	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
3263 	struct intel_crtc_state *crtc_state =
3264 		intel_atomic_get_new_crtc_state(state, crtc);
3265 	struct icl_port_dpll *port_dpll =
3266 		&crtc_state->icl_port_dplls[ICL_PORT_DPLL_DEFAULT];
3267 	struct skl_wrpll_params pll_params = {};
3268 	int ret;
3269 
3270 	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI) ||
3271 	    intel_crtc_has_type(crtc_state, INTEL_OUTPUT_DSI))
3272 		ret = icl_calc_wrpll(crtc_state, &pll_params);
3273 	else
3274 		ret = icl_calc_dp_combo_pll(crtc_state, &pll_params);
3275 
3276 	if (ret)
3277 		return ret;
3278 
3279 	icl_calc_dpll_state(i915, &pll_params, &port_dpll->hw_state);
3280 
3281 	/* this is mainly for the fastset check */
3282 	icl_set_active_port_dpll(crtc_state, ICL_PORT_DPLL_DEFAULT);
3283 
3284 	crtc_state->port_clock = icl_ddi_combo_pll_get_freq(i915, NULL,
3285 							    &port_dpll->hw_state);
3286 
3287 	return 0;
3288 }
3289 
3290 static int icl_get_combo_phy_dpll(struct intel_atomic_state *state,
3291 				  struct intel_crtc *crtc,
3292 				  struct intel_encoder *encoder)
3293 {
3294 	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
3295 	struct intel_crtc_state *crtc_state =
3296 		intel_atomic_get_new_crtc_state(state, crtc);
3297 	struct icl_port_dpll *port_dpll =
3298 		&crtc_state->icl_port_dplls[ICL_PORT_DPLL_DEFAULT];
3299 	enum port port = encoder->port;
3300 	unsigned long dpll_mask;
3301 
3302 	if (IS_ALDERLAKE_S(i915)) {
3303 		dpll_mask =
3304 			BIT(DPLL_ID_DG1_DPLL3) |
3305 			BIT(DPLL_ID_DG1_DPLL2) |
3306 			BIT(DPLL_ID_ICL_DPLL1) |
3307 			BIT(DPLL_ID_ICL_DPLL0);
3308 	} else if (IS_DG1(i915)) {
3309 		if (port == PORT_D || port == PORT_E) {
3310 			dpll_mask =
3311 				BIT(DPLL_ID_DG1_DPLL2) |
3312 				BIT(DPLL_ID_DG1_DPLL3);
3313 		} else {
3314 			dpll_mask =
3315 				BIT(DPLL_ID_DG1_DPLL0) |
3316 				BIT(DPLL_ID_DG1_DPLL1);
3317 		}
3318 	} else if (IS_ROCKETLAKE(i915)) {
3319 		dpll_mask =
3320 			BIT(DPLL_ID_EHL_DPLL4) |
3321 			BIT(DPLL_ID_ICL_DPLL1) |
3322 			BIT(DPLL_ID_ICL_DPLL0);
3323 	} else if ((IS_JASPERLAKE(i915) || IS_ELKHARTLAKE(i915)) &&
3324 		   port != PORT_A) {
3325 		dpll_mask =
3326 			BIT(DPLL_ID_EHL_DPLL4) |
3327 			BIT(DPLL_ID_ICL_DPLL1) |
3328 			BIT(DPLL_ID_ICL_DPLL0);
3329 	} else {
3330 		dpll_mask = BIT(DPLL_ID_ICL_DPLL1) | BIT(DPLL_ID_ICL_DPLL0);
3331 	}
3332 
3333 	/* Eliminate DPLLs from consideration if reserved by HTI */
3334 	dpll_mask &= ~intel_hti_dpll_mask(i915);
3335 
3336 	port_dpll->pll = intel_find_shared_dpll(state, crtc,
3337 						&port_dpll->hw_state,
3338 						dpll_mask);
3339 	if (!port_dpll->pll)
3340 		return -EINVAL;
3341 
3342 	intel_reference_shared_dpll(state, crtc,
3343 				    port_dpll->pll, &port_dpll->hw_state);
3344 
3345 	icl_update_active_dpll(state, crtc, encoder);
3346 
3347 	return 0;
3348 }
3349 
3350 static int icl_compute_tc_phy_dplls(struct intel_atomic_state *state,
3351 				    struct intel_crtc *crtc)
3352 {
3353 	struct drm_i915_private *i915 = to_i915(state->base.dev);
3354 	struct intel_crtc_state *crtc_state =
3355 		intel_atomic_get_new_crtc_state(state, crtc);
3356 	const struct intel_crtc_state *old_crtc_state =
3357 		intel_atomic_get_old_crtc_state(state, crtc);
3358 	struct icl_port_dpll *port_dpll =
3359 		&crtc_state->icl_port_dplls[ICL_PORT_DPLL_DEFAULT];
3360 	struct skl_wrpll_params pll_params = {};
3361 	int ret;
3362 
3363 	port_dpll = &crtc_state->icl_port_dplls[ICL_PORT_DPLL_DEFAULT];
3364 	ret = icl_calc_tbt_pll(crtc_state, &pll_params);
3365 	if (ret)
3366 		return ret;
3367 
3368 	icl_calc_dpll_state(i915, &pll_params, &port_dpll->hw_state);
3369 
3370 	port_dpll = &crtc_state->icl_port_dplls[ICL_PORT_DPLL_MG_PHY];
3371 	ret = icl_calc_mg_pll_state(crtc_state, &port_dpll->hw_state);
3372 	if (ret)
3373 		return ret;
3374 
3375 	/* this is mainly for the fastset check */
3376 	if (old_crtc_state->shared_dpll &&
3377 	    old_crtc_state->shared_dpll->info->id == DPLL_ID_ICL_TBTPLL)
3378 		icl_set_active_port_dpll(crtc_state, ICL_PORT_DPLL_DEFAULT);
3379 	else
3380 		icl_set_active_port_dpll(crtc_state, ICL_PORT_DPLL_MG_PHY);
3381 
3382 	crtc_state->port_clock = icl_ddi_mg_pll_get_freq(i915, NULL,
3383 							 &port_dpll->hw_state);
3384 
3385 	return 0;
3386 }
3387 
3388 static int icl_get_tc_phy_dplls(struct intel_atomic_state *state,
3389 				struct intel_crtc *crtc,
3390 				struct intel_encoder *encoder)
3391 {
3392 	struct drm_i915_private *i915 = to_i915(state->base.dev);
3393 	struct intel_crtc_state *crtc_state =
3394 		intel_atomic_get_new_crtc_state(state, crtc);
3395 	struct icl_port_dpll *port_dpll =
3396 		&crtc_state->icl_port_dplls[ICL_PORT_DPLL_DEFAULT];
3397 	enum intel_dpll_id dpll_id;
3398 	int ret;
3399 
3400 	port_dpll = &crtc_state->icl_port_dplls[ICL_PORT_DPLL_DEFAULT];
3401 	port_dpll->pll = intel_find_shared_dpll(state, crtc,
3402 						&port_dpll->hw_state,
3403 						BIT(DPLL_ID_ICL_TBTPLL));
3404 	if (!port_dpll->pll)
3405 		return -EINVAL;
3406 	intel_reference_shared_dpll(state, crtc,
3407 				    port_dpll->pll, &port_dpll->hw_state);
3408 
3409 
3410 	port_dpll = &crtc_state->icl_port_dplls[ICL_PORT_DPLL_MG_PHY];
3411 	dpll_id = icl_tc_port_to_pll_id(intel_port_to_tc(i915,
3412 							 encoder->port));
3413 	port_dpll->pll = intel_find_shared_dpll(state, crtc,
3414 						&port_dpll->hw_state,
3415 						BIT(dpll_id));
3416 	if (!port_dpll->pll) {
3417 		ret = -EINVAL;
3418 		goto err_unreference_tbt_pll;
3419 	}
3420 	intel_reference_shared_dpll(state, crtc,
3421 				    port_dpll->pll, &port_dpll->hw_state);
3422 
3423 	icl_update_active_dpll(state, crtc, encoder);
3424 
3425 	return 0;
3426 
3427 err_unreference_tbt_pll:
3428 	port_dpll = &crtc_state->icl_port_dplls[ICL_PORT_DPLL_DEFAULT];
3429 	intel_unreference_shared_dpll(state, crtc, port_dpll->pll);
3430 
3431 	return ret;
3432 }
3433 
3434 static int icl_compute_dplls(struct intel_atomic_state *state,
3435 			     struct intel_crtc *crtc,
3436 			     struct intel_encoder *encoder)
3437 {
3438 	struct drm_i915_private *i915 = to_i915(state->base.dev);
3439 	enum phy phy = intel_port_to_phy(i915, encoder->port);
3440 
3441 	if (intel_phy_is_combo(i915, phy))
3442 		return icl_compute_combo_phy_dpll(state, crtc);
3443 	else if (intel_phy_is_tc(i915, phy))
3444 		return icl_compute_tc_phy_dplls(state, crtc);
3445 
3446 	MISSING_CASE(phy);
3447 
3448 	return 0;
3449 }
3450 
3451 static int icl_get_dplls(struct intel_atomic_state *state,
3452 			 struct intel_crtc *crtc,
3453 			 struct intel_encoder *encoder)
3454 {
3455 	struct drm_i915_private *i915 = to_i915(state->base.dev);
3456 	enum phy phy = intel_port_to_phy(i915, encoder->port);
3457 
3458 	if (intel_phy_is_combo(i915, phy))
3459 		return icl_get_combo_phy_dpll(state, crtc, encoder);
3460 	else if (intel_phy_is_tc(i915, phy))
3461 		return icl_get_tc_phy_dplls(state, crtc, encoder);
3462 
3463 	MISSING_CASE(phy);
3464 
3465 	return -EINVAL;
3466 }
3467 
3468 static void icl_put_dplls(struct intel_atomic_state *state,
3469 			  struct intel_crtc *crtc)
3470 {
3471 	const struct intel_crtc_state *old_crtc_state =
3472 		intel_atomic_get_old_crtc_state(state, crtc);
3473 	struct intel_crtc_state *new_crtc_state =
3474 		intel_atomic_get_new_crtc_state(state, crtc);
3475 	enum icl_port_dpll_id id;
3476 
3477 	new_crtc_state->shared_dpll = NULL;
3478 
3479 	for (id = ICL_PORT_DPLL_DEFAULT; id < ICL_PORT_DPLL_COUNT; id++) {
3480 		const struct icl_port_dpll *old_port_dpll =
3481 			&old_crtc_state->icl_port_dplls[id];
3482 		struct icl_port_dpll *new_port_dpll =
3483 			&new_crtc_state->icl_port_dplls[id];
3484 
3485 		new_port_dpll->pll = NULL;
3486 
3487 		if (!old_port_dpll->pll)
3488 			continue;
3489 
3490 		intel_unreference_shared_dpll(state, crtc, old_port_dpll->pll);
3491 	}
3492 }
3493 
3494 static bool mg_pll_get_hw_state(struct drm_i915_private *i915,
3495 				struct intel_shared_dpll *pll,
3496 				struct intel_dpll_hw_state *hw_state)
3497 {
3498 	const enum intel_dpll_id id = pll->info->id;
3499 	enum tc_port tc_port = icl_pll_id_to_tc_port(id);
3500 	intel_wakeref_t wakeref;
3501 	bool ret = false;
3502 	u32 val;
3503 
3504 	i915_reg_t enable_reg = intel_tc_pll_enable_reg(i915, pll);
3505 
3506 	wakeref = intel_display_power_get_if_enabled(i915,
3507 						     POWER_DOMAIN_DISPLAY_CORE);
3508 	if (!wakeref)
3509 		return false;
3510 
3511 	val = intel_de_read(i915, enable_reg);
3512 	if (!(val & PLL_ENABLE))
3513 		goto out;
3514 
3515 	hw_state->mg_refclkin_ctl = intel_de_read(i915,
3516 						  MG_REFCLKIN_CTL(tc_port));
3517 	hw_state->mg_refclkin_ctl &= MG_REFCLKIN_CTL_OD_2_MUX_MASK;
3518 
3519 	hw_state->mg_clktop2_coreclkctl1 =
3520 		intel_de_read(i915, MG_CLKTOP2_CORECLKCTL1(tc_port));
3521 	hw_state->mg_clktop2_coreclkctl1 &=
3522 		MG_CLKTOP2_CORECLKCTL1_A_DIVRATIO_MASK;
3523 
3524 	hw_state->mg_clktop2_hsclkctl =
3525 		intel_de_read(i915, MG_CLKTOP2_HSCLKCTL(tc_port));
3526 	hw_state->mg_clktop2_hsclkctl &=
3527 		MG_CLKTOP2_HSCLKCTL_TLINEDRV_CLKSEL_MASK |
3528 		MG_CLKTOP2_HSCLKCTL_CORE_INPUTSEL_MASK |
3529 		MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_MASK |
3530 		MG_CLKTOP2_HSCLKCTL_DSDIV_RATIO_MASK;
3531 
3532 	hw_state->mg_pll_div0 = intel_de_read(i915, MG_PLL_DIV0(tc_port));
3533 	hw_state->mg_pll_div1 = intel_de_read(i915, MG_PLL_DIV1(tc_port));
3534 	hw_state->mg_pll_lf = intel_de_read(i915, MG_PLL_LF(tc_port));
3535 	hw_state->mg_pll_frac_lock = intel_de_read(i915,
3536 						   MG_PLL_FRAC_LOCK(tc_port));
3537 	hw_state->mg_pll_ssc = intel_de_read(i915, MG_PLL_SSC(tc_port));
3538 
3539 	hw_state->mg_pll_bias = intel_de_read(i915, MG_PLL_BIAS(tc_port));
3540 	hw_state->mg_pll_tdc_coldst_bias =
3541 		intel_de_read(i915, MG_PLL_TDC_COLDST_BIAS(tc_port));
3542 
3543 	if (i915->display.dpll.ref_clks.nssc == 38400) {
3544 		hw_state->mg_pll_tdc_coldst_bias_mask = MG_PLL_TDC_COLDST_COLDSTART;
3545 		hw_state->mg_pll_bias_mask = 0;
3546 	} else {
3547 		hw_state->mg_pll_tdc_coldst_bias_mask = -1U;
3548 		hw_state->mg_pll_bias_mask = -1U;
3549 	}
3550 
3551 	hw_state->mg_pll_tdc_coldst_bias &= hw_state->mg_pll_tdc_coldst_bias_mask;
3552 	hw_state->mg_pll_bias &= hw_state->mg_pll_bias_mask;
3553 
3554 	ret = true;
3555 out:
3556 	intel_display_power_put(i915, POWER_DOMAIN_DISPLAY_CORE, wakeref);
3557 	return ret;
3558 }
3559 
3560 static bool dkl_pll_get_hw_state(struct drm_i915_private *i915,
3561 				 struct intel_shared_dpll *pll,
3562 				 struct intel_dpll_hw_state *hw_state)
3563 {
3564 	const enum intel_dpll_id id = pll->info->id;
3565 	enum tc_port tc_port = icl_pll_id_to_tc_port(id);
3566 	intel_wakeref_t wakeref;
3567 	bool ret = false;
3568 	u32 val;
3569 
3570 	wakeref = intel_display_power_get_if_enabled(i915,
3571 						     POWER_DOMAIN_DISPLAY_CORE);
3572 	if (!wakeref)
3573 		return false;
3574 
3575 	val = intel_de_read(i915, intel_tc_pll_enable_reg(i915, pll));
3576 	if (!(val & PLL_ENABLE))
3577 		goto out;
3578 
3579 	/*
3580 	 * All registers read here have the same HIP_INDEX_REG even though
3581 	 * they are on different building blocks
3582 	 */
3583 	hw_state->mg_refclkin_ctl = intel_dkl_phy_read(i915,
3584 						       DKL_REFCLKIN_CTL(tc_port));
3585 	hw_state->mg_refclkin_ctl &= MG_REFCLKIN_CTL_OD_2_MUX_MASK;
3586 
3587 	hw_state->mg_clktop2_hsclkctl =
3588 		intel_dkl_phy_read(i915, DKL_CLKTOP2_HSCLKCTL(tc_port));
3589 	hw_state->mg_clktop2_hsclkctl &=
3590 		MG_CLKTOP2_HSCLKCTL_TLINEDRV_CLKSEL_MASK |
3591 		MG_CLKTOP2_HSCLKCTL_CORE_INPUTSEL_MASK |
3592 		MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_MASK |
3593 		MG_CLKTOP2_HSCLKCTL_DSDIV_RATIO_MASK;
3594 
3595 	hw_state->mg_clktop2_coreclkctl1 =
3596 		intel_dkl_phy_read(i915, DKL_CLKTOP2_CORECLKCTL1(tc_port));
3597 	hw_state->mg_clktop2_coreclkctl1 &=
3598 		MG_CLKTOP2_CORECLKCTL1_A_DIVRATIO_MASK;
3599 
3600 	hw_state->mg_pll_div0 = intel_dkl_phy_read(i915, DKL_PLL_DIV0(tc_port));
3601 	val = DKL_PLL_DIV0_MASK;
3602 	if (i915->display.vbt.override_afc_startup)
3603 		val |= DKL_PLL_DIV0_AFC_STARTUP_MASK;
3604 	hw_state->mg_pll_div0 &= val;
3605 
3606 	hw_state->mg_pll_div1 = intel_dkl_phy_read(i915, DKL_PLL_DIV1(tc_port));
3607 	hw_state->mg_pll_div1 &= (DKL_PLL_DIV1_IREF_TRIM_MASK |
3608 				  DKL_PLL_DIV1_TDC_TARGET_CNT_MASK);
3609 
3610 	hw_state->mg_pll_ssc = intel_dkl_phy_read(i915, DKL_PLL_SSC(tc_port));
3611 	hw_state->mg_pll_ssc &= (DKL_PLL_SSC_IREF_NDIV_RATIO_MASK |
3612 				 DKL_PLL_SSC_STEP_LEN_MASK |
3613 				 DKL_PLL_SSC_STEP_NUM_MASK |
3614 				 DKL_PLL_SSC_EN);
3615 
3616 	hw_state->mg_pll_bias = intel_dkl_phy_read(i915, DKL_PLL_BIAS(tc_port));
3617 	hw_state->mg_pll_bias &= (DKL_PLL_BIAS_FRAC_EN_H |
3618 				  DKL_PLL_BIAS_FBDIV_FRAC_MASK);
3619 
3620 	hw_state->mg_pll_tdc_coldst_bias =
3621 		intel_dkl_phy_read(i915, DKL_PLL_TDC_COLDST_BIAS(tc_port));
3622 	hw_state->mg_pll_tdc_coldst_bias &= (DKL_PLL_TDC_SSC_STEP_SIZE_MASK |
3623 					     DKL_PLL_TDC_FEED_FWD_GAIN_MASK);
3624 
3625 	ret = true;
3626 out:
3627 	intel_display_power_put(i915, POWER_DOMAIN_DISPLAY_CORE, wakeref);
3628 	return ret;
3629 }
3630 
3631 static bool icl_pll_get_hw_state(struct drm_i915_private *i915,
3632 				 struct intel_shared_dpll *pll,
3633 				 struct intel_dpll_hw_state *hw_state,
3634 				 i915_reg_t enable_reg)
3635 {
3636 	const enum intel_dpll_id id = pll->info->id;
3637 	intel_wakeref_t wakeref;
3638 	bool ret = false;
3639 	u32 val;
3640 
3641 	wakeref = intel_display_power_get_if_enabled(i915,
3642 						     POWER_DOMAIN_DISPLAY_CORE);
3643 	if (!wakeref)
3644 		return false;
3645 
3646 	val = intel_de_read(i915, enable_reg);
3647 	if (!(val & PLL_ENABLE))
3648 		goto out;
3649 
3650 	if (IS_ALDERLAKE_S(i915)) {
3651 		hw_state->cfgcr0 = intel_de_read(i915, ADLS_DPLL_CFGCR0(id));
3652 		hw_state->cfgcr1 = intel_de_read(i915, ADLS_DPLL_CFGCR1(id));
3653 	} else if (IS_DG1(i915)) {
3654 		hw_state->cfgcr0 = intel_de_read(i915, DG1_DPLL_CFGCR0(id));
3655 		hw_state->cfgcr1 = intel_de_read(i915, DG1_DPLL_CFGCR1(id));
3656 	} else if (IS_ROCKETLAKE(i915)) {
3657 		hw_state->cfgcr0 = intel_de_read(i915,
3658 						 RKL_DPLL_CFGCR0(id));
3659 		hw_state->cfgcr1 = intel_de_read(i915,
3660 						 RKL_DPLL_CFGCR1(id));
3661 	} else if (DISPLAY_VER(i915) >= 12) {
3662 		hw_state->cfgcr0 = intel_de_read(i915,
3663 						 TGL_DPLL_CFGCR0(id));
3664 		hw_state->cfgcr1 = intel_de_read(i915,
3665 						 TGL_DPLL_CFGCR1(id));
3666 		if (i915->display.vbt.override_afc_startup) {
3667 			hw_state->div0 = intel_de_read(i915, TGL_DPLL0_DIV0(id));
3668 			hw_state->div0 &= TGL_DPLL0_DIV0_AFC_STARTUP_MASK;
3669 		}
3670 	} else {
3671 		if ((IS_JASPERLAKE(i915) || IS_ELKHARTLAKE(i915)) &&
3672 		    id == DPLL_ID_EHL_DPLL4) {
3673 			hw_state->cfgcr0 = intel_de_read(i915,
3674 							 ICL_DPLL_CFGCR0(4));
3675 			hw_state->cfgcr1 = intel_de_read(i915,
3676 							 ICL_DPLL_CFGCR1(4));
3677 		} else {
3678 			hw_state->cfgcr0 = intel_de_read(i915,
3679 							 ICL_DPLL_CFGCR0(id));
3680 			hw_state->cfgcr1 = intel_de_read(i915,
3681 							 ICL_DPLL_CFGCR1(id));
3682 		}
3683 	}
3684 
3685 	ret = true;
3686 out:
3687 	intel_display_power_put(i915, POWER_DOMAIN_DISPLAY_CORE, wakeref);
3688 	return ret;
3689 }
3690 
3691 static bool combo_pll_get_hw_state(struct drm_i915_private *i915,
3692 				   struct intel_shared_dpll *pll,
3693 				   struct intel_dpll_hw_state *hw_state)
3694 {
3695 	i915_reg_t enable_reg = intel_combo_pll_enable_reg(i915, pll);
3696 
3697 	return icl_pll_get_hw_state(i915, pll, hw_state, enable_reg);
3698 }
3699 
3700 static bool tbt_pll_get_hw_state(struct drm_i915_private *i915,
3701 				 struct intel_shared_dpll *pll,
3702 				 struct intel_dpll_hw_state *hw_state)
3703 {
3704 	return icl_pll_get_hw_state(i915, pll, hw_state, TBT_PLL_ENABLE);
3705 }
3706 
3707 static void icl_dpll_write(struct drm_i915_private *i915,
3708 			   struct intel_shared_dpll *pll)
3709 {
3710 	struct intel_dpll_hw_state *hw_state = &pll->state.hw_state;
3711 	const enum intel_dpll_id id = pll->info->id;
3712 	i915_reg_t cfgcr0_reg, cfgcr1_reg, div0_reg = INVALID_MMIO_REG;
3713 
3714 	if (IS_ALDERLAKE_S(i915)) {
3715 		cfgcr0_reg = ADLS_DPLL_CFGCR0(id);
3716 		cfgcr1_reg = ADLS_DPLL_CFGCR1(id);
3717 	} else if (IS_DG1(i915)) {
3718 		cfgcr0_reg = DG1_DPLL_CFGCR0(id);
3719 		cfgcr1_reg = DG1_DPLL_CFGCR1(id);
3720 	} else if (IS_ROCKETLAKE(i915)) {
3721 		cfgcr0_reg = RKL_DPLL_CFGCR0(id);
3722 		cfgcr1_reg = RKL_DPLL_CFGCR1(id);
3723 	} else if (DISPLAY_VER(i915) >= 12) {
3724 		cfgcr0_reg = TGL_DPLL_CFGCR0(id);
3725 		cfgcr1_reg = TGL_DPLL_CFGCR1(id);
3726 		div0_reg = TGL_DPLL0_DIV0(id);
3727 	} else {
3728 		if ((IS_JASPERLAKE(i915) || IS_ELKHARTLAKE(i915)) &&
3729 		    id == DPLL_ID_EHL_DPLL4) {
3730 			cfgcr0_reg = ICL_DPLL_CFGCR0(4);
3731 			cfgcr1_reg = ICL_DPLL_CFGCR1(4);
3732 		} else {
3733 			cfgcr0_reg = ICL_DPLL_CFGCR0(id);
3734 			cfgcr1_reg = ICL_DPLL_CFGCR1(id);
3735 		}
3736 	}
3737 
3738 	intel_de_write(i915, cfgcr0_reg, hw_state->cfgcr0);
3739 	intel_de_write(i915, cfgcr1_reg, hw_state->cfgcr1);
3740 	drm_WARN_ON_ONCE(&i915->drm, i915->display.vbt.override_afc_startup &&
3741 			 !i915_mmio_reg_valid(div0_reg));
3742 	if (i915->display.vbt.override_afc_startup &&
3743 	    i915_mmio_reg_valid(div0_reg))
3744 		intel_de_rmw(i915, div0_reg,
3745 			     TGL_DPLL0_DIV0_AFC_STARTUP_MASK, hw_state->div0);
3746 	intel_de_posting_read(i915, cfgcr1_reg);
3747 }
3748 
3749 static void icl_mg_pll_write(struct drm_i915_private *i915,
3750 			     struct intel_shared_dpll *pll)
3751 {
3752 	struct intel_dpll_hw_state *hw_state = &pll->state.hw_state;
3753 	enum tc_port tc_port = icl_pll_id_to_tc_port(pll->info->id);
3754 
3755 	/*
3756 	 * Some of the following registers have reserved fields, so program
3757 	 * these with RMW based on a mask. The mask can be fixed or generated
3758 	 * during the calc/readout phase if the mask depends on some other HW
3759 	 * state like refclk, see icl_calc_mg_pll_state().
3760 	 */
3761 	intel_de_rmw(i915, MG_REFCLKIN_CTL(tc_port),
3762 		     MG_REFCLKIN_CTL_OD_2_MUX_MASK, hw_state->mg_refclkin_ctl);
3763 
3764 	intel_de_rmw(i915, MG_CLKTOP2_CORECLKCTL1(tc_port),
3765 		     MG_CLKTOP2_CORECLKCTL1_A_DIVRATIO_MASK,
3766 		     hw_state->mg_clktop2_coreclkctl1);
3767 
3768 	intel_de_rmw(i915, MG_CLKTOP2_HSCLKCTL(tc_port),
3769 		     MG_CLKTOP2_HSCLKCTL_TLINEDRV_CLKSEL_MASK |
3770 		     MG_CLKTOP2_HSCLKCTL_CORE_INPUTSEL_MASK |
3771 		     MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_MASK |
3772 		     MG_CLKTOP2_HSCLKCTL_DSDIV_RATIO_MASK,
3773 		     hw_state->mg_clktop2_hsclkctl);
3774 
3775 	intel_de_write(i915, MG_PLL_DIV0(tc_port), hw_state->mg_pll_div0);
3776 	intel_de_write(i915, MG_PLL_DIV1(tc_port), hw_state->mg_pll_div1);
3777 	intel_de_write(i915, MG_PLL_LF(tc_port), hw_state->mg_pll_lf);
3778 	intel_de_write(i915, MG_PLL_FRAC_LOCK(tc_port),
3779 		       hw_state->mg_pll_frac_lock);
3780 	intel_de_write(i915, MG_PLL_SSC(tc_port), hw_state->mg_pll_ssc);
3781 
3782 	intel_de_rmw(i915, MG_PLL_BIAS(tc_port),
3783 		     hw_state->mg_pll_bias_mask, hw_state->mg_pll_bias);
3784 
3785 	intel_de_rmw(i915, MG_PLL_TDC_COLDST_BIAS(tc_port),
3786 		     hw_state->mg_pll_tdc_coldst_bias_mask,
3787 		     hw_state->mg_pll_tdc_coldst_bias);
3788 
3789 	intel_de_posting_read(i915, MG_PLL_TDC_COLDST_BIAS(tc_port));
3790 }
3791 
3792 static void dkl_pll_write(struct drm_i915_private *i915,
3793 			  struct intel_shared_dpll *pll)
3794 {
3795 	struct intel_dpll_hw_state *hw_state = &pll->state.hw_state;
3796 	enum tc_port tc_port = icl_pll_id_to_tc_port(pll->info->id);
3797 	u32 val;
3798 
3799 	/*
3800 	 * All registers programmed here have the same HIP_INDEX_REG even
3801 	 * though on different building block
3802 	 */
3803 	/* All the registers are RMW */
3804 	val = intel_dkl_phy_read(i915, DKL_REFCLKIN_CTL(tc_port));
3805 	val &= ~MG_REFCLKIN_CTL_OD_2_MUX_MASK;
3806 	val |= hw_state->mg_refclkin_ctl;
3807 	intel_dkl_phy_write(i915, DKL_REFCLKIN_CTL(tc_port), val);
3808 
3809 	val = intel_dkl_phy_read(i915, DKL_CLKTOP2_CORECLKCTL1(tc_port));
3810 	val &= ~MG_CLKTOP2_CORECLKCTL1_A_DIVRATIO_MASK;
3811 	val |= hw_state->mg_clktop2_coreclkctl1;
3812 	intel_dkl_phy_write(i915, DKL_CLKTOP2_CORECLKCTL1(tc_port), val);
3813 
3814 	val = intel_dkl_phy_read(i915, DKL_CLKTOP2_HSCLKCTL(tc_port));
3815 	val &= ~(MG_CLKTOP2_HSCLKCTL_TLINEDRV_CLKSEL_MASK |
3816 		 MG_CLKTOP2_HSCLKCTL_CORE_INPUTSEL_MASK |
3817 		 MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_MASK |
3818 		 MG_CLKTOP2_HSCLKCTL_DSDIV_RATIO_MASK);
3819 	val |= hw_state->mg_clktop2_hsclkctl;
3820 	intel_dkl_phy_write(i915, DKL_CLKTOP2_HSCLKCTL(tc_port), val);
3821 
3822 	val = DKL_PLL_DIV0_MASK;
3823 	if (i915->display.vbt.override_afc_startup)
3824 		val |= DKL_PLL_DIV0_AFC_STARTUP_MASK;
3825 	intel_dkl_phy_rmw(i915, DKL_PLL_DIV0(tc_port), val,
3826 			  hw_state->mg_pll_div0);
3827 
3828 	val = intel_dkl_phy_read(i915, DKL_PLL_DIV1(tc_port));
3829 	val &= ~(DKL_PLL_DIV1_IREF_TRIM_MASK |
3830 		 DKL_PLL_DIV1_TDC_TARGET_CNT_MASK);
3831 	val |= hw_state->mg_pll_div1;
3832 	intel_dkl_phy_write(i915, DKL_PLL_DIV1(tc_port), val);
3833 
3834 	val = intel_dkl_phy_read(i915, DKL_PLL_SSC(tc_port));
3835 	val &= ~(DKL_PLL_SSC_IREF_NDIV_RATIO_MASK |
3836 		 DKL_PLL_SSC_STEP_LEN_MASK |
3837 		 DKL_PLL_SSC_STEP_NUM_MASK |
3838 		 DKL_PLL_SSC_EN);
3839 	val |= hw_state->mg_pll_ssc;
3840 	intel_dkl_phy_write(i915, DKL_PLL_SSC(tc_port), val);
3841 
3842 	val = intel_dkl_phy_read(i915, DKL_PLL_BIAS(tc_port));
3843 	val &= ~(DKL_PLL_BIAS_FRAC_EN_H |
3844 		 DKL_PLL_BIAS_FBDIV_FRAC_MASK);
3845 	val |= hw_state->mg_pll_bias;
3846 	intel_dkl_phy_write(i915, DKL_PLL_BIAS(tc_port), val);
3847 
3848 	val = intel_dkl_phy_read(i915, DKL_PLL_TDC_COLDST_BIAS(tc_port));
3849 	val &= ~(DKL_PLL_TDC_SSC_STEP_SIZE_MASK |
3850 		 DKL_PLL_TDC_FEED_FWD_GAIN_MASK);
3851 	val |= hw_state->mg_pll_tdc_coldst_bias;
3852 	intel_dkl_phy_write(i915, DKL_PLL_TDC_COLDST_BIAS(tc_port), val);
3853 
3854 	intel_dkl_phy_posting_read(i915, DKL_PLL_TDC_COLDST_BIAS(tc_port));
3855 }
3856 
3857 static void icl_pll_power_enable(struct drm_i915_private *i915,
3858 				 struct intel_shared_dpll *pll,
3859 				 i915_reg_t enable_reg)
3860 {
3861 	intel_de_rmw(i915, enable_reg, 0, PLL_POWER_ENABLE);
3862 
3863 	/*
3864 	 * The spec says we need to "wait" but it also says it should be
3865 	 * immediate.
3866 	 */
3867 	if (intel_de_wait_for_set(i915, enable_reg, PLL_POWER_STATE, 1))
3868 		drm_err(&i915->drm, "PLL %d Power not enabled\n",
3869 			pll->info->id);
3870 }
3871 
3872 static void icl_pll_enable(struct drm_i915_private *i915,
3873 			   struct intel_shared_dpll *pll,
3874 			   i915_reg_t enable_reg)
3875 {
3876 	intel_de_rmw(i915, enable_reg, 0, PLL_ENABLE);
3877 
3878 	/* Timeout is actually 600us. */
3879 	if (intel_de_wait_for_set(i915, enable_reg, PLL_LOCK, 1))
3880 		drm_err(&i915->drm, "PLL %d not locked\n", pll->info->id);
3881 }
3882 
3883 static void adlp_cmtg_clock_gating_wa(struct drm_i915_private *i915, struct intel_shared_dpll *pll)
3884 {
3885 	u32 val;
3886 
3887 	if (!(IS_ALDERLAKE_P(i915) && IS_DISPLAY_STEP(i915, STEP_A0, STEP_B0)) ||
3888 	    pll->info->id != DPLL_ID_ICL_DPLL0)
3889 		return;
3890 	/*
3891 	 * Wa_16011069516:adl-p[a0]
3892 	 *
3893 	 * All CMTG regs are unreliable until CMTG clock gating is disabled,
3894 	 * so we can only assume the default TRANS_CMTG_CHICKEN reg value and
3895 	 * sanity check this assumption with a double read, which presumably
3896 	 * returns the correct value even with clock gating on.
3897 	 *
3898 	 * Instead of the usual place for workarounds we apply this one here,
3899 	 * since TRANS_CMTG_CHICKEN is only accessible while DPLL0 is enabled.
3900 	 */
3901 	val = intel_de_read(i915, TRANS_CMTG_CHICKEN);
3902 	val = intel_de_rmw(i915, TRANS_CMTG_CHICKEN, ~0, DISABLE_DPT_CLK_GATING);
3903 	if (drm_WARN_ON(&i915->drm, val & ~DISABLE_DPT_CLK_GATING))
3904 		drm_dbg_kms(&i915->drm, "Unexpected flags in TRANS_CMTG_CHICKEN: %08x\n", val);
3905 }
3906 
3907 static void combo_pll_enable(struct drm_i915_private *i915,
3908 			     struct intel_shared_dpll *pll)
3909 {
3910 	i915_reg_t enable_reg = intel_combo_pll_enable_reg(i915, pll);
3911 
3912 	icl_pll_power_enable(i915, pll, enable_reg);
3913 
3914 	icl_dpll_write(i915, pll);
3915 
3916 	/*
3917 	 * DVFS pre sequence would be here, but in our driver the cdclk code
3918 	 * paths should already be setting the appropriate voltage, hence we do
3919 	 * nothing here.
3920 	 */
3921 
3922 	icl_pll_enable(i915, pll, enable_reg);
3923 
3924 	adlp_cmtg_clock_gating_wa(i915, pll);
3925 
3926 	/* DVFS post sequence would be here. See the comment above. */
3927 }
3928 
3929 static void tbt_pll_enable(struct drm_i915_private *i915,
3930 			   struct intel_shared_dpll *pll)
3931 {
3932 	icl_pll_power_enable(i915, pll, TBT_PLL_ENABLE);
3933 
3934 	icl_dpll_write(i915, pll);
3935 
3936 	/*
3937 	 * DVFS pre sequence would be here, but in our driver the cdclk code
3938 	 * paths should already be setting the appropriate voltage, hence we do
3939 	 * nothing here.
3940 	 */
3941 
3942 	icl_pll_enable(i915, pll, TBT_PLL_ENABLE);
3943 
3944 	/* DVFS post sequence would be here. See the comment above. */
3945 }
3946 
3947 static void mg_pll_enable(struct drm_i915_private *i915,
3948 			  struct intel_shared_dpll *pll)
3949 {
3950 	i915_reg_t enable_reg = intel_tc_pll_enable_reg(i915, pll);
3951 
3952 	icl_pll_power_enable(i915, pll, enable_reg);
3953 
3954 	if (DISPLAY_VER(i915) >= 12)
3955 		dkl_pll_write(i915, pll);
3956 	else
3957 		icl_mg_pll_write(i915, pll);
3958 
3959 	/*
3960 	 * DVFS pre sequence would be here, but in our driver the cdclk code
3961 	 * paths should already be setting the appropriate voltage, hence we do
3962 	 * nothing here.
3963 	 */
3964 
3965 	icl_pll_enable(i915, pll, enable_reg);
3966 
3967 	/* DVFS post sequence would be here. See the comment above. */
3968 }
3969 
3970 static void icl_pll_disable(struct drm_i915_private *i915,
3971 			    struct intel_shared_dpll *pll,
3972 			    i915_reg_t enable_reg)
3973 {
3974 	/* The first steps are done by intel_ddi_post_disable(). */
3975 
3976 	/*
3977 	 * DVFS pre sequence would be here, but in our driver the cdclk code
3978 	 * paths should already be setting the appropriate voltage, hence we do
3979 	 * nothing here.
3980 	 */
3981 
3982 	intel_de_rmw(i915, enable_reg, PLL_ENABLE, 0);
3983 
3984 	/* Timeout is actually 1us. */
3985 	if (intel_de_wait_for_clear(i915, enable_reg, PLL_LOCK, 1))
3986 		drm_err(&i915->drm, "PLL %d locked\n", pll->info->id);
3987 
3988 	/* DVFS post sequence would be here. See the comment above. */
3989 
3990 	intel_de_rmw(i915, enable_reg, PLL_POWER_ENABLE, 0);
3991 
3992 	/*
3993 	 * The spec says we need to "wait" but it also says it should be
3994 	 * immediate.
3995 	 */
3996 	if (intel_de_wait_for_clear(i915, enable_reg, PLL_POWER_STATE, 1))
3997 		drm_err(&i915->drm, "PLL %d Power not disabled\n",
3998 			pll->info->id);
3999 }
4000 
4001 static void combo_pll_disable(struct drm_i915_private *i915,
4002 			      struct intel_shared_dpll *pll)
4003 {
4004 	i915_reg_t enable_reg = intel_combo_pll_enable_reg(i915, pll);
4005 
4006 	icl_pll_disable(i915, pll, enable_reg);
4007 }
4008 
4009 static void tbt_pll_disable(struct drm_i915_private *i915,
4010 			    struct intel_shared_dpll *pll)
4011 {
4012 	icl_pll_disable(i915, pll, TBT_PLL_ENABLE);
4013 }
4014 
4015 static void mg_pll_disable(struct drm_i915_private *i915,
4016 			   struct intel_shared_dpll *pll)
4017 {
4018 	i915_reg_t enable_reg = intel_tc_pll_enable_reg(i915, pll);
4019 
4020 	icl_pll_disable(i915, pll, enable_reg);
4021 }
4022 
4023 static void icl_update_dpll_ref_clks(struct drm_i915_private *i915)
4024 {
4025 	/* No SSC ref */
4026 	i915->display.dpll.ref_clks.nssc = i915->display.cdclk.hw.ref;
4027 }
4028 
4029 static void icl_dump_hw_state(struct drm_i915_private *i915,
4030 			      const struct intel_dpll_hw_state *hw_state)
4031 {
4032 	drm_dbg_kms(&i915->drm,
4033 		    "dpll_hw_state: cfgcr0: 0x%x, cfgcr1: 0x%x, div0: 0x%x, "
4034 		    "mg_refclkin_ctl: 0x%x, hg_clktop2_coreclkctl1: 0x%x, "
4035 		    "mg_clktop2_hsclkctl: 0x%x, mg_pll_div0: 0x%x, "
4036 		    "mg_pll_div2: 0x%x, mg_pll_lf: 0x%x, "
4037 		    "mg_pll_frac_lock: 0x%x, mg_pll_ssc: 0x%x, "
4038 		    "mg_pll_bias: 0x%x, mg_pll_tdc_coldst_bias: 0x%x\n",
4039 		    hw_state->cfgcr0, hw_state->cfgcr1,
4040 		    hw_state->div0,
4041 		    hw_state->mg_refclkin_ctl,
4042 		    hw_state->mg_clktop2_coreclkctl1,
4043 		    hw_state->mg_clktop2_hsclkctl,
4044 		    hw_state->mg_pll_div0,
4045 		    hw_state->mg_pll_div1,
4046 		    hw_state->mg_pll_lf,
4047 		    hw_state->mg_pll_frac_lock,
4048 		    hw_state->mg_pll_ssc,
4049 		    hw_state->mg_pll_bias,
4050 		    hw_state->mg_pll_tdc_coldst_bias);
4051 }
4052 
4053 static bool icl_compare_hw_state(const struct intel_dpll_hw_state *a,
4054 				 const struct intel_dpll_hw_state *b)
4055 {
4056 	/* FIXME split combo vs. mg more thoroughly */
4057 	return a->cfgcr0 == b->cfgcr0 &&
4058 		a->cfgcr1 == b->cfgcr1 &&
4059 		a->div0 == b->div0 &&
4060 		a->mg_refclkin_ctl == b->mg_refclkin_ctl &&
4061 		a->mg_clktop2_coreclkctl1 == b->mg_clktop2_coreclkctl1 &&
4062 		a->mg_clktop2_hsclkctl == b->mg_clktop2_hsclkctl &&
4063 		a->mg_pll_div0 == b->mg_pll_div0 &&
4064 		a->mg_pll_div1 == b->mg_pll_div1 &&
4065 		a->mg_pll_lf == b->mg_pll_lf &&
4066 		a->mg_pll_frac_lock == b->mg_pll_frac_lock &&
4067 		a->mg_pll_ssc == b->mg_pll_ssc &&
4068 		a->mg_pll_bias == b->mg_pll_bias &&
4069 		a->mg_pll_tdc_coldst_bias == b->mg_pll_tdc_coldst_bias;
4070 }
4071 
4072 static const struct intel_shared_dpll_funcs combo_pll_funcs = {
4073 	.enable = combo_pll_enable,
4074 	.disable = combo_pll_disable,
4075 	.get_hw_state = combo_pll_get_hw_state,
4076 	.get_freq = icl_ddi_combo_pll_get_freq,
4077 };
4078 
4079 static const struct intel_shared_dpll_funcs tbt_pll_funcs = {
4080 	.enable = tbt_pll_enable,
4081 	.disable = tbt_pll_disable,
4082 	.get_hw_state = tbt_pll_get_hw_state,
4083 	.get_freq = icl_ddi_tbt_pll_get_freq,
4084 };
4085 
4086 static const struct intel_shared_dpll_funcs mg_pll_funcs = {
4087 	.enable = mg_pll_enable,
4088 	.disable = mg_pll_disable,
4089 	.get_hw_state = mg_pll_get_hw_state,
4090 	.get_freq = icl_ddi_mg_pll_get_freq,
4091 };
4092 
4093 static const struct dpll_info icl_plls[] = {
4094 	{ .name = "DPLL 0", .funcs = &combo_pll_funcs, .id = DPLL_ID_ICL_DPLL0, },
4095 	{ .name = "DPLL 1", .funcs = &combo_pll_funcs, .id = DPLL_ID_ICL_DPLL1, },
4096 	{ .name = "TBT PLL", .funcs = &tbt_pll_funcs, .id = DPLL_ID_ICL_TBTPLL,
4097 	  .is_alt_port_dpll = true, },
4098 	{ .name = "MG PLL 1", .funcs = &mg_pll_funcs, .id = DPLL_ID_ICL_MGPLL1, },
4099 	{ .name = "MG PLL 2", .funcs = &mg_pll_funcs, .id = DPLL_ID_ICL_MGPLL2, },
4100 	{ .name = "MG PLL 3", .funcs = &mg_pll_funcs, .id = DPLL_ID_ICL_MGPLL3, },
4101 	{ .name = "MG PLL 4", .funcs = &mg_pll_funcs, .id = DPLL_ID_ICL_MGPLL4, },
4102 	{}
4103 };
4104 
4105 static const struct intel_dpll_mgr icl_pll_mgr = {
4106 	.dpll_info = icl_plls,
4107 	.compute_dplls = icl_compute_dplls,
4108 	.get_dplls = icl_get_dplls,
4109 	.put_dplls = icl_put_dplls,
4110 	.update_active_dpll = icl_update_active_dpll,
4111 	.update_ref_clks = icl_update_dpll_ref_clks,
4112 	.dump_hw_state = icl_dump_hw_state,
4113 	.compare_hw_state = icl_compare_hw_state,
4114 };
4115 
4116 static const struct dpll_info ehl_plls[] = {
4117 	{ .name = "DPLL 0", .funcs = &combo_pll_funcs, .id = DPLL_ID_ICL_DPLL0, },
4118 	{ .name = "DPLL 1", .funcs = &combo_pll_funcs, .id = DPLL_ID_ICL_DPLL1, },
4119 	{ .name = "DPLL 4", .funcs = &combo_pll_funcs, .id = DPLL_ID_EHL_DPLL4,
4120 	  .power_domain = POWER_DOMAIN_DC_OFF, },
4121 	{}
4122 };
4123 
4124 static const struct intel_dpll_mgr ehl_pll_mgr = {
4125 	.dpll_info = ehl_plls,
4126 	.compute_dplls = icl_compute_dplls,
4127 	.get_dplls = icl_get_dplls,
4128 	.put_dplls = icl_put_dplls,
4129 	.update_ref_clks = icl_update_dpll_ref_clks,
4130 	.dump_hw_state = icl_dump_hw_state,
4131 	.compare_hw_state = icl_compare_hw_state,
4132 };
4133 
4134 static const struct intel_shared_dpll_funcs dkl_pll_funcs = {
4135 	.enable = mg_pll_enable,
4136 	.disable = mg_pll_disable,
4137 	.get_hw_state = dkl_pll_get_hw_state,
4138 	.get_freq = icl_ddi_mg_pll_get_freq,
4139 };
4140 
4141 static const struct dpll_info tgl_plls[] = {
4142 	{ .name = "DPLL 0", .funcs = &combo_pll_funcs, .id = DPLL_ID_ICL_DPLL0, },
4143 	{ .name = "DPLL 1", .funcs = &combo_pll_funcs, .id = DPLL_ID_ICL_DPLL1, },
4144 	{ .name = "TBT PLL", .funcs = &tbt_pll_funcs, .id = DPLL_ID_ICL_TBTPLL,
4145 	  .is_alt_port_dpll = true, },
4146 	{ .name = "TC PLL 1", .funcs = &dkl_pll_funcs, .id = DPLL_ID_ICL_MGPLL1, },
4147 	{ .name = "TC PLL 2", .funcs = &dkl_pll_funcs, .id = DPLL_ID_ICL_MGPLL2, },
4148 	{ .name = "TC PLL 3", .funcs = &dkl_pll_funcs, .id = DPLL_ID_ICL_MGPLL3, },
4149 	{ .name = "TC PLL 4", .funcs = &dkl_pll_funcs, .id = DPLL_ID_ICL_MGPLL4, },
4150 	{ .name = "TC PLL 5", .funcs = &dkl_pll_funcs, .id = DPLL_ID_TGL_MGPLL5, },
4151 	{ .name = "TC PLL 6", .funcs = &dkl_pll_funcs, .id = DPLL_ID_TGL_MGPLL6, },
4152 	{}
4153 };
4154 
4155 static const struct intel_dpll_mgr tgl_pll_mgr = {
4156 	.dpll_info = tgl_plls,
4157 	.compute_dplls = icl_compute_dplls,
4158 	.get_dplls = icl_get_dplls,
4159 	.put_dplls = icl_put_dplls,
4160 	.update_active_dpll = icl_update_active_dpll,
4161 	.update_ref_clks = icl_update_dpll_ref_clks,
4162 	.dump_hw_state = icl_dump_hw_state,
4163 	.compare_hw_state = icl_compare_hw_state,
4164 };
4165 
4166 static const struct dpll_info rkl_plls[] = {
4167 	{ .name = "DPLL 0", .funcs = &combo_pll_funcs, .id = DPLL_ID_ICL_DPLL0, },
4168 	{ .name = "DPLL 1", .funcs = &combo_pll_funcs, .id = DPLL_ID_ICL_DPLL1, },
4169 	{ .name = "DPLL 4", .funcs = &combo_pll_funcs, .id = DPLL_ID_EHL_DPLL4, },
4170 	{}
4171 };
4172 
4173 static const struct intel_dpll_mgr rkl_pll_mgr = {
4174 	.dpll_info = rkl_plls,
4175 	.compute_dplls = icl_compute_dplls,
4176 	.get_dplls = icl_get_dplls,
4177 	.put_dplls = icl_put_dplls,
4178 	.update_ref_clks = icl_update_dpll_ref_clks,
4179 	.dump_hw_state = icl_dump_hw_state,
4180 	.compare_hw_state = icl_compare_hw_state,
4181 };
4182 
4183 static const struct dpll_info dg1_plls[] = {
4184 	{ .name = "DPLL 0", .funcs = &combo_pll_funcs, .id = DPLL_ID_DG1_DPLL0, },
4185 	{ .name = "DPLL 1", .funcs = &combo_pll_funcs, .id = DPLL_ID_DG1_DPLL1, },
4186 	{ .name = "DPLL 2", .funcs = &combo_pll_funcs, .id = DPLL_ID_DG1_DPLL2, },
4187 	{ .name = "DPLL 3", .funcs = &combo_pll_funcs, .id = DPLL_ID_DG1_DPLL3, },
4188 	{}
4189 };
4190 
4191 static const struct intel_dpll_mgr dg1_pll_mgr = {
4192 	.dpll_info = dg1_plls,
4193 	.compute_dplls = icl_compute_dplls,
4194 	.get_dplls = icl_get_dplls,
4195 	.put_dplls = icl_put_dplls,
4196 	.update_ref_clks = icl_update_dpll_ref_clks,
4197 	.dump_hw_state = icl_dump_hw_state,
4198 	.compare_hw_state = icl_compare_hw_state,
4199 };
4200 
4201 static const struct dpll_info adls_plls[] = {
4202 	{ .name = "DPLL 0", .funcs = &combo_pll_funcs, .id = DPLL_ID_ICL_DPLL0, },
4203 	{ .name = "DPLL 1", .funcs = &combo_pll_funcs, .id = DPLL_ID_ICL_DPLL1, },
4204 	{ .name = "DPLL 2", .funcs = &combo_pll_funcs, .id = DPLL_ID_DG1_DPLL2, },
4205 	{ .name = "DPLL 3", .funcs = &combo_pll_funcs, .id = DPLL_ID_DG1_DPLL3, },
4206 	{}
4207 };
4208 
4209 static const struct intel_dpll_mgr adls_pll_mgr = {
4210 	.dpll_info = adls_plls,
4211 	.compute_dplls = icl_compute_dplls,
4212 	.get_dplls = icl_get_dplls,
4213 	.put_dplls = icl_put_dplls,
4214 	.update_ref_clks = icl_update_dpll_ref_clks,
4215 	.dump_hw_state = icl_dump_hw_state,
4216 	.compare_hw_state = icl_compare_hw_state,
4217 };
4218 
4219 static const struct dpll_info adlp_plls[] = {
4220 	{ .name = "DPLL 0", .funcs = &combo_pll_funcs, .id = DPLL_ID_ICL_DPLL0, },
4221 	{ .name = "DPLL 1", .funcs = &combo_pll_funcs, .id = DPLL_ID_ICL_DPLL1, },
4222 	{ .name = "TBT PLL", .funcs = &tbt_pll_funcs, .id = DPLL_ID_ICL_TBTPLL,
4223 	  .is_alt_port_dpll = true, },
4224 	{ .name = "TC PLL 1", .funcs = &dkl_pll_funcs, .id = DPLL_ID_ICL_MGPLL1, },
4225 	{ .name = "TC PLL 2", .funcs = &dkl_pll_funcs, .id = DPLL_ID_ICL_MGPLL2, },
4226 	{ .name = "TC PLL 3", .funcs = &dkl_pll_funcs, .id = DPLL_ID_ICL_MGPLL3, },
4227 	{ .name = "TC PLL 4", .funcs = &dkl_pll_funcs, .id = DPLL_ID_ICL_MGPLL4, },
4228 	{}
4229 };
4230 
4231 static const struct intel_dpll_mgr adlp_pll_mgr = {
4232 	.dpll_info = adlp_plls,
4233 	.compute_dplls = icl_compute_dplls,
4234 	.get_dplls = icl_get_dplls,
4235 	.put_dplls = icl_put_dplls,
4236 	.update_active_dpll = icl_update_active_dpll,
4237 	.update_ref_clks = icl_update_dpll_ref_clks,
4238 	.dump_hw_state = icl_dump_hw_state,
4239 	.compare_hw_state = icl_compare_hw_state,
4240 };
4241 
4242 /**
4243  * intel_shared_dpll_init - Initialize shared DPLLs
4244  * @i915: i915 device
4245  *
4246  * Initialize shared DPLLs for @i915.
4247  */
4248 void intel_shared_dpll_init(struct drm_i915_private *i915)
4249 {
4250 	const struct intel_dpll_mgr *dpll_mgr = NULL;
4251 	const struct dpll_info *dpll_info;
4252 	int i;
4253 
4254 	mutex_init(&i915->display.dpll.lock);
4255 
4256 	if (DISPLAY_VER(i915) >= 14 || IS_DG2(i915))
4257 		/* No shared DPLLs on DG2; port PLLs are part of the PHY */
4258 		dpll_mgr = NULL;
4259 	else if (IS_ALDERLAKE_P(i915))
4260 		dpll_mgr = &adlp_pll_mgr;
4261 	else if (IS_ALDERLAKE_S(i915))
4262 		dpll_mgr = &adls_pll_mgr;
4263 	else if (IS_DG1(i915))
4264 		dpll_mgr = &dg1_pll_mgr;
4265 	else if (IS_ROCKETLAKE(i915))
4266 		dpll_mgr = &rkl_pll_mgr;
4267 	else if (DISPLAY_VER(i915) >= 12)
4268 		dpll_mgr = &tgl_pll_mgr;
4269 	else if (IS_JASPERLAKE(i915) || IS_ELKHARTLAKE(i915))
4270 		dpll_mgr = &ehl_pll_mgr;
4271 	else if (DISPLAY_VER(i915) >= 11)
4272 		dpll_mgr = &icl_pll_mgr;
4273 	else if (IS_GEMINILAKE(i915) || IS_BROXTON(i915))
4274 		dpll_mgr = &bxt_pll_mgr;
4275 	else if (DISPLAY_VER(i915) == 9)
4276 		dpll_mgr = &skl_pll_mgr;
4277 	else if (HAS_DDI(i915))
4278 		dpll_mgr = &hsw_pll_mgr;
4279 	else if (HAS_PCH_IBX(i915) || HAS_PCH_CPT(i915))
4280 		dpll_mgr = &pch_pll_mgr;
4281 
4282 	if (!dpll_mgr)
4283 		return;
4284 
4285 	dpll_info = dpll_mgr->dpll_info;
4286 
4287 	for (i = 0; dpll_info[i].name; i++) {
4288 		if (drm_WARN_ON(&i915->drm,
4289 				i >= ARRAY_SIZE(i915->display.dpll.shared_dplls)))
4290 			break;
4291 
4292 		/* must fit into unsigned long bitmask on 32bit */
4293 		if (drm_WARN_ON(&i915->drm, dpll_info[i].id >= 32))
4294 			break;
4295 
4296 		i915->display.dpll.shared_dplls[i].info = &dpll_info[i];
4297 		i915->display.dpll.shared_dplls[i].index = i;
4298 	}
4299 
4300 	i915->display.dpll.mgr = dpll_mgr;
4301 	i915->display.dpll.num_shared_dpll = i;
4302 }
4303 
4304 /**
4305  * intel_compute_shared_dplls - compute DPLL state CRTC and encoder combination
4306  * @state: atomic state
4307  * @crtc: CRTC to compute DPLLs for
4308  * @encoder: encoder
4309  *
4310  * This function computes the DPLL state for the given CRTC and encoder.
4311  *
4312  * The new configuration in the atomic commit @state is made effective by
4313  * calling intel_shared_dpll_swap_state().
4314  *
4315  * Returns:
4316  * 0 on success, negative error code on falure.
4317  */
4318 int intel_compute_shared_dplls(struct intel_atomic_state *state,
4319 			       struct intel_crtc *crtc,
4320 			       struct intel_encoder *encoder)
4321 {
4322 	struct drm_i915_private *i915 = to_i915(state->base.dev);
4323 	const struct intel_dpll_mgr *dpll_mgr = i915->display.dpll.mgr;
4324 
4325 	if (drm_WARN_ON(&i915->drm, !dpll_mgr))
4326 		return -EINVAL;
4327 
4328 	return dpll_mgr->compute_dplls(state, crtc, encoder);
4329 }
4330 
4331 /**
4332  * intel_reserve_shared_dplls - reserve DPLLs for CRTC and encoder combination
4333  * @state: atomic state
4334  * @crtc: CRTC to reserve DPLLs for
4335  * @encoder: encoder
4336  *
4337  * This function reserves all required DPLLs for the given CRTC and encoder
4338  * combination in the current atomic commit @state and the new @crtc atomic
4339  * state.
4340  *
4341  * The new configuration in the atomic commit @state is made effective by
4342  * calling intel_shared_dpll_swap_state().
4343  *
4344  * The reserved DPLLs should be released by calling
4345  * intel_release_shared_dplls().
4346  *
4347  * Returns:
4348  * 0 if all required DPLLs were successfully reserved,
4349  * negative error code otherwise.
4350  */
4351 int intel_reserve_shared_dplls(struct intel_atomic_state *state,
4352 			       struct intel_crtc *crtc,
4353 			       struct intel_encoder *encoder)
4354 {
4355 	struct drm_i915_private *i915 = to_i915(state->base.dev);
4356 	const struct intel_dpll_mgr *dpll_mgr = i915->display.dpll.mgr;
4357 
4358 	if (drm_WARN_ON(&i915->drm, !dpll_mgr))
4359 		return -EINVAL;
4360 
4361 	return dpll_mgr->get_dplls(state, crtc, encoder);
4362 }
4363 
4364 /**
4365  * intel_release_shared_dplls - end use of DPLLs by CRTC in atomic state
4366  * @state: atomic state
4367  * @crtc: crtc from which the DPLLs are to be released
4368  *
4369  * This function releases all DPLLs reserved by intel_reserve_shared_dplls()
4370  * from the current atomic commit @state and the old @crtc atomic state.
4371  *
4372  * The new configuration in the atomic commit @state is made effective by
4373  * calling intel_shared_dpll_swap_state().
4374  */
4375 void intel_release_shared_dplls(struct intel_atomic_state *state,
4376 				struct intel_crtc *crtc)
4377 {
4378 	struct drm_i915_private *i915 = to_i915(state->base.dev);
4379 	const struct intel_dpll_mgr *dpll_mgr = i915->display.dpll.mgr;
4380 
4381 	/*
4382 	 * FIXME: this function is called for every platform having a
4383 	 * compute_clock hook, even though the platform doesn't yet support
4384 	 * the shared DPLL framework and intel_reserve_shared_dplls() is not
4385 	 * called on those.
4386 	 */
4387 	if (!dpll_mgr)
4388 		return;
4389 
4390 	dpll_mgr->put_dplls(state, crtc);
4391 }
4392 
4393 /**
4394  * intel_update_active_dpll - update the active DPLL for a CRTC/encoder
4395  * @state: atomic state
4396  * @crtc: the CRTC for which to update the active DPLL
4397  * @encoder: encoder determining the type of port DPLL
4398  *
4399  * Update the active DPLL for the given @crtc/@encoder in @crtc's atomic state,
4400  * from the port DPLLs reserved previously by intel_reserve_shared_dplls(). The
4401  * DPLL selected will be based on the current mode of the encoder's port.
4402  */
4403 void intel_update_active_dpll(struct intel_atomic_state *state,
4404 			      struct intel_crtc *crtc,
4405 			      struct intel_encoder *encoder)
4406 {
4407 	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
4408 	const struct intel_dpll_mgr *dpll_mgr = i915->display.dpll.mgr;
4409 
4410 	if (drm_WARN_ON(&i915->drm, !dpll_mgr))
4411 		return;
4412 
4413 	dpll_mgr->update_active_dpll(state, crtc, encoder);
4414 }
4415 
4416 /**
4417  * intel_dpll_get_freq - calculate the DPLL's output frequency
4418  * @i915: i915 device
4419  * @pll: DPLL for which to calculate the output frequency
4420  * @pll_state: DPLL state from which to calculate the output frequency
4421  *
4422  * Return the output frequency corresponding to @pll's passed in @pll_state.
4423  */
4424 int intel_dpll_get_freq(struct drm_i915_private *i915,
4425 			const struct intel_shared_dpll *pll,
4426 			const struct intel_dpll_hw_state *pll_state)
4427 {
4428 	if (drm_WARN_ON(&i915->drm, !pll->info->funcs->get_freq))
4429 		return 0;
4430 
4431 	return pll->info->funcs->get_freq(i915, pll, pll_state);
4432 }
4433 
4434 /**
4435  * intel_dpll_get_hw_state - readout the DPLL's hardware state
4436  * @i915: i915 device
4437  * @pll: DPLL for which to calculate the output frequency
4438  * @hw_state: DPLL's hardware state
4439  *
4440  * Read out @pll's hardware state into @hw_state.
4441  */
4442 bool intel_dpll_get_hw_state(struct drm_i915_private *i915,
4443 			     struct intel_shared_dpll *pll,
4444 			     struct intel_dpll_hw_state *hw_state)
4445 {
4446 	return pll->info->funcs->get_hw_state(i915, pll, hw_state);
4447 }
4448 
4449 static void readout_dpll_hw_state(struct drm_i915_private *i915,
4450 				  struct intel_shared_dpll *pll)
4451 {
4452 	struct intel_crtc *crtc;
4453 
4454 	pll->on = intel_dpll_get_hw_state(i915, pll, &pll->state.hw_state);
4455 
4456 	if (pll->on && pll->info->power_domain)
4457 		pll->wakeref = intel_display_power_get(i915, pll->info->power_domain);
4458 
4459 	pll->state.pipe_mask = 0;
4460 	for_each_intel_crtc(&i915->drm, crtc) {
4461 		struct intel_crtc_state *crtc_state =
4462 			to_intel_crtc_state(crtc->base.state);
4463 
4464 		if (crtc_state->hw.active && crtc_state->shared_dpll == pll)
4465 			intel_reference_shared_dpll_crtc(crtc, pll, &pll->state);
4466 	}
4467 	pll->active_mask = pll->state.pipe_mask;
4468 
4469 	drm_dbg_kms(&i915->drm,
4470 		    "%s hw state readout: pipe_mask 0x%x, on %i\n",
4471 		    pll->info->name, pll->state.pipe_mask, pll->on);
4472 }
4473 
4474 void intel_dpll_update_ref_clks(struct drm_i915_private *i915)
4475 {
4476 	if (i915->display.dpll.mgr && i915->display.dpll.mgr->update_ref_clks)
4477 		i915->display.dpll.mgr->update_ref_clks(i915);
4478 }
4479 
4480 void intel_dpll_readout_hw_state(struct drm_i915_private *i915)
4481 {
4482 	struct intel_shared_dpll *pll;
4483 	int i;
4484 
4485 	for_each_shared_dpll(i915, pll, i)
4486 		readout_dpll_hw_state(i915, pll);
4487 }
4488 
4489 static void sanitize_dpll_state(struct drm_i915_private *i915,
4490 				struct intel_shared_dpll *pll)
4491 {
4492 	if (!pll->on)
4493 		return;
4494 
4495 	adlp_cmtg_clock_gating_wa(i915, pll);
4496 
4497 	if (pll->active_mask)
4498 		return;
4499 
4500 	drm_dbg_kms(&i915->drm,
4501 		    "%s enabled but not in use, disabling\n",
4502 		    pll->info->name);
4503 
4504 	_intel_disable_shared_dpll(i915, pll);
4505 }
4506 
4507 void intel_dpll_sanitize_state(struct drm_i915_private *i915)
4508 {
4509 	struct intel_shared_dpll *pll;
4510 	int i;
4511 
4512 	for_each_shared_dpll(i915, pll, i)
4513 		sanitize_dpll_state(i915, pll);
4514 }
4515 
4516 /**
4517  * intel_dpll_dump_hw_state - write hw_state to dmesg
4518  * @i915: i915 drm device
4519  * @hw_state: hw state to be written to the log
4520  *
4521  * Write the relevant values in @hw_state to dmesg using drm_dbg_kms.
4522  */
4523 void intel_dpll_dump_hw_state(struct drm_i915_private *i915,
4524 			      const struct intel_dpll_hw_state *hw_state)
4525 {
4526 	if (i915->display.dpll.mgr) {
4527 		i915->display.dpll.mgr->dump_hw_state(i915, hw_state);
4528 	} else {
4529 		/* fallback for platforms that don't use the shared dpll
4530 		 * infrastructure
4531 		 */
4532 		ibx_dump_hw_state(i915, hw_state);
4533 	}
4534 }
4535 
4536 /**
4537  * intel_dpll_compare_hw_state - compare the two states
4538  * @i915: i915 drm device
4539  * @a: first DPLL hw state
4540  * @b: second DPLL hw state
4541  *
4542  * Compare DPLL hw states @a and @b.
4543  *
4544  * Returns: true if the states are equal, false if the differ
4545  */
4546 bool intel_dpll_compare_hw_state(struct drm_i915_private *i915,
4547 				 const struct intel_dpll_hw_state *a,
4548 				 const struct intel_dpll_hw_state *b)
4549 {
4550 	if (i915->display.dpll.mgr) {
4551 		return i915->display.dpll.mgr->compare_hw_state(a, b);
4552 	} else {
4553 		/* fallback for platforms that don't use the shared dpll
4554 		 * infrastructure
4555 		 */
4556 		return ibx_compare_hw_state(a, b);
4557 	}
4558 }
4559 
4560 static void
4561 verify_single_dpll_state(struct drm_i915_private *i915,
4562 			 struct intel_shared_dpll *pll,
4563 			 struct intel_crtc *crtc,
4564 			 const struct intel_crtc_state *new_crtc_state)
4565 {
4566 	struct intel_dpll_hw_state dpll_hw_state = {};
4567 	u8 pipe_mask;
4568 	bool active;
4569 
4570 	active = intel_dpll_get_hw_state(i915, pll, &dpll_hw_state);
4571 
4572 	if (!pll->info->always_on) {
4573 		I915_STATE_WARN(i915, !pll->on && pll->active_mask,
4574 				"%s: pll in active use but not on in sw tracking\n",
4575 				pll->info->name);
4576 		I915_STATE_WARN(i915, pll->on && !pll->active_mask,
4577 				"%s: pll is on but not used by any active pipe\n",
4578 				pll->info->name);
4579 		I915_STATE_WARN(i915, pll->on != active,
4580 				"%s: pll on state mismatch (expected %i, found %i)\n",
4581 				pll->info->name, pll->on, active);
4582 	}
4583 
4584 	if (!crtc) {
4585 		I915_STATE_WARN(i915,
4586 				pll->active_mask & ~pll->state.pipe_mask,
4587 				"%s: more active pll users than references: 0x%x vs 0x%x\n",
4588 				pll->info->name, pll->active_mask, pll->state.pipe_mask);
4589 
4590 		return;
4591 	}
4592 
4593 	pipe_mask = BIT(crtc->pipe);
4594 
4595 	if (new_crtc_state->hw.active)
4596 		I915_STATE_WARN(i915, !(pll->active_mask & pipe_mask),
4597 				"%s: pll active mismatch (expected pipe %c in active mask 0x%x)\n",
4598 				pll->info->name, pipe_name(crtc->pipe), pll->active_mask);
4599 	else
4600 		I915_STATE_WARN(i915, pll->active_mask & pipe_mask,
4601 				"%s: pll active mismatch (didn't expect pipe %c in active mask 0x%x)\n",
4602 				pll->info->name, pipe_name(crtc->pipe), pll->active_mask);
4603 
4604 	I915_STATE_WARN(i915, !(pll->state.pipe_mask & pipe_mask),
4605 			"%s: pll enabled crtcs mismatch (expected 0x%x in 0x%x)\n",
4606 			pll->info->name, pipe_mask, pll->state.pipe_mask);
4607 
4608 	I915_STATE_WARN(i915,
4609 			pll->on && memcmp(&pll->state.hw_state, &dpll_hw_state,
4610 					  sizeof(dpll_hw_state)),
4611 			"%s: pll hw state mismatch\n",
4612 			pll->info->name);
4613 }
4614 
4615 static bool has_alt_port_dpll(const struct intel_shared_dpll *old_pll,
4616 			      const struct intel_shared_dpll *new_pll)
4617 {
4618 	return old_pll && new_pll && old_pll != new_pll &&
4619 		(old_pll->info->is_alt_port_dpll || new_pll->info->is_alt_port_dpll);
4620 }
4621 
4622 void intel_shared_dpll_state_verify(struct intel_atomic_state *state,
4623 				    struct intel_crtc *crtc)
4624 {
4625 	struct drm_i915_private *i915 = to_i915(state->base.dev);
4626 	const struct intel_crtc_state *old_crtc_state =
4627 		intel_atomic_get_old_crtc_state(state, crtc);
4628 	const struct intel_crtc_state *new_crtc_state =
4629 		intel_atomic_get_new_crtc_state(state, crtc);
4630 
4631 	if (new_crtc_state->shared_dpll)
4632 		verify_single_dpll_state(i915, new_crtc_state->shared_dpll,
4633 					 crtc, new_crtc_state);
4634 
4635 	if (old_crtc_state->shared_dpll &&
4636 	    old_crtc_state->shared_dpll != new_crtc_state->shared_dpll) {
4637 		u8 pipe_mask = BIT(crtc->pipe);
4638 		struct intel_shared_dpll *pll = old_crtc_state->shared_dpll;
4639 
4640 		I915_STATE_WARN(i915, pll->active_mask & pipe_mask,
4641 				"%s: pll active mismatch (didn't expect pipe %c in active mask (0x%x))\n",
4642 				pll->info->name, pipe_name(crtc->pipe), pll->active_mask);
4643 
4644 		/* TC ports have both MG/TC and TBT PLL referenced simultaneously */
4645 		I915_STATE_WARN(i915, !has_alt_port_dpll(old_crtc_state->shared_dpll,
4646 							 new_crtc_state->shared_dpll) &&
4647 				pll->state.pipe_mask & pipe_mask,
4648 				"%s: pll enabled crtcs mismatch (found pipe %c in enabled mask (0x%x))\n",
4649 				pll->info->name, pipe_name(crtc->pipe), pll->state.pipe_mask);
4650 	}
4651 }
4652 
4653 void intel_shared_dpll_verify_disabled(struct intel_atomic_state *state)
4654 {
4655 	struct drm_i915_private *i915 = to_i915(state->base.dev);
4656 	struct intel_shared_dpll *pll;
4657 	int i;
4658 
4659 	for_each_shared_dpll(i915, pll, i)
4660 		verify_single_dpll_state(i915, pll, NULL, NULL);
4661 }
4662