On Fri, Mar 1, 2019 at 4:27 PM Axel Lin <axel.lin@xxxxxxxxxx> wrote: > > Current amd_fch_gpio_direction_output implementation ignores the value > argument, fix it so direction_output will set proper output level. > Code looks okay, FWIW, Reviewed-by: Andy Shevchenko <andy.shevchenko@xxxxxxxxx> > Signed-off-by: Axel Lin <axel.lin@xxxxxxxxxx> > --- > Hi Enrico, > I don't have h/w to test, so please help review and test it. > Thanks, > Axel > drivers/gpio/gpio-amd-fch.c | 11 ++++++++++- > 1 file changed, 10 insertions(+), 1 deletion(-) > > diff --git a/drivers/gpio/gpio-amd-fch.c b/drivers/gpio/gpio-amd-fch.c > index 4fd66444ea33..aa9237eacd7c 100644 > --- a/drivers/gpio/gpio-amd-fch.c > +++ b/drivers/gpio/gpio-amd-fch.c > @@ -65,9 +65,18 @@ static int amd_fch_gpio_direction_output(struct gpio_chip *gc, > unsigned long flags; > struct amd_fch_gpio_priv *priv = gpiochip_get_data(gc); > void *ptr = amd_fch_gpio_addr(priv, gpio); > + u32 val; > > spin_lock_irqsave(&priv->lock, flags); > - writel_relaxed(readl_relaxed(ptr) | AMD_FCH_GPIO_FLAG_DIRECTION, ptr); > + > + val = readl_relaxed(ptr); > + if (value) > + val |= AMD_FCH_GPIO_FLAG_WRITE; > + else > + val &= ~AMD_FCH_GPIO_FLAG_WRITE; > + > + writel_relaxed(val | AMD_FCH_GPIO_FLAG_DIRECTION, ptr); > + > spin_unlock_irqrestore(&priv->lock, flags); > > return 0; > -- > 2.17.1 > -- With Best Regards, Andy Shevchenko