All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] i2c: imx: make bus recovery through pinctrl optional
@ 2015-11-18  0:02 ` Li Yang
  0 siblings, 0 replies; 14+ messages in thread
From: Li Yang @ 2015-11-18  0:02 UTC (permalink / raw)
  To: Wolfram Sang; +Cc: linux-i2c, linux-kernel, linux-arm-kernel, Li Yang, Gao Pan

Since commit 1c4b6c3bcf30 ("i2c: imx: implement bus recovery") the driver
starts to use gpio/pinctrl to do i2c bus recovery.  But pinctrl is not
always available for platforms using this driver such as ls1021a and
ls1043a, and the device tree binding also mentioned this gpio based
recovery mechanism as optional.  The patch make it really optional that
the probe function won't bailout when pinctrl is not available and it
won't try to register recovery functions if pinctrl is NULL when the
PINCTRL is not enabled at all.

Signed-off-by: Li Yang <leoli@freescale.com>
Cc: Gao Pan <b54642@freescale.com>
---
 drivers/i2c/busses/i2c-imx.c | 13 ++++++-------
 1 file changed, 6 insertions(+), 7 deletions(-)

diff --git a/drivers/i2c/busses/i2c-imx.c b/drivers/i2c/busses/i2c-imx.c
index 1e4d99d..7813153 100644
--- a/drivers/i2c/busses/i2c-imx.c
+++ b/drivers/i2c/busses/i2c-imx.c
@@ -1086,12 +1086,6 @@ static int i2c_imx_probe(struct platform_device *pdev)
 		return ret;
 	}
 
-	i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
-	if (IS_ERR(i2c_imx->pinctrl)) {
-		ret = PTR_ERR(i2c_imx->pinctrl);
-		goto clk_disable;
-	}
-
 	/* Request IRQ */
 	ret = devm_request_irq(&pdev->dev, irq, i2c_imx_isr, 0,
 				pdev->name, i2c_imx);
@@ -1125,7 +1119,12 @@ static int i2c_imx_probe(struct platform_device *pdev)
 		goto clk_disable;
 	}
 
-	i2c_imx_init_recovery_info(i2c_imx, pdev);
+	/* optional bus recovery feature through pinctrl */
+	i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
+	if (IS_ERR_OR_NULL(i2c_imx->pinctrl))
+		dev_info(&pdev->dev, "can't get pinctrl, bus recovery feature disabled\n");
+	else
+		i2c_imx_init_recovery_info(i2c_imx, pdev);
 
 	/* Set up platform driver data */
 	platform_set_drvdata(pdev, i2c_imx);
-- 
2.3.3


^ permalink raw reply related	[flat|nested] 14+ messages in thread

* [PATCH] i2c: imx: make bus recovery through pinctrl optional
@ 2015-11-18  0:02 ` Li Yang
  0 siblings, 0 replies; 14+ messages in thread
From: Li Yang @ 2015-11-18  0:02 UTC (permalink / raw)
  To: Wolfram Sang; +Cc: linux-i2c, linux-kernel, linux-arm-kernel, Li Yang, Gao Pan

Since commit 1c4b6c3bcf30 ("i2c: imx: implement bus recovery") the driver
starts to use gpio/pinctrl to do i2c bus recovery.  But pinctrl is not
always available for platforms using this driver such as ls1021a and
ls1043a, and the device tree binding also mentioned this gpio based
recovery mechanism as optional.  The patch make it really optional that
the probe function won't bailout when pinctrl is not available and it
won't try to register recovery functions if pinctrl is NULL when the
PINCTRL is not enabled at all.

Signed-off-by: Li Yang <leoli@freescale.com>
Cc: Gao Pan <b54642@freescale.com>
---
 drivers/i2c/busses/i2c-imx.c | 13 ++++++-------
 1 file changed, 6 insertions(+), 7 deletions(-)

diff --git a/drivers/i2c/busses/i2c-imx.c b/drivers/i2c/busses/i2c-imx.c
index 1e4d99d..7813153 100644
--- a/drivers/i2c/busses/i2c-imx.c
+++ b/drivers/i2c/busses/i2c-imx.c
@@ -1086,12 +1086,6 @@ static int i2c_imx_probe(struct platform_device *pdev)
 		return ret;
 	}
 
-	i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
-	if (IS_ERR(i2c_imx->pinctrl)) {
-		ret = PTR_ERR(i2c_imx->pinctrl);
-		goto clk_disable;
-	}
-
 	/* Request IRQ */
 	ret = devm_request_irq(&pdev->dev, irq, i2c_imx_isr, 0,
 				pdev->name, i2c_imx);
@@ -1125,7 +1119,12 @@ static int i2c_imx_probe(struct platform_device *pdev)
 		goto clk_disable;
 	}
 
-	i2c_imx_init_recovery_info(i2c_imx, pdev);
+	/* optional bus recovery feature through pinctrl */
+	i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
+	if (IS_ERR_OR_NULL(i2c_imx->pinctrl))
+		dev_info(&pdev->dev, "can't get pinctrl, bus recovery feature disabled\n");
+	else
+		i2c_imx_init_recovery_info(i2c_imx, pdev);
 
 	/* Set up platform driver data */
 	platform_set_drvdata(pdev, i2c_imx);
-- 
2.3.3

^ permalink raw reply related	[flat|nested] 14+ messages in thread

