drm/i915/icl: Consider DSI for getting transcoder state

For Gen11 DSI, we use similar registers like for eDP
to find if DSI encoder is connected or not to a pipe.
This patch refactors existing hsw_get_transcoder_state()
to handle this.

v2 by Jani:
 - Add WARN_ON(dsi && edp) (Ville)

Signed-off-by: Madhav Chauhan <madhav.chauhan@intel.com>
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/2e10b977dfc7aa985a8559d6cd59ed0981848e95.1543500286.git.jani.nikula@intel.com
This commit is contained in:
Madhav Chauhan 2018-11-29 16:12:27 +02:00 committed by Jani Nikula
parent 5a8507b5aa
commit 2ca711caec

View File

@ -9477,6 +9477,8 @@ static bool hsw_get_transcoder_state(struct intel_crtc *crtc,
struct drm_i915_private *dev_priv = to_i915(dev); struct drm_i915_private *dev_priv = to_i915(dev);
enum intel_display_power_domain power_domain; enum intel_display_power_domain power_domain;
u32 tmp; u32 tmp;
bool is_dsi = false;
bool is_edp = false;
/* /*
* The pipe->transcoder mapping is fixed with the exception of the eDP * The pipe->transcoder mapping is fixed with the exception of the eDP
@ -9489,26 +9491,41 @@ static bool hsw_get_transcoder_state(struct intel_crtc *crtc,
* consistency and less surprising code; it's in always on power). * consistency and less surprising code; it's in always on power).
*/ */
tmp = I915_READ(TRANS_DDI_FUNC_CTL(TRANSCODER_EDP)); tmp = I915_READ(TRANS_DDI_FUNC_CTL(TRANSCODER_EDP));
if (tmp & TRANS_DDI_FUNC_ENABLE) { if (tmp & TRANS_DDI_FUNC_ENABLE)
enum pipe trans_edp_pipe; is_edp = true;
if (IS_ICELAKE(dev_priv)) {
tmp = I915_READ(TRANS_DDI_FUNC_CTL(TRANSCODER_DSI_0));
if (tmp & TRANS_DDI_FUNC_ENABLE)
is_dsi = true;
}
WARN_ON(is_edp && is_dsi);
if (is_edp || is_dsi) {
enum pipe trans_pipe;
switch (tmp & TRANS_DDI_EDP_INPUT_MASK) { switch (tmp & TRANS_DDI_EDP_INPUT_MASK) {
default: default:
WARN(1, "unknown pipe linked to edp transcoder\n"); WARN(1, "unknown pipe linked to edp transcoder\n");
/* fall through */ /* fall through */
case TRANS_DDI_EDP_INPUT_A_ONOFF: case TRANS_DDI_EDP_INPUT_A_ONOFF:
case TRANS_DDI_EDP_INPUT_A_ON: case TRANS_DDI_EDP_INPUT_A_ON:
trans_edp_pipe = PIPE_A; trans_pipe = PIPE_A;
break; break;
case TRANS_DDI_EDP_INPUT_B_ONOFF: case TRANS_DDI_EDP_INPUT_B_ONOFF:
trans_edp_pipe = PIPE_B; trans_pipe = PIPE_B;
break; break;
case TRANS_DDI_EDP_INPUT_C_ONOFF: case TRANS_DDI_EDP_INPUT_C_ONOFF:
trans_edp_pipe = PIPE_C; trans_pipe = PIPE_C;
break; break;
} }
if (trans_edp_pipe == crtc->pipe) if (trans_pipe == crtc->pipe) {
pipe_config->cpu_transcoder = TRANSCODER_EDP; if (is_edp)
pipe_config->cpu_transcoder = TRANSCODER_EDP;
else if (is_dsi)
pipe_config->cpu_transcoder = TRANSCODER_DSI_0;
}
} }
power_domain = POWER_DOMAIN_TRANSCODER(pipe_config->cpu_transcoder); power_domain = POWER_DOMAIN_TRANSCODER(pipe_config->cpu_transcoder);