]> git.sur5r.net Git - freertos/blob - FreeRTOS/Demo/CORTEX_M7_SAMV71_Xplained/libboard_samv7-ek/board.h
Update version number ready for V8.2.1 release.
[freertos] / FreeRTOS / Demo / CORTEX_M7_SAMV71_Xplained / libboard_samv7-ek / board.h
1 /* ----------------------------------------------------------------------------\r
2  *         SAM Software Package License\r
3  * ----------------------------------------------------------------------------\r
4  * Copyright (c) 2014, Atmel Corporation\r
5  *\r
6  * All rights reserved.\r
7  *\r
8  * Redistribution and use in source and binary forms, with or without\r
9  * modification, are permitted provided that the following conditions are met:\r
10  *\r
11  * - Redistributions of source code must retain the above copyright notice,\r
12  * this list of conditions and the disclaimer below.\r
13  *\r
14  * Atmel's name may not be used to endorse or promote products derived from\r
15  * this software without specific prior written permission.\r
16  *\r
17  * DISCLAIMER: THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR\r
18  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF\r
19  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE\r
20  * DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,\r
21  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\r
22  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\r
23  * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\r
24  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\r
25  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\r
26  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\r
27  * ----------------------------------------------------------------------------\r
28  */\r
29 \r
30 /**\r
31  * \page samv7_Xplained_ultra_board_desc SAMV7_Xplained_Ultra - Board Description\r
32  *\r
33  * \section Purpose\r
34  *\r
35  * This file is dedicated to describe the SAMV7_Xplained_Ultra board.\r
36  *\r
37  * \section Contents\r
38  *\r
39  *  - For SAMV7_Xplained_Ultra information, see \subpage samv7_Xplained_ultra_board_info.\r
40  *  - For operating frequency information, see \subpage samv7_Xplained_ultra_opfreq.\r
41  *  - For using portable PIO definitions, see \subpage samv7_Xplained_ultra_piodef.\r
42  *  - For on-board memories, see \subpage samv7_Xplained_ultra_mem.\r
43  *  - Several USB definitions are included here, see \subpage samv7_Xplained_ultra_usb.\r
44  *  - For External components, see \subpage samv7_Xplained_ultra_extcomp.\r
45  *  - For Individual chip definition, see \subpage samv7_Xplained_ultra_chipdef.\r
46  *\r
47  * To get more software details and the full list of parameters related to the\r
48  * SAMV7_Xplained_Ultra board configuration, please have a look at the source file:\r
49  * \ref board.h\n\r
50  *\r
51  * \section Usage\r
52  *\r
53  *  - The code for booting the board is provided by board_cstartup_xxx.c and\r
54  *    board_lowlevel.c.\r
55  *  - For using board PIOs, board characteristics (clock, etc.) and external\r
56  *    components, see board.h.\r
57  *  - For manipulating memories, see board_memories.h.\r
58  *\r
59  * This file can be used as a template and modified to fit a custom board, with\r
60  * specific PIOs usage or memory connections.\r
61  */\r
62 \r
63 /**\r
64  *  \file board.h\r
65  *\r
66  *  Definition of SAMV7_Xplained_Ultra characteristics, PIOs and\r
67  *  external components interface.\r
68  */\r
69 \r
70 #ifndef _BOARD_H_\r
71 #define _BOARD_H_\r
72 \r
73 /*----------------------------------------------------------------------------\r
74  *        Headers\r
75  *----------------------------------------------------------------------------*/\r
76 #include "chip.h"\r
77 \r
78 #include "include/board_lowlevel.h"\r
79 #include "include/board_memories.h"\r
80 #include "include/omnivision.h"\r
81 #include "include/ov.h"\r
82 #include "include/led.h"\r
83 #include "include/gmii.h"\r
84 #include "include/gmacb_phy.h"\r
85 #include "include/dbg_console.h"\r
86 #include "include/bmp.h"\r
87 #include "include/hamming.h"\r
88 #include "include/lcdd.h"\r
89 #include "include/ili9488_reg.h"\r
90 #include "include/ili9488.h"\r
91 #include "include/frame_buffer.h"\r
92 #include "include/lcd_color.h"\r
93 #include "include/lcd_draw.h"\r
94 #include "include/lcd_font10x14.h"\r
95 #include "include/lcd_font.h"\r
96 #include "include/lcd_gimp_image.h"\r
97 #include "include/wav.h"\r
98 #include "include/wm8904.h"\r
99 #include "include/CS2100.h"\r
100 #include "include/s25fl1.h"\r
101 #include "include/omnivision.h"\r
102 #include "include/ovyuv.h"\r
103 //#include "include/s25fl1_qspi.h"\r
104 \r
105 /*----------------------------------------------------------------------------\r
106  *        Definitions\r
107  *----------------------------------------------------------------------------*/\r
108 \r
109 /*----------------------------------------------------------------------------*/\r
110 /**\r
111  * \page samv7_Xplained_ultra_board_info "SAMV7_Xplained_Ultra - Board informations"\r
112  * This page lists several definition related to the board description.\r
113  *\r
114  * \section Definitions\r
115  * - \ref BOARD_NAME\r
116  */\r
117 \r
118 /** Name of the board */\r
119 #define BOARD_NAME "SAMV7-EK"\r
120 #define NO_PUSHBUTTON\r
121 /*----------------------------------------------------------------------------*/\r
122 /**\r
123  *  \page samv7_Xplained_ultra_opfreq "SAMV7_Xplained_Ultra - Operating frequencies"\r
124  *  This page lists several definition related to the board operating frequency\r
125  *  (when using the initialization done by board_lowlevel.c).\r
126  *\r
127  *  \section Definitions\r
128  *  - \ref BOARD_MAINOSC\r
129  *  - \ref BOARD_MCK\r
130  */\r
131 \r
132 /** Frequency of the board main oscillator */\r
133 #define BOARD_MAINOSC           12000000\r
134 \r
135 /** Master clock frequency (when using board_lowlevel.c) */\r
136 \r
137 #define BOARD_MCK               132000000\r
138 \r
139 \r
140 \r
141 /*----------------------------------------------------------------------------*/\r
142 /**\r
143  * \page samv7_Xplained_ultra_piodef "SAMV7_Xplained_Ultra - PIO definitions"\r
144  * This pages lists all the pio definitions contained in board.h. The constants\r
145  * are named using the following convention: PIN_* for a constant which defines\r
146  * a single Pin instance (but may include several PIOs sharing the same\r
147  * controller), and PINS_* for a list of Pin instances.\r
148  *\r
149  * UART\r
150  * - \ref PINS_UART\r
151  *\r
152  * EBI\r
153  * - \ref PIN_EBI_DATA_BUS\r
154  * - \ref PIN_EBI_NRD\r
155  * - \ref PIN_EBI_NWE\r
156  * - \ref PIN_EBI_NCS0\r
157  * - \ref PIN_EBI_PSRAM_ADDR_BUS\r
158  * - \ref PIN_EBI_PSRAM_NBS\r
159  * - \ref PIN_EBI_A1\r
160  * - \ref PIN_EBI_LCD_CS\r
161  * - \ref PIN_EBI_LCD_RS\r
162  *\r
163  * LEDs\r
164  * - \ref PIN_LED_0\r
165  * - \ref PIN_LED_1\r
166  * - \ref PIN_LED_2\r
167  * - \ref PIN_LED_3\r
168  * - \ref PINS_LEDS\r
169  *\r
170  * MCI\r
171  * - \ref PINS_MCI\r
172  *\r
173  * Push buttons\r
174  * - \ref PIN_PUSHBUTTON_0\r
175  * - \ref PIN_PUSHBUTTON_1\r
176  * - \ref PIN_PUSHBUTTON_2\r
177  * - \ref PIN_PUSHBUTTON_3\r
178  * - \ref PINS_PUSHBUTTONS\r
179  * - \ref PUSHBUTTON_BP0\r
180  * - \ref PUSHBUTTON_BP1\r
181  * - \ref PUSHBUTTON_BP2\r
182  * - \ref PUSHBUTTON_BP3\r
183  *\r
184  * PWMC\r
185  * - \ref PIN_PWMC_PWMH0\r
186  * - \ref PIN_PWMC_PWMH1\r
187  * - \ref PIN_PWM_LED0\r
188  * - \ref PIN_PWM_LED1\r
189  * - \ref CHANNEL_PWM_LED0\r
190  * - \ref CHANNEL_PWM_LED1\r
191  *\r
192  * SPI\r
193  * - \ref PIN_SPI_MISO\r
194  * - \ref PIN_SPI_MOSI\r
195  * - \ref PIN_SPI_SPCK\r
196  * - \ref PINS_SPI\r
197  * - \ref PIN_SPI_NPCS0_PA11\r
198  *\r
199  * PCK0\r
200  * - \ref PIN_PCK0\r
201  *\r
202  * PIO PARALLEL CAPTURE\r
203  * - \ref PIN_PIODCEN1\r
204  * - \ref PIN_PIODCEN2\r
205  *\r
206  * TWI\r
207  * - \ref TWI_V3XX\r
208  * - \ref PIN_TWI_TWD0\r
209  * - \ref PIN_TWI_TWCK0\r
210  * - \ref PINS_TWI0\r
211  *\r
212  * USART0\r
213  * - \ref PIN_USART0_RXD\r
214  * - \ref PIN_USART0_TXD\r
215  * - \ref PIN_USART0_CTS\r
216  * - \ref PIN_USART0_RTS\r
217  * - \ref PIN_USART0_SCK\r
218  *\r
219  * USB\r
220  * - \ref PIN_USB_VBUS\r
221  *\r
222  * NandFlash\r
223  * - \ref PIN_EBI_NANDOE\r
224  * - \ref PIN_EBI_NANDWE\r
225  * - \ref PIN_EBI_NANDCLE\r
226  * - \ref PIN_EBI_NANDALE\r
227  * - \ref PIN_EBI_NANDIO\r
228  * - \ref BOARD_NF_CE_PIN\r
229  * - \ref BOARD_NF_RB_PIN\r
230  * - \ref PINS_NANDFLASH\r
231  */\r
232 \r
233 \r
234 /** SSC pin Transmitter Data (TD) */\r
235 #define PIN_SSC_TD      {PIO_PD26B_TD, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}\r
236 /** SSC pin Transmitter Clock (TK) */\r
237 #define PIN_SSC_TK      {PIO_PB1D_TK, PIOB, ID_PIOB, PIO_PERIPH_D, PIO_DEFAULT}\r
238 /** SSC pin Transmitter FrameSync (TF) */\r
239 #define PIN_SSC_TF      {PIO_PB0D_TF, PIOB, ID_PIOB, PIO_PERIPH_D, PIO_DEFAULT}\r
240 /** SSC pin RD */\r
241 #define PIN_SSC_RD      {PIO_PA10C_RD, PIOA, ID_PIOA, PIO_PERIPH_C, PIO_DEFAULT}\r
242 /** SSC pin RK */\r
243 #define PIN_SSC_RK      {PIO_PA22A_RK, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}\r
244 /** SSC pin RF */\r
245 #define PIN_SSC_RF      {PIO_PD24B_RF, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}\r
246 \r
247 /** SSC pins definition for codec. */\r
248 #define PINS_SSC_CODEC  {PIN_SSC_TD,  PIN_SSC_TK, PIN_SSC_TF, PIN_SSC_RD,  PIN_SSC_RK, PIN_SSC_RF}\r
249 \r
250 \r
251 /** UART pins (UTXD0 and URXD0) definitions, PA9,10. */\r
252 #define PINS_UART0  {PIO_PA9A_URXD0 | PIO_PA10A_UTXD0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}\r
253 /** UART pins (UTXD4 and URXD4) definitions, PD19,18. */\r
254 #define PINS_UART4  {PIO_PD18C_URXD4 | PIO_PD19C_UTXD4, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}\r
255 \r
256 /** EBI Data Bus pins */\r
257 #define PIN_EBI_DATA_BUS   {0xFF, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}\r
258 /** EBI NRD pin */\r
259 #define PIN_EBI_NRD        {1 << 11, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}\r
260 /** EBI NWE pin */\r
261 #define PIN_EBI_NWE        {1 << 8, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}\r
262 /** EBI NCS0 pin */\r
263 #define PIN_EBI_NCS0       {1 << 14, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}\r
264 \r
265 /** EBI A1 pin */\r
266 #define PIN_EBI_A1         {1 << 19, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}\r
267 /* LCD CS pin (NCS3) */\r
268 #define PIN_EBI_LCD_CS     {1 << 18, PIOD, ID_PIOD, PIO_PERIPH_A, PIO_PULLUP}\r
269 /* LCD RS pin (A1) */\r
270 #define PIN_EBI_LCD_RS     {1 << 19, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}\r
271 \r
272 #define LED_YELLOW0      0\r
273 #define LED_YELLOW1      1\r
274 \r
275 /** LED #0 pin definition (BLUE). */\r
276 #define PIN_LED_0   {PIO_PA23, PIOA, ID_PIOA, PIO_OUTPUT_0, PIO_DEFAULT}\r
277 /** LED #0 pin definition (AMBER). */\r
278 #define PIN_LED_1   {PIO_PC9, PIOC, ID_PIOC, PIO_OUTPUT_0, PIO_DEFAULT}\r
279 \r
280 /** List of all LEDs definitions. */\r
281 #define PINS_LEDS   {PIN_LED_0, PIN_LED_1}\r
282 \r
283 \r
284 /** List of all SDRAM pin definitions. */\r
285 #define PIN_SDRAM_D0_7   {0x000000FF, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_DEFAULT}\r
286 #define PIN_SDRAM_D8_13  {0x0000003F, PIOE, ID_PIOE, PIO_PERIPH_A, PIO_DEFAULT}\r
287 #define PIN_SDRAM_D14_15 {0x00018000, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}\r
288 #define PIN_SDRAM_A0_9   {0x3FF00000, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_DEFAULT}\r
289 #define PIN_SDRAM_SDA10  {0x00002000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}\r
290 //#define PIN_SDRAM_A11    {0x80000000, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_DEFAULT}\r
291 \r
292 #define PIN_SDRAM_CAS    {0x00020000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}\r
293 #define PIN_SDRAM_RAS    {0x00010000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}\r
294 #define PIN_SDRAM_SDCKE  {0x00004000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}\r
295 #define PIN_SDRAM_SDCK   {0x00800000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}\r
296 #define PIN_SDRAM_SDSC   {0x00008000, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_DEFAULT}\r
297 #define PIN_SDRAM_NBS0   {0x00040000, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_DEFAULT}\r
298 #define PIN_SDRAM_NBS1   {0x00008000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}\r
299 #define PIN_SDRAM_SDWE   {0x20000000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}\r
300 #define PIN_SDRAM_BA0    {0x00100000, PIOA, ID_PIOA, PIO_PERIPH_C, PIO_DEFAULT}\r
301 \r
302 #define BOARD_SDRAM_PINS  PIN_SDRAM_D0_7, PIN_SDRAM_D8_13 , PIN_SDRAM_D14_15,\\r
303                           PIN_SDRAM_A0_9, PIN_SDRAM_SDA10, PIN_SDRAM_BA0, \\r
304                           PIN_SDRAM_CAS, PIN_SDRAM_RAS, PIN_SDRAM_SDCKE,PIN_SDRAM_SDCK,\\r
305                           PIN_SDRAM_SDSC,PIN_SDRAM_NBS0 ,PIN_SDRAM_NBS1,PIN_SDRAM_SDWE\r
306 /**\r
307  * Push button #0 definition.\r
308  * Attributes = pull-up + debounce + interrupt on rising edge.\r
309  */\r
310 #define PIN_PUSHBUTTON_0    {PIO_PA19, PIOA, ID_PIOA, PIO_INPUT, PIO_PULLUP | PIO_DEBOUNCE | PIO_IT_FALL_EDGE}\r
311 /**\r
312  * Push button #1 definition.\r
313  * Attributes = pull-up + debounce + interrupt on rising edge.\r
314  */\r
315 #define PIN_PUSHBUTTON_1    {PIO_PB12, PIOB, ID_PIOB, PIO_INPUT, PIO_PULLUP | PIO_DEBOUNCE | PIO_IT_FALL_EDGE}\r
316 \r
317 /** List of all push button definitions. */\r
318 #define PINS_PUSHBUTTONS    {PIN_PUSHBUTTON_0, PIN_PUSHBUTTON_1}\r
319 \r
320 \r
321 /** Push button #0 index. */\r
322 #define PUSHBUTTON_BP0   0\r
323 /** Push button #1 index. */\r
324 #define PUSHBUTTON_BP1   1\r
325 /** Push button #2 index. */\r
326 #define PUSHBUTTON_BP2   2\r
327 /** Push button #3 index. */\r
328 #define PUSHBUTTON_BP3   3\r
329 \r
330 /** PWMC PWM0 pin definition: Output High. */\r
331 #define PIN_PWMC_PWMH0  {PIO_PD20A_PWMH0, PIOD, ID_PIOD, PIO_PERIPH_A, PIO_DEFAULT}\r
332 /** PWMC PWM1 pin definition: Output High. */\r
333 #define PIN_PWMC_PWMH1  {PIO_PD21A_PWMH1, PIOD, ID_PIOD, PIO_PERIPH_A, PIO_DEFAULT}\r
334 /** PWM pins definition for LED0 */\r
335 #define PIN_PWM_LED0 PIN_PWMC_PWMH0\r
336 /** PWM pins definition for LED1 */\r
337 #define PIN_PWM_LED1 PIN_PWMC_PWMH1\r
338 /** PWM channel for LED0 */\r
339 #define CHANNEL_PWM_LED0 0\r
340 /** PWM channel for LED1 */\r
341 #define CHANNEL_PWM_LED1 1\r
342 \r
343 /** SPI MISO pin definition. */\r
344 #define PIN_SPI_MISO    {PIO_PD20B_SPI0_MISO, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}\r
345 /** SPI MOSI pin definition. */\r
346 #define PIN_SPI_MOSI    {PIO_PD21B_SPI0_MOSI, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}\r
347 /** SPI SPCK pin definition. */\r
348 #define PIN_SPI_SPCK    {PIO_PD22B_SPI0_SPCK, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}\r
349 /** SPI chip select pin definition. */\r
350 #define PIN_SPI_NPCS0 {PIO_PB2D_SPI0_NPCS0, PIOB, ID_PIOB, PIO_PERIPH_D, PIO_DEFAULT}\r
351 #define PIN_SPI_NPCS1 {PIO_PA31A_SPI0_NPCS1, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}\r
352 \r
353 #define PIN_SPI_NPCS3 {PIO_PD27B_SPI0_NPCS3, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}\r
354 \r
355 /** List of SPI pin definitions (MISO, MOSI & SPCK). */\r
356 #define PINS_SPI        PIN_SPI_MISO, PIN_SPI_MOSI, PIN_SPI_SPCK\r
357 \r
358 /** PCK0 */\r
359 //#define PIN_PCK0  {PIO_PB12D_PCK0, PIOB, ID_PIOB, PIO_PERIPH_D, PIO_DEFAULT}\r
360 #define PIN_PCK0  {PIO_PB13B_PCK0, PIOB, ID_PIOB, PIO_PERIPH_B, PIO_DEFAULT}\r
361 /** PCK1 */\r
362 #define PIN_PCK1  {PIO_PA17B_PCK1, PIOB, ID_PIOB, PIO_PERIPH_B, PIO_DEFAULT}\r
363 \r
364 /** PCK2 */\r
365 #define PIN_PCK2  {PIO_PA18B_PCK2, PIOA, ID_PIOA, PIO_PERIPH_B, PIO_DEFAULT}\r
366 \r
367 \r
368 /** PIO PARALLEL CAPTURE */\r
369 /** Parallel Capture Mode Data Enable1 */\r
370 #define PIN_PIODCEN1    PIO_PA15\r
371 /** Parallel Capture Mode Data Enable2 */\r
372 #define PIN_PIODCEN2    PIO_PA16\r
373 \r
374 /** TWI ver 3.xx */\r
375 #define TWI_V3XX\r
376 /** TWI0 data pin */\r
377 #define PIN_TWI_TWD0   {PIO_PA3A_TWD0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}\r
378 /** TWI0 clock pin */\r
379 #define PIN_TWI_TWCK0  {PIO_PA4A_TWCK0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}\r
380 /** TWI0 pins */\r
381 #define PINS_TWI0      {PIN_TWI_TWD0, PIN_TWI_TWCK0}\r
382 /** TWI1 data pin */\r
383 #define PIN_TWI_TWD1   {PIO_PB4A_TWD1, PIOB, ID_PIOB, PIO_PERIPH_A, PIO_DEFAULT}\r
384 /** TWI1 clock pin */\r
385 #define PIN_TWI_TWCK1  {PIO_PB5A_TWCK1, PIOB, ID_PIOB, PIO_PERIPH_A,PIO_DEFAULT}\r
386 /** TWI1 pins */\r
387 #define PINS_TWI1      {PIN_TWI_TWD1, PIN_TWI_TWCK1}\r
388 \r
389 /** USART0 pin RX */\r
390 #define PIN_USART0_RXD    {PIO_PB0C_RXD0, PIOB, ID_PIOB, PIO_PERIPH_C, PIO_DEFAULT}\r
391 /** USART0 pin TX */\r
392 #define PIN_USART0_TXD    {PIO_PB1C_TXD0, PIOB, ID_PIOB, PIO_PERIPH_C, PIO_DEFAULT}\r
393 /** USART0 pin CTS */\r
394 #define PIN_USART0_CTS    {PIO_PB2C_CTS0, PIOB, ID_PIOB, PIO_PERIPH_C, PIO_DEFAULT}\r
395 /** USART0 pin RTS */\r
396 #define PIN_USART0_RTS    {PIO_PB3C_RTS0, PIOB, ID_PIOB, PIO_PERIPH_C, PIO_DEFAULT}\r
397 /** USART0 pin SCK */\r
398 #define PIN_USART0_SCK    {PIO_PB13C_SCK0, PIOB, ID_PIOB, PIO_PERIPH_C,PIO_DEFAULT}\r
399 \r
400 /** USART1 pin RX */\r
401 #define PIN_USART1_RXD    {PIO_PA21A_RXD1, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}\r
402 /** USART1 pin TX */\r
403 #define PIN_USART1_TXD    {1<<22, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}\r
404 /** USART1 pin CTS */\r
405 #define PIN_USART1_CTS    {PIO_PA25A_CTS1, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}\r
406 /** USART1 pin RTS */\r
407 #define PIN_USART1_RTS    {PIO_PA24A_RTS1, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}\r
408 /** USART1 pin ENABLE */\r
409 #define PIN_USART1_EN     {PIO_PA23A_SCK1, PIOA, ID_PIOA, PIO_OUTPUT_0, PIO_DEFAULT}\r
410 /** USART1 pin SCK */\r
411 #define PIN_USART1_SCK    {PIO_PA23A_SCK1, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}\r
412 \r
413 /** USART2 pin RX */\r
414 #define PIN_USART2_RXD    {PIO_PD15B_RXD2, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}\r
415 /** USART2 pin TX */\r
416 #define PIN_USART2_TXD    {PIO_PD16B_TXD2, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}\r
417 /** USART2 pin CTS */\r
418 #define PIN_USART2_CTS    {PIO_PD19B_CTS2, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}\r
419 /** USART2 pin RTS */\r
420 #define PIN_USART2_RTS    {PIO_PD18B_RTS2, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}\r
421 /** USART2 pin SCK */\r
422 #define PIN_USART2_SCK    {PIO_PD17B_SCK2, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}\r
423 \r
424 /** USB VBus monitoring pin definition. */\r
425 #define PIN_USB_VBUS    {PIO_PC16, PIOC, ID_PIOC, PIO_INPUT, PIO_DEFAULT}\r
426 \r
427 \r
428 /** NandFlash pins definition: OE. */\r
429 #define PIN_EBI_NANDOE   {PIO_PC9,  PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}\r
430 /** NandFlash pins definition: WE. */\r
431 #define PIN_EBI_NANDWE   {PIO_PC10, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}\r
432 /** NandFlash pins definition: CLE. */\r
433 #define PIN_EBI_NANDCLE  {PIO_PC17, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}\r
434 /** NandFlash pins definition: ALE. */\r
435 #define PIN_EBI_NANDALE  {PIO_PC16, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}\r
436 /** NandFlash pins definition: DATA. */\r
437 #define PIN_EBI_NANDIO   {0x000000FF, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}\r
438 /** Nandflash chip enable pin definition. */\r
439 #define BOARD_NF_CE_PIN  {PIO_PC14, PIOC, ID_PIOC, PIO_OUTPUT_1, PIO_DEFAULT}\r
440 /** Nandflash ready/busy pin definition. */\r
441 #define BOARD_NF_RB_PIN  {0, 0, 0, 0, 0}\r
442 \r
443 /** Nandflash controller peripheral pins definition. */\r
444 #define PINS_NANDFLASH   {PIN_EBI_NANDIO, BOARD_NF_CE_PIN, BOARD_NF_RB_PIN, \\r
445                 PIN_EBI_NANDOE, PIN_EBI_NANDWE, PIN_EBI_NANDCLE, PIN_EBI_NANDALE}\r
446 \r
447 /*----------------------------------------------------------------------------*/\r
448 /**\r
449  * \page samv7_Xplained_ultra_usb "SAMV7_Xplained_Ultra - GMAC"\r
450  */\r
451 \r
452 \r
453 /** PHY address */\r
454 #define BOARD_GMAC_PHY_ADDR             1\r
455 /** PHY Component */\r
456 #define BOARD_GMAC_PHY_COMP_KSZ8061RNB  1\r
457 /** Board GMAC power control - ALWAYS ON */\r
458 #define BOARD_GMAC_POWER_ALWAYS_ON\r
459 /** Board GMAC work mode - RMII/MII ( 1 / 0 ) */\r
460 #define BOARD_GMAC_MODE_RMII            1\r
461 \r
462 /** The PIN list of PIO for GMAC */\r
463 #define BOARD_GMAC_PINS          { (PIO_PD0A_GTXCK | PIO_PD1A_GTXEN | PIO_PD2A_GTX0 | PIO_PD3A_GTX1 | PIO_PD4A_GRXDV | PIO_PD5A_GRX0 | PIO_PD6A_GRX1 | PIO_PD7A_GRXER | PIO_PD8A_GMDC | PIO_PD9A_GMDIO ), \\r
464                                   PIOD, ID_PIOD, PIO_PERIPH_A, PIO_DEFAULT}, \\r
465                                  {PIO_PC30, PIOC, ID_PIOC, PIO_INPUT,    PIO_PULLUP},\\r
466                                  {PIO_PA29, PIOA, ID_PIOA, PIO_INPUT,    PIO_DEFAULT}\r
467 \r
468                                    /** The PIN list of PIO for GMAC */\r
469 #define BOARD_GMAC_RESET_PIN     {PIO_PC10, PIOC, ID_PIOC, PIO_OUTPUT_1,    PIO_PULLUP}\r
470 \r
471 /** The runtime pin configure list for GMAC */\r
472 #define BOARD_GMAC_RUN_PINS BOARD_GMAC_PINS\r
473 \r
474 \r
475 #define PIN_ISI_D0   {PIO_PD22D_ISI_D0,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}\r
476 #define PIN_ISI_D1   {PIO_PD21D_ISI_D1,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}\r
477 #define PIN_ISI_D2   {PIO_PB3D_ISI_D2,  PIOB, ID_PIOB, PIO_PERIPH_D, PIO_PULLUP}\r
478 #define PIN_ISI_D3   {PIO_PA9B_ISI_D3,  PIOA, ID_PIOA, PIO_PERIPH_B, PIO_PULLUP}\r
479 #define PIN_ISI_D4   {PIO_PA5B_ISI_D4,  PIOA, ID_PIOA, PIO_PERIPH_B, PIO_PULLUP}\r
480 #define PIN_ISI_D5   {PIO_PD11D_ISI_D5,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}\r
481 #define PIN_ISI_D6   {PIO_PD12D_ISI_D6,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}\r
482 #define PIN_ISI_D7   {PIO_PA27D_ISI_D7,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}\r
483 #define PIN_ISI_D8   {PIO_PD27D_ISI_D8,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}\r
484 #define PIN_ISI_D9   {PIO_PD28D_ISI_D9,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}\r
485 \r
486 #define BOARD_ISI_VSYNC     {PIO_PD25D_ISI_VSYNC, PIOD, ID_PIOD, PIO_PERIPH_D, PIO_DEFAULT}\r
487 #define BOARD_ISI_HSYNC     {PIO_PD24D_ISI_HSYNC, PIOD, ID_PIOD, PIO_PERIPH_D, PIO_DEFAULT}\r
488 #define BOARD_ISI_PCK       {PIO_PA24D_ISI_PCK, PIOA, ID_PIOA, PIO_PERIPH_D, PIO_DEFAULT}\r
489 \r
490 #define BOARD_ISI_PINS  PIN_ISI_D0,PIN_ISI_D1,PIN_ISI_D2,PIN_ISI_D3,PIN_ISI_D4,\\r
491                         PIN_ISI_D5,PIN_ISI_D6,PIN_ISI_D7,PIN_ISI_D8,PIN_ISI_D9,\\r
492                         BOARD_ISI_VSYNC ,BOARD_ISI_HSYNC ,BOARD_ISI_PCK\r
493 /*----------------------------------------------------------------------------*/\r
494 /**\r
495  * \page samv7_Xplained_ultra_usb "SAMV7_Xplained_Ultra - USB device"\r
496  *\r
497  * \section Definitions\r
498  * - \ref BOARD_USB_BMATTRIBUTES\r
499  * - \ref CHIP_USB_UDP\r
500  * - \ref CHIP_USB_PULLUP_INTERNAL\r
501  * - \ref CHIP_USB_NUMENDPOINTS\r
502  * - \ref CHIP_USB_ENDPOINTS_MAXPACKETSIZE\r
503  * - \ref CHIP_USB_ENDPOINTS_BANKS\r
504  */\r
505 \r
506 /**\r
507  * USB attributes configuration descriptor (bus or self powered,\r
508  * remote wakeup)\r
509  */\r
510 #define BOARD_USB_BMATTRIBUTES  USBConfigurationDescriptor_SELFPOWERED_RWAKEUP\r
511 \r
512 /** Indicates chip has an UDP Full Speed. */\r
513 #define CHIP_USB_UDP\r
514 \r
515 /** Indicates chip has an internal pull-up. */\r
516 #define CHIP_USB_PULLUP_INTERNAL\r
517 \r
518 /** Number of USB endpoints */\r
519 #define CHIP_USB_NUMENDPOINTS 10\r
520 \r
521 /** Endpoints max paxcket size */\r
522 #define CHIP_USB_ENDPOINTS_MAXPACKETSIZE(i)   ((i == 0) ? 64 : 1024)\r
523 \r
524 /** Endpoints Number of Bank */\r
525 #define CHIP_USB_ENDPOINTS_BANKS(i) \\r
526    ((i == 0) ? 1 : \\r
527    ((i == 1) ? 3 : \\r
528    ((i == 2) ? 3 : 2)))\r
529 \r
530 /*----------------------------------------------------------------------------*/\r
531 /**\r
532  * \page samv7_Xplained_ultra_extcomp "SAMV7_Xplained_Ultra - External components"\r
533  * This page lists the definitions related to external on-board components\r
534  * located in the board.h file for the SAMV7_Xplained_Ultra.\r
535  *\r
536  * SD Card\r
537  * - \ref BOARD_SD_PINS\r
538  * - \ref BOARD_SD_PIN_CD\r
539  *\r
540  * LCD\r
541  * - \ref BOARD_LCD_ILI9325\r
542  * - \ref BOARD_LCD_PINS\r
543  * - \ref BOARD_BACKLIGHT_PIN\r
544  * - \ref BOARD_LCD_BASE\r
545  * - \ref BOARD_LCD_RS\r
546  * - \ref BOARD_LCD_WIDTH\r
547  * - \ref BOARD_LCD_HEIGHT\r
548  *\r
549  * TouchScreen\r
550  * - \ref BOARD_TSC_ADS7843\r
551  * - \ref PIN_TCS_IRQ\r
552  * - \ref PIN_TCS_BUSY\r
553  * - \ref BOARD_TSC_SPI_BASE\r
554  * - \ref BOARD_TSC_SPI_ID\r
555  * - \ref BOARD_TSC_SPI_PINS\r
556  * - \ref BOARD_TSC_NPCS\r
557  * - \ref BOARD_TSC_NPCS_PIN\r
558  *\r
559  * SmartCard\r
560  * - \ref SMARTCARD_CONNECT_PIN\r
561  * - \ref PIN_ISO7816_RSTMC\r
562  * - \ref PINS_ISO7816\r
563  */\r
564 \r
565 \r
566 /** Indicates board has an ILI9325 external component to manage LCD. */\r
567 #define BOARD_LCD_ILI9488\r
568 \r
569      /** SPI MISO pin definition. */\r
570 #define LCD_SPI_MISO    {PIO_PD20B_SPI0_MISO, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}\r
571 /** SPI MOSI pin definition. */\r
572 #define LCD_SPI_MOSI    {PIO_PD21B_SPI0_MOSI, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}\r
573 /** SPI SPCK pin definition. */\r
574 #define LCD_SPI_SPCK    {PIO_PD22B_SPI0_SPCK, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}\r
575 /** SPI chip select pin definition. */\r
576 #define LCD_SPI_NPCS    {PIO_PD25B_SPI0_NPCS1, PIOD, ID_PIOD, PIO_PERIPH_B,PIO_DEFAULT}\r
577 \r
578 /** LCD pins definition. */\r
579 #define BOARD_LCD_PINS  {LCD_SPI_MISO, LCD_SPI_MOSI, LCD_SPI_SPCK, LCD_SPI_NPCS}\r
580 \r
581 /** Backlight pin definition. */\r
582 \r
583 #define BOARD_LCD_BACKLIGHT_PIN   {PIO_PA0A_PWMC0_PWMH0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}\r
584 \r
585 /** PWMC PWM0 pin definition: Output Low. */\r
586 #define LCD_PIN_RESET   {PIO_PD28, PIOD, ID_PIOD, PIO_OUTPUT_1, PIO_DEFAULT}\r
587 \r
588 /** PWM channel for LED0 */\r
589 #define CHANNEL_PWM_LCD 0\r
590 \r
591 /** Display width in pixels. */\r
592 #define BOARD_LCD_WIDTH             320\r
593 /** Display height in pixels. */\r
594 #define BOARD_LCD_HEIGHT            480\r
595 \r
596 \r
597 /*----------------------------------------------------------------------------*/\r
598 /**\r
599  * \page samv7_Xplained_ultra_mem "SAMV7_Xplained_Ultra - Memories"\r
600  * This page lists definitions related to internal & external on-board memories.\r
601  *\r
602  * \section NandFlash\r
603  * - \ref BOARD_NF_COMMAND_ADDR\r
604  * - \ref BOARD_NF_ADDRESS_ADDR\r
605  * - \ref BOARD_NF_DATA_ADDR\r
606  *\r
607  * \section NorFlash\r
608  * - \ref BOARD_NORFLASH_ADDR\r
609  * - \ref BOARD_NORFLASH_DFT_BUS_SIZE\r
610  */\r
611 \r
612 /** Address for transferring command bytes to the nandflash. */\r
613 #define BOARD_NF_COMMAND_ADDR   0x60400000\r
614 /** Address for transferring address bytes to the nandflash. */\r
615 #define BOARD_NF_ADDRESS_ADDR   0x60200000\r
616 /** Address for transferring data bytes to the nandflash. */\r
617 #define BOARD_NF_DATA_ADDR      0x60000000\r
618 \r
619 /** Address for transferring command bytes to the norflash. */\r
620 #define BOARD_NORFLASH_ADDR     0x60000000\r
621 /** Default NOR bus size after power up reset */\r
622 #define BOARD_NORFLASH_DFT_BUS_SIZE 8\r
623 \r
624 /*----------------------------------------------------------------------------*/\r
625 /**\r
626  * \page samv7_Xplained_ultra_chipdef "SAMV7_Xplained_Ultra - Individual chip definition"\r
627  * This page lists the definitions related to different chip's definition\r
628  *\r
629  * \section USART\r
630  * - \ref BOARD_PIN_USART_RXD\r
631  * - \ref BOARD_PIN_USART_TXD\r
632  * - \ref BOARD_PIN_USART_CTS\r
633  * - \ref BOARD_PIN_USART_RTS\r
634  * - \ref BOARD_PIN_USART_EN\r
635  * - \ref BOARD_USART_BASE\r
636  * - \ref BOARD_ID_USART\r
637  */\r
638 \r
639 /** Rtc */\r
640 #define BOARD_RTC_ID              ID_RTC\r
641 \r
642 /** TWI ID for QTouch application to use */\r
643 #define BOARD_ID_TWI_AT42         ID_TWI0\r
644 /** TWI Base for QTouch application to use */\r
645 #define BOARD_BASE_TWI_AT42       TWI0\r
646 /** TWI pins for QTouch application to use */\r
647 #define BOARD_PINS_TWI_AT42       PINS_TWI0\r
648 \r
649 /** USART RX pin for application */\r
650 #define BOARD_PIN_USART_RXD        PIN_USART1_RXD\r
651 /** USART TX pin for application */\r
652 #define BOARD_PIN_USART_TXD        PIN_USART1_TXD\r
653 /** USART CTS pin for application */\r
654 #define BOARD_PIN_USART_CTS        PIN_USART1_CTS\r
655 /** USART RTS pin for application */\r
656 #define BOARD_PIN_USART_RTS        PIN_USART1_RTS\r
657 /** USART ENABLE pin for application */\r
658 #define BOARD_PIN_USART_EN         PIN_USART1_EN\r
659 /** USART Base for application */\r
660 #define BOARD_USART_BASE           USART1\r
661 /** USART ID for application */\r
662 #define BOARD_ID_USART             ID_USART1\r
663 \r
664 \r
665 \r
666 /** MCI0 Card detect pin definition. (PE5) */\r
667 #define BOARD_MCI_PIN_CD       {PIO_PD18, PIOD, ID_PIOD, PIO_INPUT, PIO_PULLUP}\r
668 \r
669 /** MCI0 Clock . */\r
670 #define BOARD_MCI_PIN_CK       {PIO_PA25D_MCCK, PIOA, ID_PIOA, PIO_PERIPH_D, PIO_DEFAULT}\r
671 \r
672 \r
673 /** MCI0 Solt A IO pins definition. (PC4-PC13) */\r
674 #define BOARD_MCI_PINS_SLOTA   {(PIO_PA30C_MCDA0 | PIO_PA31C_MCDA1 | PIO_PA26C_MCDA2 | PIO_PA27C_MCDA3 | PIO_PA28C_MCCDA),\\r
675                                   PIOA, ID_PIOA, PIO_PERIPH_C, PIO_DEFAULT}\r
676 \r
677 \r
678 /** MCI pins that shall be configured to access the SD card. */\r
679 #define BOARD_SD_PINS    {BOARD_MCI_PINS_SLOTA, BOARD_MCI_PIN_CK}\r
680 /** MCI Card Detect pin. */\r
681 #define BOARD_SD_PIN_CD  BOARD_MCI_PIN_CD\r
682  /** Total number of MCI interface */\r
683 #define BOARD_NUM_MCI           1\r
684 \r
685 /** Total number of MCI interface */\r
686 #define BOARD_NUM_MCI           1\r
687 \r
688 \r
689 #define PINS_QSPI_IO         { (PIO_PA11A_QCS | PIO_PA13A_QIO0 | PIO_PA12A_QIO1 | PIO_PA17A_QIO2 | PIO_PA14A_QSCK), \\r
690                                PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}\r
691 \r
692 #define PINS_QSPI_IO3       { PIO_PD31A_QIO3, PIOD, ID_PIOD, PIO_PERIPH_A, PIO_DEFAULT}\r
693 \r
694 #define PINS_QSPI           {PINS_QSPI_IO, PINS_QSPI_IO3}\r
695 \r
696 \r
697 #endif /* #ifndef _BOARD_H_ */\r
698 \r