[s3c24xx] bump to 2.6.30-rc6
[openwrt.git] / target / linux / s3c24xx / files-2.6.30 / include / linux / glamo-gpio.h
1 #ifndef __GLAMO_GPIO_H
2 #define __GLAMO_GPIO_H
3
4 struct glamo_core;
5
6 #define GLAMO_GPIO_BANKA        0x0000
7 #define GLAMO_GPIO_BANKB        0x1000
8 #define GLAMO_GPIO_BANKC        0x2000
9 #define GLAMO_GPIO_BANKD        0x3000
10
11 #define GLAMO_GPIONO(bank, pin) ((bank & 0xf000) | ((pin & 0xf) << 8))
12
13 #define GLAMO_GPIO_F_IN         0x0010
14 #define GLAMO_GPIO_F_OUT        0x0020
15 #define GLAMO_GPIO_F_FUNC       0x0030
16
17 #define GLAMO_GPIO0             GLAMO_GPIONO(GLAMO_GPIO_BANKA, 0)
18 #define GLAMO_GPIO0_INPUT       (GLAMO_GPIO0 | GLAMO_GPIO_F_IN)
19 #define GLAMO_GPIO0_OUTPUT      (GLAMO_GPIO0 | GLAMO_GPIO_F_OUT)
20 #define GLAMO_GPIO0_HA20        (GLAMO_GPIO0 | GLAMO_GPIO_F_FUNC)
21
22 #define GLAMO_GPIO1             GLAMO_GPIONO(GLAMO_GPIO_BANKA, 1)
23 #define GLAMO_GPIO1_INPUT       (GLAMO_GPIO1 | GLAMO_GPIO_F_IN)
24 #define GLAMO_GPIO1_OUTPUT      (GLAMO_GPIO1 | GLAMO_GPIO_F_OUT)
25 #define GLAMO_GPIO1_HA21        (GLAMO_GPIO1 | GLAMO_GPIO_F_FUNC)
26
27 #define GLAMO_GPIO2             GLAMO_GPIONO(GLAMO_GPIO_BANKA, 2)
28 #define GLAMO_GPIO2_INPUT       (GLAMO_GPIO2 | GLAMO_GPIO_F_IN)
29 #define GLAMO_GPIO2_OUTPUT      (GLAMO_GPIO2 | GLAMO_GPIO_F_OUT)
30 #define GLAMO_GPIO2_HA22        (GLAMO_GPIO2 | GLAMO_GPIO_F_FUNC)
31
32 #define GLAMO_GPIO3             GLAMO_GPIONO(GLAMO_GPIO_BANKA, 3)
33 #define GLAMO_GPIO3_INPUT       (GLAMO_GPIO3 | GLAMO_GPIO_F_IN)
34 #define GLAMO_GPIO3_OUTPUT      (GLAMO_GPIO3 | GLAMO_GPIO_F_OUT)
35 #define GLAMO_GPIO3_HA23        (GLAMO_GPIO3 | GLAMO_GPIO_F_FUNC)
36
37 #define GLAMO_GPIO4             GLAMO_GPIONO(GLAMO_GPIO_BANKB, 0)
38 #define GLAMO_GPIO4_INPUT       (GLAMO_GPIO4 | GLAMO_GPIO_F_IN)
39 #define GLAMO_GPIO4_OUTPUT      (GLAMO_GPIO4 | GLAMO_GPIO_F_OUT)
40 #define GLAMO_GPIO4_nLCS0       (GLAMO_GPIO4 | GLAMO_GPIO_F_FUNC)
41
42 #define GLAMO_GPIO5             GLAMO_GPIONO(GLAMO_GPIO_BANKB, 1)
43 #define GLAMO_GPIO5_INPUT       (GLAMO_GPIO5 | GLAMO_GPIO_F_IN)
44 #define GLAMO_GPIO5_OUTPUT      (GLAMO_GPIO5 | GLAMO_GPIO_F_OUT)
45 #define GLAMO_GPIO5_nLCS1       (GLAMO_GPIO5 | GLAMO_GPIO_F_FUNC)
46
47 #define GLAMO_GPIO6             GLAMO_GPIONO(GLAMO_GPIO_BANKB, 2)
48 #define GLAMO_GPIO6_INPUT       (GLAMO_GPIO6 | GLAMO_GPIO_F_IN)
49 #define GLAMO_GPIO6_OUTPUT      (GLAMO_GPIO6 | GLAMO_GPIO_F_OUT)
50 #define GLAMO_GPIO6_LDCLK       (GLAMO_GPIO6 | GLAMO_GPIO_F_FUNC)
51
52 #define GLAMO_GPIO7             GLAMO_GPIONO(GLAMO_GPIO_BANKB, 3)
53 #define GLAMO_GPIO7_INPUT       (GLAMO_GPIO7 | GLAMO_GPIO_F_IN)
54 #define GLAMO_GPIO7_OUTPUT      (GLAMO_GPIO7 | GLAMO_GPIO_F_OUT)
55 #define GLAMO_GPIO7_nLDE        (GLAMO_GPIO7 | GLAMO_GPIO_F_FUNC)
56
57 #define GLAMO_GPIO8             GLAMO_GPIONO(GLAMO_GPIO_BANKC, 0)
58 #define GLAMO_GPIO8_INPUT       (GLAMO_GPIO8 | GLAMO_GPIO_F_IN)
59 #define GLAMO_GPIO8_OUTPUT      (GLAMO_GPIO8 | GLAMO_GPIO_F_OUT)
60 #define GLAMO_GPIO8_LD16        (GLAMO_GPIO8 | GLAMO_GPIO_F_FUNC)
61
62 #define GLAMO_GPIO9             GLAMO_GPIONO(GLAMO_GPIO_BANKC, 1)
63 #define GLAMO_GPIO9_INPUT       (GLAMO_GPIO9 | GLAMO_GPIO_F_IN)
64 #define GLAMO_GPIO9_OUTPUT      (GLAMO_GPIO9 | GLAMO_GPIO_F_OUT)
65 #define GLAMO_GPIO9_LD17        (GLAMO_GPIO9 | GLAMO_GPIO_F_FUNC)
66
67 #define GLAMO_GPIO10            GLAMO_GPIONO(GLAMO_GPIO_BANKC, 2)
68 #define GLAMO_GPIO10_INPUT      (GLAMO_GPIO10 | GLAMO_GPIO_F_IN)
69 #define GLAMO_GPIO10_OUTPUT     (GLAMO_GPIO10 | GLAMO_GPIO_F_OUT)
70 #define GLAMO_GPIO10_LSCK       (GLAMO_GPIO10 | GLAMO_GPIO_F_FUNC)
71
72 #define GLAMO_GPIO11            GLAMO_GPIONO(GLAMO_GPIO_BANKC, 3)
73 #define GLAMO_GPIO11_INPUT      (GLAMO_GPIO11 | GLAMO_GPIO_F_IN)
74 #define GLAMO_GPIO11_OUTPUT     (GLAMO_GPIO11 | GLAMO_GPIO_F_OUT)
75 #define GLAMO_GPIO11_LSDA       (GLAMO_GPIO11 | GLAMO_GPIO_F_FUNC)
76
77 #define GLAMO_GPIO12            GLAMO_GPIONO(GLAMO_GPIO_BANKD, 0)
78 #define GLAMO_GPIO12_INPUT      (GLAMO_GPIO12 | GLAMO_GPIO_F_IN)
79 #define GLAMO_GPIO12_OUTPUT     (GLAMO_GPIO12 | GLAMO_GPIO_F_OUT)
80 #define GLAMO_GPIO12_LSA0       (GLAMO_GPIO12 | GLAMO_GPIO_F_FUNC)
81
82
83 #define REG_OF_GPIO(gpio)       (((gpio & 0xf000) >> 12)*2 \
84                                                 + GLAMO_REG_GPIO_GEN1)
85 #define NUM_OF_GPIO(gpio)       ((gpio & 0x0f00) >> 8)
86 #define GPIO_OUT_BIT(gpio)      (1 << (NUM_OF_GPIO(gpio) + 0))
87 #define OUTPUT_BIT(gpio)        (1 << (NUM_OF_GPIO(gpio) + 4))
88 #define INPUT_BIT(gpio)         (1 << (NUM_OF_GPIO(gpio) + 8))
89 #define FUNC_BIT(gpio)          (1 << (NUM_OF_GPIO(gpio) + 12))
90
91 void glamo_gpio_setpin(struct glamo_core *glamo, unsigned int pin,
92                        unsigned int value);
93
94 int glamo_gpio_getpin(struct glamo_core *glamo, unsigned int pin);
95
96 void glamo_gpio_cfgpin(struct glamo_core *glamo, unsigned int pinfunc);
97
98
99 #endif /* _GLAMO_GPIO */