Hi Inki, To test it properly I have to fix init/remove bugs [1]. Of course these bugs were not introduced by this patch, but they prevented some basic tests. [1]: http://permalink.gmane.org/gmane.linux.kernel.samsung-soc/37266 I have tested successfully your patch with trats and universal_c210 boards. Few additional comments below. On 09/01/2014 02:19 PM, Inki Dae wrote: > Update Exynos's DRM driver to use component match support rater than > add_components. > > Signed-off-by: Inki Dae <inki.dae@xxxxxxxxxxx> > --- > drivers/gpu/drm/exynos/exynos_drm_drv.c | 40 ++++++++++++++----------------- > 1 file changed, 18 insertions(+), 22 deletions(-) > > diff --git a/drivers/gpu/drm/exynos/exynos_drm_drv.c b/drivers/gpu/drm/exynos/exynos_drm_drv.c > index feee991..dae62c2 100644 > --- a/drivers/gpu/drm/exynos/exynos_drm_drv.c > +++ b/drivers/gpu/drm/exynos/exynos_drm_drv.c > @@ -503,16 +503,15 @@ static int compare_of(struct device *dev, void *data) > return dev == (struct device *)data; > } Nitpick. This is not a part of this patch but compare_of suggests it compares OF nodes but this function compares devices, maybe compare_dev would be better. > > -static int exynos_drm_add_components(struct device *dev, struct master *m) > +static struct component_match *exynos_drm_match_add(struct device *dev) > { > + struct component_match *match = NULL; > struct component_dev *cdev; > unsigned int attach_cnt = 0; > > mutex_lock(&drm_component_lock); > > list_for_each_entry(cdev, &drm_component_list, list) { > - int ret; > - > /* > * Add components to master only in case that crtc and > * encoder/connector device objects exist. > @@ -527,16 +526,10 @@ static int exynos_drm_add_components(struct device *dev, struct master *m) > /* > * fimd and dpi modules have same device object so add > * only crtc device object in this case. > - * > - * TODO. if dpi module follows driver-model driver then > - * below codes can be removed. > */ > if (cdev->crtc_dev == cdev->conn_dev) { > - ret = component_master_add_child(m, compare_of, > - cdev->crtc_dev); > - if (ret < 0) > - return ret; > - > + component_match_add(dev, &match, compare_of, > + cdev->crtc_dev); > goto out_lock; > } > > @@ -546,11 +539,8 @@ static int exynos_drm_add_components(struct device *dev, struct master *m) > * connector/encoder need pipe number of crtc when they > * are created. > */ > - ret = component_master_add_child(m, compare_of, cdev->crtc_dev); > - ret |= component_master_add_child(m, compare_of, > - cdev->conn_dev); > - if (ret < 0) > - return ret; > + component_match_add(dev, &match, compare_of, cdev->crtc_dev); > + component_match_add(dev, &match, compare_of, cdev->conn_dev); > > out_lock: > mutex_lock(&drm_component_lock); > @@ -558,7 +548,7 @@ out_lock: > > mutex_unlock(&drm_component_lock); > > - return attach_cnt ? 0 : -ENODEV; > + return attach_cnt ? match : ERR_PTR(-EPROBE_DEFER); > } > > static int exynos_drm_bind(struct device *dev) > @@ -572,13 +562,13 @@ static void exynos_drm_unbind(struct device *dev) > } > > static const struct component_master_ops exynos_drm_ops = { > - .add_components = exynos_drm_add_components, > .bind = exynos_drm_bind, > .unbind = exynos_drm_unbind, > }; > > static int exynos_drm_platform_probe(struct platform_device *pdev) > { > + struct component_match *match; > int ret; > > pdev->dev.coherent_dma_mask = DMA_BIT_MASK(32); > @@ -645,13 +635,19 @@ static int exynos_drm_platform_probe(struct platform_device *pdev) > goto err_unregister_ipp_drv; > #endif > > - ret = component_master_add(&pdev->dev, &exynos_drm_ops); > - if (ret < 0) > - DRM_DEBUG_KMS("re-tried by last sub driver probed later.\n"); > + match = exynos_drm_match_add(&pdev->dev); > + if (IS_ERR(match)) { > + ret = PTR_ERR(match); > + goto err_unregister_ipp_dev; > + } > > - return 0; > + return component_master_add_with_match(&pdev->dev, &exynos_drm_ops, > + match); In case component_master_add_with_match fails there will be no cleanup - platform devices and drivers will not be removed. > + > +err_unregister_ipp_dev: > > #ifdef CONFIG_DRM_EXYNOS_IPP > + exynos_platform_device_ipp_unregister(); It should not be a part of this patch. Regards Andrzej > err_unregister_ipp_drv: > platform_driver_unregister(&ipp_driver); > err_unregister_gsc_drv: > _______________________________________________ dri-devel mailing list dri-devel@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/dri-devel