Re: [PATCH] [v2] at86rf230: convert to gpio descriptors

From: Miquel Raynal
Date: Wed Feb 01 2023 - 03:33:45 EST


Hi Dmitry,

dmitry.torokhov@xxxxxxxxx wrote on Tue, 31 Jan 2023 16:50:07 -0800:

> On Tue, Jan 31, 2023 at 3:52 PM Dmitry Torokhov
> <dmitry.torokhov@xxxxxxxxx> wrote:
> >
> > Hi Arnd,
> >
> > On Thu, Jan 26, 2023 at 8:32 AM Arnd Bergmann <arnd@xxxxxxxxxx> wrote:
> > >
> > > /* Reset */
> > > - if (gpio_is_valid(rstn)) {
> > > + if (rstn) {
> > > udelay(1);
> > > - gpio_set_value_cansleep(rstn, 0);
> > > + gpiod_set_value_cansleep(rstn, 0);
> > > udelay(1);
> > > - gpio_set_value_cansleep(rstn, 1);
> > > + gpiod_set_value_cansleep(rstn, 1);
> >
> > For gpiod conversions, if we are not willing to chase whether existing
> > DTSes specify polarities
> > properly and create workarounds in case they are wrong, we should use
> > gpiod_set_raw_value*()
> > (my preference would be to do the work and not use "raw" variants).
> >
> > In this particular case, arch/arm/boot/dts/vf610-zii-dev-rev-c.dts
> > defines reset line as active low,
> > so you are leaving the device in reset state.

You mean the semantics of gpio_set_value() gpiod_set_value() are
different? Looking at your patch it looks like gpio_set_value() asserts
a physical line state (high or low) while gpiod_set_value() would
actually try to assert a logical state (enabled or disabled) with the
meaning of those being possibly inverted thanks to the DT polarities.
Am I getting this right?

> > Please review your other conversion patches.
>
> We also can not change the names of requested GPIOs from "reset-gpio"
> to "rstn-gpios" and expect
> this to work.

Yep, missed that indeed.

>
> Stefan, please consider reverting this and applying a couple of
> patches I will send out shortly.

If my above understanding is right, then, yeah, the current
patches need to be fixed.

Thanks,
Miquèl