mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-01-08 02:21:18 +00:00
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: Ville Syrjälä <ville.syrjala@linux.intel.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
This commit is contained in:
parent
e2b7826742
commit
a43f6e0fd6
@ -914,10 +914,10 @@ intel_crtc_to_shared_dpll(struct intel_crtc *crtc)
|
|||||||
{
|
{
|
||||||
struct drm_i915_private *dev_priv = crtc->base.dev->dev_private;
|
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 NULL;
|
||||||
|
|
||||||
return &dev_priv->shared_dplls[crtc->shared_dpll];
|
return &dev_priv->shared_dplls[crtc->config.shared_dpll];
|
||||||
}
|
}
|
||||||
|
|
||||||
/* For ILK+ */
|
/* For ILK+ */
|
||||||
@ -3001,7 +3001,7 @@ static void ironlake_pch_enable(struct drm_crtc *crtc)
|
|||||||
sel = TRANSC_DPLLB_SEL;
|
sel = TRANSC_DPLLB_SEL;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (intel_crtc->shared_dpll == DPLL_ID_PCH_PLL_B)
|
if (intel_crtc->config.shared_dpll == DPLL_ID_PCH_PLL_B)
|
||||||
temp |= sel;
|
temp |= sel;
|
||||||
else
|
else
|
||||||
temp &= ~sel;
|
temp &= ~sel;
|
||||||
@ -3087,7 +3087,7 @@ static void intel_put_shared_dpll(struct intel_crtc *crtc)
|
|||||||
WARN_ON(pll->active);
|
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)
|
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;
|
return NULL;
|
||||||
|
|
||||||
found:
|
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));
|
DRM_DEBUG_DRIVER("using pll %d for pipe %c\n", i, pipe_name(crtc->pipe));
|
||||||
if (pll->active == 0) {
|
if (pll->active == 0) {
|
||||||
DRM_DEBUG_DRIVER("setting up pll %d\n", i);
|
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;
|
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 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 drm_display_mode *adjusted_mode = &pipe_config->adjusted_mode;
|
||||||
struct intel_crtc *intel_crtc = to_intel_crtc(crtc);
|
|
||||||
|
|
||||||
if (HAS_PCH_SPLIT(dev)) {
|
if (HAS_PCH_SPLIT(dev)) {
|
||||||
/* FDI link clock is fixed at 2.7G */
|
/* 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))
|
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)
|
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;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -7910,7 +7914,7 @@ encoder_retry:
|
|||||||
if (!pipe_config->port_clock)
|
if (!pipe_config->port_clock)
|
||||||
pipe_config->port_clock = pipe_config->adjusted_mode.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) {
|
if (ret < 0) {
|
||||||
DRM_DEBUG_KMS("CRTC fixup failed\n");
|
DRM_DEBUG_KMS("CRTC fixup failed\n");
|
||||||
goto fail;
|
goto fail;
|
||||||
|
@ -252,6 +252,9 @@ struct intel_crtc_config {
|
|||||||
* haswell. */
|
* haswell. */
|
||||||
struct dpll dpll;
|
struct dpll dpll;
|
||||||
|
|
||||||
|
/* Selected dpll when shared or DPLL_ID_PRIVATE. */
|
||||||
|
enum intel_dpll_id shared_dpll;
|
||||||
|
|
||||||
int pipe_bpp;
|
int pipe_bpp;
|
||||||
struct intel_link_m_n dp_m_n;
|
struct intel_link_m_n dp_m_n;
|
||||||
|
|
||||||
@ -316,8 +319,6 @@ struct intel_crtc {
|
|||||||
|
|
||||||
struct intel_crtc_config config;
|
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;
|
uint32_t ddi_pll_sel;
|
||||||
|
|
||||||
/* reset counter value when the last flip was submitted */
|
/* reset counter value when the last flip was submitted */
|
||||||
|
Loading…
Reference in New Issue
Block a user