Commit e15fc81f authored by Eric Yang's avatar Eric Yang Committed by Alex Deucher

drm/amd/display: clean up encoding checks

[Why]
All ASICS we support has YCbCr support, so
the check is unnecessary, the currently logic
in validate output also returns true all
the time, so the unneccessary logic is removed
Signed-off-by: default avatarEric Yang <Eric.Yang2@amd.com>
Reviewed-by: default avatarTony Cheng <Tony.Cheng@amd.com>
Acked-by: default avatarLeo Li <sunpeng.li@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent b7cd6487
...@@ -665,21 +665,7 @@ bool dce110_link_encoder_validate_dp_output( ...@@ -665,21 +665,7 @@ bool dce110_link_encoder_validate_dp_output(
if (crtc_timing->pixel_encoding == PIXEL_ENCODING_YCBCR420) if (crtc_timing->pixel_encoding == PIXEL_ENCODING_YCBCR420)
return false; return false;
/* default RGB only */ return true;
if (crtc_timing->pixel_encoding == PIXEL_ENCODING_RGB)
return true;
if (enc110->base.features.flags.bits.IS_YCBCR_CAPABLE)
return true;
/* for DCE 8.x or later DP Y-only feature,
* we need ASIC cap + FeatureSupportDPYonly, not support 666 */
if (crtc_timing->flags.Y_ONLY &&
enc110->base.features.flags.bits.IS_YCBCR_CAPABLE &&
crtc_timing->display_color_depth != COLOR_DEPTH_666)
return true;
return false;
} }
void dce110_link_encoder_construct( void dce110_link_encoder_construct(
......
...@@ -551,8 +551,7 @@ static const struct encoder_feature_support link_enc_feature = { ...@@ -551,8 +551,7 @@ static const struct encoder_feature_support link_enc_feature = {
.max_hdmi_deep_color = COLOR_DEPTH_121212, .max_hdmi_deep_color = COLOR_DEPTH_121212,
.max_hdmi_pixel_clock = 300000, .max_hdmi_pixel_clock = 300000,
.flags.bits.IS_HBR2_CAPABLE = true, .flags.bits.IS_HBR2_CAPABLE = true,
.flags.bits.IS_TPS3_CAPABLE = true, .flags.bits.IS_TPS3_CAPABLE = true
.flags.bits.IS_YCBCR_CAPABLE = true
}; };
struct link_encoder *dce100_link_encoder_create( struct link_encoder *dce100_link_encoder_create(
......
...@@ -570,8 +570,7 @@ static const struct encoder_feature_support link_enc_feature = { ...@@ -570,8 +570,7 @@ static const struct encoder_feature_support link_enc_feature = {
.max_hdmi_deep_color = COLOR_DEPTH_121212, .max_hdmi_deep_color = COLOR_DEPTH_121212,
.max_hdmi_pixel_clock = 594000, .max_hdmi_pixel_clock = 594000,
.flags.bits.IS_HBR2_CAPABLE = true, .flags.bits.IS_HBR2_CAPABLE = true,
.flags.bits.IS_TPS3_CAPABLE = true, .flags.bits.IS_TPS3_CAPABLE = true
.flags.bits.IS_YCBCR_CAPABLE = true
}; };
static struct link_encoder *dce110_link_encoder_create( static struct link_encoder *dce110_link_encoder_create(
......
...@@ -555,8 +555,7 @@ static const struct encoder_feature_support link_enc_feature = { ...@@ -555,8 +555,7 @@ static const struct encoder_feature_support link_enc_feature = {
.flags.bits.IS_HBR2_CAPABLE = true, .flags.bits.IS_HBR2_CAPABLE = true,
.flags.bits.IS_HBR3_CAPABLE = true, .flags.bits.IS_HBR3_CAPABLE = true,
.flags.bits.IS_TPS3_CAPABLE = true, .flags.bits.IS_TPS3_CAPABLE = true,
.flags.bits.IS_TPS4_CAPABLE = true, .flags.bits.IS_TPS4_CAPABLE = true
.flags.bits.IS_YCBCR_CAPABLE = true
}; };
struct link_encoder *dce112_link_encoder_create( struct link_encoder *dce112_link_encoder_create(
......
...@@ -609,7 +609,6 @@ static const struct encoder_feature_support link_enc_feature = { ...@@ -609,7 +609,6 @@ static const struct encoder_feature_support link_enc_feature = {
.flags.bits.IS_HBR3_CAPABLE = true, .flags.bits.IS_HBR3_CAPABLE = true,
.flags.bits.IS_TPS3_CAPABLE = true, .flags.bits.IS_TPS3_CAPABLE = true,
.flags.bits.IS_TPS4_CAPABLE = true, .flags.bits.IS_TPS4_CAPABLE = true,
.flags.bits.IS_YCBCR_CAPABLE = true
}; };
static struct link_encoder *dce120_link_encoder_create( static struct link_encoder *dce120_link_encoder_create(
......
...@@ -650,8 +650,7 @@ static const struct encoder_feature_support link_enc_feature = { ...@@ -650,8 +650,7 @@ static const struct encoder_feature_support link_enc_feature = {
.max_hdmi_deep_color = COLOR_DEPTH_121212, .max_hdmi_deep_color = COLOR_DEPTH_121212,
.max_hdmi_pixel_clock = 297000, .max_hdmi_pixel_clock = 297000,
.flags.bits.IS_HBR2_CAPABLE = true, .flags.bits.IS_HBR2_CAPABLE = true,
.flags.bits.IS_TPS3_CAPABLE = true, .flags.bits.IS_TPS3_CAPABLE = true
.flags.bits.IS_YCBCR_CAPABLE = true
}; };
struct link_encoder *dce80_link_encoder_create( struct link_encoder *dce80_link_encoder_create(
......
...@@ -609,22 +609,7 @@ bool dcn10_link_encoder_validate_dp_output( ...@@ -609,22 +609,7 @@ bool dcn10_link_encoder_validate_dp_output(
if (crtc_timing->pixel_encoding == PIXEL_ENCODING_YCBCR420) if (crtc_timing->pixel_encoding == PIXEL_ENCODING_YCBCR420)
return false; return false;
/* default RGB only */ return true;
if (crtc_timing->pixel_encoding == PIXEL_ENCODING_RGB)
return true;
if (enc10->base.features.flags.bits.IS_YCBCR_CAPABLE)
return true;
/* for DCE 8.x or later DP Y-only feature,
* we need ASIC cap + FeatureSupportDPYonly, not support 666
*/
if (crtc_timing->flags.Y_ONLY &&
enc10->base.features.flags.bits.IS_YCBCR_CAPABLE &&
crtc_timing->display_color_depth != COLOR_DEPTH_666)
return true;
return false;
} }
void dcn10_link_encoder_construct( void dcn10_link_encoder_construct(
......
...@@ -711,8 +711,7 @@ static const struct encoder_feature_support link_enc_feature = { ...@@ -711,8 +711,7 @@ static const struct encoder_feature_support link_enc_feature = {
.flags.bits.IS_HBR2_CAPABLE = true, .flags.bits.IS_HBR2_CAPABLE = true,
.flags.bits.IS_HBR3_CAPABLE = true, .flags.bits.IS_HBR3_CAPABLE = true,
.flags.bits.IS_TPS3_CAPABLE = true, .flags.bits.IS_TPS3_CAPABLE = true,
.flags.bits.IS_TPS4_CAPABLE = true, .flags.bits.IS_TPS4_CAPABLE = true
.flags.bits.IS_YCBCR_CAPABLE = true
}; };
struct link_encoder *dcn10_link_encoder_create( struct link_encoder *dcn10_link_encoder_create(
......
...@@ -58,7 +58,6 @@ struct encoder_feature_support { ...@@ -58,7 +58,6 @@ struct encoder_feature_support {
uint32_t IS_HBR3_CAPABLE:1; uint32_t IS_HBR3_CAPABLE:1;
uint32_t IS_TPS3_CAPABLE:1; uint32_t IS_TPS3_CAPABLE:1;
uint32_t IS_TPS4_CAPABLE:1; uint32_t IS_TPS4_CAPABLE:1;
uint32_t IS_YCBCR_CAPABLE:1;
uint32_t HDMI_6GB_EN:1; uint32_t HDMI_6GB_EN:1;
} bits; } bits;
uint32_t raw; uint32_t raw;
......
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