Lines Matching +full:audio +full:- +full:hdmi
1 // SPDX-License-Identifier: MIT
13 * __drm_atomic_helper_connector_hdmi_reset() - Initializes all HDMI @drm_connector_state resources
17 * Initializes all HDMI resources from a @drm_connector_state without
18 * actually allocating it. This is useful for HDMI drivers, in
25 unsigned int max_bpc = connector->max_bpc; in __drm_atomic_helper_connector_hdmi_reset()
27 new_conn_state->max_bpc = max_bpc; in __drm_atomic_helper_connector_hdmi_reset()
28 new_conn_state->max_requested_bpc = max_bpc; in __drm_atomic_helper_connector_hdmi_reset()
29 new_conn_state->hdmi.broadcast_rgb = DRM_HDMI_BROADCAST_RGB_AUTO; in __drm_atomic_helper_connector_hdmi_reset()
40 state = conn_state->state; in connector_state_get_mode()
44 crtc = conn_state->crtc; in connector_state_get_mode()
52 return &crtc_state->mode; in connector_state_get_mode()
58 const struct drm_display_info *info = &connector->display_info; in hdmi_is_limited_range()
67 if (conn_state->hdmi.output_format != HDMI_COLORSPACE_RGB) in hdmi_is_limited_range()
70 if (conn_state->hdmi.broadcast_rgb == DRM_HDMI_BROADCAST_RGB_FULL) in hdmi_is_limited_range()
73 if (conn_state->hdmi.broadcast_rgb == DRM_HDMI_BROADCAST_RGB_LIMITED) in hdmi_is_limited_range()
76 if (!info->is_hdmi) in hdmi_is_limited_range()
88 struct drm_device *dev = connector->dev; in sink_supports_format_bpc()
92 * CTA-861-F, section 5.4 - Color Coding & Quantization states in sink_supports_format_bpc()
106 if (!info->is_hdmi && in sink_supports_format_bpc()
112 if (!(connector->hdmi.supported_formats & BIT(format))) { in sink_supports_format_bpc()
124 * is not an HDMI compliant EDID for some reason, the in sink_supports_format_bpc()
130 if (!(info->color_formats & DRM_COLOR_FORMAT_RGB444)) in sink_supports_format_bpc()
131 drm_warn(dev, "HDMI Sink doesn't support RGB, something's wrong.\n"); in sink_supports_format_bpc()
133 if (bpc == 10 && !(info->edid_hdmi_rgb444_dc_modes & DRM_EDID_HDMI_DC_30)) { in sink_supports_format_bpc()
138 if (bpc == 12 && !(info->edid_hdmi_rgb444_dc_modes & DRM_EDID_HDMI_DC_36)) { in sink_supports_format_bpc()
155 if (!(info->color_formats & DRM_COLOR_FORMAT_YCBCR422)) { in sink_supports_format_bpc()
166 * HDMI Spec 1.3 - Section 6.5 Pixel Encodings and Color Depth in sink_supports_format_bpc()
178 if (!(info->color_formats & DRM_COLOR_FORMAT_YCBCR444)) { in sink_supports_format_bpc()
183 if (bpc == 10 && !(info->edid_hdmi_ycbcr444_dc_modes & DRM_EDID_HDMI_DC_30)) { in sink_supports_format_bpc()
188 if (bpc == 12 && !(info->edid_hdmi_ycbcr444_dc_modes & DRM_EDID_HDMI_DC_36)) { in sink_supports_format_bpc()
207 const struct drm_connector_hdmi_funcs *funcs = connector->hdmi.funcs; in hdmi_clock_valid()
208 const struct drm_display_info *info = &connector->display_info; in hdmi_clock_valid()
210 if (info->max_tmds_clock && clock > info->max_tmds_clock * 1000) in hdmi_clock_valid()
213 if (funcs && funcs->tmds_char_rate_valid) { in hdmi_clock_valid()
216 status = funcs->tmds_char_rate_valid(connector, mode, clock); in hdmi_clock_valid()
235 return -EINVAL; in hdmi_compute_clock()
239 return -EINVAL; in hdmi_compute_clock()
241 conn_state->hdmi.tmds_char_rate = clock; in hdmi_compute_clock()
252 const struct drm_display_info *info = &connector->display_info; in hdmi_try_format_bpc()
253 struct drm_device *dev = connector->dev; in hdmi_try_format_bpc()
276 bpc, conn_state->hdmi.tmds_char_rate); in hdmi_try_format_bpc()
287 struct drm_device *dev = connector->dev; in hdmi_compute_format()
290 * TODO: Add support for YCbCr420 output for HDMI 2.0 capable in hdmi_compute_format()
294 conn_state->hdmi.output_format = HDMI_COLORSPACE_RGB; in hdmi_compute_format()
300 return -EINVAL; in hdmi_compute_format()
308 struct drm_device *dev = connector->dev; in hdmi_compute_config()
310 conn_state->max_bpc, in hdmi_compute_config()
311 8, connector->max_bpc); in hdmi_compute_config()
315 for (bpc = max_bpc; bpc >= 8; bpc -= 2) { in hdmi_compute_config()
322 conn_state->hdmi.output_bpc = bpc; in hdmi_compute_config()
326 mode->hdisplay, mode->vdisplay, drm_mode_vrefresh(mode), in hdmi_compute_config()
327 conn_state->hdmi.output_bpc, in hdmi_compute_config()
328 drm_hdmi_connector_get_output_format_name(conn_state->hdmi.output_format), in hdmi_compute_config()
329 conn_state->hdmi.tmds_char_rate); in hdmi_compute_config()
334 return -EINVAL; in hdmi_compute_config()
343 &conn_state->hdmi.infoframes.avi; in hdmi_generate_avi_infoframe()
345 &infoframe->data.avi; in hdmi_generate_avi_infoframe()
346 bool is_limited_range = conn_state->hdmi.is_limited_range; in hdmi_generate_avi_infoframe()
351 infoframe->set = false; in hdmi_generate_avi_infoframe()
357 frame->colorspace = conn_state->hdmi.output_format; in hdmi_generate_avi_infoframe()
368 infoframe->set = true; in hdmi_generate_avi_infoframe()
377 &conn_state->hdmi.infoframes.spd; in hdmi_generate_spd_infoframe()
379 &infoframe->data.spd; in hdmi_generate_spd_infoframe()
382 infoframe->set = false; in hdmi_generate_spd_infoframe()
385 connector->hdmi.vendor, in hdmi_generate_spd_infoframe()
386 connector->hdmi.product); in hdmi_generate_spd_infoframe()
390 frame->sdi = HDMI_SPD_SDI_PC; in hdmi_generate_spd_infoframe()
392 infoframe->set = true; in hdmi_generate_spd_infoframe()
401 &conn_state->hdmi.infoframes.hdr_drm; in hdmi_generate_hdr_infoframe()
403 &infoframe->data.drm; in hdmi_generate_hdr_infoframe()
406 infoframe->set = false; in hdmi_generate_hdr_infoframe()
408 if (connector->max_bpc < 10) in hdmi_generate_hdr_infoframe()
411 if (!conn_state->hdr_output_metadata) in hdmi_generate_hdr_infoframe()
418 infoframe->set = true; in hdmi_generate_hdr_infoframe()
426 const struct drm_display_info *info = &connector->display_info; in hdmi_generate_hdmi_vendor_infoframe()
430 &conn_state->hdmi.infoframes.hdmi; in hdmi_generate_hdmi_vendor_infoframe()
432 &infoframe->data.vendor.hdmi; in hdmi_generate_hdmi_vendor_infoframe()
435 infoframe->set = false; in hdmi_generate_hdmi_vendor_infoframe()
437 if (!info->has_hdmi_infoframe) in hdmi_generate_hdmi_vendor_infoframe()
444 infoframe->set = true; in hdmi_generate_hdmi_vendor_infoframe()
453 const struct drm_display_info *info = &connector->display_info; in hdmi_generate_infoframes()
456 if (!info->is_hdmi) in hdmi_generate_infoframes()
468 * Audio Infoframes will be generated by ALSA, and updated by in hdmi_generate_infoframes()
484 * drm_atomic_helper_connector_hdmi_check() - Helper to check HDMI connector atomic state
488 * Provides a default connector state check handler for HDMI connectors.
506 if (!new_conn_state->crtc || !new_conn_state->best_encoder) in drm_atomic_helper_connector_hdmi_check()
509 new_conn_state->hdmi.is_limited_range = hdmi_is_limited_range(connector, new_conn_state); in drm_atomic_helper_connector_hdmi_check()
519 if (old_conn_state->hdmi.broadcast_rgb != new_conn_state->hdmi.broadcast_rgb || in drm_atomic_helper_connector_hdmi_check()
520 old_conn_state->hdmi.output_bpc != new_conn_state->hdmi.output_bpc || in drm_atomic_helper_connector_hdmi_check()
521 old_conn_state->hdmi.output_format != new_conn_state->hdmi.output_format) { in drm_atomic_helper_connector_hdmi_check()
522 struct drm_crtc *crtc = new_conn_state->crtc; in drm_atomic_helper_connector_hdmi_check()
529 crtc_state->mode_changed = true; in drm_atomic_helper_connector_hdmi_check()
537 * drm_hdmi_connector_mode_valid() - Check if mode is valid for HDMI connector
541 * Generic .mode_valid implementation for HDMI connectors.
560 const struct drm_connector_hdmi_funcs *funcs = connector->hdmi.funcs; in clear_device_infoframe()
561 struct drm_device *dev = connector->dev; in clear_device_infoframe()
566 if (!funcs || !funcs->clear_infoframe) { in clear_device_infoframe()
571 ret = funcs->clear_infoframe(connector, type); in clear_device_infoframe()
585 ret = clear_device_infoframe(connector, old_frame->data.any.type); in clear_infoframe()
595 const struct drm_connector_hdmi_funcs *funcs = connector->hdmi.funcs; in write_device_infoframe()
596 struct drm_device *dev = connector->dev; in write_device_infoframe()
601 drm_dbg_kms(dev, "Writing infoframe type %x\n", frame->any.type); in write_device_infoframe()
603 if (!funcs || !funcs->write_infoframe) { in write_device_infoframe()
605 return -EINVAL; in write_device_infoframe()
612 ret = funcs->write_infoframe(connector, frame->any.type, buffer, len); in write_device_infoframe()
626 ret = write_device_infoframe(connector, &new_frame->data); in write_infoframe()
637 if (new_frame->set) in write_or_clear_infoframe()
640 if (old_frame->set && !new_frame->set) in write_or_clear_infoframe()
647 * drm_atomic_helper_connector_hdmi_update_infoframes - Update the Infoframes
648 * @connector: A pointer to the HDMI connector
649 * @state: The HDMI connector state to generate the infoframe from
651 * This function is meant for HDMI connector drivers to write their
665 struct drm_display_info *info = &connector->display_info; in drm_atomic_helper_connector_hdmi_update_infoframes()
668 if (!info->is_hdmi) in drm_atomic_helper_connector_hdmi_update_infoframes()
671 mutex_lock(&connector->hdmi.infoframes.lock); in drm_atomic_helper_connector_hdmi_update_infoframes()
674 &old_conn_state->hdmi.infoframes.avi, in drm_atomic_helper_connector_hdmi_update_infoframes()
675 &new_conn_state->hdmi.infoframes.avi); in drm_atomic_helper_connector_hdmi_update_infoframes()
679 if (connector->hdmi.infoframes.audio.set) { in drm_atomic_helper_connector_hdmi_update_infoframes()
681 &connector->hdmi.infoframes.audio); in drm_atomic_helper_connector_hdmi_update_infoframes()
687 &old_conn_state->hdmi.infoframes.hdr_drm, in drm_atomic_helper_connector_hdmi_update_infoframes()
688 &new_conn_state->hdmi.infoframes.hdr_drm); in drm_atomic_helper_connector_hdmi_update_infoframes()
693 &old_conn_state->hdmi.infoframes.spd, in drm_atomic_helper_connector_hdmi_update_infoframes()
694 &new_conn_state->hdmi.infoframes.spd); in drm_atomic_helper_connector_hdmi_update_infoframes()
698 if (info->has_hdmi_infoframe) { in drm_atomic_helper_connector_hdmi_update_infoframes()
700 &old_conn_state->hdmi.infoframes.hdmi, in drm_atomic_helper_connector_hdmi_update_infoframes()
701 &new_conn_state->hdmi.infoframes.hdmi); in drm_atomic_helper_connector_hdmi_update_infoframes()
707 mutex_unlock(&connector->hdmi.infoframes.lock); in drm_atomic_helper_connector_hdmi_update_infoframes()
713 * drm_atomic_helper_connector_hdmi_update_audio_infoframe - Update the Audio Infoframe
714 * @connector: A pointer to the HDMI connector
715 * @frame: A pointer to the audio infoframe to write
717 * This function is meant for HDMI connector drivers to update their
718 * audio infoframe. It will typically be used in one of the ALSA hooks
729 &connector->hdmi.infoframes.audio; in drm_atomic_helper_connector_hdmi_update_audio_infoframe()
730 struct drm_display_info *info = &connector->display_info; in drm_atomic_helper_connector_hdmi_update_audio_infoframe()
733 if (!info->is_hdmi) in drm_atomic_helper_connector_hdmi_update_audio_infoframe()
736 mutex_lock(&connector->hdmi.infoframes.lock); in drm_atomic_helper_connector_hdmi_update_audio_infoframe()
738 memcpy(&infoframe->data, frame, sizeof(infoframe->data)); in drm_atomic_helper_connector_hdmi_update_audio_infoframe()
739 infoframe->set = true; in drm_atomic_helper_connector_hdmi_update_audio_infoframe()
743 mutex_unlock(&connector->hdmi.infoframes.lock); in drm_atomic_helper_connector_hdmi_update_audio_infoframe()
750 * drm_atomic_helper_connector_hdmi_clear_audio_infoframe - Stop sending the Audio Infoframe
751 * @connector: A pointer to the HDMI connector
753 * This function is meant for HDMI connector drivers to stop sending their
754 * audio infoframe. It will typically be used in one of the ALSA hooks
764 &connector->hdmi.infoframes.audio; in drm_atomic_helper_connector_hdmi_clear_audio_infoframe()
765 struct drm_display_info *info = &connector->display_info; in drm_atomic_helper_connector_hdmi_clear_audio_infoframe()
768 if (!info->is_hdmi) in drm_atomic_helper_connector_hdmi_clear_audio_infoframe()
771 mutex_lock(&connector->hdmi.infoframes.lock); in drm_atomic_helper_connector_hdmi_clear_audio_infoframe()
773 infoframe->set = false; in drm_atomic_helper_connector_hdmi_clear_audio_infoframe()
777 memset(&infoframe->data, 0, sizeof(infoframe->data)); in drm_atomic_helper_connector_hdmi_clear_audio_infoframe()
779 mutex_unlock(&connector->hdmi.infoframes.lock); in drm_atomic_helper_connector_hdmi_clear_audio_infoframe()
792 // TODO: also handle CEC and scramber, HDMI sink disconnected. in drm_atomic_helper_connector_hdmi_update()
798 if (connector->hdmi.funcs->read_edid) in drm_atomic_helper_connector_hdmi_update()
799 drm_edid = connector->hdmi.funcs->read_edid(connector); in drm_atomic_helper_connector_hdmi_update()
808 // TODO: also handle CEC and scramber, HDMI sink is now connected. in drm_atomic_helper_connector_hdmi_update()
814 * drm_atomic_helper_connector_hdmi_hotplug - Handle the hotplug event for the HDMI connector
815 * @connector: A pointer to the HDMI connector
819 * callbacks, updating the HDMI-specific connector's data.
829 * drm_atomic_helper_connector_hdmi_force - HDMI Connector implementation of the force callback
830 * @connector: A pointer to the HDMI connector
832 * This function implements the .force() callback for the HDMI connectors. It
834 * the .force() callback implementation to maintain the HDMI-specific
839 drm_atomic_helper_connector_hdmi_update(connector, connector->status); in drm_atomic_helper_connector_hdmi_force()