* [PATCH] i2c: imx: make bus recovery through pinctrl optional
@ 2015-11-18  0:02 ` Li Yang
  0 siblings, 0 replies; 14+ messages in thread
From: Li Yang @ 2015-11-18  0:02 UTC (permalink / raw)
  To: linux-arm-kernel

Since commit 1c4b6c3bcf30 ("i2c: imx: implement bus recovery") the driver
starts to use gpio/pinctrl to do i2c bus recovery.  But pinctrl is not
always available for platforms using this driver such as ls1021a and
ls1043a, and the device tree binding also mentioned this gpio based
recovery mechanism as optional.  The patch make it really optional that
the probe function won't bailout when pinctrl is not available and it
won't try to register recovery functions if pinctrl is NULL when the
PINCTRL is not enabled at all.

Signed-off-by: Li Yang <leoli@freescale.com>
Cc: Gao Pan <b54642@freescale.com>
---
 drivers/i2c/busses/i2c-imx.c | 13 ++++++-------
 1 file changed, 6 insertions(+), 7 deletions(-)

diff --git a/drivers/i2c/busses/i2c-imx.c b/drivers/i2c/busses/i2c-imx.c
index 1e4d99d..7813153 100644
--- a/drivers/i2c/busses/i2c-imx.c
+++ b/drivers/i2c/busses/i2c-imx.c
@@ -1086,12 +1086,6 @@ static int i2c_imx_probe(struct platform_device *pdev)
 		return ret;
 	}
 
-	i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
-	if (IS_ERR(i2c_imx->pinctrl)) {
-		ret = PTR_ERR(i2c_imx->pinctrl);
-		goto clk_disable;
-	}
-
 	/* Request IRQ */
 	ret = devm_request_irq(&pdev->dev, irq, i2c_imx_isr, 0,
 				pdev->name, i2c_imx);
@@ -1125,7 +1119,12 @@ static int i2c_imx_probe(struct platform_device *pdev)
 		goto clk_disable;
 	}
 
-	i2c_imx_init_recovery_info(i2c_imx, pdev);
+	/* optional bus recovery feature through pinctrl */
+	i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
+	if (IS_ERR_OR_NULL(i2c_imx->pinctrl))
+		dev_info(&pdev->dev, "can't get pinctrl, bus recovery feature disabled\n");
+	else
+		i2c_imx_init_recovery_info(i2c_imx, pdev);
 
 	/* Set up platform driver data */
 	platform_set_drvdata(pdev, i2c_imx);
-- 
2.3.3

^ permalink raw reply related	[flat|nested] 14+ messages in thread

* Re: [PATCH] i2c: imx: make bus recovery through pinctrl optional
  2015-11-18  0:02 ` Li Yang
@ 2015-11-18  7:24   ` Uwe Kleine-König
  -1 siblings, 0 replies; 14+ messages in thread
From: Uwe Kleine-König @ 2015-11-18  7:24 UTC (permalink / raw)
  To: Li Yang; +Cc: Wolfram Sang, linux-i2c, linux-kernel, linux-arm-kernel, Gao Pan

Hello,

On Tue, Nov 17, 2015 at 06:02:59PM -0600, Li Yang wrote:
> Since commit 1c4b6c3bcf30 ("i2c: imx: implement bus recovery") the driver
> starts to use gpio/pinctrl to do i2c bus recovery.  But pinctrl is not
> always available for platforms using this driver such as ls1021a and
> ls1043a, and the device tree binding also mentioned this gpio based
> recovery mechanism as optional.  The patch make it really optional that
> the probe function won't bailout when pinctrl is not available and it
> won't try to register recovery functions if pinctrl is NULL when the
> PINCTRL is not enabled at all.
> 
> Signed-off-by: Li Yang <leoli@freescale.com>
> Cc: Gao Pan <b54642@freescale.com>
> ---
>  drivers/i2c/busses/i2c-imx.c | 13 ++++++-------
>  1 file changed, 6 insertions(+), 7 deletions(-)
> 
> diff --git a/drivers/i2c/busses/i2c-imx.c b/drivers/i2c/busses/i2c-imx.c
> index 1e4d99d..7813153 100644
> --- a/drivers/i2c/busses/i2c-imx.c
> +++ b/drivers/i2c/busses/i2c-imx.c
> @@ -1086,12 +1086,6 @@ static int i2c_imx_probe(struct platform_device *pdev)
>  		return ret;
>  	}
>  
> -	i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
> -	if (IS_ERR(i2c_imx->pinctrl)) {
> -		ret = PTR_ERR(i2c_imx->pinctrl);
> -		goto clk_disable;
> -	}
> -
>  	/* Request IRQ */
>  	ret = devm_request_irq(&pdev->dev, irq, i2c_imx_isr, 0,
>  				pdev->name, i2c_imx);
> @@ -1125,7 +1119,12 @@ static int i2c_imx_probe(struct platform_device *pdev)
>  		goto clk_disable;
>  	}
>  
> -	i2c_imx_init_recovery_info(i2c_imx, pdev);
> +	/* optional bus recovery feature through pinctrl */
> +	i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
> +	if (IS_ERR_OR_NULL(i2c_imx->pinctrl))
> +		dev_info(&pdev->dev, "can't get pinctrl, bus recovery feature disabled\n");
> +	else
> +		i2c_imx_init_recovery_info(i2c_imx, pdev);

I'm pretty sure this is wrong. If pinctrl isn't available
devm_pinctrl_get returns NULL? But AFAIK you must not ignore an error,
so the better thing to do is:

	i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
	if (IS_ERR(i2c_imx->pinctrl)) {
		ret = PTR_ERR(i2c_imx->pinctrl);
		goto errorhandling;
	}

	if (i2c_imx->pinctrl)
		i2c_imx_init_recovery_info(i2c_imx, pdev);
	else
		dev_info(&pdev->dev, "can't get pinctrl, bus recovery feature disabled\n");


right?

Uwe Kleine-König

-- 
Pengutronix e.K.                           | Uwe Kleine-König            |
Industrial Linux Solutions                 | http://www.pengutronix.de/  |

^ permalink raw reply	[flat|nested] 14+ messages in thread

* [PATCH] i2c: imx: make bus recovery through pinctrl optional
@ 2015-11-18  7:24   ` Uwe Kleine-König
  0 siblings, 0 replies; 14+ messages in thread
