]> git.baikalelectronics.ru Git - kernel.git/commitdiff
drm: bridge: panel: Register connector if DRM device is already registered
authorMarek Szyprowski <m.szyprowski@samsung.com>
Tue, 19 Apr 2022 09:14:22 +0000 (11:14 +0200)
committerRobert Foss <robert.foss@linaro.org>
Tue, 19 Apr 2022 16:11:27 +0000 (18:11 +0200)
If panel_bridge_attach() happens after DRM device registration, the
created connector will not be registered by the DRM core anymore. Fix
this by registering it explicitly in such case.

This fixes the following issue observed on Samsung Exynos4210-based Trats
board with a DSI panel (the panel driver is registered after the Exynos DRM
component device is bound):

$ ./modetest -c -Mexynos
could not get connector 56: No such file or directory
Segmentation fault

While touching this, move the connector reset() call also under the DRM
device registered check, because otherwise it is not really needed.

Fixes: d1856379ffce ("drm: bridge: panel: Reset the connector state pointer")
Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com>
Reviewed-by: Jagan Teki <jagan@amarulasolutions.com>
Signed-off-by: Robert Foss <robert.foss@linaro.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20220419091422.4255-1-m.szyprowski@samsung.com
drivers/gpu/drm/bridge/panel.c

index ff1c37b2e6e54ad04d8c46b9d8b2ef48da624935..0ee563eb2b6f9c194dec479dde9e8b1d7e86f354 100644 (file)
@@ -83,8 +83,11 @@ static int panel_bridge_attach(struct drm_bridge *bridge,
        drm_connector_attach_encoder(&panel_bridge->connector,
                                          bridge->encoder);
 
-       if (connector->funcs->reset)
-               connector->funcs->reset(connector);
+       if (bridge->dev->registered) {
+               if (connector->funcs->reset)
+                       connector->funcs->reset(connector);
+               drm_connector_register(connector);
+       }
 
        return 0;
 }