moved pin/bank configuration to global init routines to system.c + added
[my-code/arm.git] / betty / buttons.c
index 21efe01..094e356 100644 (file)
@@ -7,37 +7,25 @@
 
 #include "buttons.h"
 
+#define BUTTON_RESET \
+       IOSET2=((1<<18)|(1<<19)|(1<<20)|(1<<21)|(1<<22)|(1<<23)|(1<<24))
+
+#define COUNT_AND_CHECK        cnt++; \
+                               if(cnt==BUTTON_MAX) \
+                                       break
+
 void button_init(t_button *button) {
 
-       /* 
-        * select as input the following pins
-        *  - p0.30 : interrupt! wtf is the 'vw 3 p9'?
-        *  - p0.28, p0.27, p3.21, p3.20, p0.22, p0.13 : column select
+       /*
+        * input:
+        *  - p0.30 : interrupt! wtf is the 'vw 3 p9'? a transistor?
+        *  - p0.28, p0.27, p3.21, p3.20, p0.22, p0.13 : the columns
         *
-        *  select as output
+        * output:
         *  - p2.18-p2.24 : the rows
         */
 
-       // gpio, as is: p3.20, p3.21
-       PINSEL1&=~((1<<29)|(1<<28));    // p0.30
-       PINSEL1&=~((1<<25)|(1<<24));    // p0.28
-       PINSEL1&=~((1<<23)|(1<<22));    // p0.27
-       PINSEL1&=~((1<<13)|(1<<12));    // p0.22
-       PINSEL0&=~((1<<27)|(1<<26));    // p0.13
-
-       // ctrl databus for p2.18 - p2.24
-       PINSEL2=(PINSEL2&P2MASK&~((1<<5)|(1<<4)))|(1<<4);
-
-       // ctrl addr bus for p3.20, p3.21
-       PINSEL2=(PINSEL2&P2MASK&~((1<<27)|(1<<26)|(1<<25)))|(1<<27)|(1<<26);
-
-       // input
-       IODIR0&=~((1<<30)|(1<<28)|(1<<27)|(1<<22)|(1<<13));
-       IODIR3&=~((1<<21)|(1<<20));
-
-       // output + pull them high
-       IODIR2|=((1<<18)|(1<<19)|(1<<20)|(1<<21)|(1<<22)|(1<<23)|(1<<24));
-       IOSET2=((1<<18)|(1<<19)|(1<<20)|(1<<21)|(1<<22)|(1<<23)|(1<<24));
+       BUTTON_RESET;
 
        /* poll / interrupt mode */
        if(button->mode&BUTTON_INT) {
@@ -51,9 +39,6 @@ void button_set_retries(t_button *button,int retries) {
        button->retries=retries;
 }
 
-#define BUTTON_RESET \
-       IOSET2=((1<<18)|(1<<19)|(1<<20)|(1<<21)|(1<<22)|(1<<23)|(1<<24))
-
 void button_select_row(u8 row) {
 
        BUTTON_RESET;
@@ -62,10 +47,6 @@ void button_select_row(u8 row) {
        IOCLR2=(1<<(18+row));
 }
 
-#define COUNT_AND_CHECK        cnt++; \
-                               if(cnt==BUTTON_MAX) \
-                                       break
-
 u8 button_get_event(t_button *button) {
 
        u8 row;