Hi Dmitry,

On Fri, Feb 10, 2017 at 04:06:22PM -0800, Dmitry Torokhov wrote:
> In case of an optional regulator missing regulator core will return
> ERR_PTR(-ENOENT) and not NULL, so the check for missing regulator is
> incorrect. Also, the regulator is not optional, it may simply be missing
> from platform decsription, so let's use devm_regulator_get() and rely on
> regulator core to give us dummy supply when real one is not available.
>
> Fixes: d257f2980feb ("Input: tsc2005 - convert to gpiod")
> Signed-off-by: Dmitry Torokhov <dmitry.torok...@gmail.com>

Acked-By: Sebastian Reichel <s...@kernel.org>

> ---
> 
> Sebastian, I am wondering, what regulator this is.

On N900 the same regultor is connected to I/OVDD & SNSVDD.

> If it is IO VDD, then I think we activate it too late (i.e. we are
> truing to shut off the controller before we turn the regulator on.

Yes, it should be moved.

> If it is sensor VDD, then we probably need to mention it, and also
> add IO VVD supply as well.

-- Sebastian

> 
>  drivers/input/touchscreen/tsc200x-core.c | 19 +++++++------------
>  1 file changed, 7 insertions(+), 12 deletions(-)
> 
> diff --git a/drivers/input/touchscreen/tsc200x-core.c 
> b/drivers/input/touchscreen/tsc200x-core.c
> index b7059ed8872e..1c14a38e3748 100644
> --- a/drivers/input/touchscreen/tsc200x-core.c
> +++ b/drivers/input/touchscreen/tsc200x-core.c
> @@ -527,10 +527,10 @@ int tsc200x_probe(struct device *dev, int irq, const 
> struct input_id *tsc_id,
>               return error;
>       }
>  
> -     ts->vio = devm_regulator_get_optional(dev, "vio");
> +     ts->vio = devm_regulator_get(dev, "vio");
>       if (IS_ERR(ts->vio)) {
>               error = PTR_ERR(ts->vio);
> -             dev_err(dev, "vio regulator missing (%d)", error);
> +             dev_err(dev, "error acquiring vio regulator: %d", error);
>               return error;
>       }
>  
> @@ -587,12 +587,9 @@ int tsc200x_probe(struct device *dev, int irq, const 
> struct input_id *tsc_id,
>               return error;
>       }
>  
> -     /* enable regulator for DT */
> -     if (ts->vio) {
> -             error = regulator_enable(ts->vio);
> -             if (error)
> -                     return error;
> -     }
> +     error = regulator_enable(ts->vio);
> +     if (error)
> +             return error;
>  
>       dev_set_drvdata(dev, ts);
>       error = sysfs_create_group(&dev->kobj, &tsc200x_attr_group);
> @@ -615,8 +612,7 @@ int tsc200x_probe(struct device *dev, int irq, const 
> struct input_id *tsc_id,
>  err_remove_sysfs:
>       sysfs_remove_group(&dev->kobj, &tsc200x_attr_group);
>  disable_regulator:
> -     if (ts->vio)
> -             regulator_disable(ts->vio);
> +     regulator_disable(ts->vio);
>       return error;
>  }
>  EXPORT_SYMBOL_GPL(tsc200x_probe);
> @@ -627,8 +623,7 @@ int tsc200x_remove(struct device *dev)
>  
>       sysfs_remove_group(&dev->kobj, &tsc200x_attr_group);
>  
> -     if (ts->vio)
> -             regulator_disable(ts->vio);
> +     regulator_disable(ts->vio);
>  
>       return 0;
>  }
> -- 
> 2.11.0.483.g087da7b7c-goog
> 

Attachment: signature.asc
Description: PGP signature

Reply via email to