From: Uwe Kleine-König @ 2015-11-18  7:24 UTC (permalink / raw)
  To: linux-arm-kernel

Hello,

On Tue, Nov 17, 2015 at 06:02:59PM -0600, Li Yang wrote:
> Since commit 1c4b6c3bcf30 ("i2c: imx: implement bus recovery") the driver
> starts to use gpio/pinctrl to do i2c bus recovery.  But pinctrl is not
> always available for platforms using this driver such as ls1021a and
> ls1043a, and the device tree binding also mentioned this gpio based
> recovery mechanism as optional.  The patch make it really optional that
> the probe function won't bailout when pinctrl is not available and it
> won't try to register recovery functions if pinctrl is NULL when the
> PINCTRL is not enabled at all.
> 
> Signed-off-by: Li Yang <leoli@freescale.com>
> Cc: Gao Pan <b54642@freescale.com>
> ---
>  drivers/i2c/busses/i2c-imx.c | 13 ++++++-------
>  1 file changed, 6 insertions(+), 7 deletions(-)
> 
> diff --git a/drivers/i2c/busses/i2c-imx.c b/drivers/i2c/busses/i2c-imx.c
> index 1e4d99d..7813153 100644
> --- a/drivers/i2c/busses/i2c-imx.c
> +++ b/drivers/i2c/busses/i2c-imx.c
> @@ -1086,12 +1086,6 @@ static int i2c_imx_probe(struct platform_device *pdev)
>  		return ret;
>  	}
>  
> -	i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
> -	if (IS_ERR(i2c_imx->pinctrl)) {
> -		ret = PTR_ERR(i2c_imx->pinctrl);
> -		goto clk_disable;
> -	}
> -
>  	/* Request IRQ */
>  	ret = devm_request_irq(&pdev->dev, irq, i2c_imx_isr, 0,
>  				pdev->name, i2c_imx);
> @@ -1125,7 +1119,12 @@ static int i2c_imx_probe(struct platform_device *pdev)
>  		goto clk_disable;
>  	}
>  
> -	i2c_imx_init_recovery_info(i2c_imx, pdev);
> +	/* optional bus recovery feature through pinctrl */
> +	i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
> +	if (IS_ERR_OR_NULL(i2c_imx->pinctrl))
> +		dev_info(&pdev->dev, "can't get pinctrl, bus recovery feature disabled\n");
> +	else
> +		i2c_imx_init_recovery_info(i2c_imx, pdev);

I'm pretty sure this is wrong. If pinctrl isn't available
devm_pinctrl_get returns NULL? But AFAIK you must not ignore an error,
so the better thing to do is:

	i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
	if (IS_ERR(i2c_imx->pinctrl)) {
		ret = PTR_ERR(i2c_imx->pinctrl);
		goto errorhandling;
	}

	if (i2c_imx->pinctrl)
		i2c_imx_init_recovery_info(i2c_imx, pdev);
	else
		dev_info(&pdev->dev, "can't get pinctrl, bus recovery feature disabled\n");


right?

Uwe Kleine-K?nig

-- 
Pengutronix e.K.                           | Uwe Kleine-K?nig            |
Industrial Linux Solutions                 | http://www.pengutronix.de/  |

^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [PATCH] i2c: imx: make bus recovery through pinctrl optional
  2015-11-18  7:24   ` Uwe Kleine-König
  (?)
@ 2015-11-18 22:59     ` Li Yang
  -1 siblings, 0 replies; 14+ messages in thread
From: Li Yang @ 2015-11-18 22:59 UTC (permalink / raw)
  To: Uwe Kleine-König
  Cc: lkml, Gao Pan, linux-i2c, linux-arm-kernel, Wolfram Sang

On Wed, Nov 18, 2015 at 1:24 AM, Uwe Kleine-König
<u.kleine-koenig@pengutronix.de> wrote:
> Hello,
>
> On Tue, Nov 17, 2015 at 06:02:59PM -0600, Li Yang wrote:
>> Since commit 1c4b6c3bcf30 ("i2c: imx: implement bus recovery") the driver
>> starts to use gpio/pinctrl to do i2c bus recovery.  But pinctrl is not
>> always available for platforms using this driver such as ls1021a and
>> ls1043a, and the device tree binding also mentioned this gpio based
>> recovery mechanism as optional.  The patch make it really optional that
>> the probe function won't bailout when pinctrl is not available and it
>> won't try to register recovery functions if pinctrl is NULL when the
>> PINCTRL is not enabled at all.
>>
>> Signed-off-by: Li Yang <leoli@freescale.com>
>> Cc: Gao Pan <b54642@freescale.com>
>> ---
>>  drivers/i2c/busses/i2c-imx.c | 13 ++++++-------
>>  1 file changed, 6 insertions(+), 7 deletions(-)
>>
>> diff --git a/drivers/i2c/busses/i2c-imx.c b/drivers/i2c/busses/i2c-imx.c
>> index 1e4d99d..7813153 100644
>> --- a/drivers/i2c/busses/i2c-imx.c
>> +++ b/drivers/i2c/busses/i2c-imx.c
>> @@ -1086,12 +1086,6 @@ static int i2c_imx_probe(struct platform_device *pdev)
>>               return ret;
>>       }
>>
>> -     i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
>> -     if (IS_ERR(i2c_imx->pinctrl)) {
>> -             ret = PTR_ERR(i2c_imx->pinctrl);
>> -             goto clk_disable;
>> -     }
>> -
>>       /* Request IRQ */
>>       ret = devm_request_irq(&pdev->dev, irq, i2c_imx_isr, 0,
>>                               pdev->name, i2c_imx);
>> @@ -1125,7 +1119,12 @@ static int i2c_imx_probe(struct platform_device *pdev)
>>               goto clk_disable;
>>       }
>>
>> -     i2c_imx_init_recovery_info(i2c_imx, pdev);
>> +     /* optional bus recovery feature through pinctrl */
>> +     i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
>> +     if (IS_ERR_OR_NULL(i2c_imx->pinctrl))
>> +             dev_info(&pdev->dev, "can't get pinctrl, bus recovery feature disabled\n");
>> +     else
>> +             i2c_imx_init_recovery_info(i2c_imx, pdev);
>
> I'm pretty sure this is wrong. If pinctrl isn't available
> devm_pinctrl_get returns NULL? But AFAIK you must not ignore an error,
> so the better thing to do is:

