aboutsummaryrefslogtreecommitdiffstats
path: root/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/3030-drm-amd-display-Use-Pixel-clock-in-100Hz-units-for-H.patch
diff options
context:
space:
mode:
Diffstat (limited to 'meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/3030-drm-amd-display-Use-Pixel-clock-in-100Hz-units-for-H.patch')
-rw-r--r--meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/3030-drm-amd-display-Use-Pixel-clock-in-100Hz-units-for-H.patch316
1 files changed, 316 insertions, 0 deletions
diff --git a/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/3030-drm-amd-display-Use-Pixel-clock-in-100Hz-units-for-H.patch b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/3030-drm-amd-display-Use-Pixel-clock-in-100Hz-units-for-H.patch
new file mode 100644
index 00000000..3f3dec2c
--- /dev/null
+++ b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.19.8/3030-drm-amd-display-Use-Pixel-clock-in-100Hz-units-for-H.patch
@@ -0,0 +1,316 @@
+From 0052bb274197e3f3e6832242f9440692f64d057c Mon Sep 17 00:00:00 2001
+From: Nevenko Stupar <Nevenko.Stupar@amd.com>
+Date: Tue, 11 Jun 2019 17:35:16 -0400
+Subject: [PATCH 3030/4256] drm/amd/display:Use Pixel clock in 100Hz units for
+ HDMI Audio wall clock DTO
+
+[Why]
+-Pass and use pixel clock in 100 Hz to Audio for HDMI
+audio DTO for Audio wall clock programming so audio DTO gets
+increased precision for timings with /1001 factor.
+-For HDMI TMDS for N and CTS ACR tables are based on 10 KHz
+units, these does not need to be modified as N and CTS values
+are still valid using current tables.
+
+Signed-off-by: Nevenko Stupar <Nevenko.Stupar@amd.com>
+Reviewed-by: Charlene Liu <Charlene.Liu@amd.com>
+Acked-by: Leo Li <sunpeng.li@amd.com>
+---
+ .../gpu/drm/amd/display/dc/dce/dce_audio.c | 28 ++++++++---------
+ .../amd/display/dc/dce/dce_stream_encoder.c | 30 +++++++++----------
+ .../display/dc/dce110/dce110_hw_sequencer.c | 22 +++++++-------
+ .../display/dc/dcn10/dcn10_stream_encoder.c | 30 +++++++++----------
+ .../display/dc/dcn10/dcn10_stream_encoder.h | 4 +--
+ .../gpu/drm/amd/display/include/audio_types.h | 4 +--
+ 6 files changed, 59 insertions(+), 59 deletions(-)
+
+diff --git a/drivers/gpu/drm/amd/display/dc/dce/dce_audio.c b/drivers/gpu/drm/amd/display/dc/dce/dce_audio.c
+index d43d5d924c19..ad7bc7d44268 100644
+--- a/drivers/gpu/drm/amd/display/dc/dce/dce_audio.c
++++ b/drivers/gpu/drm/amd/display/dc/dce/dce_audio.c
+@@ -143,20 +143,20 @@ static void check_audio_bandwidth_hdmi(
+ if (channel_count > 2) {
+
+ /* Based on HDMI spec 1.3 Table 7.5 */
+- if ((crtc_info->requested_pixel_clock <= 27000) &&
++ if ((crtc_info->requested_pixel_clock_100Hz <= 270000) &&
+ (crtc_info->v_active <= 576) &&
+ !(crtc_info->interlaced) &&
+ !(crtc_info->pixel_repetition == 2 ||
+ crtc_info->pixel_repetition == 4)) {
+ limit_freq_to_48_khz = true;
+
+- } else if ((crtc_info->requested_pixel_clock <= 27000) &&
++ } else if ((crtc_info->requested_pixel_clock_100Hz <= 270000) &&
+ (crtc_info->v_active <= 576) &&
+ (crtc_info->interlaced) &&
+ (crtc_info->pixel_repetition == 2)) {
+ limit_freq_to_88_2_khz = true;
+
+- } else if ((crtc_info->requested_pixel_clock <= 54000) &&
++ } else if ((crtc_info->requested_pixel_clock_100Hz <= 540000) &&
+ (crtc_info->v_active <= 576) &&
+ !(crtc_info->interlaced)) {
+ limit_freq_to_174_4_khz = true;
+@@ -735,8 +735,8 @@ void dce_aud_az_configure(
+
+ /* search pixel clock value for Azalia HDMI Audio */
+ static void get_azalia_clock_info_hdmi(
+- uint32_t crtc_pixel_clock_in_khz,
+- uint32_t actual_pixel_clock_in_khz,
++ uint32_t crtc_pixel_clock_100hz,
++ uint32_t actual_pixel_clock_100Hz,
+ struct azalia_clock_info *azalia_clock_info)
+ {
+ /* audio_dto_phase= 24 * 10,000;
+@@ -747,11 +747,11 @@ static void get_azalia_clock_info_hdmi(
+ /* audio_dto_module = PCLKFrequency * 10,000;
+ * [khz] -> [100Hz] */
+ azalia_clock_info->audio_dto_module =
+- actual_pixel_clock_in_khz * 10;
++ actual_pixel_clock_100Hz;
+ }
+
+ static void get_azalia_clock_info_dp(
+- uint32_t requested_pixel_clock_in_khz,
++ uint32_t requested_pixel_clock_100Hz,
+ const struct audio_pll_info *pll_info,
+ struct azalia_clock_info *azalia_clock_info)
+ {
+@@ -790,15 +790,15 @@ void dce_aud_wall_dto_setup(
+
+ /* calculate DTO settings */
+ get_azalia_clock_info_hdmi(
+- crtc_info->requested_pixel_clock,
+- crtc_info->calculated_pixel_clock,
++ crtc_info->requested_pixel_clock_100Hz,
++ crtc_info->calculated_pixel_clock_100Hz,
+ &clock_info);
+
+- DC_LOG_HW_AUDIO("\n%s:Input::requested_pixel_clock = %d"\
+- "calculated_pixel_clock =%d\n"\
++ DC_LOG_HW_AUDIO("\n%s:Input::requested_pixel_clock_100Hz = %d"\
++ "calculated_pixel_clock_100Hz =%d\n"\
+ "audio_dto_module = %d audio_dto_phase =%d \n\n", __func__,\
+- crtc_info->requested_pixel_clock,\
+- crtc_info->calculated_pixel_clock,\
++ crtc_info->requested_pixel_clock_100Hz,\
++ crtc_info->calculated_pixel_clock_100Hz,\
+ clock_info.audio_dto_module,\
+ clock_info.audio_dto_phase);
+
+@@ -831,7 +831,7 @@ void dce_aud_wall_dto_setup(
+
+ calculate DTO settings */
+ get_azalia_clock_info_dp(
+- crtc_info->requested_pixel_clock,
++ crtc_info->requested_pixel_clock_100Hz,
+ pll_info,
+ &clock_info);
+
+diff --git a/drivers/gpu/drm/amd/display/dc/dce/dce_stream_encoder.c b/drivers/gpu/drm/amd/display/dc/dce/dce_stream_encoder.c
+index d13e05a1937d..bd353796b767 100644
+--- a/drivers/gpu/drm/amd/display/dc/dce/dce_stream_encoder.c
++++ b/drivers/gpu/drm/amd/display/dc/dce/dce_stream_encoder.c
+@@ -1249,13 +1249,13 @@ static uint32_t calc_max_audio_packets_per_line(
+
+ static void get_audio_clock_info(
+ enum dc_color_depth color_depth,
+- uint32_t crtc_pixel_clock_in_khz,
+- uint32_t actual_pixel_clock_in_khz,
++ uint32_t crtc_pixel_clock_100Hz,
++ uint32_t actual_pixel_clock_100Hz,
+ struct audio_clock_info *audio_clock_info)
+ {
+ const struct audio_clock_info *clock_info;
+ uint32_t index;
+- uint32_t crtc_pixel_clock_in_10khz = crtc_pixel_clock_in_khz / 10;
++ uint32_t crtc_pixel_clock_in_10khz = crtc_pixel_clock_100Hz / 100;
+ uint32_t audio_array_size;
+
+ switch (color_depth) {
+@@ -1292,16 +1292,16 @@ static void get_audio_clock_info(
+ }
+
+ /* not found */
+- if (actual_pixel_clock_in_khz == 0)
+- actual_pixel_clock_in_khz = crtc_pixel_clock_in_khz;
++ if (actual_pixel_clock_100Hz == 0)
++ actual_pixel_clock_100Hz = crtc_pixel_clock_100Hz;
+
+ /* See HDMI spec the table entry under
+ * pixel clock of "Other". */
+ audio_clock_info->pixel_clock_in_10khz =
+- actual_pixel_clock_in_khz / 10;
+- audio_clock_info->cts_32khz = actual_pixel_clock_in_khz;
+- audio_clock_info->cts_44khz = actual_pixel_clock_in_khz;
+- audio_clock_info->cts_48khz = actual_pixel_clock_in_khz;
++ actual_pixel_clock_100Hz / 100;
++ audio_clock_info->cts_32khz = actual_pixel_clock_100Hz / 10;
++ audio_clock_info->cts_44khz = actual_pixel_clock_100Hz / 10;
++ audio_clock_info->cts_48khz = actual_pixel_clock_100Hz / 10;
+
+ audio_clock_info->n_32khz = 4096;
+ audio_clock_info->n_44khz = 6272;
+@@ -1367,14 +1367,14 @@ static void dce110_se_setup_hdmi_audio(
+
+ /* Program audio clock sample/regeneration parameters */
+ get_audio_clock_info(crtc_info->color_depth,
+- crtc_info->requested_pixel_clock,
+- crtc_info->calculated_pixel_clock,
++ crtc_info->requested_pixel_clock_100Hz,
++ crtc_info->calculated_pixel_clock_100Hz,
+ &audio_clock_info);
+ DC_LOG_HW_AUDIO(
+- "\n%s:Input::requested_pixel_clock = %d" \
+- "calculated_pixel_clock = %d \n", __func__, \
+- crtc_info->requested_pixel_clock, \
+- crtc_info->calculated_pixel_clock);
++ "\n%s:Input::requested_pixel_clock_100Hz = %d" \
++ "calculated_pixel_clock_100Hz = %d \n", __func__, \
++ crtc_info->requested_pixel_clock_100Hz, \
++ crtc_info->calculated_pixel_clock_100Hz);
+
+ /* HDMI_ACR_32_0__HDMI_ACR_CTS_32_MASK */
+ REG_UPDATE(HDMI_ACR_32_0, HDMI_ACR_CTS_32, audio_clock_info.cts_32khz);
+diff --git a/drivers/gpu/drm/amd/display/dc/dce110/dce110_hw_sequencer.c b/drivers/gpu/drm/amd/display/dc/dce110/dce110_hw_sequencer.c
+index 84d90b475e2a..6fa1f6b5375b 100644
+--- a/drivers/gpu/drm/amd/display/dc/dce110/dce110_hw_sequencer.c
++++ b/drivers/gpu/drm/amd/display/dc/dce110/dce110_hw_sequencer.c
+@@ -1159,27 +1159,27 @@ static void build_audio_output(
+ stream->timing.flags.INTERLACE;
+
+ audio_output->crtc_info.refresh_rate =
+- (stream->timing.pix_clk_100hz*10000)/
++ (stream->timing.pix_clk_100hz*100)/
+ (stream->timing.h_total*stream->timing.v_total);
+
+ audio_output->crtc_info.color_depth =
+ stream->timing.display_color_depth;
+
+- audio_output->crtc_info.requested_pixel_clock =
+- pipe_ctx->stream_res.pix_clk_params.requested_pix_clk_100hz / 10;
++ audio_output->crtc_info.requested_pixel_clock_100Hz =
++ pipe_ctx->stream_res.pix_clk_params.requested_pix_clk_100hz;
+
+- audio_output->crtc_info.calculated_pixel_clock =
+- pipe_ctx->stream_res.pix_clk_params.requested_pix_clk_100hz / 10;
++ audio_output->crtc_info.calculated_pixel_clock_100Hz =
++ pipe_ctx->stream_res.pix_clk_params.requested_pix_clk_100hz;
+
+ /*for HDMI, audio ACR is with deep color ratio factor*/
+ if (dc_is_hdmi_signal(pipe_ctx->stream->signal) &&
+- audio_output->crtc_info.requested_pixel_clock ==
+- (stream->timing.pix_clk_100hz / 10)) {
++ audio_output->crtc_info.requested_pixel_clock_100Hz ==
++ (stream->timing.pix_clk_100hz)) {
+ if (pipe_ctx->stream_res.pix_clk_params.pixel_encoding == PIXEL_ENCODING_YCBCR420) {
+- audio_output->crtc_info.requested_pixel_clock =
+- audio_output->crtc_info.requested_pixel_clock/2;
+- audio_output->crtc_info.calculated_pixel_clock =
+- pipe_ctx->stream_res.pix_clk_params.requested_pix_clk_100hz/20;
++ audio_output->crtc_info.requested_pixel_clock_100Hz =
++ audio_output->crtc_info.requested_pixel_clock_100Hz/2;
++ audio_output->crtc_info.calculated_pixel_clock_100Hz =
++ pipe_ctx->stream_res.pix_clk_params.requested_pix_clk_100hz/2;
+
+ }
+ }
+diff --git a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_stream_encoder.c b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_stream_encoder.c
+index 2d15ae664226..64adb9fb300c 100644
+--- a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_stream_encoder.c
++++ b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_stream_encoder.c
+@@ -1195,13 +1195,13 @@ static union audio_cea_channels speakers_to_channels(
+
+ void get_audio_clock_info(
+ enum dc_color_depth color_depth,
+- uint32_t crtc_pixel_clock_in_khz,
+- uint32_t actual_pixel_clock_in_khz,
++ uint32_t crtc_pixel_clock_100Hz,
++ uint32_t actual_pixel_clock_100Hz,
+ struct audio_clock_info *audio_clock_info)
+ {
+ const struct audio_clock_info *clock_info;
+ uint32_t index;
+- uint32_t crtc_pixel_clock_in_10khz = crtc_pixel_clock_in_khz / 10;
++ uint32_t crtc_pixel_clock_in_10khz = crtc_pixel_clock_100Hz / 100;
+ uint32_t audio_array_size;
+
+ switch (color_depth) {
+@@ -1238,16 +1238,16 @@ void get_audio_clock_info(
+ }
+
+ /* not found */
+- if (actual_pixel_clock_in_khz == 0)
+- actual_pixel_clock_in_khz = crtc_pixel_clock_in_khz;
++ if (actual_pixel_clock_100Hz == 0)
++ actual_pixel_clock_100Hz = crtc_pixel_clock_100Hz;
+
+ /* See HDMI spec the table entry under
+ * pixel clock of "Other". */
+ audio_clock_info->pixel_clock_in_10khz =
+- actual_pixel_clock_in_khz / 10;
+- audio_clock_info->cts_32khz = actual_pixel_clock_in_khz;
+- audio_clock_info->cts_44khz = actual_pixel_clock_in_khz;
+- audio_clock_info->cts_48khz = actual_pixel_clock_in_khz;
++ actual_pixel_clock_100Hz / 100;
++ audio_clock_info->cts_32khz = actual_pixel_clock_100Hz / 10;
++ audio_clock_info->cts_44khz = actual_pixel_clock_100Hz / 10;
++ audio_clock_info->cts_48khz = actual_pixel_clock_100Hz / 10;
+
+ audio_clock_info->n_32khz = 4096;
+ audio_clock_info->n_44khz = 6272;
+@@ -1307,14 +1307,14 @@ static void enc1_se_setup_hdmi_audio(
+
+ /* Program audio clock sample/regeneration parameters */
+ get_audio_clock_info(crtc_info->color_depth,
+- crtc_info->requested_pixel_clock,
+- crtc_info->calculated_pixel_clock,
++ crtc_info->requested_pixel_clock_100Hz,
++ crtc_info->calculated_pixel_clock_100Hz,
+ &audio_clock_info);
+ DC_LOG_HW_AUDIO(
+- "\n%s:Input::requested_pixel_clock = %d" \
+- "calculated_pixel_clock = %d \n", __func__, \
+- crtc_info->requested_pixel_clock, \
+- crtc_info->calculated_pixel_clock);
++ "\n%s:Input::requested_pixel_clock_100Hz = %d" \
++ "calculated_pixel_clock_100Hz = %d \n", __func__, \
++ crtc_info->requested_pixel_clock_100Hz, \
++ crtc_info->calculated_pixel_clock_100Hz);
+
+ /* HDMI_ACR_32_0__HDMI_ACR_CTS_32_MASK */
+ REG_UPDATE(HDMI_ACR_32_0, HDMI_ACR_CTS_32, audio_clock_info.cts_32khz);
+diff --git a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_stream_encoder.h b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_stream_encoder.h
+index bc2b4af9543b..075e49c1283a 100644
+--- a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_stream_encoder.h
++++ b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_stream_encoder.h
+@@ -605,8 +605,8 @@ void enc1_se_enable_dp_audio(
+
+ void get_audio_clock_info(
+ enum dc_color_depth color_depth,
+- uint32_t crtc_pixel_clock_in_khz,
+- uint32_t actual_pixel_clock_in_khz,
++ uint32_t crtc_pixel_clock_100Hz,
++ uint32_t actual_pixel_clock_100Hz,
+ struct audio_clock_info *audio_clock_info);
+
+ #endif /* __DC_STREAM_ENCODER_DCN10_H__ */
+diff --git a/drivers/gpu/drm/amd/display/include/audio_types.h b/drivers/gpu/drm/amd/display/include/audio_types.h
+index 6364fbc24cfe..66a54da0641c 100644
+--- a/drivers/gpu/drm/amd/display/include/audio_types.h
++++ b/drivers/gpu/drm/amd/display/include/audio_types.h
+@@ -38,8 +38,8 @@ struct audio_crtc_info {
+ uint32_t h_active;
+ uint32_t v_active;
+ uint32_t pixel_repetition;
+- uint32_t requested_pixel_clock; /* in KHz */
+- uint32_t calculated_pixel_clock; /* in KHz */
++ uint32_t requested_pixel_clock_100Hz; /* in 100Hz */
++ uint32_t calculated_pixel_clock_100Hz; /* in 100Hz */
+ uint32_t refresh_rate;
+ enum dc_color_depth color_depth;
+ bool interlaced;
+--
+2.17.1
+