Blackfin arch: add BF54x missing GPIO access functions
authorMichael Hennerich <michael.hennerich@analog.com>
Mon, 2 Jul 2007 03:45:50 +0000 (11:45 +0800)
committerBryan Wu <bryan.wu@analog.com>
Mon, 2 Jul 2007 03:45:50 +0000 (11:45 +0800)
Signed-off-by: Michael Hennerich <michael.hennerich@analog.com>
Signed-off-by: Bryan Wu <bryan.wu@analog.com>
arch/blackfin/mach-bf548/gpio.c
include/asm-blackfin/gpio.h
include/asm-blackfin/mach-bf548/gpio.h

index fac7cf3d6791d5251aabeeed2ce6474f76356210..9b1a00aabf283cd57c33e669373b67fa80cc3c95 100644 (file)
@@ -52,6 +52,7 @@ inline int check_gpio(unsigned short gpio)
 {
        if (gpio == GPIO_PB15 || gpio == GPIO_PC14 || gpio == GPIO_PC15 \
                        || gpio == GPIO_PH14 || gpio == GPIO_PH15 \
+                       || gpio == GPIO_PJ14 || gpio == GPIO_PJ15 \
                        || gpio > MAX_BLACKFIN_GPIOS)
                return -EINVAL;
        return 0;
@@ -173,3 +174,19 @@ void gpio_direction_output(unsigned short gpio)
        local_irq_restore(flags);
 }
 EXPORT_SYMBOL(gpio_direction_output);
+
+void gpio_set_value(unsigned short gpio, unsigned short arg)
+{
+       if (arg)
+               gpio_array[gpio_bank(gpio)]->port_set = gpio_bit(gpio);
+       else
+               gpio_array[gpio_bank(gpio)]->port_clear = gpio_bit(gpio);
+
+}
+EXPORT_SYMBOL(gpio_set_value);
+
+unsigned short gpio_get_value(unsigned short gpio)
+{
+       return (1 & (gpio_array[gpio_bank(gpio)]->port_data >> gpio_sub_n(gpio)));
+}
+EXPORT_SYMBOL(gpio_get_value);
index bc0cca02850b3f952936f942201ea7a8a8b28a5b..e679703f7ae57936e5dd547daf433cfdea5d20d0 100644 (file)
 * MODIFICATION HISTORY :
 **************************************************************/
 
+#ifndef BF548_FAMILY
 void set_gpio_dir(unsigned short, unsigned short);
 void set_gpio_inen(unsigned short, unsigned short);
 void set_gpio_polar(unsigned short, unsigned short);
@@ -268,7 +269,6 @@ unsigned short get_gpiop_maska(unsigned short);
 unsigned short get_gpiop_maskb(unsigned short);
 unsigned short get_gpiop_data(unsigned short);
 
-#ifndef BF548_FAMILY
 struct gpio_port_t {
        unsigned short data;
        unsigned short dummy1;
@@ -363,8 +363,10 @@ void gpio_free(unsigned short);
 void gpio_set_value(unsigned short gpio, unsigned short arg);
 unsigned short gpio_get_value(unsigned short gpio);
 
+#ifndef BF548_FAMILY
 #define gpio_get_value(gpio)           get_gpio_data(gpio)
 #define gpio_set_value(gpio, value)    set_gpio_data(gpio, value)
+#endif
 
 void gpio_direction_input(unsigned short gpio);
 void gpio_direction_output(unsigned short gpio);
index 45289425ce596017255218e4c38fdb3822823825..8c5847a6680bbaa3622174690cba64c82cd9d969 100644 (file)
 #define GPIO_PJ11      155
 #define GPIO_PJ12      156
 #define GPIO_PJ13      157
-#define GPIO_PJ14      158
-#define GPIO_PJ15      159
+#define GPIO_PJ14      158     /* N/A */
+#define GPIO_PJ15      159     /* N/A */
 
 #define MAX_BLACKFIN_GPIOS 160