If CONFIG_PINCTRL is not enabled, the devm_pinctrl_get() will return
NULL directly as defined in the include/linux/pinctrl/consumer.h.

If CONFIG_PINCTRL is enabled because we are using a multi-platform
image but the actual hardware used doesn't have a pinctrl driver or
pinctrl device tree nodes.  It is expected that the devm_pinctrl_get()
will return error.  But as the pinctrl is only used for bus recovery
which is just an optional function of this driver.  We shouldn't
bailout the probe but keep the driver working without the bus recovery
function.  As for generic errors like (!dev) or out-of-memory, the
probe will fail elsewhere anyway.

Regards,
Leo

^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [PATCH] i2c: imx: make bus recovery through pinctrl optional
@ 2015-11-18 22:59     ` Li Yang
  0 siblings, 0 replies; 14+ messages in thread
From: Li Yang @ 2015-11-18 22:59 UTC (permalink / raw)
  To: Uwe Kleine-König
  Cc: lkml, Gao Pan, linux-i2c, linux-arm-kernel, Wolfram Sang

On Wed, Nov 18, 2015 at 1:24 AM, Uwe Kleine-König
<u.kleine-koenig@pengutronix.de> wrote:
> Hello,
>
> On Tue, Nov 17, 2015 at 06:02:59PM -0600, Li Yang wrote:
>> Since commit 1c4b6c3bcf30 ("i2c: imx: implement bus recovery") the driver
>> starts to use gpio/pinctrl to do i2c bus recovery.  But pinctrl is not
>> always available for platforms using this driver such as ls1021a and
>> ls1043a, and the device tree binding also mentioned this gpio based
>> recovery mechanism as optional.  The patch make it really optional that
>> the probe function won't bailout when pinctrl is not available and it
>> won't try to register recovery functions if pinctrl is NULL when the
>> PINCTRL is not enabled at all.
>>
>> Signed-off-by: Li Yang <leoli@freescale.com>
>> Cc: Gao Pan <b54642@freescale.com>
>> ---
>>  drivers/i2c/busses/i2c-imx.c | 13 ++++++-------
>>  1 file changed, 6 insertions(+), 7 deletions(-)
>>
>> diff --git a/drivers/i2c/busses/i2c-imx.c b/drivers/i2c/busses/i2c-imx.c
>> index 1e4d99d..7813153 100644
>> --- a/drivers/i2c/busses/i2c-imx.c
>> +++ b/drivers/i2c/busses/i2c-imx.c
>> @@ -1086,12 +1086,6 @@ static int i2c_imx_probe(struct platform_device *pdev)
>>               return ret;
>>       }
>>
>> -     i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
>> -     if (IS_ERR(i2c_imx->pinctrl)) {
>> -             ret = PTR_ERR(i2c_imx->pinctrl);
>> -             goto clk_disable;
>> -     }
>> -
>>       /* Request IRQ */
>>       ret = devm_request_irq(&pdev->dev, irq, i2c_imx_isr, 0,
>>                               pdev->name, i2c_imx);
>> @@ -1125,7 +1119,12 @@ static int i2c_imx_probe(struct platform_device *pdev)
>>               goto clk_disable;
>>       }
>>
>> -     i2c_imx_init_recovery_info(i2c_imx, pdev);
>> +     /* optional bus recovery feature through pinctrl */
>> +     i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
>> +     if (IS_ERR_OR_NULL(i2c_imx->pinctrl))
>> +             dev_info(&pdev->dev, "can't get pinctrl, bus recovery feature disabled\n");
>> +     else
>> +             i2c_imx_init_recovery_info(i2c_imx, pdev);
>
> I'm pretty sure this is wrong. If pinctrl isn't available
> devm_pinctrl_get returns NULL? But AFAIK you must not ignore an error,
> so the better thing to do is:

If CONFIG_PINCTRL is not enabled, the devm_pinctrl_get() will return
NULL directly as defined in the include/linux/pinctrl/consumer.h.

If CONFIG_PINCTRL is enabled because we are using a multi-platform
image but the actual hardware used doesn't have a pinctrl driver or
pinctrl device tree nodes.  It is expected that the devm_pinctrl_get()
will return error.  But as the pinctrl is only used for bus recovery
which is just an optional function of this driver.  We shouldn't
bailout the probe but keep the driver working without the bus recovery
function.  As for generic errors like (!dev) or out-of-memory, the
probe will fail elsewhere anyway.

Regards,
Leo

^ permalink raw reply	[flat|nested] 14+ messages in thread

* [PATCH] i2c: imx: make bus recovery through pinctrl optional
@ 2015-11-18 22:59     ` Li Yang
  0 siblings, 0 replies; 14+ messages in thread
From: Li Yang @ 2015-11-18 22:59 UTC (permalink / raw)
  To: linux-arm-kernel

On Wed, Nov 18, 2015 at 1:24 AM, Uwe Kleine-K?nig
<u.kleine-koenig@pengutronix.de> wrote:
> Hello,
>
> On Tue, Nov 17, 2015 at 06:02:59PM -0600, Li Yang wrote:
>> Since commit 1c4b6c3bcf30 ("i2c: imx: implement bus recovery") the driver
>> starts to use gpio/pinctrl to do i2c bus recovery.  But pinctrl is not
>> always available for platforms using this driver such as ls1021a and
>> ls1043a, and the device tree binding also mentioned this gpio based
>> recovery mechanism as optional.  The patch make it really optional that
>> the probe function won't bailout when pinctrl is not available and it
>> won't try to register recovery functions if pinctrl is NULL when the
>> PINCTRL is not enabled at all.
>>
>> Signed-off-by: Li Yang <leoli@freescale.com>
>> Cc: Gao Pan <b54642@freescale.com>
>> ---
>>  drivers/i2c/busses/i2c-imx.c | 13 ++++++-------
>>  1 file changed, 6 insertions(+), 7 deletions(-)
>>
>> diff --git a/drivers/i2c/busses/i2c-imx.c b/drivers/i2c/busses/i2c-imx.c
>> index 1e4d99d..7813153 100644
>> --- a/drivers/i2c/busses/i2c-imx.c
>> +++ b/drivers/i2c/busses/i2c-imx.c
>> @@ -1086,12 +1086,6 @@ static int i2c_imx_probe(struct platform_device *pdev)
>>               return ret;
>>       }
>>
>> -     i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
>> -     if (IS_ERR(i2c_imx->pinctrl)) {
>> -             ret = PTR_ERR(i2c_imx->pinctrl);
>> -             goto clk_disable;
>> -     }
>> -
>>       /* Request IRQ */
>>       ret = devm_request_irq(&pdev->dev, irq, i2c_imx_isr, 0,
>>                               pdev->name, i2c_imx);
>> @@ -1125,7 +1119,12 @@ static int i2c_imx_probe(struct platform_device *pdev)
>>               goto clk_disable;
>>       }
>>
>> -     i2c_imx_init_recovery_info(i2c_imx, pdev);
>> +     /* optional bus recovery feature through pinctrl */
>> +     i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
>> +     if (IS_ERR_OR_NULL(i2c_imx->pinctrl))
>> +             dev_info(&pdev->dev, "can't get pinctrl, bus recovery feature disabled\n");
>> +     else
>> +             i2c_imx_init_recovery_info(i2c_imx, pdev);
>
> I'm pretty sure this is wrong. If pinctrl isn't available
> devm_pinctrl_get returns NULL? But AFAIK you must not ignore an error,
> so the better thing to do is:

If CONFIG_PINCTRL is not enabled, the devm_pinctrl_get() will return
NULL directly as defined in the include/linux/pinctrl/consumer.h.

If CONFIG_PINCTRL is enabled because we are using a multi-platform
image but the actual hardware used doesn't have a pinctrl driver or
pinctrl device tree nodes.  It is expected that the devm_pinctrl_get()
will return error.  But as the pinctrl is only used for bus recovery
which is just an optional function of this driver.  We shouldn't
bailout the probe but keep the driver working without the bus recovery
function.  As for generic errors like (!dev) or out-of-memory, the
probe will fail elsewhere anyway.

Regards,
Leo

^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [PATCH] i2c: imx: make bus recovery through pinctrl optional
  2015-11-18 22:59     ` Li Yang
  (?)
@ 2015-11-19  8:08       ` Uwe Kleine-König
  -1 siblings, 0 replies; 14+ messages in thread
From: Uwe Kleine-König @ 2015-11-19  8:08 UTC (permalink / raw)
  To: Li Yang
  Cc: lkml, Gao Pan, linux-i2c, linux-arm-kernel, Wolfram Sang,
	Linus Walleij, linux-gpio

Hello,

Cc += Linus Walleij, linux-gpio

On Wed, Nov 18, 2015 at 04:59:11PM -0600, Li Yang wrote:
> On Wed, Nov 18, 2015 at 1:24 AM, Uwe Kleine-König
> <u.kleine-koenig@pengutronix.de> wrote:
> > On Tue, Nov 17, 2015 at 06:02:59PM -0600, Li Yang wrote:
> >> @@ -1125,7 +1119,12 @@ static int i2c_imx_probe(struct platform_device *pdev)
> >>               goto clk_disable;
> >>       }
> >>
> >> -     i2c_imx_init_recovery_info(i2c_imx, pdev);
> >> +     /* optional bus recovery feature through pinctrl */
> >> +     i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
> >> +     if (IS_ERR_OR_NULL(i2c_imx->pinctrl))
> >> +             dev_info(&pdev->dev, "can't get pinctrl, bus recovery feature disabled\n");
> >> +     else
> >> +             i2c_imx_init_recovery_info(i2c_imx, pdev);
> >
> > I'm pretty sure this is wrong. If pinctrl isn't available
> > devm_pinctrl_get returns NULL? But AFAIK you must not ignore an error,
> > so the better thing to do is:
> 
> If CONFIG_PINCTRL is not enabled, the devm_pinctrl_get() will return
> NULL directly as defined in the include/linux/pinctrl/consumer.h.
> 
> If CONFIG_PINCTRL is enabled because we are using a multi-platform
> image but the actual hardware used doesn't have a pinctrl driver or
> pinctrl device tree nodes.  It is expected that the devm_pinctrl_get()
> will return error.  But as the pinctrl is only used for bus recovery
> which is just an optional function of this driver.  We shouldn't
> bailout the probe but keep the driver working without the bus recovery
> function.  As for generic errors like (!dev) or out-of-memory, the
> probe will fail elsewhere anyway.

