Commit 151e3d6a authored by Dave Airlie's avatar Dave Airlie

Merge tag 'drm-intel-fixes-2019-02-07-1' of...

Merge tag 'drm-intel-fixes-2019-02-07-1' of git://anongit.freedesktop.org/drm/drm-intel into drm-fixes

drm/i915 fixes for v5.0-rc6:
- SNB DPLL sanitize
- ICL DDI clock selection
- SLK srckey mask
Signed-off-by: default avatarDave Airlie <airlied@redhat.com>

From: Jani Nikula <jani.nikula@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/87lg2s6nur.fsf@intel.com
parents 78eb1ca4 d028a646
...@@ -1086,7 +1086,7 @@ static uint32_t icl_pll_to_ddi_pll_sel(struct intel_encoder *encoder, ...@@ -1086,7 +1086,7 @@ static uint32_t icl_pll_to_ddi_pll_sel(struct intel_encoder *encoder,
return DDI_CLK_SEL_TBT_810; return DDI_CLK_SEL_TBT_810;
default: default:
MISSING_CASE(clock); MISSING_CASE(clock);
break; return DDI_CLK_SEL_NONE;
} }
case DPLL_ID_ICL_MGPLL1: case DPLL_ID_ICL_MGPLL1:
case DPLL_ID_ICL_MGPLL2: case DPLL_ID_ICL_MGPLL2:
......
...@@ -15415,16 +15415,45 @@ static void intel_sanitize_crtc(struct intel_crtc *crtc, ...@@ -15415,16 +15415,45 @@ static void intel_sanitize_crtc(struct intel_crtc *crtc,
} }
} }
static bool has_bogus_dpll_config(const struct intel_crtc_state *crtc_state)
{
struct drm_i915_private *dev_priv = to_i915(crtc_state->base.crtc->dev);
/*
* Some SNB BIOSen (eg. ASUS K53SV) are known to misprogram
* the hardware when a high res displays plugged in. DPLL P
* divider is zero, and the pipe timings are bonkers. We'll
* try to disable everything in that case.
*
* FIXME would be nice to be able to sanitize this state
* without several WARNs, but for now let's take the easy
* road.
*/
return IS_GEN6(dev_priv) &&
crtc_state->base.active &&
crtc_state->shared_dpll &&
crtc_state->port_clock == 0;
}
static void intel_sanitize_encoder(struct intel_encoder *encoder) static void intel_sanitize_encoder(struct intel_encoder *encoder)
{ {
struct drm_i915_private *dev_priv = to_i915(encoder->base.dev); struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
struct intel_connector *connector; struct intel_connector *connector;
struct intel_crtc *crtc = to_intel_crtc(encoder->base.crtc);
struct intel_crtc_state *crtc_state = crtc ?
to_intel_crtc_state(crtc->base.state) : NULL;
/* We need to check both for a crtc link (meaning that the /* We need to check both for a crtc link (meaning that the
* encoder is active and trying to read from a pipe) and the * encoder is active and trying to read from a pipe) and the
* pipe itself being active. */ * pipe itself being active. */
bool has_active_crtc = encoder->base.crtc && bool has_active_crtc = crtc_state &&
to_intel_crtc(encoder->base.crtc)->active; crtc_state->base.active;
if (crtc_state && has_bogus_dpll_config(crtc_state)) {
DRM_DEBUG_KMS("BIOS has misprogrammed the hardware. Disabling pipe %c\n",
pipe_name(crtc->pipe));
has_active_crtc = false;
}
connector = intel_encoder_find_connector(encoder); connector = intel_encoder_find_connector(encoder);
if (connector && !has_active_crtc) { if (connector && !has_active_crtc) {
...@@ -15435,16 +15464,25 @@ static void intel_sanitize_encoder(struct intel_encoder *encoder) ...@@ -15435,16 +15464,25 @@ static void intel_sanitize_encoder(struct intel_encoder *encoder)
/* Connector is active, but has no active pipe. This is /* Connector is active, but has no active pipe. This is
* fallout from our resume register restoring. Disable * fallout from our resume register restoring. Disable
* the encoder manually again. */ * the encoder manually again. */
if (encoder->base.crtc) { if (crtc_state) {
struct drm_crtc_state *crtc_state = encoder->base.crtc->state; struct drm_encoder *best_encoder;
DRM_DEBUG_KMS("[ENCODER:%d:%s] manually disabled\n", DRM_DEBUG_KMS("[ENCODER:%d:%s] manually disabled\n",
encoder->base.base.id, encoder->base.base.id,
encoder->base.name); encoder->base.name);
/* avoid oopsing in case the hooks consult best_encoder */
best_encoder = connector->base.state->best_encoder;
connector->base.state->best_encoder = &encoder->base;
if (encoder->disable) if (encoder->disable)
encoder->disable(encoder, to_intel_crtc_state(crtc_state), connector->base.state); encoder->disable(encoder, crtc_state,
connector->base.state);
if (encoder->post_disable) if (encoder->post_disable)
encoder->post_disable(encoder, to_intel_crtc_state(crtc_state), connector->base.state); encoder->post_disable(encoder, crtc_state,
connector->base.state);
connector->base.state->best_encoder = best_encoder;
} }
encoder->base.crtc = NULL; encoder->base.crtc = NULL;
......
...@@ -494,7 +494,7 @@ skl_program_plane(struct intel_plane *plane, ...@@ -494,7 +494,7 @@ skl_program_plane(struct intel_plane *plane,
keymax = (key->max_value & 0xffffff) | PLANE_KEYMAX_ALPHA(alpha); keymax = (key->max_value & 0xffffff) | PLANE_KEYMAX_ALPHA(alpha);
keymsk = key->channel_mask & 0x3ffffff; keymsk = key->channel_mask & 0x7ffffff;
if (alpha < 0xff) if (alpha < 0xff)
keymsk |= PLANE_KEYMSK_ALPHA_ENABLE; keymsk |= PLANE_KEYMSK_ALPHA_ENABLE;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment