Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit a43f6e0f authored by Daniel Vetter's avatar Daniel Vetter
Browse files

drm/i915: move shared_dpll into the pipe config



With the big sed-job prep work done this is now really simple. With
the exception that we only assign the right shared dpll id in the
->mode_set callback but also depend upon the old one still being
around.

Until that mess is fixed up we need to jump through a few hoops to
keep the old value save.

v2: Kill the funny whitespace spotted by Chris.

v3: Move the shared_dpll pipe config fixup into this patch as noticed
by Ville. Also unconditionally set the shared_dpll with the current
one, since otherwise we won't handle direct pch port -> cpu edp
transitions correctly.

Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
Reviewed-by: default avatarVille Syrjälä <ville.syrjala@linux.intel.com>
Signed-off-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
parent e2b78267
Loading
Loading
Loading
Loading
+15 −11
Original line number Diff line number Diff line
@@ -914,10 +914,10 @@ intel_crtc_to_shared_dpll(struct intel_crtc *crtc)
{
	struct drm_i915_private *dev_priv = crtc->base.dev->dev_private;

	if (crtc->shared_dpll < 0)
	if (crtc->config.shared_dpll < 0)
		return NULL;

	return &dev_priv->shared_dplls[crtc->shared_dpll];
	return &dev_priv->shared_dplls[crtc->config.shared_dpll];
}

/* For ILK+ */
@@ -3001,7 +3001,7 @@ static void ironlake_pch_enable(struct drm_crtc *crtc)
			sel = TRANSC_DPLLB_SEL;
			break;
		}
		if (intel_crtc->shared_dpll == DPLL_ID_PCH_PLL_B)
		if (intel_crtc->config.shared_dpll == DPLL_ID_PCH_PLL_B)
			temp |= sel;
		else
			temp &= ~sel;
@@ -3087,7 +3087,7 @@ static void intel_put_shared_dpll(struct intel_crtc *crtc)
		WARN_ON(pll->active);
	}

	crtc->shared_dpll = DPLL_ID_PRIVATE;
	crtc->config.shared_dpll = DPLL_ID_PRIVATE;
}

static struct intel_shared_dpll *intel_get_shared_dpll(struct intel_crtc *crtc, u32 dpll, u32 fp)
@@ -3143,7 +3143,7 @@ static struct intel_shared_dpll *intel_get_shared_dpll(struct intel_crtc *crtc,
	return NULL;

found:
	crtc->shared_dpll = i;
	crtc->config.shared_dpll = i;
	DRM_DEBUG_DRIVER("using pll %d for pipe %c\n", i, pipe_name(crtc->pipe));
	if (pll->active == 0) {
		DRM_DEBUG_DRIVER("setting up pll %d\n", i);
@@ -4106,12 +4106,11 @@ static void hsw_compute_ips_config(struct intel_crtc *crtc,
				   pipe_config->pipe_bpp == 24;
}

static int intel_crtc_compute_config(struct drm_crtc *crtc,
static int intel_crtc_compute_config(struct intel_crtc *crtc,
				     struct intel_crtc_config *pipe_config)
{
	struct drm_device *dev = crtc->dev;
	struct drm_device *dev = crtc->base.dev;
	struct drm_display_mode *adjusted_mode = &pipe_config->adjusted_mode;
	struct intel_crtc *intel_crtc = to_intel_crtc(crtc);

	if (HAS_PCH_SPLIT(dev)) {
		/* FDI link clock is fixed at 2.7G */
@@ -4142,10 +4141,15 @@ static int intel_crtc_compute_config(struct drm_crtc *crtc,
	}

	if (IS_HASWELL(dev))
		hsw_compute_ips_config(intel_crtc, pipe_config);
		hsw_compute_ips_config(crtc, pipe_config);

	/* XXX: PCH clock sharing is done in ->mode_set, so make sure the old
	 * clock survives for now. */
	if (HAS_PCH_IBX(dev) || HAS_PCH_CPT(dev))
		pipe_config->shared_dpll = crtc->config.shared_dpll;

	if (pipe_config->has_pch_encoder)
		return ironlake_fdi_compute_config(intel_crtc, pipe_config);
		return ironlake_fdi_compute_config(crtc, pipe_config);

	return 0;
}
@@ -7910,7 +7914,7 @@ intel_modeset_pipe_config(struct drm_crtc *crtc,
	if (!pipe_config->port_clock)
		pipe_config->port_clock = pipe_config->adjusted_mode.clock;

	ret = intel_crtc_compute_config(crtc, pipe_config);
	ret = intel_crtc_compute_config(to_intel_crtc(crtc), pipe_config);
	if (ret < 0) {
		DRM_DEBUG_KMS("CRTC fixup failed\n");
		goto fail;
+3 −2
Original line number Diff line number Diff line
@@ -252,6 +252,9 @@ struct intel_crtc_config {
	 * haswell. */
	struct dpll dpll;

	/* Selected dpll when shared or DPLL_ID_PRIVATE. */
	enum intel_dpll_id shared_dpll;

	int pipe_bpp;
	struct intel_link_m_n dp_m_n;

@@ -316,8 +319,6 @@ struct intel_crtc {

	struct intel_crtc_config config;

	/* We can share PLLs across outputs if the timings match */
	enum intel_dpll_id shared_dpll;
	uint32_t ddi_pll_sel;

	/* reset counter value when the last flip was submitted */