IMHO you shouldn't ignore -ENOMEM from devm_pinctrl_get but just the
case for "there was no pinctrl specified in dt". Also consider the i2c
driver is loaded before the pinctrl driver and devm_pinctrl_get returns
-EPROBE_DEFER (I assume it does, didn't check), this should be handled.

Best regards
Uwe

-- 
Pengutronix e.K.                           | Uwe Kleine-König            |
Industrial Linux Solutions                 | http://www.pengutronix.de/  |
--
To unsubscribe from this list: send the line "unsubscribe linux-gpio" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [PATCH] i2c: imx: make bus recovery through pinctrl optional
@ 2015-11-19  8:08       ` Uwe Kleine-König
  0 siblings, 0 replies; 14+ messages in thread
From: Uwe Kleine-König @ 2015-11-19  8:08 UTC (permalink / raw)
  To: Li Yang
  Cc: lkml, Gao Pan, linux-i2c, linux-arm-kernel, Wolfram Sang,
	Linus Walleij, linux-gpio

Hello,

Cc += Linus Walleij, linux-gpio

On Wed, Nov 18, 2015 at 04:59:11PM -0600, Li Yang wrote:
> On Wed, Nov 18, 2015 at 1:24 AM, Uwe Kleine-König
> <u.kleine-koenig@pengutronix.de> wrote:
> > On Tue, Nov 17, 2015 at 06:02:59PM -0600, Li Yang wrote:
> >> @@ -1125,7 +1119,12 @@ static int i2c_imx_probe(struct platform_device *pdev)
> >>               goto clk_disable;
> >>       }
> >>
> >> -     i2c_imx_init_recovery_info(i2c_imx, pdev);
> >> +     /* optional bus recovery feature through pinctrl */
> >> +     i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
> >> +     if (IS_ERR_OR_NULL(i2c_imx->pinctrl))
> >> +             dev_info(&pdev->dev, "can't get pinctrl, bus recovery feature disabled\n");
> >> +     else
> >> +             i2c_imx_init_recovery_info(i2c_imx, pdev);
> >
> > I'm pretty sure this is wrong. If pinctrl isn't available
> > devm_pinctrl_get returns NULL? But AFAIK you must not ignore an error,
> > so the better thing to do is:
> 
> If CONFIG_PINCTRL is not enabled, the devm_pinctrl_get() will return
> NULL directly as defined in the include/linux/pinctrl/consumer.h.
> 
> If CONFIG_PINCTRL is enabled because we are using a multi-platform
> image but the actual hardware used doesn't have a pinctrl driver or
> pinctrl device tree nodes.  It is expected that the devm_pinctrl_get()
> will return error.  But as the pinctrl is only used for bus recovery
> which is just an optional function of this driver.  We shouldn't
> bailout the probe but keep the driver working without the bus recovery
> function.  As for generic errors like (!dev) or out-of-memory, the
> probe will fail elsewhere anyway.

IMHO you shouldn't ignore -ENOMEM from devm_pinctrl_get but just the
case for "there was no pinctrl specified in dt". Also consider the i2c
driver is loaded before the pinctrl driver and devm_pinctrl_get returns
-EPROBE_DEFER (I assume it does, didn't check), this should be handled.

Best regards
Uwe

-- 
Pengutronix e.K.                           | Uwe Kleine-König            |
Industrial Linux Solutions                 | http://www.pengutronix.de/  |

^ permalink raw reply	[flat|nested] 14+ messages in thread

* [PATCH] i2c: imx: make bus recovery through pinctrl optional
@ 2015-11-19  8:08       ` Uwe Kleine-König
  0 siblings, 0 replies; 14+ messages in thread
From: Uwe Kleine-König @ 2015-11-19  8:08 UTC (permalink / raw)
  To: linux-arm-kernel

Hello,

Cc += Linus Walleij, linux-gpio

On Wed, Nov 18, 2015 at 04:59:11PM -0600, Li Yang wrote:
> On Wed, Nov 18, 2015 at 1:24 AM, Uwe Kleine-K?nig
> <u.kleine-koenig@pengutronix.de> wrote:
> > On Tue, Nov 17, 2015 at 06:02:59PM -0600, Li Yang wrote:
> >> @@ -1125,7 +1119,12 @@ static int i2c_imx_probe(struct platform_device *pdev)
> >>               goto clk_disable;
> >>       }
> >>
> >> -     i2c_imx_init_recovery_info(i2c_imx, pdev);
> >> +     /* optional bus recovery feature through pinctrl */
> >> +     i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
> >> +     if (IS_ERR_OR_NULL(i2c_imx->pinctrl))
> >> +             dev_info(&pdev->dev, "can't get pinctrl, bus recovery feature disabled\n");
> >> +     else
> >> +             i2c_imx_init_recovery_info(i2c_imx, pdev);
> >
> > I'm pretty sure this is wrong. If pinctrl isn't available
> > devm_pinctrl_get returns NULL? But AFAIK you must not ignore an error,
> > so the better thing to do is:
> 
> If CONFIG_PINCTRL is not enabled, the devm_pinctrl_get() will return
> NULL directly as defined in the include/linux/pinctrl/consumer.h.
> 
> If CONFIG_PINCTRL is enabled because we are using a multi-platform
> image but the actual hardware used doesn't have a pinctrl driver or
> pinctrl device tree nodes.  It is expected that the devm_pinctrl_get()
> will return error.  But as the pinctrl is only used for bus recovery
> which is just an optional function of this driver.  We shouldn't
> bailout the probe but keep the driver working without the bus recovery
> function.  As for generic errors like (!dev) or out-of-memory, the
> probe will fail elsewhere anyway.

