On Monday 03 July 2017 01:58 PM, Axel Lin wrote: > The value argument of lp87565_gpio_direction_output() means output level > rather than gpio direction. > > Signed-off-by: Axel Lin <axel.lin@xxxxxxxxxx> > Reviewed-by: Keerthy <j-keerthy@xxxxxx> > Tested-by: Keerthy <j-keerthy@xxxxxx> > --- > v2: Call lp87565_gpio_set() instead of open-coded. > I move lp87565_gpio_get/lp87565_gpio_set functions up to avoid forward > declaration. It's fine to only move lp87565_gpio_set() but it looks better > for me to move lp87565_gpio_get/lp87565_gpio_set together. > Hope this change is fine. Looks good to me. > > drivers/gpio/gpio-lp87565.c | 46 +++++++++++++++++++++++---------------------- > 1 file changed, 24 insertions(+), 22 deletions(-) > > diff --git a/drivers/gpio/gpio-lp87565.c b/drivers/gpio/gpio-lp87565.c > index 6313c50..a121c8f 100644 > --- a/drivers/gpio/gpio-lp87565.c > +++ b/drivers/gpio/gpio-lp87565.c > @@ -26,6 +26,27 @@ struct lp87565_gpio { > struct regmap *map; > }; > > +static int lp87565_gpio_get(struct gpio_chip *chip, unsigned int offset) > +{ > + struct lp87565_gpio *gpio = gpiochip_get_data(chip); > + int ret, val; > + > + ret = regmap_read(gpio->map, LP87565_REG_GPIO_IN, &val); > + if (ret < 0) > + return ret; > + > + return !!(val & BIT(offset)); > +} > + > +static void lp87565_gpio_set(struct gpio_chip *chip, unsigned int offset, > + int value) > +{ > + struct lp87565_gpio *gpio = gpiochip_get_data(chip); > + > + regmap_update_bits(gpio->map, LP87565_REG_GPIO_OUT, > + BIT(offset), value ? BIT(offset) : 0); > +} > + > static int lp87565_gpio_get_direction(struct gpio_chip *chip, > unsigned int offset) > { > @@ -54,30 +75,11 @@ static int lp87565_gpio_direction_output(struct gpio_chip *chip, > { > struct lp87565_gpio *gpio = gpiochip_get_data(chip); > > + lp87565_gpio_set(chip, offset, value); > + > return regmap_update_bits(gpio->map, > LP87565_REG_GPIO_CONFIG, > - BIT(offset), !value ? BIT(offset) : 0); > -} > - > -static int lp87565_gpio_get(struct gpio_chip *chip, unsigned int offset) > -{ > - struct lp87565_gpio *gpio = gpiochip_get_data(chip); > - int ret, val; > - > - ret = regmap_read(gpio->map, LP87565_REG_GPIO_IN, &val); > - if (ret < 0) > - return ret; > - > - return !!(val & BIT(offset)); > -} > - > -static void lp87565_gpio_set(struct gpio_chip *chip, unsigned int offset, > - int value) > -{ > - struct lp87565_gpio *gpio = gpiochip_get_data(chip); > - > - regmap_update_bits(gpio->map, LP87565_REG_GPIO_OUT, > - BIT(offset), value ? BIT(offset) : 0); > + BIT(offset), BIT(offset)); > } > > static int lp87565_gpio_request(struct gpio_chip *gc, unsigned int offset) > -- To unsubscribe from this list: send the line "unsubscribe linux-gpio" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html