drm/sun4i: dsi: Avoid hotplug race with DRM driver bind
authorSamuel Holland <samuel@sholland.org>
Mon, 17 Feb 2020 06:09:06 +0000 (00:09 -0600)
committerMaxime Ripard <maxime@cerno.tech>
Wed, 19 Feb 2020 15:56:57 +0000 (16:56 +0100)
We need to make sure that the DRM driver is fully registered before
allowing the panel to be attached. Otherwise, we may trigger a hotplug
event before sun4i_framebuffer_init() sets up drm->mode_config.funcs,
causing a NULL pointer dereference.

Fixes: 1a2703bd7356 ("drm/sun4i: dsi: Allow binding the host without a panel")
Signed-off-by: Samuel Holland <samuel@sholland.org>
Signed-off-by: Maxime Ripard <maxime@cerno.tech>
Link: https://patchwork.freedesktop.org/patch/msgid/20200217060906.15152-1-samuel@sholland.org
drivers/gpu/drm/sun4i/sun6i_mipi_dsi.c

index b7174d5151881c947e9f72c435a7526afb676eae..059939789730d893d089634e37daadb866c60387 100644 (file)
@@ -970,7 +970,7 @@ static int sun6i_dsi_attach(struct mipi_dsi_host *host,
 
        if (IS_ERR(panel))
                return PTR_ERR(panel);
-       if (!dsi->drm)
+       if (!dsi->drm || !dsi->drm->registered)
                return -EPROBE_DEFER;
 
        dsi->panel = panel;