summaryrefslogtreecommitdiff
path: root/arch/arm/mach-wmt/include/mach/gpio.h
blob: 793d8ce94e49e610591cdf9ab89bc53a339d7dc8 (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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
/*++
linux/include/asm-arm/arch-wmt/gpio.h

Copyright (c) 2008  WonderMedia Technologies, Inc.

This program is free software: you can redistribute it and/or modify it under the
terms of the GNU General Public License as published by the Free Software Foundation,
either version 2 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
PARTICULAR PURPOSE.  See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with
this program.  If not, see <http://www.gnu.org/licenses/>.

WonderMedia Technologies, Inc.
10F, 529, Chung-Cheng Road, Hsin-Tien, Taipei 231, R.O.C.
--*/

#ifndef __ASM_ARCH_GPIO_H
#define __ASM_ARCH_GPIO_H

/*
 * For GPIO_BASE + 0x0020 + (0x0020*n), n=0 to 2
 */
typedef struct gpio_uart_s {             /* total 32 bits */
	/* UART1 */
	unsigned char uart1_cts:1;
	unsigned char uart1_rts:1;
	unsigned char uart1_rxd:1;
	unsigned char uart1_txd:1;
	unsigned char reserve1:4;
	/* UART2 */
	unsigned char uart2_cts:1;
	unsigned char uart2_rts:1;
	unsigned char uart2_rxd:1;
	unsigned char uart2_txd:1;
	unsigned char reserve2:4;
	/* UART3 */
	unsigned char uart3_cts:1;
	unsigned char uart3_rts:1;
	unsigned char uart3_rxd:1;
	unsigned char uart3_txd:1;
	unsigned char reserve3:4;
	/* UART4 */
	unsigned char uart4_cts:1;
	unsigned char uart4_rts:1;
	unsigned char uart4_rxd:1;
	unsigned char uart4_txd:1;
	unsigned char reserve4:4;

} gpio_uart_t;

/*
 * For GPIO_BASE + 0x0024 + (0x0020*n), n=0 to 2
 */
typedef struct gpio_spi_s {              /* total 32 bits */
	/* SPI1 */
	unsigned char spi1_clk:1;
	unsigned char spi1_miso:1;
	unsigned char spi1_mosi:1;
	unsigned char spi1_ssn:1;
	unsigned char reserve1:4;
	/* SPI2 */
	unsigned char spi2_clk:1;
	unsigned char spi2_miso:1;
	unsigned char spi2_mosi:1;
	unsigned char spi2_ssn:1;
	unsigned char reserve2:4;
	/* SPI3 */
	unsigned char spi3_clk:1;
	unsigned char spi3_miso:1;
	unsigned char spi3_mosi:1;
	unsigned char spi3_ssn:1;
	unsigned char reserve3:4;
	/* SPI4 */
	unsigned char spi4_clk:1;
	unsigned char spi4_miso:1;
	unsigned char spi4_mosi:1;
	unsigned char spi4_ssn:1;
	unsigned char reserve4:4;

} gpio_spi_t;

/*
 * For GPIO_BASE + 0x0028 + (0x0020*n), n=0 to 2
 */
typedef struct gpio_kpad_s {             /* total 32 bits */
	/* KPAD_COW[7:0] */
	unsigned char cow0:1;
	unsigned char cow1:1;
	unsigned char cow2:1;
	unsigned char cow3:1;
	unsigned char cow4:1;
	unsigned char cow5:1;
	unsigned char cow6:1;
	unsigned char cow7:1;
	/* KPAD_ROW[7:0] */
	unsigned char row0:1;
	unsigned char row1:1;
	unsigned char row2:1;
	unsigned char row3:1;
	unsigned char row4:1;
	unsigned char row5:1;
	unsigned char row6:1;
	unsigned char row7:1;
	/* VIC_DATA[7:0] */
	unsigned char data0:1;
	unsigned char data1:1;
	unsigned char data2:1;
	unsigned char data3:1;
	unsigned char data4:1;
	unsigned char data5:1;
	unsigned char data6:1;
	unsigned char data7:1;
	/* VIC misc pins */
	unsigned char clk:1;
	unsigned char vreq:1;
	unsigned char vsync:1;
	unsigned char hsync:1;
	unsigned char reserv1:4;

} gpio_kpad_t;

/*
 * For GPIO_BASE + 0x002C + (0x0020*n), n=0 to 2
 */
typedef struct gpio_misc_s {             /* total 32 bits */
	/* SDMMC */
	unsigned char sd_data0:1;
	unsigned char sd_data1:1;
	unsigned char sd_data2:1;
	unsigned char sd_data3:1;
	unsigned char sd_clk:1;
	unsigned char sd_cmd:1;
	unsigned char reverse1:2;
	/* I2S */
	unsigned char i2s_sclk:1;
	unsigned char i2s_sysclk:1;
	unsigned char i2s_sdi:1;
	unsigned char i2s_sdo:1;
	unsigned char i2s_ws:1;
	/* Wake-up[4:2] */
	unsigned char wakeup2:1;
	unsigned char wakeup3:1;
	unsigned char wakeup4:1;
	/* I2C */
	unsigned char i2c_scl:1;
	unsigned char i2c_sda:1;
	/* Wake-up[1:0] */
	unsigned char wakeup0:1;
	unsigned char wakeup1:1;
	/* AC'97 */
	unsigned char ac97_bclk:1;
	unsigned char ac97_sdi:1;
	unsigned char ac97_sdo:1;
	unsigned char ac97_sync:1;
	/* PWM_OUT[3:0] */
	unsigned char pwm0:1;
	unsigned char pwm1:1;
	unsigned char pwm2:1;
	unsigned char pwm3:1;
	/* PCM */
	unsigned char pcm_clk:1;
	unsigned char pcm_in:1;
	unsigned char pcm_out:1;
	unsigned char pcm_sync:1;

} gpio_misc_t;

/*
 * For GPIO_BASE + 0x0084
 */
typedef struct gpio_irqt_s {
	/* GPIO_IRQ[9:0] type */
	unsigned char  irqt0:2;
	unsigned char  irqt1:2;
	unsigned char  irqt2:2;
	unsigned char  irqt3:2;
	unsigned char  irqt4:2;
	unsigned char  irqt5:2;
	unsigned char  irqt6:2;
	unsigned char  irqt7:2;
	unsigned char  irqt8:2;
	unsigned char  irqt9:2;
	unsigned char  reverse1:4;
	unsigned char  reverse2;

} gpio_irqt_t;

#endif /* __ASM_ARCH_GPIO_H */