]> www.infradead.org Git - users/hch/misc.git/commitdiff
drm/connector: hdmi: allow disabling Audio Infoframe
authorDmitry Baryshkov <dmitry.baryshkov@linaro.org>
Fri, 7 Jun 2024 13:22:58 +0000 (16:22 +0300)
committerDmitry Baryshkov <dmitry.baryshkov@linaro.org>
Wed, 12 Jun 2024 07:55:54 +0000 (10:55 +0300)
Add drm_atomic_helper_connector_hdmi_disable_audio_infoframe(), an API
to allow the driver disable sending the Audio Infoframe. This is to be
used by the drivers if setup of the infoframes is not tightly coupled
with the audio functionality and just disabling the audio playback
doesn't stop the HDMI hardware from sending the Infoframe.

Acked-by: Maxime Ripard <mripard@kernel.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20240607-bridge-hdmi-connector-v5-1-ab384e6021af@linaro.org
Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
drivers/gpu/drm/display/drm_hdmi_state_helper.c
include/drm/display/drm_hdmi_state_helper.h

index 437270c292107f7f546696b7e848f1b233572d95..2dab3ad8ce64962ab3ca78e9f10d3dd42bc376ec 100644 (file)
@@ -714,3 +714,39 @@ drm_atomic_helper_connector_hdmi_update_audio_infoframe(struct drm_connector *co
        return ret;
 }
 EXPORT_SYMBOL(drm_atomic_helper_connector_hdmi_update_audio_infoframe);
+
+/**
+ * drm_atomic_helper_connector_hdmi_disable_audio_infoframe - Stop sending the Audio Infoframe
+ * @connector: A pointer to the HDMI connector
+ *
+ * This function is meant for HDMI connector drivers to stop sending their
+ * audio infoframe. It will typically be used in one of the ALSA hooks
+ * (most likely shutdown).
+ *
+ * Returns:
+ * Zero on success, error code on failure.
+ */
+int
+drm_atomic_helper_connector_hdmi_disable_audio_infoframe(struct drm_connector *connector)
+{
+       struct drm_connector_hdmi_infoframe *infoframe =
+               &connector->hdmi.infoframes.audio;
+       struct drm_display_info *info = &connector->display_info;
+       int ret;
+
+       if (!info->is_hdmi)
+               return 0;
+
+       mutex_lock(&connector->hdmi.infoframes.lock);
+
+       infoframe->set = false;
+
+       ret = clear_infoframe(connector, infoframe);
+
+       memset(&infoframe->data, 0, sizeof(infoframe->data));
+
+       mutex_unlock(&connector->hdmi.infoframes.lock);
+
+       return ret;
+}
+EXPORT_SYMBOL(drm_atomic_helper_connector_hdmi_disable_audio_infoframe);
index eb162ff24de03f9cfaa0aa2e4dea7bf5f20d9750..285f366cf716420166f1422085d85cbd4ee91d10 100644 (file)
@@ -16,6 +16,7 @@ int drm_atomic_helper_connector_hdmi_check(struct drm_connector *connector,
 
 int drm_atomic_helper_connector_hdmi_update_audio_infoframe(struct drm_connector *connector,
                                                            struct hdmi_audio_infoframe *frame);
+int drm_atomic_helper_connector_hdmi_disable_audio_infoframe(struct drm_connector *connector);
 int drm_atomic_helper_connector_hdmi_update_infoframes(struct drm_connector *connector,
                                                       struct drm_atomic_state *state);