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 "intel_display_types.h"
25 #include "intel_dpio_phy.h"
26 #include "intel_dpll_mgr.h"
27
28 /**
29 * DOC: Display PLLs
30 *
31 * Display PLLs used for driving outputs vary by platform. While some have
32 * per-pipe or per-encoder dedicated PLLs, others allow the use of any PLL
33 * from a pool. In the latter scenario, it is possible that multiple pipes
34 * share a PLL if their configurations match.
35 *
36 * This file provides an abstraction over display PLLs. The function
37 * intel_shared_dpll_init() initializes the PLLs for the given platform. The
38 * users of a PLL are tracked and that tracking is integrated with the atomic
39 * modset interface. During an atomic operation, required PLLs can be reserved
40 * for a given CRTC and encoder configuration by calling
41 * intel_reserve_shared_dplls() and previously reserved PLLs can be released
42 * with intel_release_shared_dplls().
43 * Changes to the users are first staged in the atomic state, and then made
44 * effective by calling intel_shared_dpll_swap_state() during the atomic
45 * commit phase.
46 */
47
48 static void
intel_atomic_duplicate_dpll_state(struct drm_i915_private * dev_priv,struct intel_shared_dpll_state * shared_dpll)49 intel_atomic_duplicate_dpll_state(struct drm_i915_private *dev_priv,
50 struct intel_shared_dpll_state *shared_dpll)
51 {
52 enum intel_dpll_id i;
53
54 /* Copy shared dpll state */
55 for (i = 0; i < dev_priv->num_shared_dpll; i++) {
56 struct intel_shared_dpll *pll = &dev_priv->shared_dplls[i];
57
58 shared_dpll[i] = pll->state;
59 }
60 }
61
62 static struct intel_shared_dpll_state *
intel_atomic_get_shared_dpll_state(struct drm_atomic_state * s)63 intel_atomic_get_shared_dpll_state(struct drm_atomic_state *s)
64 {
65 struct intel_atomic_state *state = to_intel_atomic_state(s);
66
67 WARN_ON(!drm_modeset_is_locked(&s->dev->mode_config.connection_mutex));
68
69 if (!state->dpll_set) {
70 state->dpll_set = true;
71
72 intel_atomic_duplicate_dpll_state(to_i915(s->dev),
73 state->shared_dpll);
74 }
75
76 return state->shared_dpll;
77 }
78
79 /**
80 * intel_get_shared_dpll_by_id - get a DPLL given its id
81 * @dev_priv: i915 device instance
82 * @id: pll id
83 *
84 * Returns:
85 * A pointer to the DPLL with @id
86 */
87 struct intel_shared_dpll *
intel_get_shared_dpll_by_id(struct drm_i915_private * dev_priv,enum intel_dpll_id id)88 intel_get_shared_dpll_by_id(struct drm_i915_private *dev_priv,
89 enum intel_dpll_id id)
90 {
91 return &dev_priv->shared_dplls[id];
92 }
93
94 /**
95 * intel_get_shared_dpll_id - get the id of a DPLL
96 * @dev_priv: i915 device instance
97 * @pll: the DPLL
98 *
99 * Returns:
100 * The id of @pll
101 */
102 enum intel_dpll_id
intel_get_shared_dpll_id(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)103 intel_get_shared_dpll_id(struct drm_i915_private *dev_priv,
104 struct intel_shared_dpll *pll)
105 {
106 if (WARN_ON(pll < dev_priv->shared_dplls||
107 pll > &dev_priv->shared_dplls[dev_priv->num_shared_dpll]))
108 return -1;
109
110 return (enum intel_dpll_id) (pll - dev_priv->shared_dplls);
111 }
112
113 /* For ILK+ */
assert_shared_dpll(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll,bool state)114 void assert_shared_dpll(struct drm_i915_private *dev_priv,
115 struct intel_shared_dpll *pll,
116 bool state)
117 {
118 bool cur_state;
119 struct intel_dpll_hw_state hw_state;
120
121 if (WARN(!pll, "asserting DPLL %s with no DPLL\n", onoff(state)))
122 return;
123
124 cur_state = pll->info->funcs->get_hw_state(dev_priv, pll, &hw_state);
125 I915_STATE_WARN(cur_state != state,
126 "%s assertion failure (expected %s, current %s)\n",
127 pll->info->name, onoff(state), onoff(cur_state));
128 }
129
130 /**
131 * intel_prepare_shared_dpll - call a dpll's prepare hook
132 * @crtc_state: CRTC, and its state, which has a shared dpll
133 *
134 * This calls the PLL's prepare hook if it has one and if the PLL is not
135 * already enabled. The prepare hook is platform specific.
136 */
intel_prepare_shared_dpll(const struct intel_crtc_state * crtc_state)137 void intel_prepare_shared_dpll(const struct intel_crtc_state *crtc_state)
138 {
139 struct intel_crtc *crtc = to_intel_crtc(crtc_state->base.crtc);
140 struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
141 struct intel_shared_dpll *pll = crtc_state->shared_dpll;
142
143 if (WARN_ON(pll == NULL))
144 return;
145
146 mutex_lock(&dev_priv->dpll_lock);
147 WARN_ON(!pll->state.crtc_mask);
148 if (!pll->active_mask) {
149 DRM_DEBUG_DRIVER("setting up %s\n", pll->info->name);
150 WARN_ON(pll->on);
151 assert_shared_dpll_disabled(dev_priv, pll);
152
153 pll->info->funcs->prepare(dev_priv, pll);
154 }
155 mutex_unlock(&dev_priv->dpll_lock);
156 }
157
158 /**
159 * intel_enable_shared_dpll - enable a CRTC's shared DPLL
160 * @crtc_state: CRTC, and its state, which has a shared DPLL
161 *
162 * Enable the shared DPLL used by @crtc.
163 */
intel_enable_shared_dpll(const struct intel_crtc_state * crtc_state)164 void intel_enable_shared_dpll(const struct intel_crtc_state *crtc_state)
165 {
166 struct intel_crtc *crtc = to_intel_crtc(crtc_state->base.crtc);
167 struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
168 struct intel_shared_dpll *pll = crtc_state->shared_dpll;
169 unsigned int crtc_mask = drm_crtc_mask(&crtc->base);
170 unsigned int old_mask;
171
172 if (WARN_ON(pll == NULL))
173 return;
174
175 mutex_lock(&dev_priv->dpll_lock);
176 old_mask = pll->active_mask;
177
178 if (WARN_ON(!(pll->state.crtc_mask & crtc_mask)) ||
179 WARN_ON(pll->active_mask & crtc_mask))
180 goto out;
181
182 pll->active_mask |= crtc_mask;
183
184 DRM_DEBUG_KMS("enable %s (active %x, on? %d) for crtc %d\n",
185 pll->info->name, pll->active_mask, pll->on,
186 crtc->base.base.id);
187
188 if (old_mask) {
189 WARN_ON(!pll->on);
190 assert_shared_dpll_enabled(dev_priv, pll);
191 goto out;
192 }
193 WARN_ON(pll->on);
194
195 DRM_DEBUG_KMS("enabling %s\n", pll->info->name);
196 pll->info->funcs->enable(dev_priv, pll);
197 pll->on = true;
198
199 out:
200 mutex_unlock(&dev_priv->dpll_lock);
201 }
202
203 /**
204 * intel_disable_shared_dpll - disable a CRTC's shared DPLL
205 * @crtc_state: CRTC, and its state, which has a shared DPLL
206 *
207 * Disable the shared DPLL used by @crtc.
208 */
intel_disable_shared_dpll(const struct intel_crtc_state * crtc_state)209 void intel_disable_shared_dpll(const struct intel_crtc_state *crtc_state)
210 {
211 struct intel_crtc *crtc = to_intel_crtc(crtc_state->base.crtc);
212 struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
213 struct intel_shared_dpll *pll = crtc_state->shared_dpll;
214 unsigned int crtc_mask = drm_crtc_mask(&crtc->base);
215
216 /* PCH only available on ILK+ */
217 if (INTEL_GEN(dev_priv) < 5)
218 return;
219
220 if (pll == NULL)
221 return;
222
223 mutex_lock(&dev_priv->dpll_lock);
224 if (WARN_ON(!(pll->active_mask & crtc_mask)))
225 goto out;
226
227 DRM_DEBUG_KMS("disable %s (active %x, on? %d) for crtc %d\n",
228 pll->info->name, pll->active_mask, pll->on,
229 crtc->base.base.id);
230
231 assert_shared_dpll_enabled(dev_priv, pll);
232 WARN_ON(!pll->on);
233
234 pll->active_mask &= ~crtc_mask;
235 if (pll->active_mask)
236 goto out;
237
238 DRM_DEBUG_KMS("disabling %s\n", pll->info->name);
239 pll->info->funcs->disable(dev_priv, pll);
240 pll->on = false;
241
242 out:
243 mutex_unlock(&dev_priv->dpll_lock);
244 }
245
246 static struct intel_shared_dpll *
intel_find_shared_dpll(struct intel_atomic_state * state,const struct intel_crtc * crtc,const struct intel_dpll_hw_state * pll_state,enum intel_dpll_id range_min,enum intel_dpll_id range_max)247 intel_find_shared_dpll(struct intel_atomic_state *state,
248 const struct intel_crtc *crtc,
249 const struct intel_dpll_hw_state *pll_state,
250 enum intel_dpll_id range_min,
251 enum intel_dpll_id range_max)
252 {
253 struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
254 struct intel_shared_dpll *pll, *unused_pll = NULL;
255 struct intel_shared_dpll_state *shared_dpll;
256 enum intel_dpll_id i;
257
258 shared_dpll = intel_atomic_get_shared_dpll_state(&state->base);
259
260 for (i = range_min; i <= range_max; i++) {
261 pll = &dev_priv->shared_dplls[i];
262
263 /* Only want to check enabled timings first */
264 if (shared_dpll[i].crtc_mask == 0) {
265 if (!unused_pll)
266 unused_pll = pll;
267 continue;
268 }
269
270 if (memcmp(pll_state,
271 &shared_dpll[i].hw_state,
272 sizeof(*pll_state)) == 0) {
273 DRM_DEBUG_KMS("[CRTC:%d:%s] sharing existing %s (crtc mask 0x%08x, active %x)\n",
274 crtc->base.base.id, crtc->base.name,
275 pll->info->name,
276 shared_dpll[i].crtc_mask,
277 pll->active_mask);
278 return pll;
279 }
280 }
281
282 /* Ok no matching timings, maybe there's a free one? */
283 if (unused_pll) {
284 DRM_DEBUG_KMS("[CRTC:%d:%s] allocated %s\n",
285 crtc->base.base.id, crtc->base.name,
286 unused_pll->info->name);
287 return unused_pll;
288 }
289
290 return NULL;
291 }
292
293 static void
intel_reference_shared_dpll(struct intel_atomic_state * state,const struct intel_crtc * crtc,const struct intel_shared_dpll * pll,const struct intel_dpll_hw_state * pll_state)294 intel_reference_shared_dpll(struct intel_atomic_state *state,
295 const struct intel_crtc *crtc,
296 const struct intel_shared_dpll *pll,
297 const struct intel_dpll_hw_state *pll_state)
298 {
299 struct intel_shared_dpll_state *shared_dpll;
300 const enum intel_dpll_id id = pll->info->id;
301
302 shared_dpll = intel_atomic_get_shared_dpll_state(&state->base);
303
304 if (shared_dpll[id].crtc_mask == 0)
305 shared_dpll[id].hw_state = *pll_state;
306
307 DRM_DEBUG_DRIVER("using %s for pipe %c\n", pll->info->name,
308 pipe_name(crtc->pipe));
309
310 shared_dpll[id].crtc_mask |= 1 << crtc->pipe;
311 }
312
intel_unreference_shared_dpll(struct intel_atomic_state * state,const struct intel_crtc * crtc,const struct intel_shared_dpll * pll)313 static void intel_unreference_shared_dpll(struct intel_atomic_state *state,
314 const struct intel_crtc *crtc,
315 const struct intel_shared_dpll *pll)
316 {
317 struct intel_shared_dpll_state *shared_dpll;
318
319 shared_dpll = intel_atomic_get_shared_dpll_state(&state->base);
320 shared_dpll[pll->info->id].crtc_mask &= ~(1 << crtc->pipe);
321 }
322
intel_put_dpll(struct intel_atomic_state * state,struct intel_crtc * crtc)323 static void intel_put_dpll(struct intel_atomic_state *state,
324 struct intel_crtc *crtc)
325 {
326 const struct intel_crtc_state *old_crtc_state =
327 intel_atomic_get_old_crtc_state(state, crtc);
328 struct intel_crtc_state *new_crtc_state =
329 intel_atomic_get_new_crtc_state(state, crtc);
330
331 new_crtc_state->shared_dpll = NULL;
332
333 if (!old_crtc_state->shared_dpll)
334 return;
335
336 intel_unreference_shared_dpll(state, crtc, old_crtc_state->shared_dpll);
337 }
338
339 /**
340 * intel_shared_dpll_swap_state - make atomic DPLL configuration effective
341 * @state: atomic state
342 *
343 * This is the dpll version of drm_atomic_helper_swap_state() since the
344 * helper does not handle driver-specific global state.
345 *
346 * For consistency with atomic helpers this function does a complete swap,
347 * i.e. it also puts the current state into @state, even though there is no
348 * need for that at this moment.
349 */
intel_shared_dpll_swap_state(struct intel_atomic_state * state)350 void intel_shared_dpll_swap_state(struct intel_atomic_state *state)
351 {
352 struct drm_i915_private *dev_priv = to_i915(state->base.dev);
353 struct intel_shared_dpll_state *shared_dpll = state->shared_dpll;
354 enum intel_dpll_id i;
355
356 if (!state->dpll_set)
357 return;
358
359 for (i = 0; i < dev_priv->num_shared_dpll; i++) {
360 struct intel_shared_dpll *pll =
361 &dev_priv->shared_dplls[i];
362
363 swap(pll->state, shared_dpll[i]);
364 }
365 }
366
ibx_pch_dpll_get_hw_state(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll,struct intel_dpll_hw_state * hw_state)367 static bool ibx_pch_dpll_get_hw_state(struct drm_i915_private *dev_priv,
368 struct intel_shared_dpll *pll,
369 struct intel_dpll_hw_state *hw_state)
370 {
371 const enum intel_dpll_id id = pll->info->id;
372 intel_wakeref_t wakeref;
373 u32 val;
374
375 wakeref = intel_display_power_get_if_enabled(dev_priv,
376 POWER_DOMAIN_DISPLAY_CORE);
377 if (!wakeref)
378 return false;
379
380 val = I915_READ(PCH_DPLL(id));
381 hw_state->dpll = val;
382 hw_state->fp0 = I915_READ(PCH_FP0(id));
383 hw_state->fp1 = I915_READ(PCH_FP1(id));
384
385 intel_display_power_put(dev_priv, POWER_DOMAIN_DISPLAY_CORE, wakeref);
386
387 return val & DPLL_VCO_ENABLE;
388 }
389
ibx_pch_dpll_prepare(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)390 static void ibx_pch_dpll_prepare(struct drm_i915_private *dev_priv,
391 struct intel_shared_dpll *pll)
392 {
393 const enum intel_dpll_id id = pll->info->id;
394
395 I915_WRITE(PCH_FP0(id), pll->state.hw_state.fp0);
396 I915_WRITE(PCH_FP1(id), pll->state.hw_state.fp1);
397 }
398
ibx_assert_pch_refclk_enabled(struct drm_i915_private * dev_priv)399 static void ibx_assert_pch_refclk_enabled(struct drm_i915_private *dev_priv)
400 {
401 u32 val;
402 bool enabled;
403
404 I915_STATE_WARN_ON(!(HAS_PCH_IBX(dev_priv) || HAS_PCH_CPT(dev_priv)));
405
406 val = I915_READ(PCH_DREF_CONTROL);
407 enabled = !!(val & (DREF_SSC_SOURCE_MASK | DREF_NONSPREAD_SOURCE_MASK |
408 DREF_SUPERSPREAD_SOURCE_MASK));
409 I915_STATE_WARN(!enabled, "PCH refclk assertion failure, should be active but is disabled\n");
410 }
411
ibx_pch_dpll_enable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)412 static void ibx_pch_dpll_enable(struct drm_i915_private *dev_priv,
413 struct intel_shared_dpll *pll)
414 {
415 const enum intel_dpll_id id = pll->info->id;
416
417 /* PCH refclock must be enabled first */
418 ibx_assert_pch_refclk_enabled(dev_priv);
419
420 I915_WRITE(PCH_DPLL(id), pll->state.hw_state.dpll);
421
422 /* Wait for the clocks to stabilize. */
423 POSTING_READ(PCH_DPLL(id));
424 udelay(150);
425
426 /* The pixel multiplier can only be updated once the
427 * DPLL is enabled and the clocks are stable.
428 *
429 * So write it again.
430 */
431 I915_WRITE(PCH_DPLL(id), pll->state.hw_state.dpll);
432 POSTING_READ(PCH_DPLL(id));
433 udelay(200);
434 }
435
ibx_pch_dpll_disable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)436 static void ibx_pch_dpll_disable(struct drm_i915_private *dev_priv,
437 struct intel_shared_dpll *pll)
438 {
439 const enum intel_dpll_id id = pll->info->id;
440
441 I915_WRITE(PCH_DPLL(id), 0);
442 POSTING_READ(PCH_DPLL(id));
443 udelay(200);
444 }
445
ibx_get_dpll(struct intel_atomic_state * state,struct intel_crtc * crtc,struct intel_encoder * encoder)446 static bool ibx_get_dpll(struct intel_atomic_state *state,
447 struct intel_crtc *crtc,
448 struct intel_encoder *encoder)
449 {
450 struct intel_crtc_state *crtc_state =
451 intel_atomic_get_new_crtc_state(state, crtc);
452 struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
453 struct intel_shared_dpll *pll;
454 enum intel_dpll_id i;
455
456 if (HAS_PCH_IBX(dev_priv)) {
457 /* Ironlake PCH has a fixed PLL->PCH pipe mapping. */
458 i = (enum intel_dpll_id) crtc->pipe;
459 pll = &dev_priv->shared_dplls[i];
460
461 DRM_DEBUG_KMS("[CRTC:%d:%s] using pre-allocated %s\n",
462 crtc->base.base.id, crtc->base.name,
463 pll->info->name);
464 } else {
465 pll = intel_find_shared_dpll(state, crtc,
466 &crtc_state->dpll_hw_state,
467 DPLL_ID_PCH_PLL_A,
468 DPLL_ID_PCH_PLL_B);
469 }
470
471 if (!pll)
472 return false;
473
474 /* reference the pll */
475 intel_reference_shared_dpll(state, crtc,
476 pll, &crtc_state->dpll_hw_state);
477
478 crtc_state->shared_dpll = pll;
479
480 return true;
481 }
482
ibx_dump_hw_state(struct drm_i915_private * dev_priv,const struct intel_dpll_hw_state * hw_state)483 static void ibx_dump_hw_state(struct drm_i915_private *dev_priv,
484 const struct intel_dpll_hw_state *hw_state)
485 {
486 DRM_DEBUG_KMS("dpll_hw_state: dpll: 0x%x, dpll_md: 0x%x, "
487 "fp0: 0x%x, fp1: 0x%x\n",
488 hw_state->dpll,
489 hw_state->dpll_md,
490 hw_state->fp0,
491 hw_state->fp1);
492 }
493
494 static const struct intel_shared_dpll_funcs ibx_pch_dpll_funcs = {
495 .prepare = ibx_pch_dpll_prepare,
496 .enable = ibx_pch_dpll_enable,
497 .disable = ibx_pch_dpll_disable,
498 .get_hw_state = ibx_pch_dpll_get_hw_state,
499 };
500
hsw_ddi_wrpll_enable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)501 static void hsw_ddi_wrpll_enable(struct drm_i915_private *dev_priv,
502 struct intel_shared_dpll *pll)
503 {
504 const enum intel_dpll_id id = pll->info->id;
505
506 I915_WRITE(WRPLL_CTL(id), pll->state.hw_state.wrpll);
507 POSTING_READ(WRPLL_CTL(id));
508 udelay(20);
509 }
510
hsw_ddi_spll_enable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)511 static void hsw_ddi_spll_enable(struct drm_i915_private *dev_priv,
512 struct intel_shared_dpll *pll)
513 {
514 I915_WRITE(SPLL_CTL, pll->state.hw_state.spll);
515 POSTING_READ(SPLL_CTL);
516 udelay(20);
517 }
518
hsw_ddi_wrpll_disable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)519 static void hsw_ddi_wrpll_disable(struct drm_i915_private *dev_priv,
520 struct intel_shared_dpll *pll)
521 {
522 const enum intel_dpll_id id = pll->info->id;
523 u32 val;
524
525 val = I915_READ(WRPLL_CTL(id));
526 I915_WRITE(WRPLL_CTL(id), val & ~WRPLL_PLL_ENABLE);
527 POSTING_READ(WRPLL_CTL(id));
528
529 /*
530 * Try to set up the PCH reference clock once all DPLLs
531 * that depend on it have been shut down.
532 */
533 if (dev_priv->pch_ssc_use & BIT(id))
534 intel_init_pch_refclk(dev_priv);
535 }
536
hsw_ddi_spll_disable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)537 static void hsw_ddi_spll_disable(struct drm_i915_private *dev_priv,
538 struct intel_shared_dpll *pll)
539 {
540 enum intel_dpll_id id = pll->info->id;
541 u32 val;
542
543 val = I915_READ(SPLL_CTL);
544 I915_WRITE(SPLL_CTL, val & ~SPLL_PLL_ENABLE);
545 POSTING_READ(SPLL_CTL);
546
547 /*
548 * Try to set up the PCH reference clock once all DPLLs
549 * that depend on it have been shut down.
550 */
551 if (dev_priv->pch_ssc_use & BIT(id))
552 intel_init_pch_refclk(dev_priv);
553 }
554
hsw_ddi_wrpll_get_hw_state(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll,struct intel_dpll_hw_state * hw_state)555 static bool hsw_ddi_wrpll_get_hw_state(struct drm_i915_private *dev_priv,
556 struct intel_shared_dpll *pll,
557 struct intel_dpll_hw_state *hw_state)
558 {
559 const enum intel_dpll_id id = pll->info->id;
560 intel_wakeref_t wakeref;
561 u32 val;
562
563 wakeref = intel_display_power_get_if_enabled(dev_priv,
564 POWER_DOMAIN_DISPLAY_CORE);
565 if (!wakeref)
566 return false;
567
568 val = I915_READ(WRPLL_CTL(id));
569 hw_state->wrpll = val;
570
571 intel_display_power_put(dev_priv, POWER_DOMAIN_DISPLAY_CORE, wakeref);
572
573 return val & WRPLL_PLL_ENABLE;
574 }
575
hsw_ddi_spll_get_hw_state(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll,struct intel_dpll_hw_state * hw_state)576 static bool hsw_ddi_spll_get_hw_state(struct drm_i915_private *dev_priv,
577 struct intel_shared_dpll *pll,
578 struct intel_dpll_hw_state *hw_state)
579 {
580 intel_wakeref_t wakeref;
581 u32 val;
582
583 wakeref = intel_display_power_get_if_enabled(dev_priv,
584 POWER_DOMAIN_DISPLAY_CORE);
585 if (!wakeref)
586 return false;
587
588 val = I915_READ(SPLL_CTL);
589 hw_state->spll = val;
590
591 intel_display_power_put(dev_priv, POWER_DOMAIN_DISPLAY_CORE, wakeref);
592
593 return val & SPLL_PLL_ENABLE;
594 }
595
596 #define LC_FREQ 2700
597 #define LC_FREQ_2K U64_C(LC_FREQ * 2000)
598
599 #define P_MIN 2
600 #define P_MAX 64
601 #define P_INC 2
602
603 /* Constraints for PLL good behavior */
604 #define REF_MIN 48
605 #define REF_MAX 400
606 #define VCO_MIN 2400
607 #define VCO_MAX 4800
608
609 struct hsw_wrpll_rnp {
610 unsigned p, n2, r2;
611 };
612
hsw_wrpll_get_budget_for_freq(int clock)613 static unsigned hsw_wrpll_get_budget_for_freq(int clock)
614 {
615 unsigned budget;
616
617 switch (clock) {
618 case 25175000:
619 case 25200000:
620 case 27000000:
621 case 27027000:
622 case 37762500:
623 case 37800000:
624 case 40500000:
625 case 40541000:
626 case 54000000:
627 case 54054000:
628 case 59341000:
629 case 59400000:
630 case 72000000:
631 case 74176000:
632 case 74250000:
633 case 81000000:
634 case 81081000:
635 case 89012000:
636 case 89100000:
637 case 108000000:
638 case 108108000:
639 case 111264000:
640 case 111375000:
641 case 148352000:
642 case 148500000:
643 case 162000000:
644 case 162162000:
645 case 222525000:
646 case 222750000:
647 case 296703000:
648 case 297000000:
649 budget = 0;
650 break;
651 case 233500000:
652 case 245250000:
653 case 247750000:
654 case 253250000:
655 case 298000000:
656 budget = 1500;
657 break;
658 case 169128000:
659 case 169500000:
660 case 179500000:
661 case 202000000:
662 budget = 2000;
663 break;
664 case 256250000:
665 case 262500000:
666 case 270000000:
667 case 272500000:
668 case 273750000:
669 case 280750000:
670 case 281250000:
671 case 286000000:
672 case 291750000:
673 budget = 4000;
674 break;
675 case 267250000:
676 case 268500000:
677 budget = 5000;
678 break;
679 default:
680 budget = 1000;
681 break;
682 }
683
684 return budget;
685 }
686
hsw_wrpll_update_rnp(u64 freq2k,unsigned int budget,unsigned int r2,unsigned int n2,unsigned int p,struct hsw_wrpll_rnp * best)687 static void hsw_wrpll_update_rnp(u64 freq2k, unsigned int budget,
688 unsigned int r2, unsigned int n2,
689 unsigned int p,
690 struct hsw_wrpll_rnp *best)
691 {
692 u64 a, b, c, d, diff, diff_best;
693
694 /* No best (r,n,p) yet */
695 if (best->p == 0) {
696 best->p = p;
697 best->n2 = n2;
698 best->r2 = r2;
699 return;
700 }
701
702 /*
703 * Output clock is (LC_FREQ_2K / 2000) * N / (P * R), which compares to
704 * freq2k.
705 *
706 * delta = 1e6 *
707 * abs(freq2k - (LC_FREQ_2K * n2/(p * r2))) /
708 * freq2k;
709 *
710 * and we would like delta <= budget.
711 *
712 * If the discrepancy is above the PPM-based budget, always prefer to
713 * improve upon the previous solution. However, if you're within the
714 * budget, try to maximize Ref * VCO, that is N / (P * R^2).
715 */
716 a = freq2k * budget * p * r2;
717 b = freq2k * budget * best->p * best->r2;
718 diff = abs_diff(freq2k * p * r2, LC_FREQ_2K * n2);
719 diff_best = abs_diff(freq2k * best->p * best->r2,
720 LC_FREQ_2K * best->n2);
721 c = 1000000 * diff;
722 d = 1000000 * diff_best;
723
724 if (a < c && b < d) {
725 /* If both are above the budget, pick the closer */
726 if (best->p * best->r2 * diff < p * r2 * diff_best) {
727 best->p = p;
728 best->n2 = n2;
729 best->r2 = r2;
730 }
731 } else if (a >= c && b < d) {
732 /* If A is below the threshold but B is above it? Update. */
733 best->p = p;
734 best->n2 = n2;
735 best->r2 = r2;
736 } else if (a >= c && b >= d) {
737 /* Both are below the limit, so pick the higher n2/(r2*r2) */
738 if (n2 * best->r2 * best->r2 > best->n2 * r2 * r2) {
739 best->p = p;
740 best->n2 = n2;
741 best->r2 = r2;
742 }
743 }
744 /* Otherwise a < c && b >= d, do nothing */
745 }
746
747 static void
hsw_ddi_calculate_wrpll(int clock,unsigned * r2_out,unsigned * n2_out,unsigned * p_out)748 hsw_ddi_calculate_wrpll(int clock /* in Hz */,
749 unsigned *r2_out, unsigned *n2_out, unsigned *p_out)
750 {
751 u64 freq2k;
752 unsigned p, n2, r2;
753 struct hsw_wrpll_rnp best = { 0, 0, 0 };
754 unsigned budget;
755
756 freq2k = clock / 100;
757
758 budget = hsw_wrpll_get_budget_for_freq(clock);
759
760 /* Special case handling for 540 pixel clock: bypass WR PLL entirely
761 * and directly pass the LC PLL to it. */
762 if (freq2k == 5400000) {
763 *n2_out = 2;
764 *p_out = 1;
765 *r2_out = 2;
766 return;
767 }
768
769 /*
770 * Ref = LC_FREQ / R, where Ref is the actual reference input seen by
771 * the WR PLL.
772 *
773 * We want R so that REF_MIN <= Ref <= REF_MAX.
774 * Injecting R2 = 2 * R gives:
775 * REF_MAX * r2 > LC_FREQ * 2 and
776 * REF_MIN * r2 < LC_FREQ * 2
777 *
778 * Which means the desired boundaries for r2 are:
779 * LC_FREQ * 2 / REF_MAX < r2 < LC_FREQ * 2 / REF_MIN
780 *
781 */
782 for (r2 = LC_FREQ * 2 / REF_MAX + 1;
783 r2 <= LC_FREQ * 2 / REF_MIN;
784 r2++) {
785
786 /*
787 * VCO = N * Ref, that is: VCO = N * LC_FREQ / R
788 *
789 * Once again we want VCO_MIN <= VCO <= VCO_MAX.
790 * Injecting R2 = 2 * R and N2 = 2 * N, we get:
791 * VCO_MAX * r2 > n2 * LC_FREQ and
792 * VCO_MIN * r2 < n2 * LC_FREQ)
793 *
794 * Which means the desired boundaries for n2 are:
795 * VCO_MIN * r2 / LC_FREQ < n2 < VCO_MAX * r2 / LC_FREQ
796 */
797 for (n2 = VCO_MIN * r2 / LC_FREQ + 1;
798 n2 <= VCO_MAX * r2 / LC_FREQ;
799 n2++) {
800
801 for (p = P_MIN; p <= P_MAX; p += P_INC)
802 hsw_wrpll_update_rnp(freq2k, budget,
803 r2, n2, p, &best);
804 }
805 }
806
807 *n2_out = best.n2;
808 *p_out = best.p;
809 *r2_out = best.r2;
810 }
811
812 static struct intel_shared_dpll *
hsw_ddi_hdmi_get_dpll(struct intel_atomic_state * state,struct intel_crtc * crtc)813 hsw_ddi_hdmi_get_dpll(struct intel_atomic_state *state,
814 struct intel_crtc *crtc)
815 {
816 struct intel_crtc_state *crtc_state =
817 intel_atomic_get_new_crtc_state(state, crtc);
818 struct intel_shared_dpll *pll;
819 u32 val;
820 unsigned int p, n2, r2;
821
822 hsw_ddi_calculate_wrpll(crtc_state->port_clock * 1000, &r2, &n2, &p);
823
824 val = WRPLL_PLL_ENABLE | WRPLL_REF_LCPLL |
825 WRPLL_DIVIDER_REFERENCE(r2) | WRPLL_DIVIDER_FEEDBACK(n2) |
826 WRPLL_DIVIDER_POST(p);
827
828 crtc_state->dpll_hw_state.wrpll = val;
829
830 pll = intel_find_shared_dpll(state, crtc,
831 &crtc_state->dpll_hw_state,
832 DPLL_ID_WRPLL1, DPLL_ID_WRPLL2);
833
834 if (!pll)
835 return NULL;
836
837 return pll;
838 }
839
840 static struct intel_shared_dpll *
hsw_ddi_dp_get_dpll(struct intel_crtc_state * crtc_state)841 hsw_ddi_dp_get_dpll(struct intel_crtc_state *crtc_state)
842 {
843 struct drm_i915_private *dev_priv = to_i915(crtc_state->base.crtc->dev);
844 struct intel_shared_dpll *pll;
845 enum intel_dpll_id pll_id;
846 int clock = crtc_state->port_clock;
847
848 switch (clock / 2) {
849 case 81000:
850 pll_id = DPLL_ID_LCPLL_810;
851 break;
852 case 135000:
853 pll_id = DPLL_ID_LCPLL_1350;
854 break;
855 case 270000:
856 pll_id = DPLL_ID_LCPLL_2700;
857 break;
858 default:
859 DRM_DEBUG_KMS("Invalid clock for DP: %d\n", clock);
860 return NULL;
861 }
862
863 pll = intel_get_shared_dpll_by_id(dev_priv, pll_id);
864
865 if (!pll)
866 return NULL;
867
868 return pll;
869 }
870
hsw_get_dpll(struct intel_atomic_state * state,struct intel_crtc * crtc,struct intel_encoder * encoder)871 static bool hsw_get_dpll(struct intel_atomic_state *state,
872 struct intel_crtc *crtc,
873 struct intel_encoder *encoder)
874 {
875 struct intel_crtc_state *crtc_state =
876 intel_atomic_get_new_crtc_state(state, crtc);
877 struct intel_shared_dpll *pll;
878
879 memset(&crtc_state->dpll_hw_state, 0,
880 sizeof(crtc_state->dpll_hw_state));
881
882 if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI)) {
883 pll = hsw_ddi_hdmi_get_dpll(state, crtc);
884 } else if (intel_crtc_has_dp_encoder(crtc_state)) {
885 pll = hsw_ddi_dp_get_dpll(crtc_state);
886 } else if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_ANALOG)) {
887 if (WARN_ON(crtc_state->port_clock / 2 != 135000))
888 return false;
889
890 crtc_state->dpll_hw_state.spll =
891 SPLL_PLL_ENABLE | SPLL_FREQ_1350MHz | SPLL_REF_MUXED_SSC;
892
893 pll = intel_find_shared_dpll(state, crtc,
894 &crtc_state->dpll_hw_state,
895 DPLL_ID_SPLL, DPLL_ID_SPLL);
896 } else {
897 return false;
898 }
899
900 if (!pll)
901 return false;
902
903 intel_reference_shared_dpll(state, crtc,
904 pll, &crtc_state->dpll_hw_state);
905
906 crtc_state->shared_dpll = pll;
907
908 return true;
909 }
910
hsw_dump_hw_state(struct drm_i915_private * dev_priv,const struct intel_dpll_hw_state * hw_state)911 static void hsw_dump_hw_state(struct drm_i915_private *dev_priv,
912 const struct intel_dpll_hw_state *hw_state)
913 {
914 DRM_DEBUG_KMS("dpll_hw_state: wrpll: 0x%x spll: 0x%x\n",
915 hw_state->wrpll, hw_state->spll);
916 }
917
918 static const struct intel_shared_dpll_funcs hsw_ddi_wrpll_funcs = {
919 .enable = hsw_ddi_wrpll_enable,
920 .disable = hsw_ddi_wrpll_disable,
921 .get_hw_state = hsw_ddi_wrpll_get_hw_state,
922 };
923
924 static const struct intel_shared_dpll_funcs hsw_ddi_spll_funcs = {
925 .enable = hsw_ddi_spll_enable,
926 .disable = hsw_ddi_spll_disable,
927 .get_hw_state = hsw_ddi_spll_get_hw_state,
928 };
929
hsw_ddi_lcpll_enable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)930 static void hsw_ddi_lcpll_enable(struct drm_i915_private *dev_priv,
931 struct intel_shared_dpll *pll)
932 {
933 }
934
hsw_ddi_lcpll_disable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)935 static void hsw_ddi_lcpll_disable(struct drm_i915_private *dev_priv,
936 struct intel_shared_dpll *pll)
937 {
938 }
939
hsw_ddi_lcpll_get_hw_state(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll,struct intel_dpll_hw_state * hw_state)940 static bool hsw_ddi_lcpll_get_hw_state(struct drm_i915_private *dev_priv,
941 struct intel_shared_dpll *pll,
942 struct intel_dpll_hw_state *hw_state)
943 {
944 return true;
945 }
946
947 static const struct intel_shared_dpll_funcs hsw_ddi_lcpll_funcs = {
948 .enable = hsw_ddi_lcpll_enable,
949 .disable = hsw_ddi_lcpll_disable,
950 .get_hw_state = hsw_ddi_lcpll_get_hw_state,
951 };
952
953 struct skl_dpll_regs {
954 i915_reg_t ctl, cfgcr1, cfgcr2;
955 };
956
957 /* this array is indexed by the *shared* pll id */
958 static const struct skl_dpll_regs skl_dpll_regs[4] = {
959 {
960 /* DPLL 0 */
961 .ctl = LCPLL1_CTL,
962 /* DPLL 0 doesn't support HDMI mode */
963 },
964 {
965 /* DPLL 1 */
966 .ctl = LCPLL2_CTL,
967 .cfgcr1 = DPLL_CFGCR1(SKL_DPLL1),
968 .cfgcr2 = DPLL_CFGCR2(SKL_DPLL1),
969 },
970 {
971 /* DPLL 2 */
972 .ctl = WRPLL_CTL(0),
973 .cfgcr1 = DPLL_CFGCR1(SKL_DPLL2),
974 .cfgcr2 = DPLL_CFGCR2(SKL_DPLL2),
975 },
976 {
977 /* DPLL 3 */
978 .ctl = WRPLL_CTL(1),
979 .cfgcr1 = DPLL_CFGCR1(SKL_DPLL3),
980 .cfgcr2 = DPLL_CFGCR2(SKL_DPLL3),
981 },
982 };
983
skl_ddi_pll_write_ctrl1(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)984 static void skl_ddi_pll_write_ctrl1(struct drm_i915_private *dev_priv,
985 struct intel_shared_dpll *pll)
986 {
987 const enum intel_dpll_id id = pll->info->id;
988 u32 val;
989
990 val = I915_READ(DPLL_CTRL1);
991
992 val &= ~(DPLL_CTRL1_HDMI_MODE(id) |
993 DPLL_CTRL1_SSC(id) |
994 DPLL_CTRL1_LINK_RATE_MASK(id));
995 val |= pll->state.hw_state.ctrl1 << (id * 6);
996
997 I915_WRITE(DPLL_CTRL1, val);
998 POSTING_READ(DPLL_CTRL1);
999 }
1000
skl_ddi_pll_enable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)1001 static void skl_ddi_pll_enable(struct drm_i915_private *dev_priv,
1002 struct intel_shared_dpll *pll)
1003 {
1004 const struct skl_dpll_regs *regs = skl_dpll_regs;
1005 const enum intel_dpll_id id = pll->info->id;
1006
1007 skl_ddi_pll_write_ctrl1(dev_priv, pll);
1008
1009 I915_WRITE(regs[id].cfgcr1, pll->state.hw_state.cfgcr1);
1010 I915_WRITE(regs[id].cfgcr2, pll->state.hw_state.cfgcr2);
1011 POSTING_READ(regs[id].cfgcr1);
1012 POSTING_READ(regs[id].cfgcr2);
1013
1014 /* the enable bit is always bit 31 */
1015 I915_WRITE(regs[id].ctl,
1016 I915_READ(regs[id].ctl) | LCPLL_PLL_ENABLE);
1017
1018 if (intel_de_wait_for_set(dev_priv, DPLL_STATUS, DPLL_LOCK(id), 5))
1019 DRM_ERROR("DPLL %d not locked\n", id);
1020 }
1021
skl_ddi_dpll0_enable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)1022 static void skl_ddi_dpll0_enable(struct drm_i915_private *dev_priv,
1023 struct intel_shared_dpll *pll)
1024 {
1025 skl_ddi_pll_write_ctrl1(dev_priv, pll);
1026 }
1027
skl_ddi_pll_disable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)1028 static void skl_ddi_pll_disable(struct drm_i915_private *dev_priv,
1029 struct intel_shared_dpll *pll)
1030 {
1031 const struct skl_dpll_regs *regs = skl_dpll_regs;
1032 const enum intel_dpll_id id = pll->info->id;
1033
1034 /* the enable bit is always bit 31 */
1035 I915_WRITE(regs[id].ctl,
1036 I915_READ(regs[id].ctl) & ~LCPLL_PLL_ENABLE);
1037 POSTING_READ(regs[id].ctl);
1038 }
1039
skl_ddi_dpll0_disable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)1040 static void skl_ddi_dpll0_disable(struct drm_i915_private *dev_priv,
1041 struct intel_shared_dpll *pll)
1042 {
1043 }
1044
skl_ddi_pll_get_hw_state(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll,struct intel_dpll_hw_state * hw_state)1045 static bool skl_ddi_pll_get_hw_state(struct drm_i915_private *dev_priv,
1046 struct intel_shared_dpll *pll,
1047 struct intel_dpll_hw_state *hw_state)
1048 {
1049 u32 val;
1050 const struct skl_dpll_regs *regs = skl_dpll_regs;
1051 const enum intel_dpll_id id = pll->info->id;
1052 intel_wakeref_t wakeref;
1053 bool ret;
1054
1055 wakeref = intel_display_power_get_if_enabled(dev_priv,
1056 POWER_DOMAIN_DISPLAY_CORE);
1057 if (!wakeref)
1058 return false;
1059
1060 ret = false;
1061
1062 val = I915_READ(regs[id].ctl);
1063 if (!(val & LCPLL_PLL_ENABLE))
1064 goto out;
1065
1066 val = I915_READ(DPLL_CTRL1);
1067 hw_state->ctrl1 = (val >> (id * 6)) & 0x3f;
1068
1069 /* avoid reading back stale values if HDMI mode is not enabled */
1070 if (val & DPLL_CTRL1_HDMI_MODE(id)) {
1071 hw_state->cfgcr1 = I915_READ(regs[id].cfgcr1);
1072 hw_state->cfgcr2 = I915_READ(regs[id].cfgcr2);
1073 }
1074 ret = true;
1075
1076 out:
1077 intel_display_power_put(dev_priv, POWER_DOMAIN_DISPLAY_CORE, wakeref);
1078
1079 return ret;
1080 }
1081
skl_ddi_dpll0_get_hw_state(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll,struct intel_dpll_hw_state * hw_state)1082 static bool skl_ddi_dpll0_get_hw_state(struct drm_i915_private *dev_priv,
1083 struct intel_shared_dpll *pll,
1084 struct intel_dpll_hw_state *hw_state)
1085 {
1086 const struct skl_dpll_regs *regs = skl_dpll_regs;
1087 const enum intel_dpll_id id = pll->info->id;
1088 intel_wakeref_t wakeref;
1089 u32 val;
1090 bool ret;
1091
1092 wakeref = intel_display_power_get_if_enabled(dev_priv,
1093 POWER_DOMAIN_DISPLAY_CORE);
1094 if (!wakeref)
1095 return false;
1096
1097 ret = false;
1098
1099 /* DPLL0 is always enabled since it drives CDCLK */
1100 val = I915_READ(regs[id].ctl);
1101 if (WARN_ON(!(val & LCPLL_PLL_ENABLE)))
1102 goto out;
1103
1104 val = I915_READ(DPLL_CTRL1);
1105 hw_state->ctrl1 = (val >> (id * 6)) & 0x3f;
1106
1107 ret = true;
1108
1109 out:
1110 intel_display_power_put(dev_priv, POWER_DOMAIN_DISPLAY_CORE, wakeref);
1111
1112 return ret;
1113 }
1114
1115 struct skl_wrpll_context {
1116 u64 min_deviation; /* current minimal deviation */
1117 u64 central_freq; /* chosen central freq */
1118 u64 dco_freq; /* chosen dco freq */
1119 unsigned int p; /* chosen divider */
1120 };
1121
skl_wrpll_context_init(struct skl_wrpll_context * ctx)1122 static void skl_wrpll_context_init(struct skl_wrpll_context *ctx)
1123 {
1124 memset(ctx, 0, sizeof(*ctx));
1125
1126 ctx->min_deviation = U64_MAX;
1127 }
1128
1129 /* DCO freq must be within +1%/-6% of the DCO central freq */
1130 #define SKL_DCO_MAX_PDEVIATION 100
1131 #define SKL_DCO_MAX_NDEVIATION 600
1132
skl_wrpll_try_divider(struct skl_wrpll_context * ctx,u64 central_freq,u64 dco_freq,unsigned int divider)1133 static void skl_wrpll_try_divider(struct skl_wrpll_context *ctx,
1134 u64 central_freq,
1135 u64 dco_freq,
1136 unsigned int divider)
1137 {
1138 u64 deviation;
1139
1140 deviation = div64_u64(10000 * abs_diff(dco_freq, central_freq),
1141 central_freq);
1142
1143 /* positive deviation */
1144 if (dco_freq >= central_freq) {
1145 if (deviation < SKL_DCO_MAX_PDEVIATION &&
1146 deviation < ctx->min_deviation) {
1147 ctx->min_deviation = deviation;
1148 ctx->central_freq = central_freq;
1149 ctx->dco_freq = dco_freq;
1150 ctx->p = divider;
1151 }
1152 /* negative deviation */
1153 } else if (deviation < SKL_DCO_MAX_NDEVIATION &&
1154 deviation < ctx->min_deviation) {
1155 ctx->min_deviation = deviation;
1156 ctx->central_freq = central_freq;
1157 ctx->dco_freq = dco_freq;
1158 ctx->p = divider;
1159 }
1160 }
1161
skl_wrpll_get_multipliers(unsigned int p,unsigned int * p0,unsigned int * p1,unsigned int * p2)1162 static void skl_wrpll_get_multipliers(unsigned int p,
1163 unsigned int *p0 /* out */,
1164 unsigned int *p1 /* out */,
1165 unsigned int *p2 /* out */)
1166 {
1167 /* even dividers */
1168 if (p % 2 == 0) {
1169 unsigned int half = p / 2;
1170
1171 if (half == 1 || half == 2 || half == 3 || half == 5) {
1172 *p0 = 2;
1173 *p1 = 1;
1174 *p2 = half;
1175 } else if (half % 2 == 0) {
1176 *p0 = 2;
1177 *p1 = half / 2;
1178 *p2 = 2;
1179 } else if (half % 3 == 0) {
1180 *p0 = 3;
1181 *p1 = half / 3;
1182 *p2 = 2;
1183 } else if (half % 7 == 0) {
1184 *p0 = 7;
1185 *p1 = half / 7;
1186 *p2 = 2;
1187 }
1188 } else if (p == 3 || p == 9) { /* 3, 5, 7, 9, 15, 21, 35 */
1189 *p0 = 3;
1190 *p1 = 1;
1191 *p2 = p / 3;
1192 } else if (p == 5 || p == 7) {
1193 *p0 = p;
1194 *p1 = 1;
1195 *p2 = 1;
1196 } else if (p == 15) {
1197 *p0 = 3;
1198 *p1 = 1;
1199 *p2 = 5;
1200 } else if (p == 21) {
1201 *p0 = 7;
1202 *p1 = 1;
1203 *p2 = 3;
1204 } else if (p == 35) {
1205 *p0 = 7;
1206 *p1 = 1;
1207 *p2 = 5;
1208 }
1209 }
1210
1211 struct skl_wrpll_params {
1212 u32 dco_fraction;
1213 u32 dco_integer;
1214 u32 qdiv_ratio;
1215 u32 qdiv_mode;
1216 u32 kdiv;
1217 u32 pdiv;
1218 u32 central_freq;
1219 };
1220
skl_wrpll_params_populate(struct skl_wrpll_params * params,u64 afe_clock,u64 central_freq,u32 p0,u32 p1,u32 p2)1221 static void skl_wrpll_params_populate(struct skl_wrpll_params *params,
1222 u64 afe_clock,
1223 u64 central_freq,
1224 u32 p0, u32 p1, u32 p2)
1225 {
1226 u64 dco_freq;
1227
1228 switch (central_freq) {
1229 case 9600000000ULL:
1230 params->central_freq = 0;
1231 break;
1232 case 9000000000ULL:
1233 params->central_freq = 1;
1234 break;
1235 case 8400000000ULL:
1236 params->central_freq = 3;
1237 }
1238
1239 switch (p0) {
1240 case 1:
1241 params->pdiv = 0;
1242 break;
1243 case 2:
1244 params->pdiv = 1;
1245 break;
1246 case 3:
1247 params->pdiv = 2;
1248 break;
1249 case 7:
1250 params->pdiv = 4;
1251 break;
1252 default:
1253 WARN(1, "Incorrect PDiv\n");
1254 }
1255
1256 switch (p2) {
1257 case 5:
1258 params->kdiv = 0;
1259 break;
1260 case 2:
1261 params->kdiv = 1;
1262 break;
1263 case 3:
1264 params->kdiv = 2;
1265 break;
1266 case 1:
1267 params->kdiv = 3;
1268 break;
1269 default:
1270 WARN(1, "Incorrect KDiv\n");
1271 }
1272
1273 params->qdiv_ratio = p1;
1274 params->qdiv_mode = (params->qdiv_ratio == 1) ? 0 : 1;
1275
1276 dco_freq = p0 * p1 * p2 * afe_clock;
1277
1278 /*
1279 * Intermediate values are in Hz.
1280 * Divide by MHz to match bsepc
1281 */
1282 params->dco_integer = div_u64(dco_freq, 24 * MHz(1));
1283 params->dco_fraction =
1284 div_u64((div_u64(dco_freq, 24) -
1285 params->dco_integer * MHz(1)) * 0x8000, MHz(1));
1286 }
1287
1288 static bool
skl_ddi_calculate_wrpll(int clock,struct skl_wrpll_params * wrpll_params)1289 skl_ddi_calculate_wrpll(int clock /* in Hz */,
1290 struct skl_wrpll_params *wrpll_params)
1291 {
1292 u64 afe_clock = clock * 5; /* AFE Clock is 5x Pixel clock */
1293 u64 dco_central_freq[3] = { 8400000000ULL,
1294 9000000000ULL,
1295 9600000000ULL };
1296 static const int even_dividers[] = { 4, 6, 8, 10, 12, 14, 16, 18, 20,
1297 24, 28, 30, 32, 36, 40, 42, 44,
1298 48, 52, 54, 56, 60, 64, 66, 68,
1299 70, 72, 76, 78, 80, 84, 88, 90,
1300 92, 96, 98 };
1301 static const int odd_dividers[] = { 3, 5, 7, 9, 15, 21, 35 };
1302 static const struct {
1303 const int *list;
1304 int n_dividers;
1305 } dividers[] = {
1306 { even_dividers, ARRAY_SIZE(even_dividers) },
1307 { odd_dividers, ARRAY_SIZE(odd_dividers) },
1308 };
1309 struct skl_wrpll_context ctx;
1310 unsigned int dco, d, i;
1311 unsigned int p0, p1, p2;
1312
1313 skl_wrpll_context_init(&ctx);
1314
1315 for (d = 0; d < ARRAY_SIZE(dividers); d++) {
1316 for (dco = 0; dco < ARRAY_SIZE(dco_central_freq); dco++) {
1317 for (i = 0; i < dividers[d].n_dividers; i++) {
1318 unsigned int p = dividers[d].list[i];
1319 u64 dco_freq = p * afe_clock;
1320
1321 skl_wrpll_try_divider(&ctx,
1322 dco_central_freq[dco],
1323 dco_freq,
1324 p);
1325 /*
1326 * Skip the remaining dividers if we're sure to
1327 * have found the definitive divider, we can't
1328 * improve a 0 deviation.
1329 */
1330 if (ctx.min_deviation == 0)
1331 goto skip_remaining_dividers;
1332 }
1333 }
1334
1335 skip_remaining_dividers:
1336 /*
1337 * If a solution is found with an even divider, prefer
1338 * this one.
1339 */
1340 if (d == 0 && ctx.p)
1341 break;
1342 }
1343
1344 if (!ctx.p) {
1345 DRM_DEBUG_DRIVER("No valid divider found for %dHz\n", clock);
1346 return false;
1347 }
1348
1349 /*
1350 * gcc incorrectly analyses that these can be used without being
1351 * initialized. To be fair, it's hard to guess.
1352 */
1353 p0 = p1 = p2 = 0;
1354 skl_wrpll_get_multipliers(ctx.p, &p0, &p1, &p2);
1355 skl_wrpll_params_populate(wrpll_params, afe_clock, ctx.central_freq,
1356 p0, p1, p2);
1357
1358 return true;
1359 }
1360
skl_ddi_hdmi_pll_dividers(struct intel_crtc_state * crtc_state)1361 static bool skl_ddi_hdmi_pll_dividers(struct intel_crtc_state *crtc_state)
1362 {
1363 u32 ctrl1, cfgcr1, cfgcr2;
1364 struct skl_wrpll_params wrpll_params = { 0, };
1365
1366 /*
1367 * See comment in intel_dpll_hw_state to understand why we always use 0
1368 * as the DPLL id in this function.
1369 */
1370 ctrl1 = DPLL_CTRL1_OVERRIDE(0);
1371
1372 ctrl1 |= DPLL_CTRL1_HDMI_MODE(0);
1373
1374 if (!skl_ddi_calculate_wrpll(crtc_state->port_clock * 1000,
1375 &wrpll_params))
1376 return false;
1377
1378 cfgcr1 = DPLL_CFGCR1_FREQ_ENABLE |
1379 DPLL_CFGCR1_DCO_FRACTION(wrpll_params.dco_fraction) |
1380 wrpll_params.dco_integer;
1381
1382 cfgcr2 = DPLL_CFGCR2_QDIV_RATIO(wrpll_params.qdiv_ratio) |
1383 DPLL_CFGCR2_QDIV_MODE(wrpll_params.qdiv_mode) |
1384 DPLL_CFGCR2_KDIV(wrpll_params.kdiv) |
1385 DPLL_CFGCR2_PDIV(wrpll_params.pdiv) |
1386 wrpll_params.central_freq;
1387
1388 memset(&crtc_state->dpll_hw_state, 0,
1389 sizeof(crtc_state->dpll_hw_state));
1390
1391 crtc_state->dpll_hw_state.ctrl1 = ctrl1;
1392 crtc_state->dpll_hw_state.cfgcr1 = cfgcr1;
1393 crtc_state->dpll_hw_state.cfgcr2 = cfgcr2;
1394 return true;
1395 }
1396
1397 static bool
skl_ddi_dp_set_dpll_hw_state(struct intel_crtc_state * crtc_state)1398 skl_ddi_dp_set_dpll_hw_state(struct intel_crtc_state *crtc_state)
1399 {
1400 u32 ctrl1;
1401
1402 /*
1403 * See comment in intel_dpll_hw_state to understand why we always use 0
1404 * as the DPLL id in this function.
1405 */
1406 ctrl1 = DPLL_CTRL1_OVERRIDE(0);
1407 switch (crtc_state->port_clock / 2) {
1408 case 81000:
1409 ctrl1 |= DPLL_CTRL1_LINK_RATE(DPLL_CTRL1_LINK_RATE_810, 0);
1410 break;
1411 case 135000:
1412 ctrl1 |= DPLL_CTRL1_LINK_RATE(DPLL_CTRL1_LINK_RATE_1350, 0);
1413 break;
1414 case 270000:
1415 ctrl1 |= DPLL_CTRL1_LINK_RATE(DPLL_CTRL1_LINK_RATE_2700, 0);
1416 break;
1417 /* eDP 1.4 rates */
1418 case 162000:
1419 ctrl1 |= DPLL_CTRL1_LINK_RATE(DPLL_CTRL1_LINK_RATE_1620, 0);
1420 break;
1421 case 108000:
1422 ctrl1 |= DPLL_CTRL1_LINK_RATE(DPLL_CTRL1_LINK_RATE_1080, 0);
1423 break;
1424 case 216000:
1425 ctrl1 |= DPLL_CTRL1_LINK_RATE(DPLL_CTRL1_LINK_RATE_2160, 0);
1426 break;
1427 }
1428
1429 memset(&crtc_state->dpll_hw_state, 0,
1430 sizeof(crtc_state->dpll_hw_state));
1431
1432 crtc_state->dpll_hw_state.ctrl1 = ctrl1;
1433
1434 return true;
1435 }
1436
skl_get_dpll(struct intel_atomic_state * state,struct intel_crtc * crtc,struct intel_encoder * encoder)1437 static bool skl_get_dpll(struct intel_atomic_state *state,
1438 struct intel_crtc *crtc,
1439 struct intel_encoder *encoder)
1440 {
1441 struct intel_crtc_state *crtc_state =
1442 intel_atomic_get_new_crtc_state(state, crtc);
1443 struct intel_shared_dpll *pll;
1444 bool bret;
1445
1446 if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI)) {
1447 bret = skl_ddi_hdmi_pll_dividers(crtc_state);
1448 if (!bret) {
1449 DRM_DEBUG_KMS("Could not get HDMI pll dividers.\n");
1450 return false;
1451 }
1452 } else if (intel_crtc_has_dp_encoder(crtc_state)) {
1453 bret = skl_ddi_dp_set_dpll_hw_state(crtc_state);
1454 if (!bret) {
1455 DRM_DEBUG_KMS("Could not set DP dpll HW state.\n");
1456 return false;
1457 }
1458 } else {
1459 return false;
1460 }
1461
1462 if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_EDP))
1463 pll = intel_find_shared_dpll(state, crtc,
1464 &crtc_state->dpll_hw_state,
1465 DPLL_ID_SKL_DPLL0,
1466 DPLL_ID_SKL_DPLL0);
1467 else
1468 pll = intel_find_shared_dpll(state, crtc,
1469 &crtc_state->dpll_hw_state,
1470 DPLL_ID_SKL_DPLL1,
1471 DPLL_ID_SKL_DPLL3);
1472 if (!pll)
1473 return false;
1474
1475 intel_reference_shared_dpll(state, crtc,
1476 pll, &crtc_state->dpll_hw_state);
1477
1478 crtc_state->shared_dpll = pll;
1479
1480 return true;
1481 }
1482
skl_dump_hw_state(struct drm_i915_private * dev_priv,const struct intel_dpll_hw_state * hw_state)1483 static void skl_dump_hw_state(struct drm_i915_private *dev_priv,
1484 const struct intel_dpll_hw_state *hw_state)
1485 {
1486 DRM_DEBUG_KMS("dpll_hw_state: "
1487 "ctrl1: 0x%x, cfgcr1: 0x%x, cfgcr2: 0x%x\n",
1488 hw_state->ctrl1,
1489 hw_state->cfgcr1,
1490 hw_state->cfgcr2);
1491 }
1492
1493 static const struct intel_shared_dpll_funcs skl_ddi_pll_funcs = {
1494 .enable = skl_ddi_pll_enable,
1495 .disable = skl_ddi_pll_disable,
1496 .get_hw_state = skl_ddi_pll_get_hw_state,
1497 };
1498
1499 static const struct intel_shared_dpll_funcs skl_ddi_dpll0_funcs = {
1500 .enable = skl_ddi_dpll0_enable,
1501 .disable = skl_ddi_dpll0_disable,
1502 .get_hw_state = skl_ddi_dpll0_get_hw_state,
1503 };
1504
bxt_ddi_pll_enable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)1505 static void bxt_ddi_pll_enable(struct drm_i915_private *dev_priv,
1506 struct intel_shared_dpll *pll)
1507 {
1508 u32 temp;
1509 enum port port = (enum port)pll->info->id; /* 1:1 port->PLL mapping */
1510 enum dpio_phy phy;
1511 enum dpio_channel ch;
1512
1513 bxt_port_to_phy_channel(dev_priv, port, &phy, &ch);
1514
1515 /* Non-SSC reference */
1516 temp = I915_READ(BXT_PORT_PLL_ENABLE(port));
1517 temp |= PORT_PLL_REF_SEL;
1518 I915_WRITE(BXT_PORT_PLL_ENABLE(port), temp);
1519
1520 if (IS_GEMINILAKE(dev_priv)) {
1521 temp = I915_READ(BXT_PORT_PLL_ENABLE(port));
1522 temp |= PORT_PLL_POWER_ENABLE;
1523 I915_WRITE(BXT_PORT_PLL_ENABLE(port), temp);
1524
1525 if (wait_for_us((I915_READ(BXT_PORT_PLL_ENABLE(port)) &
1526 PORT_PLL_POWER_STATE), 200))
1527 DRM_ERROR("Power state not set for PLL:%d\n", port);
1528 }
1529
1530 /* Disable 10 bit clock */
1531 temp = I915_READ(BXT_PORT_PLL_EBB_4(phy, ch));
1532 temp &= ~PORT_PLL_10BIT_CLK_ENABLE;
1533 I915_WRITE(BXT_PORT_PLL_EBB_4(phy, ch), temp);
1534
1535 /* Write P1 & P2 */
1536 temp = I915_READ(BXT_PORT_PLL_EBB_0(phy, ch));
1537 temp &= ~(PORT_PLL_P1_MASK | PORT_PLL_P2_MASK);
1538 temp |= pll->state.hw_state.ebb0;
1539 I915_WRITE(BXT_PORT_PLL_EBB_0(phy, ch), temp);
1540
1541 /* Write M2 integer */
1542 temp = I915_READ(BXT_PORT_PLL(phy, ch, 0));
1543 temp &= ~PORT_PLL_M2_MASK;
1544 temp |= pll->state.hw_state.pll0;
1545 I915_WRITE(BXT_PORT_PLL(phy, ch, 0), temp);
1546
1547 /* Write N */
1548 temp = I915_READ(BXT_PORT_PLL(phy, ch, 1));
1549 temp &= ~PORT_PLL_N_MASK;
1550 temp |= pll->state.hw_state.pll1;
1551 I915_WRITE(BXT_PORT_PLL(phy, ch, 1), temp);
1552
1553 /* Write M2 fraction */
1554 temp = I915_READ(BXT_PORT_PLL(phy, ch, 2));
1555 temp &= ~PORT_PLL_M2_FRAC_MASK;
1556 temp |= pll->state.hw_state.pll2;
1557 I915_WRITE(BXT_PORT_PLL(phy, ch, 2), temp);
1558
1559 /* Write M2 fraction enable */
1560 temp = I915_READ(BXT_PORT_PLL(phy, ch, 3));
1561 temp &= ~PORT_PLL_M2_FRAC_ENABLE;
1562 temp |= pll->state.hw_state.pll3;
1563 I915_WRITE(BXT_PORT_PLL(phy, ch, 3), temp);
1564
1565 /* Write coeff */
1566 temp = I915_READ(BXT_PORT_PLL(phy, ch, 6));
1567 temp &= ~PORT_PLL_PROP_COEFF_MASK;
1568 temp &= ~PORT_PLL_INT_COEFF_MASK;
1569 temp &= ~PORT_PLL_GAIN_CTL_MASK;
1570 temp |= pll->state.hw_state.pll6;
1571 I915_WRITE(BXT_PORT_PLL(phy, ch, 6), temp);
1572
1573 /* Write calibration val */
1574 temp = I915_READ(BXT_PORT_PLL(phy, ch, 8));
1575 temp &= ~PORT_PLL_TARGET_CNT_MASK;
1576 temp |= pll->state.hw_state.pll8;
1577 I915_WRITE(BXT_PORT_PLL(phy, ch, 8), temp);
1578
1579 temp = I915_READ(BXT_PORT_PLL(phy, ch, 9));
1580 temp &= ~PORT_PLL_LOCK_THRESHOLD_MASK;
1581 temp |= pll->state.hw_state.pll9;
1582 I915_WRITE(BXT_PORT_PLL(phy, ch, 9), temp);
1583
1584 temp = I915_READ(BXT_PORT_PLL(phy, ch, 10));
1585 temp &= ~PORT_PLL_DCO_AMP_OVR_EN_H;
1586 temp &= ~PORT_PLL_DCO_AMP_MASK;
1587 temp |= pll->state.hw_state.pll10;
1588 I915_WRITE(BXT_PORT_PLL(phy, ch, 10), temp);
1589
1590 /* Recalibrate with new settings */
1591 temp = I915_READ(BXT_PORT_PLL_EBB_4(phy, ch));
1592 temp |= PORT_PLL_RECALIBRATE;
1593 I915_WRITE(BXT_PORT_PLL_EBB_4(phy, ch), temp);
1594 temp &= ~PORT_PLL_10BIT_CLK_ENABLE;
1595 temp |= pll->state.hw_state.ebb4;
1596 I915_WRITE(BXT_PORT_PLL_EBB_4(phy, ch), temp);
1597
1598 /* Enable PLL */
1599 temp = I915_READ(BXT_PORT_PLL_ENABLE(port));
1600 temp |= PORT_PLL_ENABLE;
1601 I915_WRITE(BXT_PORT_PLL_ENABLE(port), temp);
1602 POSTING_READ(BXT_PORT_PLL_ENABLE(port));
1603
1604 if (wait_for_us((I915_READ(BXT_PORT_PLL_ENABLE(port)) & PORT_PLL_LOCK),
1605 200))
1606 DRM_ERROR("PLL %d not locked\n", port);
1607
1608 if (IS_GEMINILAKE(dev_priv)) {
1609 temp = I915_READ(BXT_PORT_TX_DW5_LN0(phy, ch));
1610 temp |= DCC_DELAY_RANGE_2;
1611 I915_WRITE(BXT_PORT_TX_DW5_GRP(phy, ch), temp);
1612 }
1613
1614 /*
1615 * While we write to the group register to program all lanes at once we
1616 * can read only lane registers and we pick lanes 0/1 for that.
1617 */
1618 temp = I915_READ(BXT_PORT_PCS_DW12_LN01(phy, ch));
1619 temp &= ~LANE_STAGGER_MASK;
1620 temp &= ~LANESTAGGER_STRAP_OVRD;
1621 temp |= pll->state.hw_state.pcsdw12;
1622 I915_WRITE(BXT_PORT_PCS_DW12_GRP(phy, ch), temp);
1623 }
1624
bxt_ddi_pll_disable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)1625 static void bxt_ddi_pll_disable(struct drm_i915_private *dev_priv,
1626 struct intel_shared_dpll *pll)
1627 {
1628 enum port port = (enum port)pll->info->id; /* 1:1 port->PLL mapping */
1629 u32 temp;
1630
1631 temp = I915_READ(BXT_PORT_PLL_ENABLE(port));
1632 temp &= ~PORT_PLL_ENABLE;
1633 I915_WRITE(BXT_PORT_PLL_ENABLE(port), temp);
1634 POSTING_READ(BXT_PORT_PLL_ENABLE(port));
1635
1636 if (IS_GEMINILAKE(dev_priv)) {
1637 temp = I915_READ(BXT_PORT_PLL_ENABLE(port));
1638 temp &= ~PORT_PLL_POWER_ENABLE;
1639 I915_WRITE(BXT_PORT_PLL_ENABLE(port), temp);
1640
1641 if (wait_for_us(!(I915_READ(BXT_PORT_PLL_ENABLE(port)) &
1642 PORT_PLL_POWER_STATE), 200))
1643 DRM_ERROR("Power state not reset for PLL:%d\n", port);
1644 }
1645 }
1646
bxt_ddi_pll_get_hw_state(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll,struct intel_dpll_hw_state * hw_state)1647 static bool bxt_ddi_pll_get_hw_state(struct drm_i915_private *dev_priv,
1648 struct intel_shared_dpll *pll,
1649 struct intel_dpll_hw_state *hw_state)
1650 {
1651 enum port port = (enum port)pll->info->id; /* 1:1 port->PLL mapping */
1652 intel_wakeref_t wakeref;
1653 enum dpio_phy phy;
1654 enum dpio_channel ch;
1655 u32 val;
1656 bool ret;
1657
1658 bxt_port_to_phy_channel(dev_priv, port, &phy, &ch);
1659
1660 wakeref = intel_display_power_get_if_enabled(dev_priv,
1661 POWER_DOMAIN_DISPLAY_CORE);
1662 if (!wakeref)
1663 return false;
1664
1665 ret = false;
1666
1667 val = I915_READ(BXT_PORT_PLL_ENABLE(port));
1668 if (!(val & PORT_PLL_ENABLE))
1669 goto out;
1670
1671 hw_state->ebb0 = I915_READ(BXT_PORT_PLL_EBB_0(phy, ch));
1672 hw_state->ebb0 &= PORT_PLL_P1_MASK | PORT_PLL_P2_MASK;
1673
1674 hw_state->ebb4 = I915_READ(BXT_PORT_PLL_EBB_4(phy, ch));
1675 hw_state->ebb4 &= PORT_PLL_10BIT_CLK_ENABLE;
1676
1677 hw_state->pll0 = I915_READ(BXT_PORT_PLL(phy, ch, 0));
1678 hw_state->pll0 &= PORT_PLL_M2_MASK;
1679
1680 hw_state->pll1 = I915_READ(BXT_PORT_PLL(phy, ch, 1));
1681 hw_state->pll1 &= PORT_PLL_N_MASK;
1682
1683 hw_state->pll2 = I915_READ(BXT_PORT_PLL(phy, ch, 2));
1684 hw_state->pll2 &= PORT_PLL_M2_FRAC_MASK;
1685
1686 hw_state->pll3 = I915_READ(BXT_PORT_PLL(phy, ch, 3));
1687 hw_state->pll3 &= PORT_PLL_M2_FRAC_ENABLE;
1688
1689 hw_state->pll6 = I915_READ(BXT_PORT_PLL(phy, ch, 6));
1690 hw_state->pll6 &= PORT_PLL_PROP_COEFF_MASK |
1691 PORT_PLL_INT_COEFF_MASK |
1692 PORT_PLL_GAIN_CTL_MASK;
1693
1694 hw_state->pll8 = I915_READ(BXT_PORT_PLL(phy, ch, 8));
1695 hw_state->pll8 &= PORT_PLL_TARGET_CNT_MASK;
1696
1697 hw_state->pll9 = I915_READ(BXT_PORT_PLL(phy, ch, 9));
1698 hw_state->pll9 &= PORT_PLL_LOCK_THRESHOLD_MASK;
1699
1700 hw_state->pll10 = I915_READ(BXT_PORT_PLL(phy, ch, 10));
1701 hw_state->pll10 &= PORT_PLL_DCO_AMP_OVR_EN_H |
1702 PORT_PLL_DCO_AMP_MASK;
1703
1704 /*
1705 * While we write to the group register to program all lanes at once we
1706 * can read only lane registers. We configure all lanes the same way, so
1707 * here just read out lanes 0/1 and output a note if lanes 2/3 differ.
1708 */
1709 hw_state->pcsdw12 = I915_READ(BXT_PORT_PCS_DW12_LN01(phy, ch));
1710 if (I915_READ(BXT_PORT_PCS_DW12_LN23(phy, ch)) != hw_state->pcsdw12)
1711 DRM_DEBUG_DRIVER("lane stagger config different for lane 01 (%08x) and 23 (%08x)\n",
1712 hw_state->pcsdw12,
1713 I915_READ(BXT_PORT_PCS_DW12_LN23(phy, ch)));
1714 hw_state->pcsdw12 &= LANE_STAGGER_MASK | LANESTAGGER_STRAP_OVRD;
1715
1716 ret = true;
1717
1718 out:
1719 intel_display_power_put(dev_priv, POWER_DOMAIN_DISPLAY_CORE, wakeref);
1720
1721 return ret;
1722 }
1723
1724 /* bxt clock parameters */
1725 struct bxt_clk_div {
1726 int clock;
1727 u32 p1;
1728 u32 p2;
1729 u32 m2_int;
1730 u32 m2_frac;
1731 bool m2_frac_en;
1732 u32 n;
1733
1734 int vco;
1735 };
1736
1737 /* pre-calculated values for DP linkrates */
1738 static const struct bxt_clk_div bxt_dp_clk_val[] = {
1739 {162000, 4, 2, 32, 1677722, 1, 1},
1740 {270000, 4, 1, 27, 0, 0, 1},
1741 {540000, 2, 1, 27, 0, 0, 1},
1742 {216000, 3, 2, 32, 1677722, 1, 1},
1743 {243000, 4, 1, 24, 1258291, 1, 1},
1744 {324000, 4, 1, 32, 1677722, 1, 1},
1745 {432000, 3, 1, 32, 1677722, 1, 1}
1746 };
1747
1748 static bool
bxt_ddi_hdmi_pll_dividers(struct intel_crtc_state * crtc_state,struct bxt_clk_div * clk_div)1749 bxt_ddi_hdmi_pll_dividers(struct intel_crtc_state *crtc_state,
1750 struct bxt_clk_div *clk_div)
1751 {
1752 struct intel_crtc *crtc = to_intel_crtc(crtc_state->base.crtc);
1753 struct dpll best_clock;
1754
1755 /* Calculate HDMI div */
1756 /*
1757 * FIXME: tie the following calculation into
1758 * i9xx_crtc_compute_clock
1759 */
1760 if (!bxt_find_best_dpll(crtc_state, &best_clock)) {
1761 DRM_DEBUG_DRIVER("no PLL dividers found for clock %d pipe %c\n",
1762 crtc_state->port_clock,
1763 pipe_name(crtc->pipe));
1764 return false;
1765 }
1766
1767 clk_div->p1 = best_clock.p1;
1768 clk_div->p2 = best_clock.p2;
1769 WARN_ON(best_clock.m1 != 2);
1770 clk_div->n = best_clock.n;
1771 clk_div->m2_int = best_clock.m2 >> 22;
1772 clk_div->m2_frac = best_clock.m2 & ((1 << 22) - 1);
1773 clk_div->m2_frac_en = clk_div->m2_frac != 0;
1774
1775 clk_div->vco = best_clock.vco;
1776
1777 return true;
1778 }
1779
bxt_ddi_dp_pll_dividers(struct intel_crtc_state * crtc_state,struct bxt_clk_div * clk_div)1780 static void bxt_ddi_dp_pll_dividers(struct intel_crtc_state *crtc_state,
1781 struct bxt_clk_div *clk_div)
1782 {
1783 int clock = crtc_state->port_clock;
1784 int i;
1785
1786 *clk_div = bxt_dp_clk_val[0];
1787 for (i = 0; i < ARRAY_SIZE(bxt_dp_clk_val); ++i) {
1788 if (bxt_dp_clk_val[i].clock == clock) {
1789 *clk_div = bxt_dp_clk_val[i];
1790 break;
1791 }
1792 }
1793
1794 clk_div->vco = clock * 10 / 2 * clk_div->p1 * clk_div->p2;
1795 }
1796
bxt_ddi_set_dpll_hw_state(struct intel_crtc_state * crtc_state,const struct bxt_clk_div * clk_div)1797 static bool bxt_ddi_set_dpll_hw_state(struct intel_crtc_state *crtc_state,
1798 const struct bxt_clk_div *clk_div)
1799 {
1800 struct intel_dpll_hw_state *dpll_hw_state = &crtc_state->dpll_hw_state;
1801 int clock = crtc_state->port_clock;
1802 int vco = clk_div->vco;
1803 u32 prop_coef, int_coef, gain_ctl, targ_cnt;
1804 u32 lanestagger;
1805
1806 memset(dpll_hw_state, 0, sizeof(*dpll_hw_state));
1807
1808 if (vco >= 6200000 && vco <= 6700000) {
1809 prop_coef = 4;
1810 int_coef = 9;
1811 gain_ctl = 3;
1812 targ_cnt = 8;
1813 } else if ((vco > 5400000 && vco < 6200000) ||
1814 (vco >= 4800000 && vco < 5400000)) {
1815 prop_coef = 5;
1816 int_coef = 11;
1817 gain_ctl = 3;
1818 targ_cnt = 9;
1819 } else if (vco == 5400000) {
1820 prop_coef = 3;
1821 int_coef = 8;
1822 gain_ctl = 1;
1823 targ_cnt = 9;
1824 } else {
1825 DRM_ERROR("Invalid VCO\n");
1826 return false;
1827 }
1828
1829 if (clock > 270000)
1830 lanestagger = 0x18;
1831 else if (clock > 135000)
1832 lanestagger = 0x0d;
1833 else if (clock > 67000)
1834 lanestagger = 0x07;
1835 else if (clock > 33000)
1836 lanestagger = 0x04;
1837 else
1838 lanestagger = 0x02;
1839
1840 dpll_hw_state->ebb0 = PORT_PLL_P1(clk_div->p1) | PORT_PLL_P2(clk_div->p2);
1841 dpll_hw_state->pll0 = clk_div->m2_int;
1842 dpll_hw_state->pll1 = PORT_PLL_N(clk_div->n);
1843 dpll_hw_state->pll2 = clk_div->m2_frac;
1844
1845 if (clk_div->m2_frac_en)
1846 dpll_hw_state->pll3 = PORT_PLL_M2_FRAC_ENABLE;
1847
1848 dpll_hw_state->pll6 = prop_coef | PORT_PLL_INT_COEFF(int_coef);
1849 dpll_hw_state->pll6 |= PORT_PLL_GAIN_CTL(gain_ctl);
1850
1851 dpll_hw_state->pll8 = targ_cnt;
1852
1853 dpll_hw_state->pll9 = 5 << PORT_PLL_LOCK_THRESHOLD_SHIFT;
1854
1855 dpll_hw_state->pll10 =
1856 PORT_PLL_DCO_AMP(PORT_PLL_DCO_AMP_DEFAULT)
1857 | PORT_PLL_DCO_AMP_OVR_EN_H;
1858
1859 dpll_hw_state->ebb4 = PORT_PLL_10BIT_CLK_ENABLE;
1860
1861 dpll_hw_state->pcsdw12 = LANESTAGGER_STRAP_OVRD | lanestagger;
1862
1863 return true;
1864 }
1865
1866 static bool
bxt_ddi_dp_set_dpll_hw_state(struct intel_crtc_state * crtc_state)1867 bxt_ddi_dp_set_dpll_hw_state(struct intel_crtc_state *crtc_state)
1868 {
1869 struct bxt_clk_div clk_div = {};
1870
1871 bxt_ddi_dp_pll_dividers(crtc_state, &clk_div);
1872
1873 return bxt_ddi_set_dpll_hw_state(crtc_state, &clk_div);
1874 }
1875
1876 static bool
bxt_ddi_hdmi_set_dpll_hw_state(struct intel_crtc_state * crtc_state)1877 bxt_ddi_hdmi_set_dpll_hw_state(struct intel_crtc_state *crtc_state)
1878 {
1879 struct bxt_clk_div clk_div = {};
1880
1881 bxt_ddi_hdmi_pll_dividers(crtc_state, &clk_div);
1882
1883 return bxt_ddi_set_dpll_hw_state(crtc_state, &clk_div);
1884 }
1885
bxt_get_dpll(struct intel_atomic_state * state,struct intel_crtc * crtc,struct intel_encoder * encoder)1886 static bool bxt_get_dpll(struct intel_atomic_state *state,
1887 struct intel_crtc *crtc,
1888 struct intel_encoder *encoder)
1889 {
1890 struct intel_crtc_state *crtc_state =
1891 intel_atomic_get_new_crtc_state(state, crtc);
1892 struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
1893 struct intel_shared_dpll *pll;
1894 enum intel_dpll_id id;
1895
1896 if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI) &&
1897 !bxt_ddi_hdmi_set_dpll_hw_state(crtc_state))
1898 return false;
1899
1900 if (intel_crtc_has_dp_encoder(crtc_state) &&
1901 !bxt_ddi_dp_set_dpll_hw_state(crtc_state))
1902 return false;
1903
1904 /* 1:1 mapping between ports and PLLs */
1905 id = (enum intel_dpll_id) encoder->port;
1906 pll = intel_get_shared_dpll_by_id(dev_priv, id);
1907
1908 DRM_DEBUG_KMS("[CRTC:%d:%s] using pre-allocated %s\n",
1909 crtc->base.base.id, crtc->base.name, pll->info->name);
1910
1911 intel_reference_shared_dpll(state, crtc,
1912 pll, &crtc_state->dpll_hw_state);
1913
1914 crtc_state->shared_dpll = pll;
1915
1916 return true;
1917 }
1918
bxt_dump_hw_state(struct drm_i915_private * dev_priv,const struct intel_dpll_hw_state * hw_state)1919 static void bxt_dump_hw_state(struct drm_i915_private *dev_priv,
1920 const struct intel_dpll_hw_state *hw_state)
1921 {
1922 DRM_DEBUG_KMS("dpll_hw_state: ebb0: 0x%x, ebb4: 0x%x,"
1923 "pll0: 0x%x, pll1: 0x%x, pll2: 0x%x, pll3: 0x%x, "
1924 "pll6: 0x%x, pll8: 0x%x, pll9: 0x%x, pll10: 0x%x, pcsdw12: 0x%x\n",
1925 hw_state->ebb0,
1926 hw_state->ebb4,
1927 hw_state->pll0,
1928 hw_state->pll1,
1929 hw_state->pll2,
1930 hw_state->pll3,
1931 hw_state->pll6,
1932 hw_state->pll8,
1933 hw_state->pll9,
1934 hw_state->pll10,
1935 hw_state->pcsdw12);
1936 }
1937
1938 static const struct intel_shared_dpll_funcs bxt_ddi_pll_funcs = {
1939 .enable = bxt_ddi_pll_enable,
1940 .disable = bxt_ddi_pll_disable,
1941 .get_hw_state = bxt_ddi_pll_get_hw_state,
1942 };
1943
1944 struct intel_dpll_mgr {
1945 const struct dpll_info *dpll_info;
1946
1947 bool (*get_dplls)(struct intel_atomic_state *state,
1948 struct intel_crtc *crtc,
1949 struct intel_encoder *encoder);
1950 void (*put_dplls)(struct intel_atomic_state *state,
1951 struct intel_crtc *crtc);
1952 void (*update_active_dpll)(struct intel_atomic_state *state,
1953 struct intel_crtc *crtc,
1954 struct intel_encoder *encoder);
1955 void (*dump_hw_state)(struct drm_i915_private *dev_priv,
1956 const struct intel_dpll_hw_state *hw_state);
1957 };
1958
1959 static const struct dpll_info pch_plls[] = {
1960 { "PCH DPLL A", &ibx_pch_dpll_funcs, DPLL_ID_PCH_PLL_A, 0 },
1961 { "PCH DPLL B", &ibx_pch_dpll_funcs, DPLL_ID_PCH_PLL_B, 0 },
1962 { },
1963 };
1964
1965 static const struct intel_dpll_mgr pch_pll_mgr = {
1966 .dpll_info = pch_plls,
1967 .get_dplls = ibx_get_dpll,
1968 .put_dplls = intel_put_dpll,
1969 .dump_hw_state = ibx_dump_hw_state,
1970 };
1971
1972 static const struct dpll_info hsw_plls[] = {
1973 { "WRPLL 1", &hsw_ddi_wrpll_funcs, DPLL_ID_WRPLL1, 0 },
1974 { "WRPLL 2", &hsw_ddi_wrpll_funcs, DPLL_ID_WRPLL2, 0 },
1975 { "SPLL", &hsw_ddi_spll_funcs, DPLL_ID_SPLL, 0 },
1976 { "LCPLL 810", &hsw_ddi_lcpll_funcs, DPLL_ID_LCPLL_810, INTEL_DPLL_ALWAYS_ON },
1977 { "LCPLL 1350", &hsw_ddi_lcpll_funcs, DPLL_ID_LCPLL_1350, INTEL_DPLL_ALWAYS_ON },
1978 { "LCPLL 2700", &hsw_ddi_lcpll_funcs, DPLL_ID_LCPLL_2700, INTEL_DPLL_ALWAYS_ON },
1979 { },
1980 };
1981
1982 static const struct intel_dpll_mgr hsw_pll_mgr = {
1983 .dpll_info = hsw_plls,
1984 .get_dplls = hsw_get_dpll,
1985 .put_dplls = intel_put_dpll,
1986 .dump_hw_state = hsw_dump_hw_state,
1987 };
1988
1989 static const struct dpll_info skl_plls[] = {
1990 { "DPLL 0", &skl_ddi_dpll0_funcs, DPLL_ID_SKL_DPLL0, INTEL_DPLL_ALWAYS_ON },
1991 { "DPLL 1", &skl_ddi_pll_funcs, DPLL_ID_SKL_DPLL1, 0 },
1992 { "DPLL 2", &skl_ddi_pll_funcs, DPLL_ID_SKL_DPLL2, 0 },
1993 { "DPLL 3", &skl_ddi_pll_funcs, DPLL_ID_SKL_DPLL3, 0 },
1994 { },
1995 };
1996
1997 static const struct intel_dpll_mgr skl_pll_mgr = {
1998 .dpll_info = skl_plls,
1999 .get_dplls = skl_get_dpll,
2000 .put_dplls = intel_put_dpll,
2001 .dump_hw_state = skl_dump_hw_state,
2002 };
2003
2004 static const struct dpll_info bxt_plls[] = {
2005 { "PORT PLL A", &bxt_ddi_pll_funcs, DPLL_ID_SKL_DPLL0, 0 },
2006 { "PORT PLL B", &bxt_ddi_pll_funcs, DPLL_ID_SKL_DPLL1, 0 },
2007 { "PORT PLL C", &bxt_ddi_pll_funcs, DPLL_ID_SKL_DPLL2, 0 },
2008 { },
2009 };
2010
2011 static const struct intel_dpll_mgr bxt_pll_mgr = {
2012 .dpll_info = bxt_plls,
2013 .get_dplls = bxt_get_dpll,
2014 .put_dplls = intel_put_dpll,
2015 .dump_hw_state = bxt_dump_hw_state,
2016 };
2017
cnl_ddi_pll_enable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)2018 static void cnl_ddi_pll_enable(struct drm_i915_private *dev_priv,
2019 struct intel_shared_dpll *pll)
2020 {
2021 const enum intel_dpll_id id = pll->info->id;
2022 u32 val;
2023
2024 /* 1. Enable DPLL power in DPLL_ENABLE. */
2025 val = I915_READ(CNL_DPLL_ENABLE(id));
2026 val |= PLL_POWER_ENABLE;
2027 I915_WRITE(CNL_DPLL_ENABLE(id), val);
2028
2029 /* 2. Wait for DPLL power state enabled in DPLL_ENABLE. */
2030 if (intel_de_wait_for_set(dev_priv, CNL_DPLL_ENABLE(id),
2031 PLL_POWER_STATE, 5))
2032 DRM_ERROR("PLL %d Power not enabled\n", id);
2033
2034 /*
2035 * 3. Configure DPLL_CFGCR0 to set SSC enable/disable,
2036 * select DP mode, and set DP link rate.
2037 */
2038 val = pll->state.hw_state.cfgcr0;
2039 I915_WRITE(CNL_DPLL_CFGCR0(id), val);
2040
2041 /* 4. Reab back to ensure writes completed */
2042 POSTING_READ(CNL_DPLL_CFGCR0(id));
2043
2044 /* 3. Configure DPLL_CFGCR0 */
2045 /* Avoid touch CFGCR1 if HDMI mode is not enabled */
2046 if (pll->state.hw_state.cfgcr0 & DPLL_CFGCR0_HDMI_MODE) {
2047 val = pll->state.hw_state.cfgcr1;
2048 I915_WRITE(CNL_DPLL_CFGCR1(id), val);
2049 /* 4. Reab back to ensure writes completed */
2050 POSTING_READ(CNL_DPLL_CFGCR1(id));
2051 }
2052
2053 /*
2054 * 5. If the frequency will result in a change to the voltage
2055 * requirement, follow the Display Voltage Frequency Switching
2056 * Sequence Before Frequency Change
2057 *
2058 * Note: DVFS is actually handled via the cdclk code paths,
2059 * hence we do nothing here.
2060 */
2061
2062 /* 6. Enable DPLL in DPLL_ENABLE. */
2063 val = I915_READ(CNL_DPLL_ENABLE(id));
2064 val |= PLL_ENABLE;
2065 I915_WRITE(CNL_DPLL_ENABLE(id), val);
2066
2067 /* 7. Wait for PLL lock status in DPLL_ENABLE. */
2068 if (intel_de_wait_for_set(dev_priv, CNL_DPLL_ENABLE(id), PLL_LOCK, 5))
2069 DRM_ERROR("PLL %d not locked\n", id);
2070
2071 /*
2072 * 8. If the frequency will result in a change to the voltage
2073 * requirement, follow the Display Voltage Frequency Switching
2074 * Sequence After Frequency Change
2075 *
2076 * Note: DVFS is actually handled via the cdclk code paths,
2077 * hence we do nothing here.
2078 */
2079
2080 /*
2081 * 9. turn on the clock for the DDI and map the DPLL to the DDI
2082 * Done at intel_ddi_clk_select
2083 */
2084 }
2085
cnl_ddi_pll_disable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)2086 static void cnl_ddi_pll_disable(struct drm_i915_private *dev_priv,
2087 struct intel_shared_dpll *pll)
2088 {
2089 const enum intel_dpll_id id = pll->info->id;
2090 u32 val;
2091
2092 /*
2093 * 1. Configure DPCLKA_CFGCR0 to turn off the clock for the DDI.
2094 * Done at intel_ddi_post_disable
2095 */
2096
2097 /*
2098 * 2. If the frequency will result in a change to the voltage
2099 * requirement, follow the Display Voltage Frequency Switching
2100 * Sequence Before Frequency Change
2101 *
2102 * Note: DVFS is actually handled via the cdclk code paths,
2103 * hence we do nothing here.
2104 */
2105
2106 /* 3. Disable DPLL through DPLL_ENABLE. */
2107 val = I915_READ(CNL_DPLL_ENABLE(id));
2108 val &= ~PLL_ENABLE;
2109 I915_WRITE(CNL_DPLL_ENABLE(id), val);
2110
2111 /* 4. Wait for PLL not locked status in DPLL_ENABLE. */
2112 if (intel_de_wait_for_clear(dev_priv, CNL_DPLL_ENABLE(id), PLL_LOCK, 5))
2113 DRM_ERROR("PLL %d locked\n", id);
2114
2115 /*
2116 * 5. If the frequency will result in a change to the voltage
2117 * requirement, follow the Display Voltage Frequency Switching
2118 * Sequence After Frequency Change
2119 *
2120 * Note: DVFS is actually handled via the cdclk code paths,
2121 * hence we do nothing here.
2122 */
2123
2124 /* 6. Disable DPLL power in DPLL_ENABLE. */
2125 val = I915_READ(CNL_DPLL_ENABLE(id));
2126 val &= ~PLL_POWER_ENABLE;
2127 I915_WRITE(CNL_DPLL_ENABLE(id), val);
2128
2129 /* 7. Wait for DPLL power state disabled in DPLL_ENABLE. */
2130 if (intel_de_wait_for_clear(dev_priv, CNL_DPLL_ENABLE(id),
2131 PLL_POWER_STATE, 5))
2132 DRM_ERROR("PLL %d Power not disabled\n", id);
2133 }
2134
cnl_ddi_pll_get_hw_state(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll,struct intel_dpll_hw_state * hw_state)2135 static bool cnl_ddi_pll_get_hw_state(struct drm_i915_private *dev_priv,
2136 struct intel_shared_dpll *pll,
2137 struct intel_dpll_hw_state *hw_state)
2138 {
2139 const enum intel_dpll_id id = pll->info->id;
2140 intel_wakeref_t wakeref;
2141 u32 val;
2142 bool ret;
2143
2144 wakeref = intel_display_power_get_if_enabled(dev_priv,
2145 POWER_DOMAIN_DISPLAY_CORE);
2146 if (!wakeref)
2147 return false;
2148
2149 ret = false;
2150
2151 val = I915_READ(CNL_DPLL_ENABLE(id));
2152 if (!(val & PLL_ENABLE))
2153 goto out;
2154
2155 val = I915_READ(CNL_DPLL_CFGCR0(id));
2156 hw_state->cfgcr0 = val;
2157
2158 /* avoid reading back stale values if HDMI mode is not enabled */
2159 if (val & DPLL_CFGCR0_HDMI_MODE) {
2160 hw_state->cfgcr1 = I915_READ(CNL_DPLL_CFGCR1(id));
2161 }
2162 ret = true;
2163
2164 out:
2165 intel_display_power_put(dev_priv, POWER_DOMAIN_DISPLAY_CORE, wakeref);
2166
2167 return ret;
2168 }
2169
cnl_wrpll_get_multipliers(int bestdiv,int * pdiv,int * qdiv,int * kdiv)2170 static void cnl_wrpll_get_multipliers(int bestdiv, int *pdiv,
2171 int *qdiv, int *kdiv)
2172 {
2173 /* even dividers */
2174 if (bestdiv % 2 == 0) {
2175 if (bestdiv == 2) {
2176 *pdiv = 2;
2177 *qdiv = 1;
2178 *kdiv = 1;
2179 } else if (bestdiv % 4 == 0) {
2180 *pdiv = 2;
2181 *qdiv = bestdiv / 4;
2182 *kdiv = 2;
2183 } else if (bestdiv % 6 == 0) {
2184 *pdiv = 3;
2185 *qdiv = bestdiv / 6;
2186 *kdiv = 2;
2187 } else if (bestdiv % 5 == 0) {
2188 *pdiv = 5;
2189 *qdiv = bestdiv / 10;
2190 *kdiv = 2;
2191 } else if (bestdiv % 14 == 0) {
2192 *pdiv = 7;
2193 *qdiv = bestdiv / 14;
2194 *kdiv = 2;
2195 }
2196 } else {
2197 if (bestdiv == 3 || bestdiv == 5 || bestdiv == 7) {
2198 *pdiv = bestdiv;
2199 *qdiv = 1;
2200 *kdiv = 1;
2201 } else { /* 9, 15, 21 */
2202 *pdiv = bestdiv / 3;
2203 *qdiv = 1;
2204 *kdiv = 3;
2205 }
2206 }
2207 }
2208
cnl_wrpll_params_populate(struct skl_wrpll_params * params,u32 dco_freq,u32 ref_freq,int pdiv,int qdiv,int kdiv)2209 static void cnl_wrpll_params_populate(struct skl_wrpll_params *params,
2210 u32 dco_freq, u32 ref_freq,
2211 int pdiv, int qdiv, int kdiv)
2212 {
2213 u32 dco;
2214
2215 switch (kdiv) {
2216 case 1:
2217 params->kdiv = 1;
2218 break;
2219 case 2:
2220 params->kdiv = 2;
2221 break;
2222 case 3:
2223 params->kdiv = 4;
2224 break;
2225 default:
2226 WARN(1, "Incorrect KDiv\n");
2227 }
2228
2229 switch (pdiv) {
2230 case 2:
2231 params->pdiv = 1;
2232 break;
2233 case 3:
2234 params->pdiv = 2;
2235 break;
2236 case 5:
2237 params->pdiv = 4;
2238 break;
2239 case 7:
2240 params->pdiv = 8;
2241 break;
2242 default:
2243 WARN(1, "Incorrect PDiv\n");
2244 }
2245
2246 WARN_ON(kdiv != 2 && qdiv != 1);
2247
2248 params->qdiv_ratio = qdiv;
2249 params->qdiv_mode = (qdiv == 1) ? 0 : 1;
2250
2251 dco = div_u64((u64)dco_freq << 15, ref_freq);
2252
2253 params->dco_integer = dco >> 15;
2254 params->dco_fraction = dco & 0x7fff;
2255 }
2256
cnl_hdmi_pll_ref_clock(struct drm_i915_private * dev_priv)2257 int cnl_hdmi_pll_ref_clock(struct drm_i915_private *dev_priv)
2258 {
2259 int ref_clock = dev_priv->cdclk.hw.ref;
2260
2261 /*
2262 * For ICL+, the spec states: if reference frequency is 38.4,
2263 * use 19.2 because the DPLL automatically divides that by 2.
2264 */
2265 if (INTEL_GEN(dev_priv) >= 11 && ref_clock == 38400)
2266 ref_clock = 19200;
2267
2268 return ref_clock;
2269 }
2270
2271 static bool
cnl_ddi_calculate_wrpll(struct intel_crtc_state * crtc_state,struct skl_wrpll_params * wrpll_params)2272 cnl_ddi_calculate_wrpll(struct intel_crtc_state *crtc_state,
2273 struct skl_wrpll_params *wrpll_params)
2274 {
2275 struct drm_i915_private *dev_priv = to_i915(crtc_state->base.crtc->dev);
2276 u32 afe_clock = crtc_state->port_clock * 5;
2277 u32 ref_clock;
2278 u32 dco_min = 7998000;
2279 u32 dco_max = 10000000;
2280 u32 dco_mid = (dco_min + dco_max) / 2;
2281 static const int dividers[] = { 2, 4, 6, 8, 10, 12, 14, 16,
2282 18, 20, 24, 28, 30, 32, 36, 40,
2283 42, 44, 48, 50, 52, 54, 56, 60,
2284 64, 66, 68, 70, 72, 76, 78, 80,
2285 84, 88, 90, 92, 96, 98, 100, 102,
2286 3, 5, 7, 9, 15, 21 };
2287 u32 dco, best_dco = 0, dco_centrality = 0;
2288 u32 best_dco_centrality = U32_MAX; /* Spec meaning of 999999 MHz */
2289 int d, best_div = 0, pdiv = 0, qdiv = 0, kdiv = 0;
2290
2291 for (d = 0; d < ARRAY_SIZE(dividers); d++) {
2292 dco = afe_clock * dividers[d];
2293
2294 if ((dco <= dco_max) && (dco >= dco_min)) {
2295 dco_centrality = abs(dco - dco_mid);
2296
2297 if (dco_centrality < best_dco_centrality) {
2298 best_dco_centrality = dco_centrality;
2299 best_div = dividers[d];
2300 best_dco = dco;
2301 }
2302 }
2303 }
2304
2305 if (best_div == 0)
2306 return false;
2307
2308 cnl_wrpll_get_multipliers(best_div, &pdiv, &qdiv, &kdiv);
2309
2310 ref_clock = cnl_hdmi_pll_ref_clock(dev_priv);
2311
2312 cnl_wrpll_params_populate(wrpll_params, best_dco, ref_clock,
2313 pdiv, qdiv, kdiv);
2314
2315 return true;
2316 }
2317
cnl_ddi_hdmi_pll_dividers(struct intel_crtc_state * crtc_state)2318 static bool cnl_ddi_hdmi_pll_dividers(struct intel_crtc_state *crtc_state)
2319 {
2320 u32 cfgcr0, cfgcr1;
2321 struct skl_wrpll_params wrpll_params = { 0, };
2322
2323 cfgcr0 = DPLL_CFGCR0_HDMI_MODE;
2324
2325 if (!cnl_ddi_calculate_wrpll(crtc_state, &wrpll_params))
2326 return false;
2327
2328 cfgcr0 |= DPLL_CFGCR0_DCO_FRACTION(wrpll_params.dco_fraction) |
2329 wrpll_params.dco_integer;
2330
2331 cfgcr1 = DPLL_CFGCR1_QDIV_RATIO(wrpll_params.qdiv_ratio) |
2332 DPLL_CFGCR1_QDIV_MODE(wrpll_params.qdiv_mode) |
2333 DPLL_CFGCR1_KDIV(wrpll_params.kdiv) |
2334 DPLL_CFGCR1_PDIV(wrpll_params.pdiv) |
2335 DPLL_CFGCR1_CENTRAL_FREQ;
2336
2337 memset(&crtc_state->dpll_hw_state, 0,
2338 sizeof(crtc_state->dpll_hw_state));
2339
2340 crtc_state->dpll_hw_state.cfgcr0 = cfgcr0;
2341 crtc_state->dpll_hw_state.cfgcr1 = cfgcr1;
2342 return true;
2343 }
2344
2345 static bool
cnl_ddi_dp_set_dpll_hw_state(struct intel_crtc_state * crtc_state)2346 cnl_ddi_dp_set_dpll_hw_state(struct intel_crtc_state *crtc_state)
2347 {
2348 u32 cfgcr0;
2349
2350 cfgcr0 = DPLL_CFGCR0_SSC_ENABLE;
2351
2352 switch (crtc_state->port_clock / 2) {
2353 case 81000:
2354 cfgcr0 |= DPLL_CFGCR0_LINK_RATE_810;
2355 break;
2356 case 135000:
2357 cfgcr0 |= DPLL_CFGCR0_LINK_RATE_1350;
2358 break;
2359 case 270000:
2360 cfgcr0 |= DPLL_CFGCR0_LINK_RATE_2700;
2361 break;
2362 /* eDP 1.4 rates */
2363 case 162000:
2364 cfgcr0 |= DPLL_CFGCR0_LINK_RATE_1620;
2365 break;
2366 case 108000:
2367 cfgcr0 |= DPLL_CFGCR0_LINK_RATE_1080;
2368 break;
2369 case 216000:
2370 cfgcr0 |= DPLL_CFGCR0_LINK_RATE_2160;
2371 break;
2372 case 324000:
2373 /* Some SKUs may require elevated I/O voltage to support this */
2374 cfgcr0 |= DPLL_CFGCR0_LINK_RATE_3240;
2375 break;
2376 case 405000:
2377 /* Some SKUs may require elevated I/O voltage to support this */
2378 cfgcr0 |= DPLL_CFGCR0_LINK_RATE_4050;
2379 break;
2380 }
2381
2382 memset(&crtc_state->dpll_hw_state, 0,
2383 sizeof(crtc_state->dpll_hw_state));
2384
2385 crtc_state->dpll_hw_state.cfgcr0 = cfgcr0;
2386
2387 return true;
2388 }
2389
cnl_get_dpll(struct intel_atomic_state * state,struct intel_crtc * crtc,struct intel_encoder * encoder)2390 static bool cnl_get_dpll(struct intel_atomic_state *state,
2391 struct intel_crtc *crtc,
2392 struct intel_encoder *encoder)
2393 {
2394 struct intel_crtc_state *crtc_state =
2395 intel_atomic_get_new_crtc_state(state, crtc);
2396 struct intel_shared_dpll *pll;
2397 bool bret;
2398
2399 if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI)) {
2400 bret = cnl_ddi_hdmi_pll_dividers(crtc_state);
2401 if (!bret) {
2402 DRM_DEBUG_KMS("Could not get HDMI pll dividers.\n");
2403 return false;
2404 }
2405 } else if (intel_crtc_has_dp_encoder(crtc_state)) {
2406 bret = cnl_ddi_dp_set_dpll_hw_state(crtc_state);
2407 if (!bret) {
2408 DRM_DEBUG_KMS("Could not set DP dpll HW state.\n");
2409 return false;
2410 }
2411 } else {
2412 DRM_DEBUG_KMS("Skip DPLL setup for output_types 0x%x\n",
2413 crtc_state->output_types);
2414 return false;
2415 }
2416
2417 pll = intel_find_shared_dpll(state, crtc,
2418 &crtc_state->dpll_hw_state,
2419 DPLL_ID_SKL_DPLL0,
2420 DPLL_ID_SKL_DPLL2);
2421 if (!pll) {
2422 DRM_DEBUG_KMS("No PLL selected\n");
2423 return false;
2424 }
2425
2426 intel_reference_shared_dpll(state, crtc,
2427 pll, &crtc_state->dpll_hw_state);
2428
2429 crtc_state->shared_dpll = pll;
2430
2431 return true;
2432 }
2433
cnl_dump_hw_state(struct drm_i915_private * dev_priv,const struct intel_dpll_hw_state * hw_state)2434 static void cnl_dump_hw_state(struct drm_i915_private *dev_priv,
2435 const struct intel_dpll_hw_state *hw_state)
2436 {
2437 DRM_DEBUG_KMS("dpll_hw_state: "
2438 "cfgcr0: 0x%x, cfgcr1: 0x%x\n",
2439 hw_state->cfgcr0,
2440 hw_state->cfgcr1);
2441 }
2442
2443 static const struct intel_shared_dpll_funcs cnl_ddi_pll_funcs = {
2444 .enable = cnl_ddi_pll_enable,
2445 .disable = cnl_ddi_pll_disable,
2446 .get_hw_state = cnl_ddi_pll_get_hw_state,
2447 };
2448
2449 static const struct dpll_info cnl_plls[] = {
2450 { "DPLL 0", &cnl_ddi_pll_funcs, DPLL_ID_SKL_DPLL0, 0 },
2451 { "DPLL 1", &cnl_ddi_pll_funcs, DPLL_ID_SKL_DPLL1, 0 },
2452 { "DPLL 2", &cnl_ddi_pll_funcs, DPLL_ID_SKL_DPLL2, 0 },
2453 { },
2454 };
2455
2456 static const struct intel_dpll_mgr cnl_pll_mgr = {
2457 .dpll_info = cnl_plls,
2458 .get_dplls = cnl_get_dpll,
2459 .put_dplls = intel_put_dpll,
2460 .dump_hw_state = cnl_dump_hw_state,
2461 };
2462
2463 struct icl_combo_pll_params {
2464 int clock;
2465 struct skl_wrpll_params wrpll;
2466 };
2467
2468 /*
2469 * These values alrea already adjusted: they're the bits we write to the
2470 * registers, not the logical values.
2471 */
2472 static const struct icl_combo_pll_params icl_dp_combo_pll_24MHz_values[] = {
2473 { 540000,
2474 { .dco_integer = 0x151, .dco_fraction = 0x4000, /* [0]: 5.4 */
2475 .pdiv = 0x2 /* 3 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2476 { 270000,
2477 { .dco_integer = 0x151, .dco_fraction = 0x4000, /* [1]: 2.7 */
2478 .pdiv = 0x2 /* 3 */, .kdiv = 2, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2479 { 162000,
2480 { .dco_integer = 0x151, .dco_fraction = 0x4000, /* [2]: 1.62 */
2481 .pdiv = 0x4 /* 5 */, .kdiv = 2, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2482 { 324000,
2483 { .dco_integer = 0x151, .dco_fraction = 0x4000, /* [3]: 3.24 */
2484 .pdiv = 0x4 /* 5 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2485 { 216000,
2486 { .dco_integer = 0x168, .dco_fraction = 0x0000, /* [4]: 2.16 */
2487 .pdiv = 0x1 /* 2 */, .kdiv = 2, .qdiv_mode = 1, .qdiv_ratio = 2, }, },
2488 { 432000,
2489 { .dco_integer = 0x168, .dco_fraction = 0x0000, /* [5]: 4.32 */
2490 .pdiv = 0x1 /* 2 */, .kdiv = 2, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2491 { 648000,
2492 { .dco_integer = 0x195, .dco_fraction = 0x0000, /* [6]: 6.48 */
2493 .pdiv = 0x2 /* 3 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2494 { 810000,
2495 { .dco_integer = 0x151, .dco_fraction = 0x4000, /* [7]: 8.1 */
2496 .pdiv = 0x1 /* 2 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2497 };
2498
2499
2500 /* Also used for 38.4 MHz values. */
2501 static const struct icl_combo_pll_params icl_dp_combo_pll_19_2MHz_values[] = {
2502 { 540000,
2503 { .dco_integer = 0x1A5, .dco_fraction = 0x7000, /* [0]: 5.4 */
2504 .pdiv = 0x2 /* 3 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2505 { 270000,
2506 { .dco_integer = 0x1A5, .dco_fraction = 0x7000, /* [1]: 2.7 */
2507 .pdiv = 0x2 /* 3 */, .kdiv = 2, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2508 { 162000,
2509 { .dco_integer = 0x1A5, .dco_fraction = 0x7000, /* [2]: 1.62 */
2510 .pdiv = 0x4 /* 5 */, .kdiv = 2, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2511 { 324000,
2512 { .dco_integer = 0x1A5, .dco_fraction = 0x7000, /* [3]: 3.24 */
2513 .pdiv = 0x4 /* 5 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2514 { 216000,
2515 { .dco_integer = 0x1C2, .dco_fraction = 0x0000, /* [4]: 2.16 */
2516 .pdiv = 0x1 /* 2 */, .kdiv = 2, .qdiv_mode = 1, .qdiv_ratio = 2, }, },
2517 { 432000,
2518 { .dco_integer = 0x1C2, .dco_fraction = 0x0000, /* [5]: 4.32 */
2519 .pdiv = 0x1 /* 2 */, .kdiv = 2, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2520 { 648000,
2521 { .dco_integer = 0x1FA, .dco_fraction = 0x2000, /* [6]: 6.48 */
2522 .pdiv = 0x2 /* 3 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2523 { 810000,
2524 { .dco_integer = 0x1A5, .dco_fraction = 0x7000, /* [7]: 8.1 */
2525 .pdiv = 0x1 /* 2 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0, }, },
2526 };
2527
2528 static const struct skl_wrpll_params icl_tbt_pll_24MHz_values = {
2529 .dco_integer = 0x151, .dco_fraction = 0x4000,
2530 .pdiv = 0x4 /* 5 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0,
2531 };
2532
2533 static const struct skl_wrpll_params icl_tbt_pll_19_2MHz_values = {
2534 .dco_integer = 0x1A5, .dco_fraction = 0x7000,
2535 .pdiv = 0x4 /* 5 */, .kdiv = 1, .qdiv_mode = 0, .qdiv_ratio = 0,
2536 };
2537
icl_calc_dp_combo_pll(struct intel_crtc_state * crtc_state,struct skl_wrpll_params * pll_params)2538 static bool icl_calc_dp_combo_pll(struct intel_crtc_state *crtc_state,
2539 struct skl_wrpll_params *pll_params)
2540 {
2541 struct drm_i915_private *dev_priv = to_i915(crtc_state->base.crtc->dev);
2542 const struct icl_combo_pll_params *params =
2543 dev_priv->cdclk.hw.ref == 24000 ?
2544 icl_dp_combo_pll_24MHz_values :
2545 icl_dp_combo_pll_19_2MHz_values;
2546 int clock = crtc_state->port_clock;
2547 int i;
2548
2549 for (i = 0; i < ARRAY_SIZE(icl_dp_combo_pll_24MHz_values); i++) {
2550 if (clock == params[i].clock) {
2551 *pll_params = params[i].wrpll;
2552 return true;
2553 }
2554 }
2555
2556 MISSING_CASE(clock);
2557 return false;
2558 }
2559
icl_calc_tbt_pll(struct intel_crtc_state * crtc_state,struct skl_wrpll_params * pll_params)2560 static bool icl_calc_tbt_pll(struct intel_crtc_state *crtc_state,
2561 struct skl_wrpll_params *pll_params)
2562 {
2563 struct drm_i915_private *dev_priv = to_i915(crtc_state->base.crtc->dev);
2564
2565 *pll_params = dev_priv->cdclk.hw.ref == 24000 ?
2566 icl_tbt_pll_24MHz_values : icl_tbt_pll_19_2MHz_values;
2567 return true;
2568 }
2569
icl_calc_dpll_state(struct intel_crtc_state * crtc_state,struct intel_encoder * encoder,struct intel_dpll_hw_state * pll_state)2570 static bool icl_calc_dpll_state(struct intel_crtc_state *crtc_state,
2571 struct intel_encoder *encoder,
2572 struct intel_dpll_hw_state *pll_state)
2573 {
2574 struct drm_i915_private *dev_priv = to_i915(crtc_state->base.crtc->dev);
2575 u32 cfgcr0, cfgcr1;
2576 struct skl_wrpll_params pll_params = { 0 };
2577 bool ret;
2578
2579 if (intel_phy_is_tc(dev_priv, intel_port_to_phy(dev_priv,
2580 encoder->port)))
2581 ret = icl_calc_tbt_pll(crtc_state, &pll_params);
2582 else if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI) ||
2583 intel_crtc_has_type(crtc_state, INTEL_OUTPUT_DSI))
2584 ret = cnl_ddi_calculate_wrpll(crtc_state, &pll_params);
2585 else
2586 ret = icl_calc_dp_combo_pll(crtc_state, &pll_params);
2587
2588 if (!ret)
2589 return false;
2590
2591 cfgcr0 = DPLL_CFGCR0_DCO_FRACTION(pll_params.dco_fraction) |
2592 pll_params.dco_integer;
2593
2594 cfgcr1 = DPLL_CFGCR1_QDIV_RATIO(pll_params.qdiv_ratio) |
2595 DPLL_CFGCR1_QDIV_MODE(pll_params.qdiv_mode) |
2596 DPLL_CFGCR1_KDIV(pll_params.kdiv) |
2597 DPLL_CFGCR1_PDIV(pll_params.pdiv);
2598
2599 if (INTEL_GEN(dev_priv) >= 12)
2600 cfgcr1 |= TGL_DPLL_CFGCR1_CFSELOVRD_NORMAL_XTAL;
2601 else
2602 cfgcr1 |= DPLL_CFGCR1_CENTRAL_FREQ_8400;
2603
2604 memset(pll_state, 0, sizeof(*pll_state));
2605
2606 pll_state->cfgcr0 = cfgcr0;
2607 pll_state->cfgcr1 = cfgcr1;
2608
2609 return true;
2610 }
2611
2612
icl_pll_id_to_tc_port(enum intel_dpll_id id)2613 static enum tc_port icl_pll_id_to_tc_port(enum intel_dpll_id id)
2614 {
2615 return id - DPLL_ID_ICL_MGPLL1;
2616 }
2617
icl_tc_port_to_pll_id(enum tc_port tc_port)2618 enum intel_dpll_id icl_tc_port_to_pll_id(enum tc_port tc_port)
2619 {
2620 return tc_port + DPLL_ID_ICL_MGPLL1;
2621 }
2622
icl_mg_pll_find_divisors(int clock_khz,bool is_dp,bool use_ssc,u32 * target_dco_khz,struct intel_dpll_hw_state * state)2623 static bool icl_mg_pll_find_divisors(int clock_khz, bool is_dp, bool use_ssc,
2624 u32 *target_dco_khz,
2625 struct intel_dpll_hw_state *state)
2626 {
2627 u32 dco_min_freq, dco_max_freq;
2628 int div1_vals[] = {7, 5, 3, 2};
2629 unsigned int i;
2630 int div2;
2631
2632 dco_min_freq = is_dp ? 8100000 : use_ssc ? 8000000 : 7992000;
2633 dco_max_freq = is_dp ? 8100000 : 10000000;
2634
2635 for (i = 0; i < ARRAY_SIZE(div1_vals); i++) {
2636 int div1 = div1_vals[i];
2637
2638 for (div2 = 10; div2 > 0; div2--) {
2639 int dco = div1 * div2 * clock_khz * 5;
2640 int a_divratio, tlinedrv, inputsel;
2641 u32 hsdiv;
2642
2643 if (dco < dco_min_freq || dco > dco_max_freq)
2644 continue;
2645
2646 if (div2 >= 2) {
2647 a_divratio = is_dp ? 10 : 5;
2648 tlinedrv = 2;
2649 } else {
2650 a_divratio = 5;
2651 tlinedrv = 0;
2652 }
2653 inputsel = is_dp ? 0 : 1;
2654
2655 switch (div1) {
2656 default:
2657 MISSING_CASE(div1);
2658 /* fall through */
2659 case 2:
2660 hsdiv = MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_2;
2661 break;
2662 case 3:
2663 hsdiv = MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_3;
2664 break;
2665 case 5:
2666 hsdiv = MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_5;
2667 break;
2668 case 7:
2669 hsdiv = MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_7;
2670 break;
2671 }
2672
2673 *target_dco_khz = dco;
2674
2675 state->mg_refclkin_ctl = MG_REFCLKIN_CTL_OD_2_MUX(1);
2676
2677 state->mg_clktop2_coreclkctl1 =
2678 MG_CLKTOP2_CORECLKCTL1_A_DIVRATIO(a_divratio);
2679
2680 state->mg_clktop2_hsclkctl =
2681 MG_CLKTOP2_HSCLKCTL_TLINEDRV_CLKSEL(tlinedrv) |
2682 MG_CLKTOP2_HSCLKCTL_CORE_INPUTSEL(inputsel) |
2683 hsdiv |
2684 MG_CLKTOP2_HSCLKCTL_DSDIV_RATIO(div2);
2685
2686 return true;
2687 }
2688 }
2689
2690 return false;
2691 }
2692
2693 /*
2694 * The specification for this function uses real numbers, so the math had to be
2695 * adapted to integer-only calculation, that's why it looks so different.
2696 */
icl_calc_mg_pll_state(struct intel_crtc_state * crtc_state,struct intel_dpll_hw_state * pll_state)2697 static bool icl_calc_mg_pll_state(struct intel_crtc_state *crtc_state,
2698 struct intel_dpll_hw_state *pll_state)
2699 {
2700 struct drm_i915_private *dev_priv = to_i915(crtc_state->base.crtc->dev);
2701 int refclk_khz = dev_priv->cdclk.hw.ref;
2702 int clock = crtc_state->port_clock;
2703 u32 dco_khz, m1div, m2div_int, m2div_rem, m2div_frac;
2704 u32 iref_ndiv, iref_trim, iref_pulse_w;
2705 u32 prop_coeff, int_coeff;
2706 u32 tdc_targetcnt, feedfwgain;
2707 u64 ssc_stepsize, ssc_steplen, ssc_steplog;
2708 u64 tmp;
2709 bool use_ssc = false;
2710 bool is_dp = !intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI);
2711
2712 memset(pll_state, 0, sizeof(*pll_state));
2713
2714 if (!icl_mg_pll_find_divisors(clock, is_dp, use_ssc, &dco_khz,
2715 pll_state)) {
2716 DRM_DEBUG_KMS("Failed to find divisors for clock %d\n", clock);
2717 return false;
2718 }
2719
2720 m1div = 2;
2721 m2div_int = dco_khz / (refclk_khz * m1div);
2722 if (m2div_int > 255) {
2723 m1div = 4;
2724 m2div_int = dco_khz / (refclk_khz * m1div);
2725 if (m2div_int > 255) {
2726 DRM_DEBUG_KMS("Failed to find mdiv for clock %d\n",
2727 clock);
2728 return false;
2729 }
2730 }
2731 m2div_rem = dco_khz % (refclk_khz * m1div);
2732
2733 tmp = (u64)m2div_rem * (1 << 22);
2734 do_div(tmp, refclk_khz * m1div);
2735 m2div_frac = tmp;
2736
2737 switch (refclk_khz) {
2738 case 19200:
2739 iref_ndiv = 1;
2740 iref_trim = 28;
2741 iref_pulse_w = 1;
2742 break;
2743 case 24000:
2744 iref_ndiv = 1;
2745 iref_trim = 25;
2746 iref_pulse_w = 2;
2747 break;
2748 case 38400:
2749 iref_ndiv = 2;
2750 iref_trim = 28;
2751 iref_pulse_w = 1;
2752 break;
2753 default:
2754 MISSING_CASE(refclk_khz);
2755 return false;
2756 }
2757
2758 /*
2759 * tdc_res = 0.000003
2760 * tdc_targetcnt = int(2 / (tdc_res * 8 * 50 * 1.1) / refclk_mhz + 0.5)
2761 *
2762 * The multiplication by 1000 is due to refclk MHz to KHz conversion. It
2763 * was supposed to be a division, but we rearranged the operations of
2764 * the formula to avoid early divisions so we don't multiply the
2765 * rounding errors.
2766 *
2767 * 0.000003 * 8 * 50 * 1.1 = 0.00132, also known as 132 / 100000, which
2768 * we also rearrange to work with integers.
2769 *
2770 * The 0.5 transformed to 5 results in a multiplication by 10 and the
2771 * last division by 10.
2772 */
2773 tdc_targetcnt = (2 * 1000 * 100000 * 10 / (132 * refclk_khz) + 5) / 10;
2774
2775 /*
2776 * Here we divide dco_khz by 10 in order to allow the dividend to fit in
2777 * 32 bits. That's not a problem since we round the division down
2778 * anyway.
2779 */
2780 feedfwgain = (use_ssc || m2div_rem > 0) ?
2781 m1div * 1000000 * 100 / (dco_khz * 3 / 10) : 0;
2782
2783 if (dco_khz >= 9000000) {
2784 prop_coeff = 5;
2785 int_coeff = 10;
2786 } else {
2787 prop_coeff = 4;
2788 int_coeff = 8;
2789 }
2790
2791 if (use_ssc) {
2792 tmp = mul_u32_u32(dco_khz, 47 * 32);
2793 do_div(tmp, refclk_khz * m1div * 10000);
2794 ssc_stepsize = tmp;
2795
2796 tmp = mul_u32_u32(dco_khz, 1000);
2797 ssc_steplen = DIV_ROUND_UP_ULL(tmp, 32 * 2 * 32);
2798 } else {
2799 ssc_stepsize = 0;
2800 ssc_steplen = 0;
2801 }
2802 ssc_steplog = 4;
2803
2804 pll_state->mg_pll_div0 = (m2div_rem > 0 ? MG_PLL_DIV0_FRACNEN_H : 0) |
2805 MG_PLL_DIV0_FBDIV_FRAC(m2div_frac) |
2806 MG_PLL_DIV0_FBDIV_INT(m2div_int);
2807
2808 pll_state->mg_pll_div1 = MG_PLL_DIV1_IREF_NDIVRATIO(iref_ndiv) |
2809 MG_PLL_DIV1_DITHER_DIV_2 |
2810 MG_PLL_DIV1_NDIVRATIO(1) |
2811 MG_PLL_DIV1_FBPREDIV(m1div);
2812
2813 pll_state->mg_pll_lf = MG_PLL_LF_TDCTARGETCNT(tdc_targetcnt) |
2814 MG_PLL_LF_AFCCNTSEL_512 |
2815 MG_PLL_LF_GAINCTRL(1) |
2816 MG_PLL_LF_INT_COEFF(int_coeff) |
2817 MG_PLL_LF_PROP_COEFF(prop_coeff);
2818
2819 pll_state->mg_pll_frac_lock = MG_PLL_FRAC_LOCK_TRUELOCK_CRIT_32 |
2820 MG_PLL_FRAC_LOCK_EARLYLOCK_CRIT_32 |
2821 MG_PLL_FRAC_LOCK_LOCKTHRESH(10) |
2822 MG_PLL_FRAC_LOCK_DCODITHEREN |
2823 MG_PLL_FRAC_LOCK_FEEDFWRDGAIN(feedfwgain);
2824 if (use_ssc || m2div_rem > 0)
2825 pll_state->mg_pll_frac_lock |= MG_PLL_FRAC_LOCK_FEEDFWRDCAL_EN;
2826
2827 pll_state->mg_pll_ssc = (use_ssc ? MG_PLL_SSC_EN : 0) |
2828 MG_PLL_SSC_TYPE(2) |
2829 MG_PLL_SSC_STEPLENGTH(ssc_steplen) |
2830 MG_PLL_SSC_STEPNUM(ssc_steplog) |
2831 MG_PLL_SSC_FLLEN |
2832 MG_PLL_SSC_STEPSIZE(ssc_stepsize);
2833
2834 pll_state->mg_pll_tdc_coldst_bias = MG_PLL_TDC_COLDST_COLDSTART |
2835 MG_PLL_TDC_COLDST_IREFINT_EN |
2836 MG_PLL_TDC_COLDST_REFBIAS_START_PULSE_W(iref_pulse_w) |
2837 MG_PLL_TDC_TDCOVCCORR_EN |
2838 MG_PLL_TDC_TDCSEL(3);
2839
2840 pll_state->mg_pll_bias = MG_PLL_BIAS_BIAS_GB_SEL(3) |
2841 MG_PLL_BIAS_INIT_DCOAMP(0x3F) |
2842 MG_PLL_BIAS_BIAS_BONUS(10) |
2843 MG_PLL_BIAS_BIASCAL_EN |
2844 MG_PLL_BIAS_CTRIM(12) |
2845 MG_PLL_BIAS_VREF_RDAC(4) |
2846 MG_PLL_BIAS_IREFTRIM(iref_trim);
2847
2848 if (refclk_khz == 38400) {
2849 pll_state->mg_pll_tdc_coldst_bias_mask = MG_PLL_TDC_COLDST_COLDSTART;
2850 pll_state->mg_pll_bias_mask = 0;
2851 } else {
2852 pll_state->mg_pll_tdc_coldst_bias_mask = -1U;
2853 pll_state->mg_pll_bias_mask = -1U;
2854 }
2855
2856 pll_state->mg_pll_tdc_coldst_bias &= pll_state->mg_pll_tdc_coldst_bias_mask;
2857 pll_state->mg_pll_bias &= pll_state->mg_pll_bias_mask;
2858
2859 return true;
2860 }
2861
2862 /**
2863 * icl_set_active_port_dpll - select the active port DPLL for a given CRTC
2864 * @crtc_state: state for the CRTC to select the DPLL for
2865 * @port_dpll_id: the active @port_dpll_id to select
2866 *
2867 * Select the given @port_dpll_id instance from the DPLLs reserved for the
2868 * CRTC.
2869 */
icl_set_active_port_dpll(struct intel_crtc_state * crtc_state,enum icl_port_dpll_id port_dpll_id)2870 void icl_set_active_port_dpll(struct intel_crtc_state *crtc_state,
2871 enum icl_port_dpll_id port_dpll_id)
2872 {
2873 struct icl_port_dpll *port_dpll =
2874 &crtc_state->icl_port_dplls[port_dpll_id];
2875
2876 crtc_state->shared_dpll = port_dpll->pll;
2877 crtc_state->dpll_hw_state = port_dpll->hw_state;
2878 }
2879
icl_update_active_dpll(struct intel_atomic_state * state,struct intel_crtc * crtc,struct intel_encoder * encoder)2880 static void icl_update_active_dpll(struct intel_atomic_state *state,
2881 struct intel_crtc *crtc,
2882 struct intel_encoder *encoder)
2883 {
2884 struct intel_crtc_state *crtc_state =
2885 intel_atomic_get_new_crtc_state(state, crtc);
2886 struct intel_digital_port *primary_port;
2887 enum icl_port_dpll_id port_dpll_id = ICL_PORT_DPLL_DEFAULT;
2888
2889 primary_port = encoder->type == INTEL_OUTPUT_DP_MST ?
2890 enc_to_mst(&encoder->base)->primary :
2891 enc_to_dig_port(&encoder->base);
2892
2893 if (primary_port &&
2894 (primary_port->tc_mode == TC_PORT_DP_ALT ||
2895 primary_port->tc_mode == TC_PORT_LEGACY))
2896 port_dpll_id = ICL_PORT_DPLL_MG_PHY;
2897
2898 icl_set_active_port_dpll(crtc_state, port_dpll_id);
2899 }
2900
icl_get_combo_phy_dpll(struct intel_atomic_state * state,struct intel_crtc * crtc,struct intel_encoder * encoder)2901 static bool icl_get_combo_phy_dpll(struct intel_atomic_state *state,
2902 struct intel_crtc *crtc,
2903 struct intel_encoder *encoder)
2904 {
2905 struct intel_crtc_state *crtc_state =
2906 intel_atomic_get_new_crtc_state(state, crtc);
2907 struct icl_port_dpll *port_dpll =
2908 &crtc_state->icl_port_dplls[ICL_PORT_DPLL_DEFAULT];
2909 struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
2910 enum port port = encoder->port;
2911 bool has_dpll4 = false;
2912
2913 if (!icl_calc_dpll_state(crtc_state, encoder, &port_dpll->hw_state)) {
2914 DRM_DEBUG_KMS("Could not calculate combo PHY PLL state.\n");
2915
2916 return false;
2917 }
2918
2919 if (IS_ELKHARTLAKE(dev_priv) && port != PORT_A)
2920 has_dpll4 = true;
2921
2922 port_dpll->pll = intel_find_shared_dpll(state, crtc,
2923 &port_dpll->hw_state,
2924 DPLL_ID_ICL_DPLL0,
2925 has_dpll4 ? DPLL_ID_EHL_DPLL4
2926 : DPLL_ID_ICL_DPLL1);
2927 if (!port_dpll->pll) {
2928 DRM_DEBUG_KMS("No combo PHY PLL found for port %c\n",
2929 port_name(encoder->port));
2930 return false;
2931 }
2932
2933 intel_reference_shared_dpll(state, crtc,
2934 port_dpll->pll, &port_dpll->hw_state);
2935
2936 icl_update_active_dpll(state, crtc, encoder);
2937
2938 return true;
2939 }
2940
icl_get_tc_phy_dplls(struct intel_atomic_state * state,struct intel_crtc * crtc,struct intel_encoder * encoder)2941 static bool icl_get_tc_phy_dplls(struct intel_atomic_state *state,
2942 struct intel_crtc *crtc,
2943 struct intel_encoder *encoder)
2944 {
2945 struct drm_i915_private *dev_priv = to_i915(state->base.dev);
2946 struct intel_crtc_state *crtc_state =
2947 intel_atomic_get_new_crtc_state(state, crtc);
2948 struct icl_port_dpll *port_dpll;
2949 enum intel_dpll_id dpll_id;
2950
2951 port_dpll = &crtc_state->icl_port_dplls[ICL_PORT_DPLL_DEFAULT];
2952 if (!icl_calc_dpll_state(crtc_state, encoder, &port_dpll->hw_state)) {
2953 DRM_DEBUG_KMS("Could not calculate TBT PLL state.\n");
2954 return false;
2955 }
2956
2957 port_dpll->pll = intel_find_shared_dpll(state, crtc,
2958 &port_dpll->hw_state,
2959 DPLL_ID_ICL_TBTPLL,
2960 DPLL_ID_ICL_TBTPLL);
2961 if (!port_dpll->pll) {
2962 DRM_DEBUG_KMS("No TBT-ALT PLL found\n");
2963 return false;
2964 }
2965 intel_reference_shared_dpll(state, crtc,
2966 port_dpll->pll, &port_dpll->hw_state);
2967
2968
2969 port_dpll = &crtc_state->icl_port_dplls[ICL_PORT_DPLL_MG_PHY];
2970 if (!icl_calc_mg_pll_state(crtc_state, &port_dpll->hw_state)) {
2971 DRM_DEBUG_KMS("Could not calculate MG PHY PLL state.\n");
2972 goto err_unreference_tbt_pll;
2973 }
2974
2975 dpll_id = icl_tc_port_to_pll_id(intel_port_to_tc(dev_priv,
2976 encoder->port));
2977 port_dpll->pll = intel_find_shared_dpll(state, crtc,
2978 &port_dpll->hw_state,
2979 dpll_id,
2980 dpll_id);
2981 if (!port_dpll->pll) {
2982 DRM_DEBUG_KMS("No MG PHY PLL found\n");
2983 goto err_unreference_tbt_pll;
2984 }
2985 intel_reference_shared_dpll(state, crtc,
2986 port_dpll->pll, &port_dpll->hw_state);
2987
2988 icl_update_active_dpll(state, crtc, encoder);
2989
2990 return true;
2991
2992 err_unreference_tbt_pll:
2993 port_dpll = &crtc_state->icl_port_dplls[ICL_PORT_DPLL_DEFAULT];
2994 intel_unreference_shared_dpll(state, crtc, port_dpll->pll);
2995
2996 return false;
2997 }
2998
icl_get_dplls(struct intel_atomic_state * state,struct intel_crtc * crtc,struct intel_encoder * encoder)2999 static bool icl_get_dplls(struct intel_atomic_state *state,
3000 struct intel_crtc *crtc,
3001 struct intel_encoder *encoder)
3002 {
3003 struct drm_i915_private *dev_priv = to_i915(state->base.dev);
3004 enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
3005
3006 if (intel_phy_is_combo(dev_priv, phy))
3007 return icl_get_combo_phy_dpll(state, crtc, encoder);
3008 else if (intel_phy_is_tc(dev_priv, phy))
3009 return icl_get_tc_phy_dplls(state, crtc, encoder);
3010
3011 MISSING_CASE(phy);
3012
3013 return false;
3014 }
3015
icl_put_dplls(struct intel_atomic_state * state,struct intel_crtc * crtc)3016 static void icl_put_dplls(struct intel_atomic_state *state,
3017 struct intel_crtc *crtc)
3018 {
3019 const struct intel_crtc_state *old_crtc_state =
3020 intel_atomic_get_old_crtc_state(state, crtc);
3021 struct intel_crtc_state *new_crtc_state =
3022 intel_atomic_get_new_crtc_state(state, crtc);
3023 enum icl_port_dpll_id id;
3024
3025 new_crtc_state->shared_dpll = NULL;
3026
3027 for (id = ICL_PORT_DPLL_DEFAULT; id < ICL_PORT_DPLL_COUNT; id++) {
3028 const struct icl_port_dpll *old_port_dpll =
3029 &old_crtc_state->icl_port_dplls[id];
3030 struct icl_port_dpll *new_port_dpll =
3031 &new_crtc_state->icl_port_dplls[id];
3032
3033 new_port_dpll->pll = NULL;
3034
3035 if (!old_port_dpll->pll)
3036 continue;
3037
3038 intel_unreference_shared_dpll(state, crtc, old_port_dpll->pll);
3039 }
3040 }
3041
mg_pll_get_hw_state(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll,struct intel_dpll_hw_state * hw_state)3042 static bool mg_pll_get_hw_state(struct drm_i915_private *dev_priv,
3043 struct intel_shared_dpll *pll,
3044 struct intel_dpll_hw_state *hw_state)
3045 {
3046 const enum intel_dpll_id id = pll->info->id;
3047 enum tc_port tc_port = icl_pll_id_to_tc_port(id);
3048 intel_wakeref_t wakeref;
3049 bool ret = false;
3050 u32 val;
3051
3052 wakeref = intel_display_power_get_if_enabled(dev_priv,
3053 POWER_DOMAIN_DISPLAY_CORE);
3054 if (!wakeref)
3055 return false;
3056
3057 val = I915_READ(MG_PLL_ENABLE(tc_port));
3058 if (!(val & PLL_ENABLE))
3059 goto out;
3060
3061 hw_state->mg_refclkin_ctl = I915_READ(MG_REFCLKIN_CTL(tc_port));
3062 hw_state->mg_refclkin_ctl &= MG_REFCLKIN_CTL_OD_2_MUX_MASK;
3063
3064 hw_state->mg_clktop2_coreclkctl1 =
3065 I915_READ(MG_CLKTOP2_CORECLKCTL1(tc_port));
3066 hw_state->mg_clktop2_coreclkctl1 &=
3067 MG_CLKTOP2_CORECLKCTL1_A_DIVRATIO_MASK;
3068
3069 hw_state->mg_clktop2_hsclkctl =
3070 I915_READ(MG_CLKTOP2_HSCLKCTL(tc_port));
3071 hw_state->mg_clktop2_hsclkctl &=
3072 MG_CLKTOP2_HSCLKCTL_TLINEDRV_CLKSEL_MASK |
3073 MG_CLKTOP2_HSCLKCTL_CORE_INPUTSEL_MASK |
3074 MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_MASK |
3075 MG_CLKTOP2_HSCLKCTL_DSDIV_RATIO_MASK;
3076
3077 hw_state->mg_pll_div0 = I915_READ(MG_PLL_DIV0(tc_port));
3078 hw_state->mg_pll_div1 = I915_READ(MG_PLL_DIV1(tc_port));
3079 hw_state->mg_pll_lf = I915_READ(MG_PLL_LF(tc_port));
3080 hw_state->mg_pll_frac_lock = I915_READ(MG_PLL_FRAC_LOCK(tc_port));
3081 hw_state->mg_pll_ssc = I915_READ(MG_PLL_SSC(tc_port));
3082
3083 hw_state->mg_pll_bias = I915_READ(MG_PLL_BIAS(tc_port));
3084 hw_state->mg_pll_tdc_coldst_bias =
3085 I915_READ(MG_PLL_TDC_COLDST_BIAS(tc_port));
3086
3087 if (dev_priv->cdclk.hw.ref == 38400) {
3088 hw_state->mg_pll_tdc_coldst_bias_mask = MG_PLL_TDC_COLDST_COLDSTART;
3089 hw_state->mg_pll_bias_mask = 0;
3090 } else {
3091 hw_state->mg_pll_tdc_coldst_bias_mask = -1U;
3092 hw_state->mg_pll_bias_mask = -1U;
3093 }
3094
3095 hw_state->mg_pll_tdc_coldst_bias &= hw_state->mg_pll_tdc_coldst_bias_mask;
3096 hw_state->mg_pll_bias &= hw_state->mg_pll_bias_mask;
3097
3098 ret = true;
3099 out:
3100 intel_display_power_put(dev_priv, POWER_DOMAIN_DISPLAY_CORE, wakeref);
3101 return ret;
3102 }
3103
icl_pll_get_hw_state(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll,struct intel_dpll_hw_state * hw_state,i915_reg_t enable_reg)3104 static bool icl_pll_get_hw_state(struct drm_i915_private *dev_priv,
3105 struct intel_shared_dpll *pll,
3106 struct intel_dpll_hw_state *hw_state,
3107 i915_reg_t enable_reg)
3108 {
3109 const enum intel_dpll_id id = pll->info->id;
3110 intel_wakeref_t wakeref;
3111 bool ret = false;
3112 u32 val;
3113
3114 wakeref = intel_display_power_get_if_enabled(dev_priv,
3115 POWER_DOMAIN_DISPLAY_CORE);
3116 if (!wakeref)
3117 return false;
3118
3119 val = I915_READ(enable_reg);
3120 if (!(val & PLL_ENABLE))
3121 goto out;
3122
3123 if (INTEL_GEN(dev_priv) >= 12) {
3124 hw_state->cfgcr0 = I915_READ(TGL_DPLL_CFGCR0(id));
3125 hw_state->cfgcr1 = I915_READ(TGL_DPLL_CFGCR1(id));
3126 } else {
3127 if (IS_ELKHARTLAKE(dev_priv) && id == DPLL_ID_EHL_DPLL4) {
3128 hw_state->cfgcr0 = I915_READ(ICL_DPLL_CFGCR0(4));
3129 hw_state->cfgcr1 = I915_READ(ICL_DPLL_CFGCR1(4));
3130 } else {
3131 hw_state->cfgcr0 = I915_READ(ICL_DPLL_CFGCR0(id));
3132 hw_state->cfgcr1 = I915_READ(ICL_DPLL_CFGCR1(id));
3133 }
3134 }
3135
3136 ret = true;
3137 out:
3138 intel_display_power_put(dev_priv, POWER_DOMAIN_DISPLAY_CORE, wakeref);
3139 return ret;
3140 }
3141
combo_pll_get_hw_state(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll,struct intel_dpll_hw_state * hw_state)3142 static bool combo_pll_get_hw_state(struct drm_i915_private *dev_priv,
3143 struct intel_shared_dpll *pll,
3144 struct intel_dpll_hw_state *hw_state)
3145 {
3146 i915_reg_t enable_reg = CNL_DPLL_ENABLE(pll->info->id);
3147
3148 if (IS_ELKHARTLAKE(dev_priv) &&
3149 pll->info->id == DPLL_ID_EHL_DPLL4) {
3150 enable_reg = MG_PLL_ENABLE(0);
3151 }
3152
3153 return icl_pll_get_hw_state(dev_priv, pll, hw_state, enable_reg);
3154 }
3155
tbt_pll_get_hw_state(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll,struct intel_dpll_hw_state * hw_state)3156 static bool tbt_pll_get_hw_state(struct drm_i915_private *dev_priv,
3157 struct intel_shared_dpll *pll,
3158 struct intel_dpll_hw_state *hw_state)
3159 {
3160 return icl_pll_get_hw_state(dev_priv, pll, hw_state, TBT_PLL_ENABLE);
3161 }
3162
icl_dpll_write(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)3163 static void icl_dpll_write(struct drm_i915_private *dev_priv,
3164 struct intel_shared_dpll *pll)
3165 {
3166 struct intel_dpll_hw_state *hw_state = &pll->state.hw_state;
3167 const enum intel_dpll_id id = pll->info->id;
3168 i915_reg_t cfgcr0_reg, cfgcr1_reg;
3169
3170 if (INTEL_GEN(dev_priv) >= 12) {
3171 cfgcr0_reg = TGL_DPLL_CFGCR0(id);
3172 cfgcr1_reg = TGL_DPLL_CFGCR1(id);
3173 } else {
3174 if (IS_ELKHARTLAKE(dev_priv) && id == DPLL_ID_EHL_DPLL4) {
3175 cfgcr0_reg = ICL_DPLL_CFGCR0(4);
3176 cfgcr1_reg = ICL_DPLL_CFGCR1(4);
3177 } else {
3178 cfgcr0_reg = ICL_DPLL_CFGCR0(id);
3179 cfgcr1_reg = ICL_DPLL_CFGCR1(id);
3180 }
3181 }
3182
3183 I915_WRITE(cfgcr0_reg, hw_state->cfgcr0);
3184 I915_WRITE(cfgcr1_reg, hw_state->cfgcr1);
3185 POSTING_READ(cfgcr1_reg);
3186 }
3187
icl_mg_pll_write(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)3188 static void icl_mg_pll_write(struct drm_i915_private *dev_priv,
3189 struct intel_shared_dpll *pll)
3190 {
3191 struct intel_dpll_hw_state *hw_state = &pll->state.hw_state;
3192 enum tc_port tc_port = icl_pll_id_to_tc_port(pll->info->id);
3193 u32 val;
3194
3195 /*
3196 * Some of the following registers have reserved fields, so program
3197 * these with RMW based on a mask. The mask can be fixed or generated
3198 * during the calc/readout phase if the mask depends on some other HW
3199 * state like refclk, see icl_calc_mg_pll_state().
3200 */
3201 val = I915_READ(MG_REFCLKIN_CTL(tc_port));
3202 val &= ~MG_REFCLKIN_CTL_OD_2_MUX_MASK;
3203 val |= hw_state->mg_refclkin_ctl;
3204 I915_WRITE(MG_REFCLKIN_CTL(tc_port), val);
3205
3206 val = I915_READ(MG_CLKTOP2_CORECLKCTL1(tc_port));
3207 val &= ~MG_CLKTOP2_CORECLKCTL1_A_DIVRATIO_MASK;
3208 val |= hw_state->mg_clktop2_coreclkctl1;
3209 I915_WRITE(MG_CLKTOP2_CORECLKCTL1(tc_port), val);
3210
3211 val = I915_READ(MG_CLKTOP2_HSCLKCTL(tc_port));
3212 val &= ~(MG_CLKTOP2_HSCLKCTL_TLINEDRV_CLKSEL_MASK |
3213 MG_CLKTOP2_HSCLKCTL_CORE_INPUTSEL_MASK |
3214 MG_CLKTOP2_HSCLKCTL_HSDIV_RATIO_MASK |
3215 MG_CLKTOP2_HSCLKCTL_DSDIV_RATIO_MASK);
3216 val |= hw_state->mg_clktop2_hsclkctl;
3217 I915_WRITE(MG_CLKTOP2_HSCLKCTL(tc_port), val);
3218
3219 I915_WRITE(MG_PLL_DIV0(tc_port), hw_state->mg_pll_div0);
3220 I915_WRITE(MG_PLL_DIV1(tc_port), hw_state->mg_pll_div1);
3221 I915_WRITE(MG_PLL_LF(tc_port), hw_state->mg_pll_lf);
3222 I915_WRITE(MG_PLL_FRAC_LOCK(tc_port), hw_state->mg_pll_frac_lock);
3223 I915_WRITE(MG_PLL_SSC(tc_port), hw_state->mg_pll_ssc);
3224
3225 val = I915_READ(MG_PLL_BIAS(tc_port));
3226 val &= ~hw_state->mg_pll_bias_mask;
3227 val |= hw_state->mg_pll_bias;
3228 I915_WRITE(MG_PLL_BIAS(tc_port), val);
3229
3230 val = I915_READ(MG_PLL_TDC_COLDST_BIAS(tc_port));
3231 val &= ~hw_state->mg_pll_tdc_coldst_bias_mask;
3232 val |= hw_state->mg_pll_tdc_coldst_bias;
3233 I915_WRITE(MG_PLL_TDC_COLDST_BIAS(tc_port), val);
3234
3235 POSTING_READ(MG_PLL_TDC_COLDST_BIAS(tc_port));
3236 }
3237
icl_pll_power_enable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll,i915_reg_t enable_reg)3238 static void icl_pll_power_enable(struct drm_i915_private *dev_priv,
3239 struct intel_shared_dpll *pll,
3240 i915_reg_t enable_reg)
3241 {
3242 u32 val;
3243
3244 val = I915_READ(enable_reg);
3245 val |= PLL_POWER_ENABLE;
3246 I915_WRITE(enable_reg, val);
3247
3248 /*
3249 * The spec says we need to "wait" but it also says it should be
3250 * immediate.
3251 */
3252 if (intel_de_wait_for_set(dev_priv, enable_reg, PLL_POWER_STATE, 1))
3253 DRM_ERROR("PLL %d Power not enabled\n", pll->info->id);
3254 }
3255
icl_pll_enable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll,i915_reg_t enable_reg)3256 static void icl_pll_enable(struct drm_i915_private *dev_priv,
3257 struct intel_shared_dpll *pll,
3258 i915_reg_t enable_reg)
3259 {
3260 u32 val;
3261
3262 val = I915_READ(enable_reg);
3263 val |= PLL_ENABLE;
3264 I915_WRITE(enable_reg, val);
3265
3266 /* Timeout is actually 600us. */
3267 if (intel_de_wait_for_set(dev_priv, enable_reg, PLL_LOCK, 1))
3268 DRM_ERROR("PLL %d not locked\n", pll->info->id);
3269 }
3270
combo_pll_enable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)3271 static void combo_pll_enable(struct drm_i915_private *dev_priv,
3272 struct intel_shared_dpll *pll)
3273 {
3274 i915_reg_t enable_reg = CNL_DPLL_ENABLE(pll->info->id);
3275
3276 if (IS_ELKHARTLAKE(dev_priv) &&
3277 pll->info->id == DPLL_ID_EHL_DPLL4) {
3278 enable_reg = MG_PLL_ENABLE(0);
3279
3280 /*
3281 * We need to disable DC states when this DPLL is enabled.
3282 * This can be done by taking a reference on DPLL4 power
3283 * domain.
3284 */
3285 pll->wakeref = intel_display_power_get(dev_priv,
3286 POWER_DOMAIN_DPLL_DC_OFF);
3287 }
3288
3289 icl_pll_power_enable(dev_priv, pll, enable_reg);
3290
3291 icl_dpll_write(dev_priv, pll);
3292
3293 /*
3294 * DVFS pre sequence would be here, but in our driver the cdclk code
3295 * paths should already be setting the appropriate voltage, hence we do
3296 * nothing here.
3297 */
3298
3299 icl_pll_enable(dev_priv, pll, enable_reg);
3300
3301 /* DVFS post sequence would be here. See the comment above. */
3302 }
3303
tbt_pll_enable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)3304 static void tbt_pll_enable(struct drm_i915_private *dev_priv,
3305 struct intel_shared_dpll *pll)
3306 {
3307 icl_pll_power_enable(dev_priv, pll, TBT_PLL_ENABLE);
3308
3309 icl_dpll_write(dev_priv, pll);
3310
3311 /*
3312 * DVFS pre sequence would be here, but in our driver the cdclk code
3313 * paths should already be setting the appropriate voltage, hence we do
3314 * nothing here.
3315 */
3316
3317 icl_pll_enable(dev_priv, pll, TBT_PLL_ENABLE);
3318
3319 /* DVFS post sequence would be here. See the comment above. */
3320 }
3321
mg_pll_enable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)3322 static void mg_pll_enable(struct drm_i915_private *dev_priv,
3323 struct intel_shared_dpll *pll)
3324 {
3325 i915_reg_t enable_reg =
3326 MG_PLL_ENABLE(icl_pll_id_to_tc_port(pll->info->id));
3327
3328 icl_pll_power_enable(dev_priv, pll, enable_reg);
3329
3330 icl_mg_pll_write(dev_priv, pll);
3331
3332 /*
3333 * DVFS pre sequence would be here, but in our driver the cdclk code
3334 * paths should already be setting the appropriate voltage, hence we do
3335 * nothing here.
3336 */
3337
3338 icl_pll_enable(dev_priv, pll, enable_reg);
3339
3340 /* DVFS post sequence would be here. See the comment above. */
3341 }
3342
icl_pll_disable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll,i915_reg_t enable_reg)3343 static void icl_pll_disable(struct drm_i915_private *dev_priv,
3344 struct intel_shared_dpll *pll,
3345 i915_reg_t enable_reg)
3346 {
3347 u32 val;
3348
3349 /* The first steps are done by intel_ddi_post_disable(). */
3350
3351 /*
3352 * DVFS pre sequence would be here, but in our driver the cdclk code
3353 * paths should already be setting the appropriate voltage, hence we do
3354 * nothign here.
3355 */
3356
3357 val = I915_READ(enable_reg);
3358 val &= ~PLL_ENABLE;
3359 I915_WRITE(enable_reg, val);
3360
3361 /* Timeout is actually 1us. */
3362 if (intel_de_wait_for_clear(dev_priv, enable_reg, PLL_LOCK, 1))
3363 DRM_ERROR("PLL %d locked\n", pll->info->id);
3364
3365 /* DVFS post sequence would be here. See the comment above. */
3366
3367 val = I915_READ(enable_reg);
3368 val &= ~PLL_POWER_ENABLE;
3369 I915_WRITE(enable_reg, val);
3370
3371 /*
3372 * The spec says we need to "wait" but it also says it should be
3373 * immediate.
3374 */
3375 if (intel_de_wait_for_clear(dev_priv, enable_reg, PLL_POWER_STATE, 1))
3376 DRM_ERROR("PLL %d Power not disabled\n", pll->info->id);
3377 }
3378
combo_pll_disable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)3379 static void combo_pll_disable(struct drm_i915_private *dev_priv,
3380 struct intel_shared_dpll *pll)
3381 {
3382 i915_reg_t enable_reg = CNL_DPLL_ENABLE(pll->info->id);
3383
3384 if (IS_ELKHARTLAKE(dev_priv) &&
3385 pll->info->id == DPLL_ID_EHL_DPLL4) {
3386 enable_reg = MG_PLL_ENABLE(0);
3387 icl_pll_disable(dev_priv, pll, enable_reg);
3388
3389 intel_display_power_put(dev_priv, POWER_DOMAIN_DPLL_DC_OFF,
3390 pll->wakeref);
3391 return;
3392 }
3393
3394 icl_pll_disable(dev_priv, pll, enable_reg);
3395 }
3396
tbt_pll_disable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)3397 static void tbt_pll_disable(struct drm_i915_private *dev_priv,
3398 struct intel_shared_dpll *pll)
3399 {
3400 icl_pll_disable(dev_priv, pll, TBT_PLL_ENABLE);
3401 }
3402
mg_pll_disable(struct drm_i915_private * dev_priv,struct intel_shared_dpll * pll)3403 static void mg_pll_disable(struct drm_i915_private *dev_priv,
3404 struct intel_shared_dpll *pll)
3405 {
3406 i915_reg_t enable_reg =
3407 MG_PLL_ENABLE(icl_pll_id_to_tc_port(pll->info->id));
3408
3409 icl_pll_disable(dev_priv, pll, enable_reg);
3410 }
3411
icl_dump_hw_state(struct drm_i915_private * dev_priv,const struct intel_dpll_hw_state * hw_state)3412 static void icl_dump_hw_state(struct drm_i915_private *dev_priv,
3413 const struct intel_dpll_hw_state *hw_state)
3414 {
3415 DRM_DEBUG_KMS("dpll_hw_state: cfgcr0: 0x%x, cfgcr1: 0x%x, "
3416 "mg_refclkin_ctl: 0x%x, hg_clktop2_coreclkctl1: 0x%x, "
3417 "mg_clktop2_hsclkctl: 0x%x, mg_pll_div0: 0x%x, "
3418 "mg_pll_div2: 0x%x, mg_pll_lf: 0x%x, "
3419 "mg_pll_frac_lock: 0x%x, mg_pll_ssc: 0x%x, "
3420 "mg_pll_bias: 0x%x, mg_pll_tdc_coldst_bias: 0x%x\n",
3421 hw_state->cfgcr0, hw_state->cfgcr1,
3422 hw_state->mg_refclkin_ctl,
3423 hw_state->mg_clktop2_coreclkctl1,
3424 hw_state->mg_clktop2_hsclkctl,
3425 hw_state->mg_pll_div0,
3426 hw_state->mg_pll_div1,
3427 hw_state->mg_pll_lf,
3428 hw_state->mg_pll_frac_lock,
3429 hw_state->mg_pll_ssc,
3430 hw_state->mg_pll_bias,
3431 hw_state->mg_pll_tdc_coldst_bias);
3432 }
3433
3434 static const struct intel_shared_dpll_funcs combo_pll_funcs = {
3435 .enable = combo_pll_enable,
3436 .disable = combo_pll_disable,
3437 .get_hw_state = combo_pll_get_hw_state,
3438 };
3439
3440 static const struct intel_shared_dpll_funcs tbt_pll_funcs = {
3441 .enable = tbt_pll_enable,
3442 .disable = tbt_pll_disable,
3443 .get_hw_state = tbt_pll_get_hw_state,
3444 };
3445
3446 static const struct intel_shared_dpll_funcs mg_pll_funcs = {
3447 .enable = mg_pll_enable,
3448 .disable = mg_pll_disable,
3449 .get_hw_state = mg_pll_get_hw_state,
3450 };
3451
3452 static const struct dpll_info icl_plls[] = {
3453 { "DPLL 0", &combo_pll_funcs, DPLL_ID_ICL_DPLL0, 0 },
3454 { "DPLL 1", &combo_pll_funcs, DPLL_ID_ICL_DPLL1, 0 },
3455 { "TBT PLL", &tbt_pll_funcs, DPLL_ID_ICL_TBTPLL, 0 },
3456 { "MG PLL 1", &mg_pll_funcs, DPLL_ID_ICL_MGPLL1, 0 },
3457 { "MG PLL 2", &mg_pll_funcs, DPLL_ID_ICL_MGPLL2, 0 },
3458 { "MG PLL 3", &mg_pll_funcs, DPLL_ID_ICL_MGPLL3, 0 },
3459 { "MG PLL 4", &mg_pll_funcs, DPLL_ID_ICL_MGPLL4, 0 },
3460 { },
3461 };
3462
3463 static const struct intel_dpll_mgr icl_pll_mgr = {
3464 .dpll_info = icl_plls,
3465 .get_dplls = icl_get_dplls,
3466 .put_dplls = icl_put_dplls,
3467 .update_active_dpll = icl_update_active_dpll,
3468 .dump_hw_state = icl_dump_hw_state,
3469 };
3470
3471 static const struct dpll_info ehl_plls[] = {
3472 { "DPLL 0", &combo_pll_funcs, DPLL_ID_ICL_DPLL0, 0 },
3473 { "DPLL 1", &combo_pll_funcs, DPLL_ID_ICL_DPLL1, 0 },
3474 { "DPLL 4", &combo_pll_funcs, DPLL_ID_EHL_DPLL4, 0 },
3475 { },
3476 };
3477
3478 static const struct intel_dpll_mgr ehl_pll_mgr = {
3479 .dpll_info = ehl_plls,
3480 .get_dplls = icl_get_dplls,
3481 .put_dplls = icl_put_dplls,
3482 .dump_hw_state = icl_dump_hw_state,
3483 };
3484
3485 static const struct dpll_info tgl_plls[] = {
3486 { "DPLL 0", &combo_pll_funcs, DPLL_ID_ICL_DPLL0, 0 },
3487 { "DPLL 1", &combo_pll_funcs, DPLL_ID_ICL_DPLL1, 0 },
3488 { "TBT PLL", &tbt_pll_funcs, DPLL_ID_ICL_TBTPLL, 0 },
3489 /* TODO: Add typeC plls */
3490 { },
3491 };
3492
3493 static const struct intel_dpll_mgr tgl_pll_mgr = {
3494 .dpll_info = tgl_plls,
3495 .get_dplls = icl_get_dplls,
3496 .put_dplls = icl_put_dplls,
3497 .dump_hw_state = icl_dump_hw_state,
3498 };
3499
3500 /**
3501 * intel_shared_dpll_init - Initialize shared DPLLs
3502 * @dev: drm device
3503 *
3504 * Initialize shared DPLLs for @dev.
3505 */
intel_shared_dpll_init(struct drm_device * dev)3506 void intel_shared_dpll_init(struct drm_device *dev)
3507 {
3508 struct drm_i915_private *dev_priv = to_i915(dev);
3509 const struct intel_dpll_mgr *dpll_mgr = NULL;
3510 const struct dpll_info *dpll_info;
3511 int i;
3512
3513 if (INTEL_GEN(dev_priv) >= 12)
3514 dpll_mgr = &tgl_pll_mgr;
3515 else if (IS_ELKHARTLAKE(dev_priv))
3516 dpll_mgr = &ehl_pll_mgr;
3517 else if (INTEL_GEN(dev_priv) >= 11)
3518 dpll_mgr = &icl_pll_mgr;
3519 else if (IS_CANNONLAKE(dev_priv))
3520 dpll_mgr = &cnl_pll_mgr;
3521 else if (IS_GEN9_BC(dev_priv))
3522 dpll_mgr = &skl_pll_mgr;
3523 else if (IS_GEN9_LP(dev_priv))
3524 dpll_mgr = &bxt_pll_mgr;
3525 else if (HAS_DDI(dev_priv))
3526 dpll_mgr = &hsw_pll_mgr;
3527 else if (HAS_PCH_IBX(dev_priv) || HAS_PCH_CPT(dev_priv))
3528 dpll_mgr = &pch_pll_mgr;
3529
3530 if (!dpll_mgr) {
3531 dev_priv->num_shared_dpll = 0;
3532 return;
3533 }
3534
3535 dpll_info = dpll_mgr->dpll_info;
3536
3537 for (i = 0; dpll_info[i].name; i++) {
3538 WARN_ON(i != dpll_info[i].id);
3539 dev_priv->shared_dplls[i].info = &dpll_info[i];
3540 }
3541
3542 dev_priv->dpll_mgr = dpll_mgr;
3543 dev_priv->num_shared_dpll = i;
3544 mutex_init(&dev_priv->dpll_lock);
3545
3546 BUG_ON(dev_priv->num_shared_dpll > I915_NUM_PLLS);
3547 }
3548
3549 /**
3550 * intel_reserve_shared_dplls - reserve DPLLs for CRTC and encoder combination
3551 * @state: atomic state
3552 * @crtc: CRTC to reserve DPLLs for
3553 * @encoder: encoder
3554 *
3555 * This function reserves all required DPLLs for the given CRTC and encoder
3556 * combination in the current atomic commit @state and the new @crtc atomic
3557 * state.
3558 *
3559 * The new configuration in the atomic commit @state is made effective by
3560 * calling intel_shared_dpll_swap_state().
3561 *
3562 * The reserved DPLLs should be released by calling
3563 * intel_release_shared_dplls().
3564 *
3565 * Returns:
3566 * True if all required DPLLs were successfully reserved.
3567 */
intel_reserve_shared_dplls(struct intel_atomic_state * state,struct intel_crtc * crtc,struct intel_encoder * encoder)3568 bool intel_reserve_shared_dplls(struct intel_atomic_state *state,
3569 struct intel_crtc *crtc,
3570 struct intel_encoder *encoder)
3571 {
3572 struct drm_i915_private *dev_priv = to_i915(state->base.dev);
3573 const struct intel_dpll_mgr *dpll_mgr = dev_priv->dpll_mgr;
3574
3575 if (WARN_ON(!dpll_mgr))
3576 return false;
3577
3578 return dpll_mgr->get_dplls(state, crtc, encoder);
3579 }
3580
3581 /**
3582 * intel_release_shared_dplls - end use of DPLLs by CRTC in atomic state
3583 * @state: atomic state
3584 * @crtc: crtc from which the DPLLs are to be released
3585 *
3586 * This function releases all DPLLs reserved by intel_reserve_shared_dplls()
3587 * from the current atomic commit @state and the old @crtc atomic state.
3588 *
3589 * The new configuration in the atomic commit @state is made effective by
3590 * calling intel_shared_dpll_swap_state().
3591 */
intel_release_shared_dplls(struct intel_atomic_state * state,struct intel_crtc * crtc)3592 void intel_release_shared_dplls(struct intel_atomic_state *state,
3593 struct intel_crtc *crtc)
3594 {
3595 struct drm_i915_private *dev_priv = to_i915(state->base.dev);
3596 const struct intel_dpll_mgr *dpll_mgr = dev_priv->dpll_mgr;
3597
3598 /*
3599 * FIXME: this function is called for every platform having a
3600 * compute_clock hook, even though the platform doesn't yet support
3601 * the shared DPLL framework and intel_reserve_shared_dplls() is not
3602 * called on those.
3603 */
3604 if (!dpll_mgr)
3605 return;
3606
3607 dpll_mgr->put_dplls(state, crtc);
3608 }
3609
3610 /**
3611 * intel_update_active_dpll - update the active DPLL for a CRTC/encoder
3612 * @state: atomic state
3613 * @crtc: the CRTC for which to update the active DPLL
3614 * @encoder: encoder determining the type of port DPLL
3615 *
3616 * Update the active DPLL for the given @crtc/@encoder in @crtc's atomic state,
3617 * from the port DPLLs reserved previously by intel_reserve_shared_dplls(). The
3618 * DPLL selected will be based on the current mode of the encoder's port.
3619 */
intel_update_active_dpll(struct intel_atomic_state * state,struct intel_crtc * crtc,struct intel_encoder * encoder)3620 void intel_update_active_dpll(struct intel_atomic_state *state,
3621 struct intel_crtc *crtc,
3622 struct intel_encoder *encoder)
3623 {
3624 struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
3625 const struct intel_dpll_mgr *dpll_mgr = dev_priv->dpll_mgr;
3626
3627 if (WARN_ON(!dpll_mgr))
3628 return;
3629
3630 dpll_mgr->update_active_dpll(state, crtc, encoder);
3631 }
3632
3633 /**
3634 * intel_shared_dpll_dump_hw_state - write hw_state to dmesg
3635 * @dev_priv: i915 drm device
3636 * @hw_state: hw state to be written to the log
3637 *
3638 * Write the relevant values in @hw_state to dmesg using DRM_DEBUG_KMS.
3639 */
intel_dpll_dump_hw_state(struct drm_i915_private * dev_priv,const struct intel_dpll_hw_state * hw_state)3640 void intel_dpll_dump_hw_state(struct drm_i915_private *dev_priv,
3641 const struct intel_dpll_hw_state *hw_state)
3642 {
3643 if (dev_priv->dpll_mgr) {
3644 dev_priv->dpll_mgr->dump_hw_state(dev_priv, hw_state);
3645 } else {
3646 /* fallback for platforms that don't use the shared dpll
3647 * infrastructure
3648 */
3649 DRM_DEBUG_KMS("dpll_hw_state: dpll: 0x%x, dpll_md: 0x%x, "
3650 "fp0: 0x%x, fp1: 0x%x\n",
3651 hw_state->dpll,
3652 hw_state->dpll_md,
3653 hw_state->fp0,
3654 hw_state->fp1);
3655 }
3656 }
3657