Commit 06fa3284 authored by Ville Syrjälä's avatar Ville Syrjälä

drm/i915: Nuke lspcon_downsampling

crtc_state->lspcon_downsampling isn't particularly useful at
the moment since we can't even do proper readout for it.
Let's get rid of it. Will help with unifying the LSPCON with
the regular DFP YCbCr output support.
Signed-off-by: default avatarVille Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20200924184156.24491-1-ville.syrjala@linux.intel.comReviewed-by: default avatarUma Shankar <uma.shankar@intel.com>
parent 2c1e63ba
...@@ -11294,18 +11294,6 @@ static bool hsw_get_pipe_config(struct intel_crtc *crtc, ...@@ -11294,18 +11294,6 @@ static bool hsw_get_pipe_config(struct intel_crtc *crtc,
} else { } else {
pipe_config->output_format = pipe_config->output_format =
bdw_get_pipemisc_output_format(crtc); bdw_get_pipemisc_output_format(crtc);
/*
* Currently there is no interface defined to
* check user preference between RGB/YCBCR444
* or YCBCR420. So the only possible case for
* YCBCR444 usage is driving YCBCR420 output
* with LSPCON, when pipe is configured for
* YCBCR444 output and LSPCON takes care of
* downsampling it.
*/
pipe_config->lspcon_downsampling =
pipe_config->output_format == INTEL_OUTPUT_FORMAT_YCBCR444;
} }
pipe_config->gamma_mode = intel_de_read(dev_priv, pipe_config->gamma_mode = intel_de_read(dev_priv,
......
...@@ -1055,9 +1055,6 @@ struct intel_crtc_state { ...@@ -1055,9 +1055,6 @@ struct intel_crtc_state {
/* Output format RGB/YCBCR etc */ /* Output format RGB/YCBCR etc */
enum intel_output_format output_format; enum intel_output_format output_format;
/* Output down scaling is done in LSPCON device */
bool lspcon_downsampling;
/* enable pipe gamma? */ /* enable pipe gamma? */
bool gamma_enable; bool gamma_enable;
......
...@@ -195,7 +195,6 @@ void lspcon_ycbcr420_config(struct drm_connector *connector, ...@@ -195,7 +195,6 @@ void lspcon_ycbcr420_config(struct drm_connector *connector,
connector->ycbcr_420_allowed) { connector->ycbcr_420_allowed) {
crtc_state->port_clock /= 2; crtc_state->port_clock /= 2;
crtc_state->output_format = INTEL_OUTPUT_FORMAT_YCBCR444; crtc_state->output_format = INTEL_OUTPUT_FORMAT_YCBCR444;
crtc_state->lspcon_downsampling = true;
} }
} }
...@@ -492,14 +491,19 @@ void lspcon_set_infoframes(struct intel_encoder *encoder, ...@@ -492,14 +491,19 @@ void lspcon_set_infoframes(struct intel_encoder *encoder,
return; return;
} }
if (crtc_state->output_format == INTEL_OUTPUT_FORMAT_YCBCR444) { /*
if (crtc_state->lspcon_downsampling) * Currently there is no interface defined to
frame.avi.colorspace = HDMI_COLORSPACE_YUV420; * check user preference between RGB/YCBCR444
else * or YCBCR420. So the only possible case for
frame.avi.colorspace = HDMI_COLORSPACE_YUV444; * YCBCR444 usage is driving YCBCR420 output
} else { * with LSPCON, when pipe is configured for
* YCBCR444 output and LSPCON takes care of
* downsampling it.
*/
if (crtc_state->output_format == INTEL_OUTPUT_FORMAT_YCBCR444)
frame.avi.colorspace = HDMI_COLORSPACE_YUV420;
else
frame.avi.colorspace = HDMI_COLORSPACE_RGB; frame.avi.colorspace = HDMI_COLORSPACE_RGB;
}
drm_hdmi_avi_infoframe_quant_range(&frame.avi, drm_hdmi_avi_infoframe_quant_range(&frame.avi,
conn_state->connector, conn_state->connector,
......
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