Re: [PATCH] iio: resolver: ad2s1210: add reset gpio support

From: Jonathan Cameron
Date: Wed Oct 18 2023 - 15:26:06 EST


On Tue, 17 Oct 2023 13:46:51 +0000
"Hennerich, Michael" <Michael.Hennerich@xxxxxxxxxx> wrote:

> > -----Original Message-----
> > From: David Lechner <dlechner@xxxxxxxxxxxx>
> > Sent: Montag, 16. Oktober 2023 17:43
> > To: linux-iio@xxxxxxxxxxxxxxx
> > Cc: David Lechner <dlechner@xxxxxxxxxxxx>; Jonathan Cameron
> > <jic23@xxxxxxxxxx>; Hennerich, Michael <Michael.Hennerich@xxxxxxxxxx>;
> > Sa, Nuno <Nuno.Sa@xxxxxxxxxx>; linux-kernel@xxxxxxxxxxxxxxx
> > Subject: [PATCH] iio: resolver: ad2s1210: add reset gpio support
> >
> >
> > This adds support for the optional reset gpio to the ad2s1210 resolver driver. If
> > the gpio is present in the device tree, it is toggled during driver probe before the
> > reset of the device initialization. As per the devicetree bindings, it is expected for
> > the gpio to configured as active low.
> >
> > Suggested-by: Michael Hennerich <Michael.Hennerich@xxxxxxxxxx>
> > Signed-off-by: David Lechner <dlechner@xxxxxxxxxxxx>
> > ---
>
> Acked-by: Michael Hennerich <michael.hennerich@xxxxxxxxxx>
Applied and pushed out as testing for 0-day to poke at it.

Thanks,

Jonathan

>
> > drivers/iio/resolver/ad2s1210.c | 12 ++++++++++++
> > 1 file changed, 12 insertions(+)
> >
> > diff --git a/drivers/iio/resolver/ad2s1210.c b/drivers/iio/resolver/ad2s1210.c
> > index 8646389ec88d..a414eef12e5e 100644
> > --- a/drivers/iio/resolver/ad2s1210.c
> > +++ b/drivers/iio/resolver/ad2s1210.c
> > @@ -1426,6 +1426,7 @@ static int ad2s1210_setup_gpios(struct
> > ad2s1210_state *st) {
> > struct device *dev = &st->sdev->dev;
> > struct gpio_descs *resolution_gpios;
> > + struct gpio_desc *reset_gpio;
> > DECLARE_BITMAP(bitmap, 2);
> > int ret;
> >
> > @@ -1481,6 +1482,17 @@ static int ad2s1210_setup_gpios(struct
> > ad2s1210_state *st)
> > "failed to set resolution gpios\n");
> > }
> >
> > + /* If the optional reset GPIO is present, toggle it to do a hard reset. */
> > + reset_gpio = devm_gpiod_get_optional(dev, "reset",
> > GPIOD_OUT_HIGH);
> > + if (IS_ERR(reset_gpio))
> > + return dev_err_probe(dev, PTR_ERR(reset_gpio),
> > + "failed to request reset GPIO\n");
> > +
> > + if (reset_gpio) {
> > + udelay(10);
> > + gpiod_set_value(reset_gpio, 0);
> > + }
> > +
> > return 0;
> > }
> >
> > --
> > 2.42.0
>