From mboxrd@z Thu Jan 1 00:00:00 1970 Return-path: Received: from mail-lb0-f170.google.com ([209.85.217.170]) by merlin.infradead.org with esmtps (Exim 4.76 #1 (Red Hat Linux)) id 1U1L41-0002Sb-ET for barebox@lists.infradead.org; Fri, 01 Feb 2013 18:10:14 +0000 Received: by mail-lb0-f170.google.com with SMTP id ge1so4853376lbb.1 for ; Fri, 01 Feb 2013 10:10:12 -0800 (PST) From: Antony Pavlov Date: Fri, 1 Feb 2013 22:22:19 +0400 Message-Id: <1359742941-30516-3-git-send-email-antonynpavlov@gmail.com> In-Reply-To: <1359742941-30516-1-git-send-email-antonynpavlov@gmail.com> References: <1359742941-30516-1-git-send-email-antonynpavlov@gmail.com> List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: barebox-bounces@lists.infradead.org Errors-To: barebox-bounces+u.kleine-koenig=pengutronix.de@lists.infradead.org Subject: [PATCH v3 2/4] gpiolib: add gpio_request_{in,out}put support To: barebox@lists.infradead.org gpio_request() followed by gpio_direction_{in,out}put is a gpio usage pattern (e.g. the similar functions are used in a ARM boards code). Signed-off-by: Antony Pavlov --- drivers/gpio/gpio.c | 40 ++++++++++++++++++++++++++++++++++++++++ include/gpio.h | 13 +++++++++++++ 2 files changed, 53 insertions(+) diff --git a/drivers/gpio/gpio.c b/drivers/gpio/gpio.c index d37f5a0..c0c66ae 100644 --- a/drivers/gpio/gpio.c +++ b/drivers/gpio/gpio.c @@ -47,6 +47,46 @@ int gpio_request(unsigned gpio, const char *label) return 0; } +int gpio_request_input(unsigned gpio, const char *label) +{ + int ret; + + ret = gpio_request(gpio, label); + if (ret) { + pr_err("can't request gpio %d as %s (%d)\n", + gpio, label, ret); + return ret; + } + + ret = gpio_direction_input(gpio); + if (ret) { + pr_err("can't configure gpio %d (%s) as input (%d)\n", + gpio, label, ret); + } + + return ret; +} + +int gpio_request_output(unsigned gpio, const char *label, int value) +{ + int ret; + + ret = gpio_request(gpio, label); + if (ret) { + pr_err("can't request gpio %d as %s (%d)\n", + gpio, label, ret); + return ret; + } + + ret = gpio_direction_output(gpio, value); + if (ret) { + pr_err("can't configure gpio %d (%s) as output (%d)\n", + gpio, label, ret); + } + + return ret; +} + void gpio_free(unsigned gpio) { struct gpio_info *gi = &gpio_desc[gpio]; diff --git a/include/gpio.h b/include/gpio.h index 794d959..309c1c5 100644 --- a/include/gpio.h +++ b/include/gpio.h @@ -9,11 +9,24 @@ static inline int gpio_request(unsigned gpio, const char *label) return 0; } +static inline int gpio_request_input(unsigned gpio, const char *label) +{ + return 0; +} + +static inline int gpio_request_output(unsigned gpio, const char *label, + int value) +{ + return 0; +} + static inline void gpio_free(unsigned gpio) { } #else int gpio_request(unsigned gpio, const char *label); +int gpio_request_input(unsigned gpio, const char *label); +int gpio_request_output(unsigned gpio, const char *label, int value); void gpio_free(unsigned gpio); #endif -- 1.7.10.4 _______________________________________________ barebox mailing list barebox@lists.infradead.org http://lists.infradead.org/mailman/listinfo/barebox