mirror of
https://github.com/torvalds/linux.git
synced 2026-05-29 09:33:31 +02:00
drm/connector: Allow clearing HDMI infoframes
Our infoframe setting code currently lacks the ability to clear
infoframes. For some of the infoframes, we only need to replace them,
so if an error occurred when generating a new infoframe we would leave
a stale frame instead of clearing the frame.
However, the Dynamic Range and Mastering (DRM) infoframe should only
be present when displaying HDR content (ie: the HDR_OUTPUT_METADATA blob
is set). If we can't clear infoframes, the stale DRM infoframe will
remain and we can never set the display back to SDR mode.
With this change, we clear infoframes when they can not, or should not,
be generated. This fixes switching to an SDR mode from an HDR one.
Fixes: f378b77227 ("drm/connector: hdmi: Add Infoframes generation")
Signed-off-by: Derek Foreman <derek.foreman@collabora.com>
Reviewed-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20241202181939.724011-1-derek.foreman@collabora.com
Signed-off-by: Maxime Ripard <mripard@kernel.org>
This commit is contained in:
parent
9ce43bba65
commit
d34357743b
|
|
@ -347,6 +347,8 @@ static int hdmi_generate_avi_infoframe(const struct drm_connector *connector,
|
|||
is_limited_range ? HDMI_QUANTIZATION_RANGE_LIMITED : HDMI_QUANTIZATION_RANGE_FULL;
|
||||
int ret;
|
||||
|
||||
infoframe->set = false;
|
||||
|
||||
ret = drm_hdmi_avi_infoframe_from_display_mode(frame, connector, mode);
|
||||
if (ret)
|
||||
return ret;
|
||||
|
|
@ -376,6 +378,8 @@ static int hdmi_generate_spd_infoframe(const struct drm_connector *connector,
|
|||
&infoframe->data.spd;
|
||||
int ret;
|
||||
|
||||
infoframe->set = false;
|
||||
|
||||
ret = hdmi_spd_infoframe_init(frame,
|
||||
connector->hdmi.vendor,
|
||||
connector->hdmi.product);
|
||||
|
|
@ -398,6 +402,8 @@ static int hdmi_generate_hdr_infoframe(const struct drm_connector *connector,
|
|||
&infoframe->data.drm;
|
||||
int ret;
|
||||
|
||||
infoframe->set = false;
|
||||
|
||||
if (connector->max_bpc < 10)
|
||||
return 0;
|
||||
|
||||
|
|
@ -425,6 +431,8 @@ static int hdmi_generate_hdmi_vendor_infoframe(const struct drm_connector *conne
|
|||
&infoframe->data.vendor.hdmi;
|
||||
int ret;
|
||||
|
||||
infoframe->set = false;
|
||||
|
||||
if (!info->has_hdmi_infoframe)
|
||||
return 0;
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user