]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
pinctrl: mcp23s08: use new GPIO line value setter callbacks
authorBartosz Golaszewski <bartosz.golaszewski@linaro.org>
Thu, 12 Jun 2025 13:15:13 +0000 (15:15 +0200)
committerLinus Walleij <linus.walleij@linaro.org>
Wed, 18 Jun 2025 12:08:37 +0000 (14:08 +0200)
struct gpio_chip now has callbacks for setting line values that return
an integer, allowing to indicate failures. Convert the driver to using
them.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
Link: https://lore.kernel.org/20250612-gpiochip-set-rv-pinctrl-remaining-v1-4-556b0a530cd4@linaro.org
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/pinctrl/pinctrl-mcp23s08.c

index c2f4b16f42d20b0dfb0e1e6c79f8336392307c70..c8027ef03eccdf54809dfcd76ed8c07c424b41c3 100644 (file)
@@ -341,24 +341,30 @@ static int __mcp23s08_set(struct mcp23s08 *mcp, unsigned mask, bool value)
        return mcp_update_bits(mcp, MCP_OLAT, mask, value ? mask : 0);
 }
 
-static void mcp23s08_set(struct gpio_chip *chip, unsigned offset, int value)
+static int mcp23s08_set(struct gpio_chip *chip, unsigned int offset, int value)
 {
        struct mcp23s08 *mcp = gpiochip_get_data(chip);
        unsigned mask = BIT(offset);
+       int ret;
 
        mutex_lock(&mcp->lock);
-       __mcp23s08_set(mcp, mask, !!value);
+       ret = __mcp23s08_set(mcp, mask, !!value);
        mutex_unlock(&mcp->lock);
+
+       return ret;
 }
 
-static void mcp23s08_set_multiple(struct gpio_chip *chip,
-                                 unsigned long *mask, unsigned long *bits)
+static int mcp23s08_set_multiple(struct gpio_chip *chip,
+                                unsigned long *mask, unsigned long *bits)
 {
        struct mcp23s08 *mcp = gpiochip_get_data(chip);
+       int ret;
 
        mutex_lock(&mcp->lock);
-       mcp_update_bits(mcp, MCP_OLAT, *mask, *bits);
+       ret = mcp_update_bits(mcp, MCP_OLAT, *mask, *bits);
        mutex_unlock(&mcp->lock);
+
+       return ret;
 }
 
 static int
@@ -626,8 +632,8 @@ int mcp23s08_probe_one(struct mcp23s08 *mcp, struct device *dev,
        mcp->chip.get = mcp23s08_get;
        mcp->chip.get_multiple = mcp23s08_get_multiple;
        mcp->chip.direction_output = mcp23s08_direction_output;
-       mcp->chip.set = mcp23s08_set;
-       mcp->chip.set_multiple = mcp23s08_set_multiple;
+       mcp->chip.set_rv = mcp23s08_set;
+       mcp->chip.set_multiple_rv = mcp23s08_set_multiple;
 
        mcp->chip.base = base;
        mcp->chip.can_sleep = true;