summaryrefslogtreecommitdiffstats
path: root/target/linux/brcm47xx/patches-2.6.25/710-add-gpio-is-valid.patch
blob: 59552ed9271b2a428d2b78a1cd7dc99d78006c15 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
Add gpio_is_valid() for bcm47xx
--- a/arch/mips/bcm47xx/gpio.c
+++ b/arch/mips/bcm47xx/gpio.c
@@ -77,3 +77,15 @@
 }
 EXPORT_SYMBOL_GPL(bcm47xx_gpio_direction_output);
 
+int bcm47xx_gpio_is_valid(int gpio)
+{
+	if (ssb_bcm47xx.chipco.dev) {
+		if (gpio >= 0 && gpio < BCM47XX_CHIPCO_GPIO_LINES)
+			return 1;
+	} else if (ssb_bcm47xx.extif.dev) {
+		if (gpio >= 0 && gpio < BCM47XX_EXTIF_GPIO_LINES)
+			return 1;
+	}
+	return 0;
+}
+EXPORT_SYMBOL_GPL(bcm47xx_gpio_is_valid);
--- a/include/asm-mips/mach-bcm47xx/gpio.h
+++ b/include/asm-mips/mach-bcm47xx/gpio.h
@@ -17,6 +17,7 @@
 extern void bcm47xx_gpio_set_value(unsigned gpio, int value);
 extern int bcm47xx_gpio_direction_input(unsigned gpio);
 extern int bcm47xx_gpio_direction_output(unsigned gpio, int value);
+extern int bcm47xx_gpio_is_valid(int gpio);
 
 static inline int gpio_request(unsigned gpio, const char *label)
 {
@@ -52,6 +53,8 @@
 	return bcm47xx_gpio_direction_output(gpio, value);
 }
 
+#define gpio_is_valid	bcm47xx_gpio_is_valid
+
 
 /* cansleep wrappers */
 #include <asm-generic/gpio.h>