IMHO you shouldn't ignore -ENOMEM from devm_pinctrl_get but just the
case for "there was no pinctrl specified in dt". Also consider the i2c
driver is loaded before the pinctrl driver and devm_pinctrl_get returns
-EPROBE_DEFER (I assume it does, didn't check), this should be handled.

Best regards
Uwe

-- 
Pengutronix e.K.                           | Uwe Kleine-K?nig            |
Industrial Linux Solutions                 | http://www.pengutronix.de/  |

^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [PATCH] i2c: imx: make bus recovery through pinctrl optional
  2015-11-19  8:08       ` Uwe Kleine-König
  (?)
@ 2015-11-20 18:04         ` Li Yang
  -1 siblings, 0 replies; 14+ messages in thread
From: Li Yang @ 2015-11-20 18:04 UTC (permalink / raw)
  To: Uwe Kleine-König
  Cc: Wolfram Sang, Linus Walleij, lkml, Gao Pan, linux-gpio,
	linux-i2c, linux-arm-kernel

On Thu, Nov 19, 2015 at 2:08 AM, Uwe Kleine-König
<u.kleine-koenig@pengutronix.de> wrote:
> Hello,
>
> Cc += Linus Walleij, linux-gpio
>
> On Wed, Nov 18, 2015 at 04:59:11PM -0600, Li Yang wrote:
>> On Wed, Nov 18, 2015 at 1:24 AM, Uwe Kleine-König
>> <u.kleine-koenig@pengutronix.de> wrote:
>> > On Tue, Nov 17, 2015 at 06:02:59PM -0600, Li Yang wrote:
>> >> @@ -1125,7 +1119,12 @@ static int i2c_imx_probe(struct platform_device *pdev)
>> >>               goto clk_disable;
>> >>       }
>> >>
>> >> -     i2c_imx_init_recovery_info(i2c_imx, pdev);
>> >> +     /* optional bus recovery feature through pinctrl */
>> >> +     i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
>> >> +     if (IS_ERR_OR_NULL(i2c_imx->pinctrl))
>> >> +             dev_info(&pdev->dev, "can't get pinctrl, bus recovery feature disabled\n");
>> >> +     else
>> >> +             i2c_imx_init_recovery_info(i2c_imx, pdev);
>> >
>> > I'm pretty sure this is wrong. If pinctrl isn't available
>> > devm_pinctrl_get returns NULL? But AFAIK you must not ignore an error,
>> > so the better thing to do is:
>>
>> If CONFIG_PINCTRL is not enabled, the devm_pinctrl_get() will return
>> NULL directly as defined in the include/linux/pinctrl/consumer.h.
>>
>> If CONFIG_PINCTRL is enabled because we are using a multi-platform
>> image but the actual hardware used doesn't have a pinctrl driver or
>> pinctrl device tree nodes.  It is expected that the devm_pinctrl_get()
>> will return error.  But as the pinctrl is only used for bus recovery
>> which is just an optional function of this driver.  We shouldn't
>> bailout the probe but keep the driver working without the bus recovery
>> function.  As for generic errors like (!dev) or out-of-memory, the
>> probe will fail elsewhere anyway.
>
> IMHO you shouldn't ignore -ENOMEM from devm_pinctrl_get but just the
> case for "there was no pinctrl specified in dt". Also consider the i2c
> driver is loaded before the pinctrl driver and devm_pinctrl_get returns
> -EPROBE_DEFER (I assume it does, didn't check), this should be handled.

Make sense.   -EPROBE_DEFER should be honored.  Maybe it's good to
check the -ENOMEM too.  I will send a new version.

Thanks,
Leo
--
To unsubscribe from this list: send the line "unsubscribe linux-gpio" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [PATCH] i2c: imx: make bus recovery through pinctrl optional
@ 2015-11-20 18:04         ` Li Yang
  0 siblings, 0 replies; 14+ messages in thread
From: Li Yang @ 2015-11-20 18:04 UTC (permalink / raw)
  To: Uwe Kleine-König
  Cc: Wolfram Sang, Linus Walleij, lkml, Gao Pan, linux-gpio,
	linux-i2c, linux-arm-kernel

On Thu, Nov 19, 2015 at 2:08 AM, Uwe Kleine-König
<u.kleine-koenig@pengutronix.de> wrote:
> Hello,
>
> Cc += Linus Walleij, linux-gpio
>
> On Wed, Nov 18, 2015 at 04:59:11PM -0600, Li Yang wrote:
>> On Wed, Nov 18, 2015 at 1:24 AM, Uwe Kleine-König
>> <u.kleine-koenig@pengutronix.de> wrote:
>> > On Tue, Nov 17, 2015 at 06:02:59PM -0600, Li Yang wrote:
>> >> @@ -1125,7 +1119,12 @@ static int i2c_imx_probe(struct platform_device *pdev)
>> >>               goto clk_disable;
>> >>       }
>> >>
>> >> -     i2c_imx_init_recovery_info(i2c_imx, pdev);
>> >> +     /* optional bus recovery feature through pinctrl */
>> >> +     i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
>> >> +     if (IS_ERR_OR_NULL(i2c_imx->pinctrl))
>> >> +             dev_info(&pdev->dev, "can't get pinctrl, bus recovery feature disabled\n");
>> >> +     else
>> >> +             i2c_imx_init_recovery_info(i2c_imx, pdev);
>> >
>> > I'm pretty sure this is wrong. If pinctrl isn't available
>> > devm_pinctrl_get returns NULL? But AFAIK you must not ignore an error,
>> > so the better thing to do is:
>>
>> If CONFIG_PINCTRL is not enabled, the devm_pinctrl_get() will return
>> NULL directly as defined in the include/linux/pinctrl/consumer.h.
>>
>> If CONFIG_PINCTRL is enabled because we are using a multi-platform
>> image but the actual hardware used doesn't have a pinctrl driver or
>> pinctrl device tree nodes.  It is expected that the devm_pinctrl_get()
>> will return error.  But as the pinctrl is only used for bus recovery
>> which is just an optional function of this driver.  We shouldn't
>> bailout the probe but keep the driver working without the bus recovery
>> function.  As for generic errors like (!dev) or out-of-memory, the
>> probe will fail elsewhere anyway.
>
> IMHO you shouldn't ignore -ENOMEM from devm_pinctrl_get but just the
> case for "there was no pinctrl specified in dt". Also consider the i2c
> driver is loaded before the pinctrl driver and devm_pinctrl_get returns
> -EPROBE_DEFER (I assume it does, didn't check), this should be handled.

Make sense.   -EPROBE_DEFER should be honored.  Maybe it's good to
check the -ENOMEM too.  I will send a new version.

Thanks,
Leo

^ permalink raw reply	[flat|nested] 14+ messages in thread

* [PATCH] i2c: imx: make bus recovery through pinctrl optional
@ 2015-11-20 18:04         ` Li Yang
  0 siblings, 0 replies; 14+ messages in thread
From: Li Yang @ 2015-11-20 18:04 UTC (permalink / raw)
  To: linux-arm-kernel

On Thu, Nov 19, 2015 at 2:08 AM, Uwe Kleine-K?nig
<u.kleine-koenig@pengutronix.de> wrote:
> Hello,
>
> Cc += Linus Walleij, linux-gpio
>
> On Wed, Nov 18, 2015 at 04:59:11PM -0600, Li Yang wrote:
>> On Wed, Nov 18, 2015 at 1:24 AM, Uwe Kleine-K?nig
>> <u.kleine-koenig@pengutronix.de> wrote:
>> > On Tue, Nov 17, 2015 at 06:02:59PM -0600, Li Yang wrote:
>> >> @@ -1125,7 +1119,12 @@ static int i2c_imx_probe(struct platform_device *pdev)
>> >>               goto clk_disable;
>> >>       }
>> >>
>> >> -     i2c_imx_init_recovery_info(i2c_imx, pdev);
>> >> +     /* optional bus recovery feature through pinctrl */
>> >> +     i2c_imx->pinctrl = devm_pinctrl_get(&pdev->dev);
>> >> +     if (IS_ERR_OR_NULL(i2c_imx->pinctrl))
>> >> +             dev_info(&pdev->dev, "can't get pinctrl, bus recovery feature disabled\n");
>> >> +     else
>> >> +             i2c_imx_init_recovery_info(i2c_imx, pdev);
>> >
>> > I'm pretty sure this is wrong. If pinctrl isn't available
>> > devm_pinctrl_get returns NULL? But AFAIK you must not ignore an error,
>> > so the better thing to do is:
>>
>> If CONFIG_PINCTRL is not enabled, the devm_pinctrl_get() will return
>> NULL directly as defined in the include/linux/pinctrl/consumer.h.
>>
>> If CONFIG_PINCTRL is enabled because we are using a multi-platform
>> image but the actual hardware used doesn't have a pinctrl driver or
>> pinctrl device tree nodes.  It is expected that the devm_pinctrl_get()
>> will return error.  But as the pinctrl is only used for bus recovery
>> which is just an optional function of this driver.  We shouldn't
>> bailout the probe but keep the driver working without the bus recovery
>> function.  As for generic errors like (!dev) or out-of-memory, the
>> probe will fail elsewhere anyway.
>
> IMHO you shouldn't ignore -ENOMEM from devm_pinctrl_get but just the
> case for "there was no pinctrl specified in dt". Also consider the i2c
> driver is loaded before the pinctrl driver and devm_pinctrl_get returns
> -EPROBE_DEFER (I assume it does, didn't check), this should be handled.

Make sense.   -EPROBE_DEFER should be honored.  Maybe it's good to
check the -ENOMEM too.  I will send a new version.

Thanks,
Leo

^ permalink raw reply	[flat|nested] 14+ messages in thread

end of thread, other threads:[~2015-11-20 18:04 UTC | newest]

Thread overview: 14+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-11-18  0:02 [PATCH] i2c: imx: make bus recovery through pinctrl optional Li Yang
2015-11-18  0:02 ` Li Yang
2015-11-18  0:02 ` Li Yang
2015-11-18  7:24 ` Uwe Kleine-König
2015-11-18  7:24   ` Uwe Kleine-König
2015-11-18 22:59   ` Li Yang
2015-11-18 22:59     ` Li Yang
2015-11-18 22:59     ` Li Yang
2015-11-19  8:08     ` Uwe Kleine-König
2015-11-19  8:08       ` Uwe Kleine-König
2015-11-19  8:08       ` Uwe Kleine-König
2015-11-20 18:04       ` Li Yang
2015-11-20 18:04         ` Li Yang
2015-11-20 18:04         ` Li Yang

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.