Commit 099326d8 authored by Fabio Estevam's avatar Fabio Estevam Committed by Greg Kroah-Hartman

staging: imx-drm: Fix probe failure

Since commit b5dc0d10 (drm/imx: kill firstopen callback) the following probe
failure is seen:

[drm] Supports vblank timestamp caching Rev 1 (10.10.2010).
[drm] No driver support for vblank timestamp query.
[drm] Initialized imx-drm 1.0.0 20120507 on minor 0
imx-ldb ldb.10: adding encoder failed with -16
imx-ldb: probe of ldb.10 failed with error -16
imx-ipuv3 2400000.ipu: IPUv3H probed
imx-ipuv3 2800000.ipu: IPUv3H probed
imx-ipuv3-crtc imx-ipuv3-crtc.0: adding crtc failed with -16.
imx-ipuv3-crtc: probe of imx-ipuv3-crtc.0 failed with error -16
imx-ipuv3-crtc imx-ipuv3-crtc.1: adding crtc failed with -16.
imx-ipuv3-crtc: probe of imx-ipuv3-crtc.1 failed with error -16
imx-ipuv3-crtc imx-ipuv3-crtc.2: adding crtc failed with -16.
imx-ipuv3-crtc: probe of imx-ipuv3-crtc.2 failed with error -16
imx-ipuv3-crtc imx-ipuv3-crtc.3: adding crtc failed with -16.
imx-ipuv3-crtc: probe of imx-ipuv3-crtc.3 failed with error -16

The reason for the probe failure is that now 'imxdrm->references' is incremented
early in imx_drm_driver_load(), so the following checks in imx_drm_add_crtc()
and imx_drm_add_encoder():

	if (imxdrm->references) {
		ret = -EBUSY;
		goto err_busy;
	}

,will always fail.

Instead of manually keeping the references in the imx-drm driver, let's use
drm->open_count.

After this patch, lvds panel is functional on a mx6qsabrelite board.
Signed-off-by: default avatarFabio Estevam <fabio.estevam@freescale.com>
Acked-by: default avatarSascha Hauer <s.hauer@pengutronix.de>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 5e8c3d3e
...@@ -41,7 +41,6 @@ struct imx_drm_device { ...@@ -41,7 +41,6 @@ struct imx_drm_device {
struct list_head encoder_list; struct list_head encoder_list;
struct list_head connector_list; struct list_head connector_list;
struct mutex mutex; struct mutex mutex;
int references;
int pipes; int pipes;
struct drm_fbdev_cma *fbhelper; struct drm_fbdev_cma *fbhelper;
}; };
...@@ -241,8 +240,6 @@ struct drm_device *imx_drm_device_get(void) ...@@ -241,8 +240,6 @@ struct drm_device *imx_drm_device_get(void)
} }
} }
imxdrm->references++;
return imxdrm->drm; return imxdrm->drm;
unwind_crtc: unwind_crtc:
...@@ -280,8 +277,6 @@ void imx_drm_device_put(void) ...@@ -280,8 +277,6 @@ void imx_drm_device_put(void)
list_for_each_entry(enc, &imxdrm->encoder_list, list) list_for_each_entry(enc, &imxdrm->encoder_list, list)
module_put(enc->owner); module_put(enc->owner);
imxdrm->references--;
mutex_unlock(&imxdrm->mutex); mutex_unlock(&imxdrm->mutex);
} }
EXPORT_SYMBOL_GPL(imx_drm_device_put); EXPORT_SYMBOL_GPL(imx_drm_device_put);
...@@ -485,7 +480,7 @@ int imx_drm_add_crtc(struct drm_crtc *crtc, ...@@ -485,7 +480,7 @@ int imx_drm_add_crtc(struct drm_crtc *crtc,
mutex_lock(&imxdrm->mutex); mutex_lock(&imxdrm->mutex);
if (imxdrm->references) { if (imxdrm->drm->open_count) {
ret = -EBUSY; ret = -EBUSY;
goto err_busy; goto err_busy;
} }
...@@ -564,7 +559,7 @@ int imx_drm_add_encoder(struct drm_encoder *encoder, ...@@ -564,7 +559,7 @@ int imx_drm_add_encoder(struct drm_encoder *encoder,
mutex_lock(&imxdrm->mutex); mutex_lock(&imxdrm->mutex);
if (imxdrm->references) { if (imxdrm->drm->open_count) {
ret = -EBUSY; ret = -EBUSY;
goto err_busy; goto err_busy;
} }
...@@ -709,7 +704,7 @@ int imx_drm_add_connector(struct drm_connector *connector, ...@@ -709,7 +704,7 @@ int imx_drm_add_connector(struct drm_connector *connector,
mutex_lock(&imxdrm->mutex); mutex_lock(&imxdrm->mutex);
if (imxdrm->references) { if (imxdrm->drm->open_count) {
ret = -EBUSY; ret = -EBUSY;
goto err_busy; goto err_busy;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment