drm: Add default modes for connectors in unknown state
authorLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Fri, 14 Jun 2013 00:55:25 +0000 (02:55 +0200)
committerLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Tue, 5 Jan 2021 05:19:50 +0000 (07:19 +0200)
The DRM CRTC helpers add default modes to connectors in the connected
state if no mode can be retrieved from the connector. This behaviour is
useful for VGA or DVI outputs that have no connected DDC bus. However,
in such cases, the status of the output usually can't be retrieved and
is reported as connector_status_unknown.

Extend the addition of default modes to connectors in an unknown state
to support outputs that can retrieve neither the modes nor the
connection status.

Signed-off-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Acked-by: Sam Ravnborg <sam@ravnborg.org>
Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch>
drivers/gpu/drm/drm_probe_helper.c
include/drm/drm_modeset_helper_vtables.h

index d6017726cc2a0c84005997ed577d599e7f0e2160..ad59a51eab6d897f863ce0ba8dffded5f7266c6d 100644 (file)
@@ -515,7 +515,8 @@ retry:
        if (count == 0 && connector->status == connector_status_connected)
                count = drm_add_override_edid_modes(connector);
 
-       if (count == 0 && connector->status == connector_status_connected)
+       if (count == 0 && (connector->status == connector_status_connected ||
+                          connector->status == connector_status_unknown))
                count = drm_add_modes_noedid(connector, 1024, 768);
        count += drm_helper_probe_add_cmdline_mode(connector);
        if (count == 0)
index 16ff3fa148f5ce42daaab7db457549aa6819d6bd..0d184d526a22e7f4d5e0a8e2a6cac445b854761a 100644 (file)
@@ -866,13 +866,19 @@ struct drm_connector_helper_funcs {
         * The usual way to implement this is to cache the EDID retrieved in the
         * probe callback somewhere in the driver-private connector structure.
         * In this function drivers then parse the modes in the EDID and add
-        * them by calling drm_add_edid_modes(). But connectors that driver a
+        * them by calling drm_add_edid_modes(). But connectors that drive a
         * fixed panel can also manually add specific modes using
         * drm_mode_probed_add(). Drivers which manually add modes should also
         * make sure that the &drm_connector.display_info,
         * &drm_connector.width_mm and &drm_connector.height_mm fields are
         * filled in.
         *
+        * Note that the caller function will automatically add standard VESA
+        * DMT modes up to 1024x768 if the .get_modes() helper operation returns
+        * no mode and if the connector status is connector_status_connected or
+        * connector_status_unknown. There is no need to call
+        * drm_add_modes_noedid() manually in that case.
+        *
         * Virtual drivers that just want some standard VESA mode with a given
         * resolution can call drm_add_modes_noedid(), and mark the preferred
         * one using drm_set_preferred_mode().