1 /* ----------------------------------------------------------------------------
\r
2 * SAM Software Package License
\r
3 * ----------------------------------------------------------------------------
\r
4 * Copyright (c) 2014, Atmel Corporation
\r
6 * All rights reserved.
\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
11 * - Redistributions of source code must retain the above copyright notice,
\r
12 * this list of conditions and the disclaimer below.
\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
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
31 * \page samv7_Xplained_ultra_board_desc SAMV7_Xplained_Ultra - Board Description
\r
35 * This file is dedicated to describe the SAMV7_Xplained_Ultra board.
\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
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
53 * - The code for booting the board is provided by board_cstartup_xxx.c and
\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
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
66 * Definition of SAMV7_Xplained_Ultra characteristics, PIOs and
\r
67 * external components interface.
\r
73 /*----------------------------------------------------------------------------
\r
75 *----------------------------------------------------------------------------*/
\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
105 /*----------------------------------------------------------------------------
\r
107 *----------------------------------------------------------------------------*/
\r
109 /*----------------------------------------------------------------------------*/
\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
114 * \section Definitions
\r
115 * - \ref BOARD_NAME
\r
118 /** Name of the board */
\r
119 #define BOARD_NAME "SAMV7-EK"
\r
120 #define NO_PUSHBUTTON
\r
121 /*----------------------------------------------------------------------------*/
\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
127 * \section Definitions
\r
128 * - \ref BOARD_MAINOSC
\r
132 /** Frequency of the board main oscillator */
\r
133 #define BOARD_MAINOSC 12000000
\r
135 /** Master clock frequency (when using board_lowlevel.c) */
\r
137 #define BOARD_MCK 132000000
\r
141 /*----------------------------------------------------------------------------*/
\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
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
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
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
193 * - \ref PIN_SPI_MISO
\r
194 * - \ref PIN_SPI_MOSI
\r
195 * - \ref PIN_SPI_SPCK
\r
197 * - \ref PIN_SPI_NPCS0_PA11
\r
202 * PIO PARALLEL CAPTURE
\r
203 * - \ref PIN_PIODCEN1
\r
204 * - \ref PIN_PIODCEN2
\r
208 * - \ref PIN_TWI_TWD0
\r
209 * - \ref PIN_TWI_TWCK0
\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
220 * - \ref PIN_USB_VBUS
\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
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
241 #define PIN_SSC_RD {PIO_PA10C_RD, PIOA, ID_PIOA, PIO_PERIPH_C, PIO_DEFAULT}
\r
243 #define PIN_SSC_RK {PIO_PA22A_RK, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
\r
245 #define PIN_SSC_RF {PIO_PD24B_RF, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
\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
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
256 /** EBI Data Bus pins */
\r
257 #define PIN_EBI_DATA_BUS {0xFF, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}
\r
259 #define PIN_EBI_NRD {1 << 11, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}
\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
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
272 #define LED_YELLOW0 0
\r
273 #define LED_YELLOW1 1
\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
280 /** List of all LEDs definitions. */
\r
281 #define PINS_LEDS {PIN_LED_0, PIN_LED_1}
\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
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
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
307 * Push button #0 definition.
\r
308 * Attributes = pull-up + debounce + interrupt on rising edge.
\r
310 #define PIN_PUSHBUTTON_0 {PIO_PA19, PIOA, ID_PIOA, PIO_INPUT, PIO_PULLUP | PIO_DEBOUNCE | PIO_IT_FALL_EDGE}
\r
312 * Push button #1 definition.
\r
313 * Attributes = pull-up + debounce + interrupt on rising edge.
\r
315 #define PIN_PUSHBUTTON_1 {PIO_PB12, PIOB, ID_PIOB, PIO_INPUT, PIO_PULLUP | PIO_DEBOUNCE | PIO_IT_FALL_EDGE}
\r
317 /** List of all push button definitions. */
\r
318 #define PINS_PUSHBUTTONS {PIN_PUSHBUTTON_0, PIN_PUSHBUTTON_1}
\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
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
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
353 #define PIN_SPI_NPCS3 {PIO_PD27B_SPI0_NPCS3, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
\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
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
362 #define PIN_PCK1 {PIO_PA17B_PCK1, PIOB, ID_PIOB, PIO_PERIPH_B, PIO_DEFAULT}
\r
365 #define PIN_PCK2 {PIO_PA18B_PCK2, PIOA, ID_PIOA, PIO_PERIPH_B, PIO_DEFAULT}
\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
374 /** TWI ver 3.xx */
\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
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
387 #define PINS_TWI1 {PIN_TWI_TWD1, PIN_TWI_TWCK1}
\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
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
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
424 /** USB VBus monitoring pin definition. */
\r
425 #define PIN_USB_VBUS {PIO_PC16, PIOC, ID_PIOC, PIO_INPUT, PIO_DEFAULT}
\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
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
447 /*----------------------------------------------------------------------------*/
\r
449 * \page samv7_Xplained_ultra_usb "SAMV7_Xplained_Ultra - GMAC"
\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
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
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
471 /** The runtime pin configure list for GMAC */
\r
472 #define BOARD_GMAC_RUN_PINS BOARD_GMAC_PINS
\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
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
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
495 * \page samv7_Xplained_ultra_usb "SAMV7_Xplained_Ultra - USB device"
\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
507 * USB attributes configuration descriptor (bus or self powered,
\r
510 #define BOARD_USB_BMATTRIBUTES USBConfigurationDescriptor_SELFPOWERED_RWAKEUP
\r
512 /** Indicates chip has an UDP Full Speed. */
\r
513 #define CHIP_USB_UDP
\r
515 /** Indicates chip has an internal pull-up. */
\r
516 #define CHIP_USB_PULLUP_INTERNAL
\r
518 /** Number of USB endpoints */
\r
519 #define CHIP_USB_NUMENDPOINTS 10
\r
521 /** Endpoints max paxcket size */
\r
522 #define CHIP_USB_ENDPOINTS_MAXPACKETSIZE(i) ((i == 0) ? 64 : 1024)
\r
524 /** Endpoints Number of Bank */
\r
525 #define CHIP_USB_ENDPOINTS_BANKS(i) \
\r
528 ((i == 2) ? 3 : 2)))
\r
530 /*----------------------------------------------------------------------------*/
\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
537 * - \ref BOARD_SD_PINS
\r
538 * - \ref BOARD_SD_PIN_CD
\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
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
560 * - \ref SMARTCARD_CONNECT_PIN
\r
561 * - \ref PIN_ISO7816_RSTMC
\r
562 * - \ref PINS_ISO7816
\r
566 /** Indicates board has an ILI9325 external component to manage LCD. */
\r
567 #define BOARD_LCD_ILI9488
\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
578 /** LCD pins definition. */
\r
579 #define BOARD_LCD_PINS {LCD_SPI_MISO, LCD_SPI_MOSI, LCD_SPI_SPCK, LCD_SPI_NPCS}
\r
581 /** Backlight pin definition. */
\r
583 #define BOARD_LCD_BACKLIGHT_PIN {PIO_PA0A_PWMC0_PWMH0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
\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
588 /** PWM channel for LED0 */
\r
589 #define CHANNEL_PWM_LCD 0
\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
597 /*----------------------------------------------------------------------------*/
\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
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
607 * \section NorFlash
\r
608 * - \ref BOARD_NORFLASH_ADDR
\r
609 * - \ref BOARD_NORFLASH_DFT_BUS_SIZE
\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
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
624 /*----------------------------------------------------------------------------*/
\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
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
640 #define BOARD_RTC_ID ID_RTC
\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
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
666 /** MCI0 Card detect pin definition. (PE5) */
\r
667 #define BOARD_MCI_PIN_CD {PIO_PD18, PIOD, ID_PIOD, PIO_INPUT, PIO_PULLUP}
\r
669 /** MCI0 Clock . */
\r
670 #define BOARD_MCI_PIN_CK {PIO_PA25D_MCCK, PIOA, ID_PIOA, PIO_PERIPH_D, PIO_DEFAULT}
\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
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
685 /** Total number of MCI interface */
\r
686 #define BOARD_NUM_MCI 1
\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
692 #define PINS_QSPI_IO3 { PIO_PD31A_QIO3, PIOD, ID_PIOD, PIO_PERIPH_A, PIO_DEFAULT}
\r
694 #define PINS_QSPI {PINS_QSPI_IO, PINS_QSPI_IO3}
\r
697 #endif /* #ifndef _BOARD_H_ */
\r