diff mbox

drm/exynos: update to use component match support

Message ID 1409573992-19721-1-git-send-email-inki.dae@samsung.com (mailing list archive)
State Not Applicable, archived
Headers show

Commit Message

대인기/Tizen Platform Lab(SR)/삼성전자 Sept. 1, 2014, 12:19 p.m. UTC
Update Exynos's DRM driver to use component match support rater than
add_components.

Signed-off-by: Inki Dae <inki.dae@samsung.com>
---
 drivers/gpu/drm/exynos/exynos_drm_drv.c |   40 ++++++++++++++-----------------
 1 file changed, 18 insertions(+), 22 deletions(-)

Comments

Andrzej Hajda Sept. 10, 2014, 10:24 a.m. UTC | #1
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@samsung.com>
> ---
>  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:
> 

--
To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
대인기/Tizen Platform Lab(SR)/삼성전자 Sept. 11, 2014, 1:46 a.m. UTC | #2
On 2014? 09? 10? 19:24, Andrzej Hajda wrote:
> 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@samsung.com>
>> ---
>>  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.

Agree.

> 
>>  
>> -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.
> 

Right.

>> +
>> +err_unregister_ipp_dev:
>>  
>>  #ifdef CONFIG_DRM_EXYNOS_IPP
>> +	exynos_platform_device_ipp_unregister();
> 
> It should not be a part of this patch.

ipp should be unregistered if exynos_drm_match_add() failed so it seems
better to include this exception.

Thanks,
Inki Dae

> 
> Regards
> Andrzej
> 
>>  err_unregister_ipp_drv:
>>  	platform_driver_unregister(&ipp_driver);
>>  err_unregister_gsc_drv:
>>
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 

--
To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
대인기/Tizen Platform Lab(SR)/삼성전자 Sept. 11, 2014, 6:37 a.m. UTC | #3
On 2014? 09? 10? 19:24, Andrzej Hajda wrote:
> 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.

I had tested my patch with trats2 board, and works well without below
patch set. hm.. it seems that there is other corner cases I missed. Can
you give me more details about 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.

Thanks for testing and above fixup patch set. Will look into them soon. :)

Thanks,
Inki Dae

> 
> 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@samsung.com>
>> ---
>>  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:
>>
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 

--
To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Andrzej Hajda Sept. 11, 2014, 7:05 a.m. UTC | #4
On 09/11/2014 08:37 AM, Inki Dae wrote:
> On 2014? 09? 10? 19:24, Andrzej Hajda wrote:
>> 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.
> I had tested my patch with trats2 board, and works well without below
> patch set. hm.. it seems that there is other corner cases I missed. Can
> you give me more details about basic tests?

As the component framework is about bringing up/down the master when
all/some components becomes available/unavailable I have tested
what happens when I change availability of components using bind/unbind
sysfs properties, for example:
echo 11c80000.dsi >/sys/bus/platform/drivers/exynos-dsi/unbind
echo 11c80000.dsi >/sys/bus/platform/drivers/exynos-dsi/bind

Regards
Andrzej

>
>> [1]: http://permalink.gmane.org/gmane.linux.kernel.samsung-soc/37266
>>
>> I have tested successfully your patch with trats and universal_c210 boards.
> Thanks for testing and above fixup patch set. Will look into them soon. :)
>
> Thanks,
> Inki Dae
>
>> 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@samsung.com>
>>> ---
>>>  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:
>>>
>> --
>> To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in
>> the body of a message to majordomo@vger.kernel.org
>> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>>
>

--
To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
diff mbox

Patch

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;
 }
 
-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);
+
+err_unregister_ipp_dev:
 
 #ifdef CONFIG_DRM_EXYNOS_IPP
+	exynos_platform_device_ipp_unregister();
 err_unregister_ipp_drv:
 	platform_driver_unregister(&ipp_driver);
 err_unregister_gsc_drv: