LKML Archive on lore.kernel.org
help / color / mirror / Atom feed
* [patch 2.6.25-rc2-git] gpio: <linux/gpio.h> and "no GPIO support here" stubs
@ 2008-02-23 1:12 David Brownell
2008-02-27 23:48 ` Andrew Morton
0 siblings, 1 reply; 3+ messages in thread
From: David Brownell @ 2008-02-23 1:12 UTC (permalink / raw)
To: Andrew Morton; +Cc: lkml, cbouatmailru, Anton Vorontsov, Florian Fainelli
Add a <linux/gpio.h> defining fail/warn stubs for GPIO calls on platforms
that don't support the GPIO programming interface. That includes the
arch-specific implementation glue otherwise.
This facilitates a new model for GPIO usage: drivers that can use GPIOs
if they're available, but don't require them. One example of such a
driver is NAND driver for various FreeScale chips. On platforms update
with GPIO support, they can be used instead of a worst-case delay to
verify that the BUSY signal is off.
(Also includes a couple minor unrelated doc updates.)
Signed-off-by: David Brownell <dbrownell@users.sourceforge.net>
---
Please include before 2.6.25-final ...
Documentation/gpio.txt | 16 ++++++--
include/linux/gpio.h | 95 +++++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 107 insertions(+), 4 deletions(-)
--- g26.orig/Documentation/gpio.txt 2008-02-22 16:20:36.000000000 -0800
+++ g26/Documentation/gpio.txt 2008-02-22 17:02:00.000000000 -0800
@@ -2,6 +2,9 @@ GPIO Interfaces
This provides an overview of GPIO access conventions on Linux.
+These calls use the gpio_* naming prefix. No other calls should use that
+prefix, or the related __gpio_* prefix.
+
What is a GPIO?
===============
@@ -69,11 +72,13 @@ in this document, but drivers acting as
not care how it's implemented.)
That said, if the convention is supported on their platform, drivers should
-use it when possible. Platforms should declare GENERIC_GPIO support in
-Kconfig (boolean true), which multi-platform drivers can depend on when
-using the include file:
+use it when possible. Platforms must declare GENERIC_GPIO support in their
+Kconfig (boolean true), and provide an <asm/gpio.h> file. Drivers that can't
+work without standard GPIO calls should have Kconfig entries which depend
+on GENERIC_GPIO. The GPIO calls are available, either as "real code" or as
+optimized-away stubs, when drivers use the include file:
- #include <asm/gpio.h>
+ #include <linux/gpio.h>
If you stick to this convention then it'll be easier for other developers to
see what your code is doing, and help maintain it.
@@ -326,6 +331,9 @@ pulldowns integrated on some platforms.
or support them in the same way; and any given board might use external
pullups (or pulldowns) so that the on-chip ones should not be used.
(When a circuit needs 5 kOhm, on-chip 100 kOhm resistors won't do.)
+Likewise drive strength (2 mA vs 20 mA) and voltage (1.8V vs 3.3V) is a
+platform-specific issue, as are models like (not) having a one-to-one
+correspondence between configurable pins and GPIOs.
There are other system-specific mechanisms that are not specified here,
like the aforementioned options for input de-glitching and wire-OR output.
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
+++ g26/include/linux/gpio.h 2008-02-22 17:05:48.000000000 -0800
@@ -0,0 +1,95 @@
+#ifndef __LINUX_GPIO_H
+#define __LINUX_GPIO_H
+
+/* see Documentation/gpio.txt */
+
+#ifdef CONFIG_GENERIC_GPIO
+#include <asm/gpio.h>
+
+#else
+
+/*
+ * Some platforms don't support the GPIO programming interface.
+ *
+ * In case some driver uses it anyway (it should normally have
+ * depended on GENERIC_GPIO), these routines help the compiler
+ * optimize out much GPIO-related code ... or trigger a runtime
+ * warning when something is wrongly called.
+ */
+
+static inline int gpio_is_valid(int number)
+{
+ return 0;
+}
+
+static inline int gpio_request(unsigned gpio, const char *label)
+{
+ return -ENOSYS;
+}
+
+static inline void gpio_free(unsigned gpio)
+{
+ /* GPIO can never have been requested */
+ WARN_ON(1);
+}
+
+static inline int gpio_direction_input(unsigned gpio)
+{
+ return -ENOSYS;
+}
+
+static inline int gpio_direction_output(unsigned gpio, int value)
+{
+ return -ENOSYS;
+}
+
+static inline int gpio_get_value(unsigned gpio)
+{
+ /* GPIO can never have been requested or set as {in,out}put */
+ WARN_ON(1);
+ return 0;
+}
+
+static inline void gpio_set_value(unsigned gpio, int value)
+{
+ /* GPIO can never have been requested or set as output */
+ WARN_ON(1);
+}
+
+static inline int gpio_cansleep(unsigned gpio)
+{
+ /* GPIO can never have been requested or set as {in,out}put */
+ WARN_ON(1);
+ return 0;
+}
+
+static inline int gpio_get_value_cansleep(unsigned gpio)
+{
+ /* GPIO can never have been requested or set as {in,out}put */
+ WARN_ON(1);
+ return 0;
+}
+
+static inline void gpio_set_value_cansleep(unsigned gpio, int value)
+{
+ /* GPIO can never have been requested or set as output */
+ WARN_ON(1);
+}
+
+static inline int gpio_to_irq(unsigned gpio)
+{
+ /* GPIO can never have been requested or set as input */
+ WARN_ON(1);
+ return -EINVAL;
+}
+
+static inline int irq_to_gpio(unsigned irq)
+{
+ /* irq can never have been returned from gpio_to_irq() */
+ WARN_ON(1);
+ return -EINVAL;
+}
+
+#endif
+
+#endif /* __LINUX_GPIO_H */
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [patch 2.6.25-rc2-git] gpio: <linux/gpio.h> and "no GPIO support here" stubs
2008-02-23 1:12 [patch 2.6.25-rc2-git] gpio: <linux/gpio.h> and "no GPIO support here" stubs David Brownell
@ 2008-02-27 23:48 ` Andrew Morton
2008-02-28 0:42 ` David Brownell
0 siblings, 1 reply; 3+ messages in thread
From: Andrew Morton @ 2008-02-27 23:48 UTC (permalink / raw)
To: David Brownell; +Cc: linux-kernel, cbouatmailru, avorontsov, florian.fainelli
On Fri, 22 Feb 2008 17:12:17 -0800
David Brownell <david-b@pacbell.net> wrote:
> Add a <linux/gpio.h> defining fail/warn stubs for GPIO calls on platforms
> that don't support the GPIO programming interface. That includes the
> arch-specific implementation glue otherwise.
>
> This facilitates a new model for GPIO usage: drivers that can use GPIOs
> if they're available, but don't require them. One example of such a
> driver is NAND driver for various FreeScale chips. On platforms update
> with GPIO support, they can be used instead of a worst-case delay to
> verify that the BUSY signal is off.
>
> (Also includes a couple minor unrelated doc updates.)
>
Looks sane.
> Please include before 2.6.25-final ...
For what reason?
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [patch 2.6.25-rc2-git] gpio: <linux/gpio.h> and "no GPIO support here" stubs
2008-02-27 23:48 ` Andrew Morton
@ 2008-02-28 0:42 ` David Brownell
0 siblings, 0 replies; 3+ messages in thread
From: David Brownell @ 2008-02-28 0:42 UTC (permalink / raw)
To: Andrew Morton; +Cc: linux-kernel, cbouatmailru, avorontsov, florian.fainelli
> > Add a <linux/gpio.h> defining fail/warn stubs for GPIO calls on platforms
> > that don't support the GPIO programming interface. That includes the
> > arch-specific implementation glue otherwise.
> >
> > This facilitates a new model for GPIO usage: drivers that can use GPIOs
> > if they're available, but don't require them. ...
> >
>
> Looks sane.
>
> > Please include before 2.6.25-final ...
>
> For what reason?
So that 2.6.25 based systems can start to use it. This patch is in that
"safe, can't break any existing code" category, so I don't see a downside.
- Dave
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2008-02-28 0:43 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2008-02-23 1:12 [patch 2.6.25-rc2-git] gpio: <linux/gpio.h> and "no GPIO support here" stubs David Brownell
2008-02-27 23:48 ` Andrew Morton
2008-02-28 0:42 ` David Brownell
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).