diff options
Diffstat (limited to 'meta-amd-bsp/recipes-kernel/linux-4.19/linux-yocto-4.19.8/1083-drm-amd-display-Add-new-infopacket-definition.patch')
-rw-r--r-- | meta-amd-bsp/recipes-kernel/linux-4.19/linux-yocto-4.19.8/1083-drm-amd-display-Add-new-infopacket-definition.patch | 188 |
1 files changed, 188 insertions, 0 deletions
diff --git a/meta-amd-bsp/recipes-kernel/linux-4.19/linux-yocto-4.19.8/1083-drm-amd-display-Add-new-infopacket-definition.patch b/meta-amd-bsp/recipes-kernel/linux-4.19/linux-yocto-4.19.8/1083-drm-amd-display-Add-new-infopacket-definition.patch new file mode 100644 index 00000000..8b99d2f9 --- /dev/null +++ b/meta-amd-bsp/recipes-kernel/linux-4.19/linux-yocto-4.19.8/1083-drm-amd-display-Add-new-infopacket-definition.patch @@ -0,0 +1,188 @@ +From 1762f63a046fb58a41d52ce3d8560ff7d232dde2 Mon Sep 17 00:00:00 2001 +From: Bayan Zabihiyan <Bayan.Zabihiyan@amd.com> +Date: Thu, 27 Dec 2018 08:43:45 -0500 +Subject: [PATCH 1083/2940] drm/amd/display: Add new infopacket definition + +Modify freesync module to build VTEM infopackets when in HdmiVRR mode + +Signed-off-by: Bayan Zabihiyan <Bayan.Zabihiyan@amd.com> +Reviewed-by: Jun Lei <Jun.Lei@amd.com> +Acked-by: Leo Li <sunpeng.li@amd.com> +Signed-off-by: Alex Deucher <alexander.deucher@amd.com> +--- + .../amd/display/modules/freesync/freesync.c | 94 ++++++++++++++++++- + .../amd/display/modules/inc/mod_freesync.h | 2 +- + .../drm/amd/display/modules/inc/mod_shared.h | 3 +- + 3 files changed, 92 insertions(+), 7 deletions(-) + +diff --git a/drivers/gpu/drm/amd/display/modules/freesync/freesync.c b/drivers/gpu/drm/amd/display/modules/freesync/freesync.c +index d967ac001f59..94a84bc57c7a 100644 +--- a/drivers/gpu/drm/amd/display/modules/freesync/freesync.c ++++ b/drivers/gpu/drm/amd/display/modules/freesync/freesync.c +@@ -461,6 +461,26 @@ bool mod_freesync_get_v_position(struct mod_freesync *mod_freesync, + return false; + } + ++static void build_vrr_infopacket_header_vtem(enum signal_type signal, ++ struct dc_info_packet *infopacket) ++{ ++ // HEADER ++ ++ // HB0, HB1, HB2 indicates PacketType VTEMPacket ++ infopacket->hb0 = 0x7F; ++ infopacket->hb1 = 0xC0; ++ infopacket->hb2 = 0x00; ++ /* HB3 Bit Fields ++ * Reserved :1 = 0 ++ * Sync :1 = 0 ++ * VFR :1 = 1 ++ * Ds_Type :2 = 0 ++ * End :1 = 0 ++ * New :1 = 0 ++ */ ++ infopacket->hb3 = 0x20; ++} ++ + static void build_vrr_infopacket_header_v1(enum signal_type signal, + struct dc_info_packet *infopacket, + unsigned int *payload_size) +@@ -559,6 +579,54 @@ static void build_vrr_infopacket_header_v2(enum signal_type signal, + } + } + ++static void build_vrr_vtem_infopacket_data(const struct dc_stream_state *stream, ++ const struct mod_vrr_params *vrr, ++ struct dc_info_packet *infopacket) ++{ ++ /* dc_info_packet to VtemPacket Translation of Bit-fields, ++ * SB[6] ++ * unsigned char VRR_EN :1 ++ * unsigned char M_CONST :1 ++ * unsigned char Reserved2 :2 ++ * unsigned char FVA_Factor_M1 :4 ++ * SB[7] ++ * unsigned char Base_Vfront :8 ++ * SB[8] ++ * unsigned char Base_Refresh_Rate_98 :2 ++ * unsigned char RB :1 ++ * unsigned char Reserved3 :5 ++ * SB[9] ++ * unsigned char Base_RefreshRate_07 :8 ++ */ ++ unsigned int fieldRateInHz; ++ ++ if (vrr->state == VRR_STATE_ACTIVE_VARIABLE || ++ vrr->state == VRR_STATE_ACTIVE_FIXED){ ++ infopacket->sb[6] |= 0x80; //VRR_EN Bit = 1 ++ } else { ++ infopacket->sb[6] &= 0x7F; //VRR_EN Bit = 0 ++ } ++ ++ if (!stream->timing.vic) { ++ infopacket->sb[7] = stream->timing.v_front_porch; ++ ++ /* TODO: In dal2, we check mode flags for a reduced blanking timing. ++ * Need a way to relay that information to this function. ++ * if("ReducedBlanking") ++ * { ++ * infopacket->sb[8] |= 0x20; //Set 3rd bit to 1 ++ * } ++ */ ++ fieldRateInHz = (stream->timing.pix_clk_100hz * 100)/ ++ (stream->timing.h_total * stream->timing.v_total); ++ ++ infopacket->sb[8] |= ((fieldRateInHz & 0x300) >> 2); ++ infopacket->sb[9] |= fieldRateInHz & 0xFF; ++ ++ } ++ infopacket->valid = true; ++} ++ + static void build_vrr_infopacket_data(const struct mod_vrr_params *vrr, + struct dc_info_packet *infopacket) + { +@@ -672,6 +740,19 @@ static void build_vrr_infopacket_v2(enum signal_type signal, + infopacket->valid = true; + } + ++static void build_vrr_infopacket_vtem(const struct dc_stream_state *stream, ++ const struct mod_vrr_params *vrr, ++ struct dc_info_packet *infopacket) ++{ ++ //VTEM info packet for HdmiVrr ++ ++ //VTEM Packet is structured differently ++ build_vrr_infopacket_header_vtem(stream->signal, infopacket); ++ build_vrr_vtem_infopacket_data(stream, vrr, infopacket); ++ ++ infopacket->valid = true; ++} ++ + void mod_freesync_build_vrr_infopacket(struct mod_freesync *mod_freesync, + const struct dc_stream_state *stream, + const struct mod_vrr_params *vrr, +@@ -679,18 +760,21 @@ void mod_freesync_build_vrr_infopacket(struct mod_freesync *mod_freesync, + const enum color_transfer_func *app_tf, + struct dc_info_packet *infopacket) + { +- /* SPD info packet for FreeSync */ +- +- /* Check if Freesync is supported. Return if false. If true, ++ /* SPD info packet for FreeSync ++ * VTEM info packet for HdmiVRR ++ * Check if Freesync is supported. Return if false. If true, + * set the corresponding bit in the info packet + */ +- if (!vrr->supported || !vrr->send_vsif) ++ if (!vrr->supported || (!vrr->send_info_frame && packet_type != PACKET_TYPE_VTEM)) + return; + + switch (packet_type) { + case PACKET_TYPE_FS2: + build_vrr_infopacket_v2(stream->signal, vrr, app_tf, infopacket); + break; ++ case PACKET_TYPE_VTEM: ++ build_vrr_infopacket_vtem(stream, vrr, infopacket); ++ break; + case PACKET_TYPE_VRR: + case PACKET_TYPE_FS1: + default: +@@ -739,7 +823,7 @@ void mod_freesync_build_vrr_params(struct mod_freesync *mod_freesync, + return; + + in_out_vrr->state = in_config->state; +- in_out_vrr->send_vsif = in_config->vsif_supported; ++ in_out_vrr->send_info_frame = in_config->vsif_supported; + + if (in_config->state == VRR_STATE_UNSUPPORTED) { + in_out_vrr->state = VRR_STATE_UNSUPPORTED; +diff --git a/drivers/gpu/drm/amd/display/modules/inc/mod_freesync.h b/drivers/gpu/drm/amd/display/modules/inc/mod_freesync.h +index 949a8b62aa98..4222e403b151 100644 +--- a/drivers/gpu/drm/amd/display/modules/inc/mod_freesync.h ++++ b/drivers/gpu/drm/amd/display/modules/inc/mod_freesync.h +@@ -104,7 +104,7 @@ struct mod_vrr_params_fixed_refresh { + + struct mod_vrr_params { + bool supported; +- bool send_vsif; ++ bool send_info_frame; + enum mod_vrr_state state; + + uint32_t min_refresh_in_uhz; +diff --git a/drivers/gpu/drm/amd/display/modules/inc/mod_shared.h b/drivers/gpu/drm/amd/display/modules/inc/mod_shared.h +index 1bd02c0ac30c..b711e7e6c204 100644 +--- a/drivers/gpu/drm/amd/display/modules/inc/mod_shared.h ++++ b/drivers/gpu/drm/amd/display/modules/inc/mod_shared.h +@@ -41,7 +41,8 @@ enum color_transfer_func { + enum vrr_packet_type { + PACKET_TYPE_VRR, + PACKET_TYPE_FS1, +- PACKET_TYPE_FS2 ++ PACKET_TYPE_FS2, ++ PACKET_TYPE_VTEM + }; + + +-- +2.17.1 + |