]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
pinctrl: lpass-lpi: implement .get_direction() for the GPIO driver
authorBartosz Golaszewski <bartosz.golaszewski@oss.qualcomm.com>
Tue, 3 Feb 2026 23:48:50 +0000 (18:48 -0500)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 6 Feb 2026 15:44:25 +0000 (16:44 +0100)
[ Upstream commit 4f0d22ec60cee420125f4055af76caa0f373a3fe ]

GPIO controller driver should typically implement the .get_direction()
callback as GPIOLIB internals may try to use it to determine the state
of a pin. Add it for the LPASS LPI driver.

Reported-by: Abel Vesa <abelvesa@kernel.org>
Cc: stable@vger.kernel.org
Fixes: 6e261d1090d6 ("pinctrl: qcom: Add sm8250 lpass lpi pinctrl driver")
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@oss.qualcomm.com>
Reviewed-by: Konrad Dybcio <konrad.dybcio@oss.qualcomm.com>
Tested-by: Konrad Dybcio <konrad.dybcio@oss.qualcomm.com> # X1E CRD
Tested-by: Abel Vesa <abel.vesa@oss.qualcomm.com>
Signed-off-by: Linus Walleij <linusw@kernel.org>
[ PIN_CONFIG_LEVEL => PIN_CONFIG_OUTPUT ]
Signed-off-by: Sasha Levin <sashal@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/pinctrl/qcom/pinctrl-lpass-lpi.c

index 35f46ca4cf9fc1c63ad51f659ca4dde3aa9ac30c..c90bc60b3386ceca76d25a4f3384439c1a4e8d5c 100644 (file)
@@ -248,6 +248,22 @@ static const struct pinconf_ops lpi_gpio_pinconf_ops = {
        .pin_config_group_set           = lpi_config_set,
 };
 
+static int lpi_gpio_get_direction(struct gpio_chip *chip, unsigned int pin)
+{
+       unsigned long config = pinconf_to_config_packed(PIN_CONFIG_OUTPUT, 0);
+       struct lpi_pinctrl *state = gpiochip_get_data(chip);
+       unsigned long arg;
+       int ret;
+
+       ret = lpi_config_get(state->ctrl, pin, &config);
+       if (ret)
+               return ret;
+
+       arg = pinconf_to_config_argument(config);
+
+       return arg ? GPIO_LINE_DIRECTION_OUT : GPIO_LINE_DIRECTION_IN;
+}
+
 static int lpi_gpio_direction_input(struct gpio_chip *chip, unsigned int pin)
 {
        struct lpi_pinctrl *state = gpiochip_get_data(chip);
@@ -346,6 +362,7 @@ static void lpi_gpio_dbg_show(struct seq_file *s, struct gpio_chip *chip)
 #endif
 
 static const struct gpio_chip lpi_gpio_template = {
+       .get_direction          = lpi_gpio_get_direction,
        .direction_input        = lpi_gpio_direction_input,
        .direction_output       = lpi_gpio_direction_output,
        .get                    = lpi_gpio_get,