* [PATCH v1] gpiolib: add gpio_array_to_id helper to get ID out of GPIO array
@ 2020-07-20 6:41 Oleksij Rempel
2020-07-23 6:25 ` Oleksij Rempel
0 siblings, 1 reply; 2+ messages in thread
From: Oleksij Rempel @ 2020-07-20 6:41 UTC (permalink / raw)
To: barebox, yegorslists; +Cc: Oleksij Rempel, david
Some boards provide a board version and/or ID coded by pull-up/down
resistors connected to the gpio pins (or pins which can be multiplexed
at some point as gpio). In this case every one implements own gpio id
reader function.
To avoid it, provide the common helper function to extract a value out
of provided gpio array.
Signed-off-by: Oleksij Rempel <o.rempel@pengutronix.de>
---
drivers/gpio/gpiolib.c | 28 ++++++++++++++++++++++++++++
include/gpio.h | 5 +++++
2 files changed, 33 insertions(+)
diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c
index 27674af54c..b3d7450ef2 100644
--- a/drivers/gpio/gpiolib.c
+++ b/drivers/gpio/gpiolib.c
@@ -381,6 +381,34 @@ void gpio_free_array(const struct gpio *array, size_t num)
}
EXPORT_SYMBOL_GPL(gpio_free_array);
+int gpio_array_to_id(const struct gpio *array, size_t num, u32 *val)
+{
+ u32 id = 0;
+ int ret, i;
+
+ if (num >= 32)
+ return -EOVERFLOW;
+
+ ret = gpio_request_array(array, num);
+ if (ret)
+ return ret;
+
+ /* Wait untill logic level will be stable */
+ udelay(5);
+ for (i = 0; i < num; i++) {
+ ret = gpio_get_value(array[i].gpio);
+ if (ret < 0)
+ return ret;
+
+ id |= ret << i;
+ }
+
+ *val = id;
+
+ return 0;
+}
+EXPORT_SYMBOL(gpio_array_to_id);
+
static int gpiochip_find_base(int start, int ngpio)
{
int i;
diff --git a/include/gpio.h b/include/gpio.h
index 98c5b93ba2..81beb47309 100644
--- a/include/gpio.h
+++ b/include/gpio.h
@@ -145,6 +145,10 @@ static inline void gpio_free_array(const struct gpio *array, size_t num)
/* GPIO can never have been requested */
WARN_ON(1);
}
+static inline int gpio_array_to_id(const struct gpio *array, size_t num, u32 *val)
+{
+ return -EINVAL;
+}
#else
int gpio_request(unsigned gpio, const char *label);
int gpio_find_by_name(const char *name);
@@ -153,6 +157,7 @@ void gpio_free(unsigned gpio);
int gpio_request_one(unsigned gpio, unsigned long flags, const char *label);
int gpio_request_array(const struct gpio *array, size_t num);
void gpio_free_array(const struct gpio *array, size_t num);
+int gpio_array_to_id(const struct gpio *array, size_t num, u32 *val);
#endif
struct gpio_chip;
--
2.27.0
_______________________________________________
barebox mailing list
barebox@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/barebox
^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: [PATCH v1] gpiolib: add gpio_array_to_id helper to get ID out of GPIO array
2020-07-20 6:41 [PATCH v1] gpiolib: add gpio_array_to_id helper to get ID out of GPIO array Oleksij Rempel
@ 2020-07-23 6:25 ` Oleksij Rempel
0 siblings, 0 replies; 2+ messages in thread
From: Oleksij Rempel @ 2020-07-23 6:25 UTC (permalink / raw)
To: barebox
This version need some fixes,
I'll send a new version soon
Am 20.07.20 um 08:41 schrieb Oleksij Rempel:
> Some boards provide a board version and/or ID coded by pull-up/down
> resistors connected to the gpio pins (or pins which can be multiplexed
> at some point as gpio). In this case every one implements own gpio id
> reader function.
>
> To avoid it, provide the common helper function to extract a value out
> of provided gpio array.
>
> Signed-off-by: Oleksij Rempel <o.rempel@pengutronix.de>
> ---
> drivers/gpio/gpiolib.c | 28 ++++++++++++++++++++++++++++
> include/gpio.h | 5 +++++
> 2 files changed, 33 insertions(+)
>
> diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c
> index 27674af54c..b3d7450ef2 100644
> --- a/drivers/gpio/gpiolib.c
> +++ b/drivers/gpio/gpiolib.c
> @@ -381,6 +381,34 @@ void gpio_free_array(const struct gpio *array, size_t num)
> }
> EXPORT_SYMBOL_GPL(gpio_free_array);
>
> +int gpio_array_to_id(const struct gpio *array, size_t num, u32 *val)
> +{
> + u32 id = 0;
> + int ret, i;
> +
> + if (num >= 32)
> + return -EOVERFLOW;
> +
> + ret = gpio_request_array(array, num);
> + if (ret)
> + return ret;
> +
> + /* Wait untill logic level will be stable */
> + udelay(5);
> + for (i = 0; i < num; i++) {
> + ret = gpio_get_value(array[i].gpio);
> + if (ret < 0)
> + return ret;
> +
> + id |= ret << i;
> + }
> +
> + *val = id;
> +
> + return 0;
> +}
> +EXPORT_SYMBOL(gpio_array_to_id);
> +
> static int gpiochip_find_base(int start, int ngpio)
> {
> int i;
> diff --git a/include/gpio.h b/include/gpio.h
> index 98c5b93ba2..81beb47309 100644
> --- a/include/gpio.h
> +++ b/include/gpio.h
> @@ -145,6 +145,10 @@ static inline void gpio_free_array(const struct gpio *array, size_t num)
> /* GPIO can never have been requested */
> WARN_ON(1);
> }
> +static inline int gpio_array_to_id(const struct gpio *array, size_t num, u32 *val)
> +{
> + return -EINVAL;
> +}
> #else
> int gpio_request(unsigned gpio, const char *label);
> int gpio_find_by_name(const char *name);
> @@ -153,6 +157,7 @@ void gpio_free(unsigned gpio);
> int gpio_request_one(unsigned gpio, unsigned long flags, const char *label);
> int gpio_request_array(const struct gpio *array, size_t num);
> void gpio_free_array(const struct gpio *array, size_t num);
> +int gpio_array_to_id(const struct gpio *array, size_t num, u32 *val);
> #endif
>
> struct gpio_chip;
>
--
Regards,
Oleksij
_______________________________________________
barebox mailing list
barebox@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/barebox
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2020-07-23 6:38 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-07-20 6:41 [PATCH v1] gpiolib: add gpio_array_to_id helper to get ID out of GPIO array Oleksij Rempel
2020-07-23 6:25 ` Oleksij Rempel
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox