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).