mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/herbert/cryptodev-2.6.git
synced 2026-04-23 05:56:14 -04:00
drm/amd/display: Update VSC HDR infoPacket on TF change
[why] OnSetSourceContentAttribute it does not trigger an update for the VSC with TF change. [how] In this call, create a new VSC infoPacket based on the new config, and allow DisplayTarget decide if an update and pursuant passive flip is necessary Tested-by: Daniel Wheeler <daniel.wheeler@amd.com> Reviewed-by: Krunoslav Kovac <Krunoslav.Kovac@amd.com> Acked-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com> Signed-off-by: Reza Amini <Reza.Amini@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
@@ -130,7 +130,8 @@ enum ColorimetryYCCDP {
|
||||
};
|
||||
|
||||
void mod_build_vsc_infopacket(const struct dc_stream_state *stream,
|
||||
struct dc_info_packet *info_packet)
|
||||
struct dc_info_packet *info_packet,
|
||||
enum dc_color_space cs)
|
||||
{
|
||||
unsigned int vsc_packet_revision = vsc_packet_undefined;
|
||||
unsigned int i;
|
||||
@@ -331,13 +332,13 @@ void mod_build_vsc_infopacket(const struct dc_stream_state *stream,
|
||||
/* Set Colorimetry format based on pixel encoding */
|
||||
switch (stream->timing.pixel_encoding) {
|
||||
case PIXEL_ENCODING_RGB:
|
||||
if ((stream->output_color_space == COLOR_SPACE_SRGB) ||
|
||||
(stream->output_color_space == COLOR_SPACE_SRGB_LIMITED))
|
||||
if ((cs == COLOR_SPACE_SRGB) ||
|
||||
(cs == COLOR_SPACE_SRGB_LIMITED))
|
||||
colorimetryFormat = ColorimetryRGB_DP_sRGB;
|
||||
else if (stream->output_color_space == COLOR_SPACE_ADOBERGB)
|
||||
else if (cs == COLOR_SPACE_ADOBERGB)
|
||||
colorimetryFormat = ColorimetryRGB_DP_AdobeRGB;
|
||||
else if ((stream->output_color_space == COLOR_SPACE_2020_RGB_FULLRANGE) ||
|
||||
(stream->output_color_space == COLOR_SPACE_2020_RGB_LIMITEDRANGE))
|
||||
else if ((cs == COLOR_SPACE_2020_RGB_FULLRANGE) ||
|
||||
(cs == COLOR_SPACE_2020_RGB_LIMITEDRANGE))
|
||||
colorimetryFormat = ColorimetryRGB_DP_ITU_R_BT2020RGB;
|
||||
break;
|
||||
|
||||
@@ -347,13 +348,13 @@ void mod_build_vsc_infopacket(const struct dc_stream_state *stream,
|
||||
/* Note: xvYCC probably not supported correctly here on DP since colorspace translation
|
||||
* loses distinction between BT601 vs xvYCC601 in translation
|
||||
*/
|
||||
if (stream->output_color_space == COLOR_SPACE_YCBCR601)
|
||||
if (cs == COLOR_SPACE_YCBCR601)
|
||||
colorimetryFormat = ColorimetryYCC_DP_ITU601;
|
||||
else if (stream->output_color_space == COLOR_SPACE_YCBCR709)
|
||||
else if (cs == COLOR_SPACE_YCBCR709)
|
||||
colorimetryFormat = ColorimetryYCC_DP_ITU709;
|
||||
else if (stream->output_color_space == COLOR_SPACE_ADOBERGB)
|
||||
else if (cs == COLOR_SPACE_ADOBERGB)
|
||||
colorimetryFormat = ColorimetryYCC_DP_AdobeYCC;
|
||||
else if (stream->output_color_space == COLOR_SPACE_2020_YCBCR)
|
||||
else if (cs == COLOR_SPACE_2020_YCBCR)
|
||||
colorimetryFormat = ColorimetryYCC_DP_ITU2020YCbCr;
|
||||
break;
|
||||
|
||||
@@ -391,8 +392,8 @@ void mod_build_vsc_infopacket(const struct dc_stream_state *stream,
|
||||
}
|
||||
|
||||
/* all YCbCr are always limited range */
|
||||
if ((stream->output_color_space == COLOR_SPACE_SRGB_LIMITED) ||
|
||||
(stream->output_color_space == COLOR_SPACE_2020_RGB_LIMITEDRANGE) ||
|
||||
if ((cs == COLOR_SPACE_SRGB_LIMITED) ||
|
||||
(cs == COLOR_SPACE_2020_RGB_LIMITEDRANGE) ||
|
||||
(pixelEncoding != 0x0)) {
|
||||
info_packet->sb[17] |= 0x80; /* DB17 bit 7 set to 1 for CEA timing. */
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user