[xburst] gpio.h: Add proper parenthesis to JZ_GPIO_PORTX macros
[openwrt/svn-archive/archive.git] / target / linux / xburst / files-2.6.32 / arch / mips / include / asm / mach-jz4740 / gpio.h
1 /*
2 * Copyright (C) 2009, Lars-Peter Clausen <lars@metafoo.de>
3 * JZ7420/JZ4740 GPIO pin definitions
4 *
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License as published by the
7 * Free Software Foundation; either version 2 of the License, or (at your
8 * option) any later version.
9 *
10 * You should have received a copy of the GNU General Public License along
11 * with this program; if not, write to the Free Software Foundation, Inc.,
12 * 675 Mass Ave, Cambridge, MA 02139, USA.
13 *
14 */
15
16 #ifndef _JZ_GPIO_H
17 #define _JZ_GPIO_H
18
19 #include <linux/types.h>
20
21 enum jz_gpio_function {
22 JZ_GPIO_FUNC_NONE,
23 JZ_GPIO_FUNC1,
24 JZ_GPIO_FUNC2,
25 JZ_GPIO_FUNC3,
26 };
27
28
29 /*
30 Usually a driver for a SoC component has to request several gpio pins and
31 configure them as funcion pins.
32 jz_gpio_bulk_request can be used to ease this process.
33 Usually one would do something like:
34
35 const static struct jz_gpio_bulk_request i2c_pins[] = {
36 JZ_GPIO_BULK_PIN(I2C_SDA),
37 JZ_GPIO_BULK_PIN(I2C_SCK),
38 };
39
40 inside the probe function:
41
42 ret = jz_gpio_bulk_request(i2c_pins, ARRAY_SIZE(i2c_pins));
43 if (ret) {
44 ...
45
46 inside the remove function:
47
48 jz_gpio_bulk_free(i2c_pins, ARRAY_SIZE(i2c_pins));
49
50
51 */
52 struct jz_gpio_bulk_request {
53 int gpio;
54 const char *name;
55 enum jz_gpio_function function;
56 };
57
58 #define JZ_GPIO_BULK_PIN(pin) { \
59 .gpio = JZ_GPIO_ ## pin, \
60 .name = #pin, \
61 .function = JZ_GPIO_FUNC_ ## pin \
62 }
63
64 int jz_gpio_bulk_request(const struct jz_gpio_bulk_request *request, size_t num);
65 void jz_gpio_bulk_free(const struct jz_gpio_bulk_request *request, size_t num);
66 void jz_gpio_bulk_suspend(const struct jz_gpio_bulk_request *request, size_t num);
67 void jz_gpio_bulk_resume(const struct jz_gpio_bulk_request *request, size_t num);
68 void jz_gpio_enable_pullup(unsigned gpio);
69 void jz_gpio_disable_pullup(unsigned gpio);
70 int jz_gpio_set_function(int gpio, enum jz_gpio_function function);
71
72 int jz_gpio_port_direction_input(int port, uint32_t mask);
73 int jz_gpio_port_direction_output(int port, uint32_t mask);
74 void jz_gpio_port_set_value(int port, uint32_t value, uint32_t mask);
75 uint32_t jz_gpio_port_get_value(int port, uint32_t mask);
76
77 #include <asm/mach-generic/gpio.h>
78
79 #define JZ_GPIO_PORTA(x) ((x) + 32 * 0)
80 #define JZ_GPIO_PORTB(x) ((x) + 32 * 1)
81 #define JZ_GPIO_PORTC(x) ((x) + 32 * 2)
82 #define JZ_GPIO_PORTD(x) ((x) + 32 * 3)
83
84 /* Port A function pins */
85 #define JZ_GPIO_MEM_DATA0 JZ_GPIO_PORTA(0)
86 #define JZ_GPIO_MEM_DATA1 JZ_GPIO_PORTA(1)
87 #define JZ_GPIO_MEM_DATA2 JZ_GPIO_PORTA(2)
88 #define JZ_GPIO_MEM_DATA3 JZ_GPIO_PORTA(3)
89 #define JZ_GPIO_MEM_DATA4 JZ_GPIO_PORTA(4)
90 #define JZ_GPIO_MEM_DATA5 JZ_GPIO_PORTA(5)
91 #define JZ_GPIO_MEM_DATA6 JZ_GPIO_PORTA(6)
92 #define JZ_GPIO_MEM_DATA7 JZ_GPIO_PORTA(7)
93 #define JZ_GPIO_MEM_DATA8 JZ_GPIO_PORTA(8)
94 #define JZ_GPIO_MEM_DATA9 JZ_GPIO_PORTA(9)
95 #define JZ_GPIO_MEM_DATA10 JZ_GPIO_PORTA(10)
96 #define JZ_GPIO_MEM_DATA11 JZ_GPIO_PORTA(11)
97 #define JZ_GPIO_MEM_DATA12 JZ_GPIO_PORTA(12)
98 #define JZ_GPIO_MEM_DATA13 JZ_GPIO_PORTA(13)
99 #define JZ_GPIO_MEM_DATA14 JZ_GPIO_PORTA(14)
100 #define JZ_GPIO_MEM_DATA15 JZ_GPIO_PORTA(15)
101 #define JZ_GPIO_MEM_DATA16 JZ_GPIO_PORTA(16)
102 #define JZ_GPIO_MEM_DATA17 JZ_GPIO_PORTA(17)
103 #define JZ_GPIO_MEM_DATA18 JZ_GPIO_PORTA(18)
104 #define JZ_GPIO_MEM_DATA19 JZ_GPIO_PORTA(19)
105 #define JZ_GPIO_MEM_DATA20 JZ_GPIO_PORTA(20)
106 #define JZ_GPIO_MEM_DATA21 JZ_GPIO_PORTA(21)
107 #define JZ_GPIO_MEM_DATA22 JZ_GPIO_PORTA(22)
108 #define JZ_GPIO_MEM_DATA23 JZ_GPIO_PORTA(23)
109 #define JZ_GPIO_MEM_DATA24 JZ_GPIO_PORTA(24)
110 #define JZ_GPIO_MEM_DATA25 JZ_GPIO_PORTA(25)
111 #define JZ_GPIO_MEM_DATA26 JZ_GPIO_PORTA(26)
112 #define JZ_GPIO_MEM_DATA27 JZ_GPIO_PORTA(27)
113 #define JZ_GPIO_MEM_DATA28 JZ_GPIO_PORTA(28)
114 #define JZ_GPIO_MEM_DATA29 JZ_GPIO_PORTA(29)
115 #define JZ_GPIO_MEM_DATA30 JZ_GPIO_PORTA(30)
116 #define JZ_GPIO_MEM_DATA31 JZ_GPIO_PORTA(31)
117
118 #define JZ_GPIO_FUNC_MEM_DATA0 JZ_GPIO_FUNC1
119 #define JZ_GPIO_FUNC_MEM_DATA1 JZ_GPIO_FUNC1
120 #define JZ_GPIO_FUNC_MEM_DATA2 JZ_GPIO_FUNC1
121 #define JZ_GPIO_FUNC_MEM_DATA3 JZ_GPIO_FUNC1
122 #define JZ_GPIO_FUNC_MEM_DATA4 JZ_GPIO_FUNC1
123 #define JZ_GPIO_FUNC_MEM_DATA5 JZ_GPIO_FUNC1
124 #define JZ_GPIO_FUNC_MEM_DATA6 JZ_GPIO_FUNC1
125 #define JZ_GPIO_FUNC_MEM_DATA7 JZ_GPIO_FUNC1
126 #define JZ_GPIO_FUNC_MEM_DATA8 JZ_GPIO_FUNC1
127 #define JZ_GPIO_FUNC_MEM_DATA9 JZ_GPIO_FUNC1
128 #define JZ_GPIO_FUNC_MEM_DATA10 JZ_GPIO_FUNC1
129 #define JZ_GPIO_FUNC_MEM_DATA11 JZ_GPIO_FUNC1
130 #define JZ_GPIO_FUNC_MEM_DATA12 JZ_GPIO_FUNC1
131 #define JZ_GPIO_FUNC_MEM_DATA13 JZ_GPIO_FUNC1
132 #define JZ_GPIO_FUNC_MEM_DATA14 JZ_GPIO_FUNC1
133 #define JZ_GPIO_FUNC_MEM_DATA15 JZ_GPIO_FUNC1
134 #define JZ_GPIO_FUNC_MEM_DATA16 JZ_GPIO_FUNC1
135 #define JZ_GPIO_FUNC_MEM_DATA17 JZ_GPIO_FUNC1
136 #define JZ_GPIO_FUNC_MEM_DATA18 JZ_GPIO_FUNC1
137 #define JZ_GPIO_FUNC_MEM_DATA19 JZ_GPIO_FUNC1
138 #define JZ_GPIO_FUNC_MEM_DATA20 JZ_GPIO_FUNC1
139 #define JZ_GPIO_FUNC_MEM_DATA21 JZ_GPIO_FUNC1
140 #define JZ_GPIO_FUNC_MEM_DATA22 JZ_GPIO_FUNC1
141 #define JZ_GPIO_FUNC_MEM_DATA23 JZ_GPIO_FUNC1
142 #define JZ_GPIO_FUNC_MEM_DATA24 JZ_GPIO_FUNC1
143 #define JZ_GPIO_FUNC_MEM_DATA25 JZ_GPIO_FUNC1
144 #define JZ_GPIO_FUNC_MEM_DATA26 JZ_GPIO_FUNC1
145 #define JZ_GPIO_FUNC_MEM_DATA27 JZ_GPIO_FUNC1
146 #define JZ_GPIO_FUNC_MEM_DATA28 JZ_GPIO_FUNC1
147 #define JZ_GPIO_FUNC_MEM_DATA29 JZ_GPIO_FUNC1
148 #define JZ_GPIO_FUNC_MEM_DATA30 JZ_GPIO_FUNC1
149 #define JZ_GPIO_FUNC_MEM_DATA31 JZ_GPIO_FUNC1
150
151 /* Port B function pins */
152 #define JZ_GPIO_MEM_ADDR0 JZ_GPIO_PORTB(0)
153 #define JZ_GPIO_MEM_ADDR1 JZ_GPIO_PORTB(1)
154 #define JZ_GPIO_MEM_ADDR2 JZ_GPIO_PORTB(2)
155 #define JZ_GPIO_MEM_ADDR3 JZ_GPIO_PORTB(3)
156 #define JZ_GPIO_MEM_ADDR4 JZ_GPIO_PORTB(4)
157 #define JZ_GPIO_MEM_ADDR5 JZ_GPIO_PORTB(5)
158 #define JZ_GPIO_MEM_ADDR6 JZ_GPIO_PORTB(6)
159 #define JZ_GPIO_MEM_ADDR7 JZ_GPIO_PORTB(7)
160 #define JZ_GPIO_MEM_ADDR8 JZ_GPIO_PORTB(8)
161 #define JZ_GPIO_MEM_ADDR9 JZ_GPIO_PORTB(9)
162 #define JZ_GPIO_MEM_ADDR10 JZ_GPIO_PORTB(10)
163 #define JZ_GPIO_MEM_ADDR11 JZ_GPIO_PORTB(11)
164 #define JZ_GPIO_MEM_ADDR12 JZ_GPIO_PORTB(12)
165 #define JZ_GPIO_MEM_ADDR13 JZ_GPIO_PORTB(13)
166 #define JZ_GPIO_MEM_ADDR14 JZ_GPIO_PORTB(14)
167 #define JZ_GPIO_MEM_ADDR15 JZ_GPIO_PORTB(15)
168 #define JZ_GPIO_MEM_ADDR16 JZ_GPIO_PORTB(16)
169 #define JZ_GPIO_MEM_CLS JZ_GPIO_PORTB(17)
170 #define JZ_GPIO_MEM_SPL JZ_GPIO_PORTB(18)
171 #define JZ_GPIO_MEM_DCS JZ_GPIO_PORTB(19)
172 #define JZ_GPIO_MEM_RAS JZ_GPIO_PORTB(20)
173 #define JZ_GPIO_MEM_CAS JZ_GPIO_PORTB(21)
174 #define JZ_GPIO_MEM_SDWE JZ_GPIO_PORTB(22)
175 #define JZ_GPIO_MEM_CKE JZ_GPIO_PORTB(23)
176 #define JZ_GPIO_MEM_CKO JZ_GPIO_PORTB(24)
177 #define JZ_GPIO_MEM_CS0 JZ_GPIO_PORTB(25)
178 #define JZ_GPIO_MEM_CS1 JZ_GPIO_PORTB(26)
179 #define JZ_GPIO_MEM_CS2 JZ_GPIO_PORTB(27)
180 #define JZ_GPIO_MEM_CS3 JZ_GPIO_PORTB(28)
181 #define JZ_GPIO_MEM_RD JZ_GPIO_PORTB(29)
182 #define JZ_GPIO_MEM_WR JZ_GPIO_PORTB(30)
183 #define JZ_GPIO_MEM_WE0 JZ_GPIO_PORTB(31)
184
185 #define JZ_GPIO_FUNC_MEM_ADDR0 JZ_GPIO_FUNC1
186 #define JZ_GPIO_FUNC_MEM_ADDR1 JZ_GPIO_FUNC1
187 #define JZ_GPIO_FUNC_MEM_ADDR2 JZ_GPIO_FUNC1
188 #define JZ_GPIO_FUNC_MEM_ADDR3 JZ_GPIO_FUNC1
189 #define JZ_GPIO_FUNC_MEM_ADDR4 JZ_GPIO_FUNC1
190 #define JZ_GPIO_FUNC_MEM_ADDR5 JZ_GPIO_FUNC1
191 #define JZ_GPIO_FUNC_MEM_ADDR6 JZ_GPIO_FUNC1
192 #define JZ_GPIO_FUNC_MEM_ADDR7 JZ_GPIO_FUNC1
193 #define JZ_GPIO_FUNC_MEM_ADDR8 JZ_GPIO_FUNC1
194 #define JZ_GPIO_FUNC_MEM_ADDR9 JZ_GPIO_FUNC1
195 #define JZ_GPIO_FUNC_MEM_ADDR10 JZ_GPIO_FUNC1
196 #define JZ_GPIO_FUNC_MEM_ADDR11 JZ_GPIO_FUNC1
197 #define JZ_GPIO_FUNC_MEM_ADDR12 JZ_GPIO_FUNC1
198 #define JZ_GPIO_FUNC_MEM_ADDR13 JZ_GPIO_FUNC1
199 #define JZ_GPIO_FUNC_MEM_ADDR14 JZ_GPIO_FUNC1
200 #define JZ_GPIO_FUNC_MEM_ADDR15 JZ_GPIO_FUNC1
201 #define JZ_GPIO_FUNC_MEM_ADDR16 JZ_GPIO_FUNC1
202 #define JZ_GPIO_FUNC_MEM_CLS JZ_GPIO_FUNC1
203 #define JZ_GPIO_FUNC_MEM_SPL JZ_GPIO_FUNC1
204 #define JZ_GPIO_FUNC_MEM_DCS JZ_GPIO_FUNC1
205 #define JZ_GPIO_FUNC_MEM_RAS JZ_GPIO_FUNC1
206 #define JZ_GPIO_FUNC_MEM_CAS JZ_GPIO_FUNC1
207 #define JZ_GPIO_FUNC_MEM_SDWE JZ_GPIO_FUNC1
208 #define JZ_GPIO_FUNC_MEM_CKE JZ_GPIO_FUNC1
209 #define JZ_GPIO_FUNC_MEM_CKO JZ_GPIO_FUNC1
210 #define JZ_GPIO_FUNC_MEM_CS0 JZ_GPIO_FUNC1
211 #define JZ_GPIO_FUNC_MEM_CS1 JZ_GPIO_FUNC1
212 #define JZ_GPIO_FUNC_MEM_CS2 JZ_GPIO_FUNC1
213 #define JZ_GPIO_FUNC_MEM_CS3 JZ_GPIO_FUNC1
214 #define JZ_GPIO_FUNC_MEM_RD JZ_GPIO_FUNC1
215 #define JZ_GPIO_FUNC_MEM_WR JZ_GPIO_FUNC1
216 #define JZ_GPIO_FUNC_MEM_WE0 JZ_GPIO_FUNC1
217
218
219 #define JZ_GPIO_MEM_ADDR21 JZ_GPIO_PORTB(17)
220 #define JZ_GPIO_MEM_ADDR22 JZ_GPIO_PORTB(18)
221
222 #define JZ_GPIO_FUNC_MEM_ADDR21 JZ_GPIO_FUNC2
223 #define JZ_GPIO_FUNC_MEM_ADDR22 JZ_GPIO_FUNC2
224
225 /* Port C function pins */
226 #define JZ_GPIO_LCD_DATA0 JZ_GPIO_PORTC(0)
227 #define JZ_GPIO_LCD_DATA1 JZ_GPIO_PORTC(1)
228 #define JZ_GPIO_LCD_DATA2 JZ_GPIO_PORTC(2)
229 #define JZ_GPIO_LCD_DATA3 JZ_GPIO_PORTC(3)
230 #define JZ_GPIO_LCD_DATA4 JZ_GPIO_PORTC(4)
231 #define JZ_GPIO_LCD_DATA5 JZ_GPIO_PORTC(5)
232 #define JZ_GPIO_LCD_DATA6 JZ_GPIO_PORTC(6)
233 #define JZ_GPIO_LCD_DATA7 JZ_GPIO_PORTC(7)
234 #define JZ_GPIO_LCD_DATA8 JZ_GPIO_PORTC(8)
235 #define JZ_GPIO_LCD_DATA9 JZ_GPIO_PORTC(9)
236 #define JZ_GPIO_LCD_DATA10 JZ_GPIO_PORTC(10)
237 #define JZ_GPIO_LCD_DATA11 JZ_GPIO_PORTC(11)
238 #define JZ_GPIO_LCD_DATA12 JZ_GPIO_PORTC(12)
239 #define JZ_GPIO_LCD_DATA13 JZ_GPIO_PORTC(13)
240 #define JZ_GPIO_LCD_DATA14 JZ_GPIO_PORTC(14)
241 #define JZ_GPIO_LCD_DATA15 JZ_GPIO_PORTC(15)
242 #define JZ_GPIO_LCD_DATA16 JZ_GPIO_PORTC(16)
243 #define JZ_GPIO_LCD_DATA17 JZ_GPIO_PORTC(17)
244 #define JZ_GPIO_LCD_PCLK JZ_GPIO_PORTC(18)
245 #define JZ_GPIO_LCD_HSYNC JZ_GPIO_PORTC(19)
246 #define JZ_GPIO_LCD_VSYNC JZ_GPIO_PORTC(20)
247 #define JZ_GPIO_LCD_DE JZ_GPIO_PORTC(21)
248 #define JZ_GPIO_LCD_PS JZ_GPIO_PORTC(22)
249 #define JZ_GPIO_LCD_REV JZ_GPIO_PORTC(23)
250 #define JZ_GPIO_MEM_WE1 JZ_GPIO_PORTC(24)
251 #define JZ_GPIO_MEM_WE2 JZ_GPIO_PORTC(25)
252 #define JZ_GPIO_MEM_WE3 JZ_GPIO_PORTC(26)
253 #define JZ_GPIO_MEM_WAIT JZ_GPIO_PORTC(27)
254 #define JZ_GPIO_MEM_FRE JZ_GPIO_PORTC(28)
255 #define JZ_GPIO_MEM_FWE JZ_GPIO_PORTC(29)
256
257 #define JZ_GPIO_FUNC_LCD_DATA0 JZ_GPIO_FUNC1
258 #define JZ_GPIO_FUNC_LCD_DATA1 JZ_GPIO_FUNC1
259 #define JZ_GPIO_FUNC_LCD_DATA2 JZ_GPIO_FUNC1
260 #define JZ_GPIO_FUNC_LCD_DATA3 JZ_GPIO_FUNC1
261 #define JZ_GPIO_FUNC_LCD_DATA4 JZ_GPIO_FUNC1
262 #define JZ_GPIO_FUNC_LCD_DATA5 JZ_GPIO_FUNC1
263 #define JZ_GPIO_FUNC_LCD_DATA6 JZ_GPIO_FUNC1
264 #define JZ_GPIO_FUNC_LCD_DATA7 JZ_GPIO_FUNC1
265 #define JZ_GPIO_FUNC_LCD_DATA8 JZ_GPIO_FUNC1
266 #define JZ_GPIO_FUNC_LCD_DATA9 JZ_GPIO_FUNC1
267 #define JZ_GPIO_FUNC_LCD_DATA10 JZ_GPIO_FUNC1
268 #define JZ_GPIO_FUNC_LCD_DATA11 JZ_GPIO_FUNC1
269 #define JZ_GPIO_FUNC_LCD_DATA12 JZ_GPIO_FUNC1
270 #define JZ_GPIO_FUNC_LCD_DATA13 JZ_GPIO_FUNC1
271 #define JZ_GPIO_FUNC_LCD_DATA14 JZ_GPIO_FUNC1
272 #define JZ_GPIO_FUNC_LCD_DATA15 JZ_GPIO_FUNC1
273 #define JZ_GPIO_FUNC_LCD_DATA16 JZ_GPIO_FUNC1
274 #define JZ_GPIO_FUNC_LCD_DATA17 JZ_GPIO_FUNC1
275 #define JZ_GPIO_FUNC_LCD_PCLK JZ_GPIO_FUNC1
276 #define JZ_GPIO_FUNC_LCD_VSYNC JZ_GPIO_FUNC1
277 #define JZ_GPIO_FUNC_LCD_HSYNC JZ_GPIO_FUNC1
278 #define JZ_GPIO_FUNC_LCD_DE JZ_GPIO_FUNC1
279 #define JZ_GPIO_FUNC_LCD_PS JZ_GPIO_FUNC1
280 #define JZ_GPIO_FUNC_LCD_REV JZ_GPIO_FUNC1
281 #define JZ_GPIO_FUNC_MEM_WE1 JZ_GPIO_FUNC1
282 #define JZ_GPIO_FUNC_MEM_WE2 JZ_GPIO_FUNC1
283 #define JZ_GPIO_FUNC_MEM_WE3 JZ_GPIO_FUNC1
284 #define JZ_GPIO_FUNC_MEM_WAIT JZ_GPIO_FUNC1
285 #define JZ_GPIO_FUNC_MEM_FRE JZ_GPIO_FUNC1
286 #define JZ_GPIO_FUNC_MEM_FWE JZ_GPIO_FUNC1
287
288
289 #define JZ_GPIO_MEM_ADDR19 JZ_GPIO_PORTB(22)
290 #define JZ_GPIO_MEM_ADDR20 JZ_GPIO_PORTB(23)
291
292 #define JZ_GPIO_FUNC_MEM_ADDR19 JZ_GPIO_FUNC2
293 #define JZ_GPIO_FUNC_MEM_ADDR20 JZ_GPIO_FUNC2
294
295 /* Port D function pins */
296 #define JZ_GPIO_CIM_DATA0 JZ_GPIO_PORTD(0)
297 #define JZ_GPIO_CIM_DATA1 JZ_GPIO_PORTD(1)
298 #define JZ_GPIO_CIM_DATA2 JZ_GPIO_PORTD(2)
299 #define JZ_GPIO_CIM_DATA3 JZ_GPIO_PORTD(3)
300 #define JZ_GPIO_CIM_DATA4 JZ_GPIO_PORTD(4)
301 #define JZ_GPIO_CIM_DATA5 JZ_GPIO_PORTD(5)
302 #define JZ_GPIO_CIM_DATA6 JZ_GPIO_PORTD(6)
303 #define JZ_GPIO_CIM_DATA7 JZ_GPIO_PORTD(7)
304 #define JZ_GPIO_MSC_CMD JZ_GPIO_PORTD(8)
305 #define JZ_GPIO_MSC_CLK JZ_GPIO_PORTD(9)
306 #define JZ_GPIO_MSC_DATA0 JZ_GPIO_PORTD(10)
307 #define JZ_GPIO_MSC_DATA1 JZ_GPIO_PORTD(11)
308 #define JZ_GPIO_MSC_DATA2 JZ_GPIO_PORTD(12)
309 #define JZ_GPIO_MSC_DATA3 JZ_GPIO_PORTD(13)
310 #define JZ_GPIO_CIM_MCLK JZ_GPIO_PORTD(14)
311 #define JZ_GPIO_CIM_PCLK JZ_GPIO_PORTD(15)
312 #define JZ_GPIO_CIM_VSYNC JZ_GPIO_PORTD(16)
313 #define JZ_GPIO_CIM_HSYNC JZ_GPIO_PORTD(17)
314 #define JZ_GPIO_SPI_CLK JZ_GPIO_PORTD(18)
315 #define JZ_GPIO_SPI_CE0 JZ_GPIO_PORTD(19)
316 #define JZ_GPIO_SPI_DT JZ_GPIO_PORTD(20)
317 #define JZ_GPIO_SPI_DR JZ_GPIO_PORTD(21)
318 #define JZ_GPIO_SPI_CE1 JZ_GPIO_PORTD(22)
319 #define JZ_GPIO_PWM0 JZ_GPIO_PORTD(23)
320 #define JZ_GPIO_PWM1 JZ_GPIO_PORTD(24)
321 #define JZ_GPIO_PWM2 JZ_GPIO_PORTD(25)
322 #define JZ_GPIO_PWM3 JZ_GPIO_PORTD(26)
323 #define JZ_GPIO_PWM4 JZ_GPIO_PORTD(27)
324 #define JZ_GPIO_PWM5 JZ_GPIO_PORTD(28)
325 #define JZ_GPIO_PWM6 JZ_GPIO_PORTD(30)
326 #define JZ_GPIO_PWM7 JZ_GPIO_PORTD(31)
327
328 #define JZ_GPIO_FUNC_CIM_DATA0 JZ_GPIO_FUNC1
329 #define JZ_GPIO_FUNC_CIM_DATA1 JZ_GPIO_FUNC1
330 #define JZ_GPIO_FUNC_CIM_DATA2 JZ_GPIO_FUNC1
331 #define JZ_GPIO_FUNC_CIM_DATA3 JZ_GPIO_FUNC1
332 #define JZ_GPIO_FUNC_CIM_DATA4 JZ_GPIO_FUNC1
333 #define JZ_GPIO_FUNC_CIM_DATA5 JZ_GPIO_FUNC1
334 #define JZ_GPIO_FUNC_CIM_DATA6 JZ_GPIO_FUNC1
335 #define JZ_GPIO_FUNC_CIM_DATA7 JZ_GPIO_FUNC1
336 #define JZ_GPIO_FUNC_MSC_CMD JZ_GPIO_FUNC1
337 #define JZ_GPIO_FUNC_MSC_CLK JZ_GPIO_FUNC1
338 #define JZ_GPIO_FUNC_MSC_DATA0 JZ_GPIO_FUNC1
339 #define JZ_GPIO_FUNC_MSC_DATA1 JZ_GPIO_FUNC1
340 #define JZ_GPIO_FUNC_MSC_DATA2 JZ_GPIO_FUNC1
341 #define JZ_GPIO_FUNC_MSC_DATA3 JZ_GPIO_FUNC1
342 #define JZ_GPIO_FUNC_CIM_MCLK JZ_GPIO_FUNC1
343 #define JZ_GPIO_FUNC_CIM_PCLK JZ_GPIO_FUNC1
344 #define JZ_GPIO_FUNC_CIM_VSYNC JZ_GPIO_FUNC1
345 #define JZ_GPIO_FUNC_CIM_HSYNC JZ_GPIO_FUNC1
346 #define JZ_GPIO_FUNC_SPI_CLK JZ_GPIO_FUNC1
347 #define JZ_GPIO_FUNC_SPI_CE0 JZ_GPIO_FUNC1
348 #define JZ_GPIO_FUNC_SPI_DT JZ_GPIO_FUNC1
349 #define JZ_GPIO_FUNC_SPI_DR JZ_GPIO_FUNC1
350 #define JZ_GPIO_FUNC_SPI_CE1 JZ_GPIO_FUNC1
351 #define JZ_GPIO_FUNC_PWM0 JZ_GPIO_FUNC1
352 #define JZ_GPIO_FUNC_PWM1 JZ_GPIO_FUNC1
353 #define JZ_GPIO_FUNC_PWM2 JZ_GPIO_FUNC1
354 #define JZ_GPIO_FUNC_PWM3 JZ_GPIO_FUNC1
355 #define JZ_GPIO_FUNC_PWM4 JZ_GPIO_FUNC1
356 #define JZ_GPIO_FUNC_PWM5 JZ_GPIO_FUNC1
357 #define JZ_GPIO_FUNC_PWM6 JZ_GPIO_FUNC1
358
359 #define JZ_GPIO_MEM_SCLK_RSTN JZ_GPIO_PORTD(18)
360 #define JZ_GPIO_MEM_BCLK JZ_GPIO_PORTD(19)
361 #define JZ_GPIO_MEM_SDATO JZ_GPIO_PORTD(20)
362 #define JZ_GPIO_MEM_SDATI JZ_GPIO_PORTD(21)
363 #define JZ_GPIO_MEM_SYNC JZ_GPIO_PORTD(22)
364 #define JZ_GPIO_I2C_SDA JZ_GPIO_PORTD(23)
365 #define JZ_GPIO_I2C_SCK JZ_GPIO_PORTD(24)
366 #define JZ_GPIO_UART0_TXD JZ_GPIO_PORTD(25)
367 #define JZ_GPIO_UART0_RXD JZ_GPIO_PORTD(26)
368 #define JZ_GPIO_MEM_ADDR17 JZ_GPIO_PORTD(27)
369 #define JZ_GPIO_MEM_ADDR18 JZ_GPIO_PORTD(28)
370 #define JZ_GPIO_UART0_CTS JZ_GPIO_PORTD(30)
371 #define JZ_GPIO_UART0_RTS JZ_GPIO_PORTD(31)
372
373 #define JZ_GPIO_FUNC_MEM_SCLK_RSTN JZ_GPIO_FUNC2
374 #define JZ_GPIO_FUNC_MEM_BCLK JZ_GPIO_FUNC2
375 #define JZ_GPIO_FUNC_MEM_SDATO JZ_GPIO_FUNC2
376 #define JZ_GPIO_FUNC_MEM_SDATI JZ_GPIO_FUNC2
377 #define JZ_GPIO_FUNC_MEM_SYNC JZ_GPIO_FUNC2
378 #define JZ_GPIO_FUNC_I2C_SDA JZ_GPIO_FUNC2
379 #define JZ_GPIO_FUNC_I2C_SCK JZ_GPIO_FUNC2
380 #define JZ_GPIO_FUNC_UART0_TXD JZ_GPIO_FUNC2
381 #define JZ_GPIO_FUNC_UART0_RXD JZ_GPIO_FUNC2
382 #define JZ_GPIO_FUNC_MEM_ADDR17 JZ_GPIO_FUNC2
383 #define JZ_GPIO_FUNC_MEM_ADDR18 JZ_GPIO_FUNC2
384 #define JZ_GPIO_FUNC_UART0_CTS JZ_GPIO_FUNC2
385 #define JZ_GPIO_FUNC_UART0_RTS JZ_GPIO_FUNC2
386
387 #define JZ_GPIO_UART1_RXD JZ_GPIO_PORTD(30)
388 #define JZ_GPIO_UART1_TXD JZ_GPIO_PORTD(31)
389
390 #define JZ_GPIO_FUNC_UART1_RXD JZ_GPIO_FUNC3
391 #define JZ_GPIO_FUNC_UART1_TXD JZ_GPIO_FUNC3
392
393 #endif