Commit 7fe538a4 authored by Charlene Liu's avatar Charlene Liu Committed by Alex Deucher

drm/amd/display: fix DP 422 VID_M half the rate issue.

[Description]
when programming VID_TIMING, we were using the original VESA timing for DP_VIDM/N.
for YCbCr420 or compressed YCbCr422, using half rate as  YCbCr444.
Signed-off-by: default avatarCharlene Liu <charlene.liu@amd.com>
Reviewed-by: default avatarNikola Cornij <Nikola.Cornij@amd.com>
Acked-by: default avatarLeo Li <sunpeng.li@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent ae5041f3
...@@ -977,7 +977,7 @@ static void dce110_stream_encoder_dp_unblank( ...@@ -977,7 +977,7 @@ static void dce110_stream_encoder_dp_unblank(
uint64_t m_vid_l = n_vid; uint64_t m_vid_l = n_vid;
m_vid_l *= param->pixel_clk_khz; m_vid_l *= param->timing.pix_clk_100hz / 10;
m_vid_l = div_u64(m_vid_l, m_vid_l = div_u64(m_vid_l,
param->link_settings.link_rate param->link_settings.link_rate
* LINK_RATE_REF_FREQ_IN_KHZ); * LINK_RATE_REF_FREQ_IN_KHZ);
......
...@@ -1052,9 +1052,8 @@ void dce110_unblank_stream(struct pipe_ctx *pipe_ctx, ...@@ -1052,9 +1052,8 @@ void dce110_unblank_stream(struct pipe_ctx *pipe_ctx,
struct dc_link *link = stream->link; struct dc_link *link = stream->link;
/* only 3 items below are used by unblank */ /* only 3 items below are used by unblank */
params.pixel_clk_khz = pipe_ctx->stream->timing.pix_clk_100hz / 10; params.timing = pipe_ctx->stream->timing;
params.link_settings.link_rate = link_settings->link_rate; params.link_settings.link_rate = link_settings->link_rate;
params.pixel_encoding = pipe_ctx->stream->timing.pixel_encoding;
if (dc_is_dp_signal(pipe_ctx->stream->signal)) if (dc_is_dp_signal(pipe_ctx->stream->signal))
pipe_ctx->stream_res.stream_enc->funcs->dp_unblank(pipe_ctx->stream_res.stream_enc, &params); pipe_ctx->stream_res.stream_enc->funcs->dp_unblank(pipe_ctx->stream_res.stream_enc, &params);
......
...@@ -2900,6 +2900,29 @@ static void dcn10_setup_vupdate_interrupt(struct pipe_ctx *pipe_ctx) ...@@ -2900,6 +2900,29 @@ static void dcn10_setup_vupdate_interrupt(struct pipe_ctx *pipe_ctx)
tg->funcs->setup_vertical_interrupt2(tg, start_line); tg->funcs->setup_vertical_interrupt2(tg, start_line);
} }
static void dcn10_unblank_stream(struct pipe_ctx *pipe_ctx,
struct dc_link_settings *link_settings)
{
struct encoder_unblank_param params = { { 0 } };
struct dc_stream_state *stream = pipe_ctx->stream;
struct dc_link *link = stream->link;
/* only 3 items below are used by unblank */
params.timing = pipe_ctx->stream->timing;
params.link_settings.link_rate = link_settings->link_rate;
if (dc_is_dp_signal(pipe_ctx->stream->signal)) {
if (params.timing.pixel_encoding == PIXEL_ENCODING_YCBCR420)
params.timing.pix_clk_100hz /= 2;
pipe_ctx->stream_res.stream_enc->funcs->dp_unblank(pipe_ctx->stream_res.stream_enc, &params);
}
if (link->local_sink && link->local_sink->sink_signal == SIGNAL_TYPE_EDP) {
link->dc->hwss.edp_backlight_control(link, true);
}
}
static const struct hw_sequencer_funcs dcn10_funcs = { static const struct hw_sequencer_funcs dcn10_funcs = {
.program_gamut_remap = program_gamut_remap, .program_gamut_remap = program_gamut_remap,
.init_hw = dcn10_init_hw, .init_hw = dcn10_init_hw,
...@@ -2921,7 +2944,7 @@ static const struct hw_sequencer_funcs dcn10_funcs = { ...@@ -2921,7 +2944,7 @@ static const struct hw_sequencer_funcs dcn10_funcs = {
.update_info_frame = dce110_update_info_frame, .update_info_frame = dce110_update_info_frame,
.enable_stream = dce110_enable_stream, .enable_stream = dce110_enable_stream,
.disable_stream = dce110_disable_stream, .disable_stream = dce110_disable_stream,
.unblank_stream = dce110_unblank_stream, .unblank_stream = dcn10_unblank_stream,
.blank_stream = dce110_blank_stream, .blank_stream = dce110_blank_stream,
.enable_audio_stream = dce110_enable_audio_stream, .enable_audio_stream = dce110_enable_audio_stream,
.disable_audio_stream = dce110_disable_audio_stream, .disable_audio_stream = dce110_disable_audio_stream,
......
...@@ -836,14 +836,15 @@ void enc1_stream_encoder_dp_unblank( ...@@ -836,14 +836,15 @@ void enc1_stream_encoder_dp_unblank(
uint64_t m_vid_l = n_vid; uint64_t m_vid_l = n_vid;
/* YCbCr 4:2:0 : Computed VID_M will be 2X the input rate */ /* YCbCr 4:2:0 : Computed VID_M will be 2X the input rate */
if (param->pixel_encoding == PIXEL_ENCODING_YCBCR420) if (param->timing.pixel_encoding == PIXEL_ENCODING_YCBCR420) {
/*this param->pixel_clk_khz is half of 444 rate for 420 already*/
n_multiply = 1; n_multiply = 1;
}
/* M / N = Fstream / Flink /* M / N = Fstream / Flink
* m_vid / n_vid = pixel rate / link rate * m_vid / n_vid = pixel rate / link rate
*/ */
m_vid_l *= param->pixel_clk_khz; m_vid_l *= param->timing.pix_clk_100hz / 10;
m_vid_l = div_u64(m_vid_l, m_vid_l = div_u64(m_vid_l,
param->link_settings.link_rate param->link_settings.link_rate
* LINK_RATE_REF_FREQ_IN_KHZ); * LINK_RATE_REF_FREQ_IN_KHZ);
......
...@@ -67,8 +67,7 @@ struct encoder_info_frame { ...@@ -67,8 +67,7 @@ struct encoder_info_frame {
struct encoder_unblank_param { struct encoder_unblank_param {
struct dc_link_settings link_settings; struct dc_link_settings link_settings;
unsigned int pixel_clk_khz; struct dc_crtc_timing timing;
enum dc_pixel_encoding pixel_encoding;
}; };
struct encoder_set_dp_phy_pattern_param { struct encoder_set_dp_phy_pattern_param {
......
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