[PATCH 6/7] gpiolib: implement of_gpio_get_chip_by_alias
Ahmad Fatoum
a.fatoum at pengutronix.de
Mon Jul 1 00:32:19 PDT 2024
Rockchip pinctrl binding can configure GPIO direction, so let's add a
function that returns a gpio_chip that can be used for this.
Signed-off-by: Ahmad Fatoum <a.fatoum at pengutronix.de>
---
drivers/gpio/gpiolib.c | 19 +++++++++++++++++++
include/gpio.h | 6 ++++++
2 files changed, 25 insertions(+)
diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c
index 520ffed2eefb..f34dce0e98c6 100644
--- a/drivers/gpio/gpiolib.c
+++ b/drivers/gpio/gpiolib.c
@@ -1057,6 +1057,25 @@ struct gpio_chip *gpio_get_chip_by_dev(struct device *dev)
return NULL;
}
+struct gpio_chip *of_gpio_get_chip_by_alias(const char *alias)
+{
+ struct gpio_chip *chip;
+ struct device_node *np;
+
+ np = of_find_node_by_alias(NULL, alias);
+ if (!np)
+ return NULL;
+
+ of_device_ensure_probed(np);
+
+ list_for_each_entry(chip, &chip_list, list) {
+ if (dev_of_node(chip->dev) == np)
+ return chip;
+ }
+
+ return NULL;
+}
+
int gpio_get_num(struct device *dev, int gpio)
{
struct gpio_chip *chip;
diff --git a/include/gpio.h b/include/gpio.h
index 71896c9d6bdb..8c3eea73d8bb 100644
--- a/include/gpio.h
+++ b/include/gpio.h
@@ -36,6 +36,7 @@ void gpio_set_active(unsigned gpio, bool state);
int gpio_is_active(unsigned gpio);
int gpio_direction_active(unsigned gpio, bool state);
struct gpio_chip *gpio_get_chip_by_dev(struct device *);
+struct gpio_chip *of_gpio_get_chip_by_alias(const char *alias);
/**
* gpio_poll_timeout_us - Poll till GPIO reaches requested active state
@@ -69,6 +70,11 @@ static inline struct gpio_chip *gpio_get_chip_by_dev(struct device *dev)
return NULL;
}
+static struct gpio_chip *of_gpio_get_chip_by_alias(const char *alias)
+{
+ return NULL;
+}
+
#define gpio_poll_timeout_us(gpio, val, timeout_us) (-ENOSYS)
#endif
--
2.39.2
More information about the barebox
mailing list