SAMV71 Xplained Ultra Software Package 1.5

board_v71_xult.h

00001 /* ---------------------------------------------------------------------------- */
00002 /*                  Atmel Microcontroller Software Support                      */
00003 /*                       SAM Software Package License                           */
00004 /* ---------------------------------------------------------------------------- */
00005 /* Copyright (c) 2015, Atmel Corporation                                        */
00006 /*                                                                              */
00007 /* All rights reserved.                                                         */
00008 /*                                                                              */
00009 /* Redistribution and use in source and binary forms, with or without           */
00010 /* modification, are permitted provided that the following condition is met:    */
00011 /*                                                                              */
00012 /* - Redistributions of source code must retain the above copyright notice,     */
00013 /* this list of conditions and the disclaimer below.                            */
00014 /*                                                                              */
00015 /* Atmel's name may not be used to endorse or promote products derived from     */
00016 /* this software without specific prior written permission.                     */
00017 /*                                                                              */
00018 /* DISCLAIMER:  THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR   */
00019 /* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF */
00020 /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE   */
00021 /* DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,      */
00022 /* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT */
00023 /* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,  */
00024 /* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF    */
00025 /* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING         */
00026 /* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, */
00027 /* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.                           */
00028 /* ---------------------------------------------------------------------------- */
00029 
00030 /**
00031  * \page samv7_Xplained_ultra_board_desc SAM V71 Xplained Ultra - Board
00032  * Description
00033  *
00034  * \section Purpose
00035  *
00036  * This file is dedicated to describe the SAM V71 Xplained Ultra board.
00037  *
00038  * \section Contents
00039  *
00040  *  - For SAM V71 Xplained Ultra board information, see
00041  *    \subpage samv7_Xplained_ultra_board_info.
00042  *  - For operating frequency information, see \subpage samv7_Xplained_ultra_opfreq.
00043  *  - For using portable PIO definitions, see \subpage samv7_Xplained_ultra_piodef.
00044  *  - For using GMAC PIO definitions, see \subpage samv7_Xplained_ultra_gmac.
00045  *  - For using ISI definitions, see \subpage samv7_Xplained_ultra_isi.
00046  *  - For on-board memories, see \subpage samv7_Xplained_ultra_mem.
00047  *  - Several USB definitions are included here,
00048  *    see \subpage samv7_Xplained_ultra_usb.
00049  *  - For External components, see \subpage samv7_Xplained_ultra_extcomp.
00050  *  - For Individual chip definition, see \subpage samv7_Xplained_ultra_chipdef.
00051  *
00052  * To get more software details and the full list of parameters related to the
00053  * SAM V71 Xplained Ultra board configuration, please have a look at the source
00054  * file:
00055  * \ref board.h, \ref board_v71_xult.h\n
00056  *
00057  * \section Usage
00058  *
00059  *  - The code for booting the board is provided by startup_samv71.c and
00060  *    board_lowlevel.c.
00061  *  - For using board PIOs, board characteristics (clock, etc.) and external
00062  *    components, see board.h, board_v71_xult.h.
00063  *  - For manipulating memories, see board_memories.h.
00064  *
00065  * This file can be used as a template and modified to fit a custom board, with
00066  * specific PIOs usage or memory connections.
00067  */
00068 
00069 /**
00070  *  \file board.h
00071  *
00072  *  Definition of SAM V71 Xplained Ultra board characteristics, PIOs and
00073  *  external components interface.
00074  */
00075 
00076 #ifndef _BOARD_V71_XULT_H_
00077 #define _BOARD_V71_XULT_H_
00078 
00079 /*----------------------------------------------------------------------------
00080  *        Headers
00081  *----------------------------------------------------------------------------*/
00082 
00083 #include "chip.h"
00084 
00085 #include "include/board_lowlevel.h"
00086 #include "include/board_memories.h"
00087 #include "include/led.h"
00088 #include "include/gmii.h"
00089 #include "include/gmacb_phy.h"
00090 #include "include/dbg_console.h"
00091 #include "include/bmp.h"
00092 #include "include/lcdd.h"
00093 #include "include/ili9488.h"
00094 #include "include/ili9488_reg.h"
00095 #include "include/ili9488_spi.h"
00096 #include "include/ili9488_ebi.h"
00097 #include "include/ili9488_dma.h"
00098 #include "include/ili9488_spi_dma.h"
00099 #include "include/ili9488_ebi_dma.h"
00100 #include "include/frame_buffer.h"
00101 #include "include/lcd_color.h"
00102 #include "include/lcd_draw.h"
00103 #include "include/lcd_font10x14.h"
00104 #include "include/lcd_font.h"
00105 #include "include/lcd_gimp_image.h"
00106 #include "include/rtc_calib.h"
00107 #include "include/wm8904.h"
00108 #include "include/cs2100.h"
00109 #include "include/s25fl1.h"
00110 #include "include/image_sensor_inf.h"
00111 #include "include/iso7816_4.h"
00112 
00113 #if defined (__GNUC__)
00114     #include "include/syscalls.h"
00115 #endif
00116 /*----------------------------------------------------------------------------
00117  *        Definitions
00118  *----------------------------------------------------------------------------*/
00119 
00120 /*----------------------------------------------------------------------------*/
00121 /**
00122  * \page samv7_Xplained_ultra_board_info "SAM V71 Xplained Ultra - Board informations"
00123  * This page lists several definition related to the board description.
00124  *
00125  * \section Definitions
00126  * - \ref BOARD_NAME
00127  */
00128 
00129 /** Name of the board */
00130 #define BOARD_NAME "SAM V71 Xplained Ultra"
00131 #define NO_PUSHBUTTON
00132 /*----------------------------------------------------------------------------*/
00133 /**
00134  *  \page samv7_Xplained_ultra_opfreq "SAM V71 Xplained Ultra - Operating frequencies"
00135  *  This page lists several definition related to the board operating frequency
00136  *  (when using the initialization done by board_lowlevel.c).
00137  *
00138  *  \section Definitions
00139  *  - \ref BOARD_MAINOSC
00140  *  - \ref BOARD_MCK
00141  */
00142 
00143 /** Frequency of the board main oscillator */
00144 #define BOARD_MAINOSC    12000000
00145 
00146 /** Master clock frequency (when using board_lowlevel.c) */
00147 
00148 #ifdef MCK_123MHZ
00149     #define BOARD_MCK    123000000
00150 #else
00151     #define BOARD_MCK    150000000
00152 #endif
00153 
00154 #if (BOARD_MCK==123000000)
00155 
00156     #define PLL_MUL    0x16
00157     #define PLL_DIV    0x01
00158 
00159 #else   // 300MHz(PCK) and 150MHz(MCK) by default
00160 
00161     #define PLL_MUL    0x19
00162     #define PLL_DIV    0x01
00163 
00164 #endif
00165 
00166 /*----------------------------------------------------------------------------*/
00167 /**
00168  * \page samv7_Xplained_ultra_piodef "SAM V71 Xplained Ultra - PIO definitions"
00169  * This pages lists all the PIOs definitions contained in board.h. The constants
00170  * are named using the following convention: PIN_* for a constant which defines
00171  * a single Pin instance (but may include several PIOs sharing the same
00172  * controller), and PINS_* for a list of Pin instances.
00173  *
00174  * UART0
00175  * - \ref PINS_UART0
00176  *
00177  * UART4
00178  * - \ref PINS_UART4
00179  *
00180  * LEDs
00181  * - \ref PIN_LED_0
00182  * - \ref PIN_LED_1
00183  * - \ref PINS_LEDS
00184  *
00185  * Push buttons
00186  * - \ref PIN_PUSHBUTTON_0
00187  * - \ref PIN_PUSHBUTTON_1
00188  * - \ref PINS_PUSHBUTTONS
00189  * - \ref PUSHBUTTON_BP0
00190  * - \ref PUSHBUTTON_BP1
00191  *
00192  * PWMC
00193  * - \ref PIN_PWMC_PWMH0
00194  * - \ref PIN_PWMC_PWMH1
00195  * - \ref PIN_PWM_LED0
00196  * - \ref PIN_PWM_LED1
00197  * - \ref CHANNEL_PWM_LED0
00198  * - \ref CHANNEL_PWM_LED1
00199  *
00200  * SPI
00201  * - \ref PIN_SPI_MISO
00202  * - \ref PIN_SPI_MOSI
00203  * - \ref PIN_SPI_SPCK
00204  * - \ref PINS_SPI
00205  *
00206  * PCK0
00207  * - \ref PIN_PCK0
00208  * - \ref PIN_PCK1
00209  * - \ref PIN_PCK2
00210  *
00211  * PIO PARALLEL CAPTURE
00212  * - \ref PIN_PIODCEN1
00213  * - \ref PIN_PIODCEN2
00214  *
00215  * TWI
00216  * - \ref TWI_V3XX
00217  * - \ref PIN_TWI_TWD0
00218  * - \ref PIN_TWI_TWCK0
00219  * - \ref PINS_TWI0
00220  * - \ref PIN_TWI_TWD1
00221  * - \ref PIN_TWI_TWCK1
00222  * - \ref PINS_TWI1
00223  *
00224  * USART0
00225  * - \ref PIN_USART0_RXD
00226  * - \ref PIN_USART0_TXD
00227  * - \ref PIN_USART0_CTS
00228  * - \ref PIN_USART0_RTS
00229  * - \ref PIN_USART0_SCK
00230  *
00231  * USART1
00232  * - \ref PIN_USART1_RXD
00233  * - \ref PIN_USART1_TXD
00234  * - \ref PIN_USART1_CTS
00235  * - \ref PIN_USART1_RTS
00236  * - \ref PIN_USART1_SCK
00237  *
00238  * USART2
00239  * - \ref PIN_USART2_RXD
00240  * - \ref PIN_USART2_TXD
00241  * - \ref PIN_USART2_CTS
00242  * - \ref PIN_USART2_RTS
00243  * - \ref PIN_USART2_SCK
00244  *
00245  * SSC
00246  * - \ref PIN_SSC_TD
00247  * - \ref PIN_SSC_TK
00248  * - \ref PIN_SSC_TF
00249  * - \ref PIN_SSC_RD
00250  * - \ref PIN_SSC_RK
00251  * - \ref PIN_SSC_RF
00252  * - \ref PIN_SSC_TD
00253  * - \ref PINS_SSC_CODEC
00254  *
00255  * MCAN
00256  * - \ref PIN_MCAN0_TXD
00257  * - \ref PIN_MCAN0_RXD
00258  * - \ref PIN_MCAN1_TXD
00259  * - \ref PIN_MCAN1_RXD
00260  */
00261 
00262 /** SSC pin Transmitter Data (TD) */
00263 #define PIN_SSC_TD  {PIO_PD26B_TD, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00264 /** SSC pin Transmitter Clock (TK) */
00265 #define PIN_SSC_TK  {PIO_PB1D_TK, PIOB, ID_PIOB, PIO_PERIPH_D, PIO_DEFAULT}
00266 /** SSC pin Transmitter FrameSync (TF) */
00267 #define PIN_SSC_TF  {PIO_PB0D_TF, PIOB, ID_PIOB, PIO_PERIPH_D, PIO_DEFAULT}
00268 /** SSC pin RD */
00269 #define PIN_SSC_RD  {PIO_PA10C_RD, PIOA, ID_PIOA, PIO_PERIPH_C, PIO_DEFAULT}
00270 /** SSC pin RK */
00271 #define PIN_SSC_RK  {PIO_PA22A_RK, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
00272 /** SSC pin RF */
00273 #define PIN_SSC_RF  {PIO_PD24B_RF, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00274 
00275 /** SSC pins definition for codec. */
00276 #define PINS_SSC_CODEC \
00277     {PIN_SSC_TD,  PIN_SSC_TK, PIN_SSC_TF, PIN_SSC_RD,  PIN_SSC_RK, PIN_SSC_RF}
00278 
00279 /** UART pins (UTXD0 and URXD0) definitions, PA9,10. */
00280 #define PINS_UART0  \
00281     {PIO_PA9A_URXD0 | PIO_PA10A_UTXD0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
00282 /** UART pins (UTXD4 and URXD4) definitions, PD19,18. */
00283 #define PINS_UART4 \
00284     {PIO_PD18C_URXD4 | PIO_PD19C_UTXD4, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}
00285 
00286 /* LED pins definitions */
00287 #define LED_YELLOW0  0
00288 #define LED_YELLOW1  1
00289 
00290 /** LED #0 pin definition (YELLOW). */
00291 #define PIN_LED_0  {PIO_PC9, PIOC, ID_PIOC, PIO_OUTPUT_1, PIO_DEFAULT}
00292 /** LED #1 pin definition (YELLOW). */
00293 #define PIN_LED_1  {PIO_PA23, PIOA, ID_PIOA, PIO_OUTPUT_1, PIO_DEFAULT}
00294 
00295 /** List of all LEDs definitions. */
00296 #define PINS_LEDS  {PIN_LED_0, PIN_LED_1}
00297 
00298 /** Number of LEDs */
00299 #define LED_NUM  2
00300 
00301 /**
00302  * Push button #0 definition.
00303  * Attributes = pull-up + debounce + interrupt on rising edge.
00304  */
00305 #define PIN_PUSHBUTTON_0 \
00306     {PIO_PA9, PIOA, ID_PIOA, PIO_INPUT, PIO_PULLUP | PIO_DEBOUNCE | PIO_IT_FALL_EDGE}
00307 /**
00308  * Push button #1 definition.
00309  * Attributes = pull-up + debounce + interrupt on rising edge.
00310  */
00311 #define PIN_PUSHBUTTON_1 \
00312     {PIO_PB12, PIOB, ID_PIOB, PIO_INPUT, PIO_PULLUP | PIO_DEBOUNCE | PIO_IT_FALL_EDGE}
00313 
00314 /** List of all push button definitions. */
00315 #define PINS_PUSHBUTTONS {PIN_PUSHBUTTON_0, PIN_PUSHBUTTON_1}
00316 
00317 /** Push button #0 index. */
00318 #define PUSHBUTTON_BP0  0
00319 /** Push button #1 index. */
00320 #define PUSHBUTTON_BP1  1
00321 
00322 /** Number of Buttons */
00323 #define BUTTON_NUM  2
00324 
00325 /** Index of wakeup source */
00326 #define WKUP_IDX    6
00327 
00328 /** PWMC PWM0 pin definition: Output High. */
00329 #define PIN_PWMC_PWMH0  {PIO_PD20A_PWMH0, PIOD, ID_PIOD, PIO_PERIPH_A, PIO_DEFAULT}
00330 /** PWMC PWM1 pin definition: Output High. */
00331 #define PIN_PWMC_PWMH1  {PIO_PD21A_PWMH1, PIOD, ID_PIOD, PIO_PERIPH_A, PIO_DEFAULT}
00332 /** PWM pins definition for LED0 */
00333 #define PIN_PWM_LED0  PIN_PWMC_PWMH0
00334 /** PWM pins definition for LED1 */
00335 #define PIN_PWM_LED1  PIN_PWMC_PWMH1
00336 /** PWM channel for LED0 */
00337 #define CHANNEL_PWM_LED0 0
00338 /** PWM channel for LED1 */
00339 #define CHANNEL_PWM_LED1 1
00340 
00341 /** SPI MISO pin definition. */
00342 #define PIN_SPI_MISO {PIO_PD20B_SPI0_MISO, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00343 /** SPI MOSI pin definition. */
00344 #define PIN_SPI_MOSI {PIO_PD21B_SPI0_MOSI, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00345 /** SPI SPCK pin definition. */
00346 #define PIN_SPI_SPCK {PIO_PD22B_SPI0_SPCK, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00347 /** SPI chip select pin definition. */
00348 #define PIN_SPI_NPCS0 {PIO_PB2D_SPI0_NPCS0, PIOB, ID_PIOB, PIO_PERIPH_D, PIO_DEFAULT}
00349 #define PIN_SPI_NPCS1 {PIO_PD25B_SPI0_NPCS1, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00350 #define PIN_SPI_NPCS3 {PIO_PD27B_SPI0_NPCS3, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00351 
00352 /** List of SPI pin definitions (MISO, MOSI & SPCK). */
00353 #define PINS_SPI  PIN_SPI_MISO, PIN_SPI_MOSI, PIN_SPI_SPCK
00354 
00355 /** PCK0 */
00356 #define PIN_PCK0  {PIO_PB13B_PCK0, PIOB, ID_PIOB, PIO_PERIPH_B, PIO_DEFAULT}
00357 /** PCK1 */
00358 #define PIN_PCK1  {PIO_PA17B_PCK1, PIOB, ID_PIOB, PIO_PERIPH_B, PIO_DEFAULT}
00359 /** PCK2 */
00360 #define PIN_PCK2   {PIO_PA18B_PCK2, PIOA, ID_PIOA, PIO_PERIPH_B, PIO_DEFAULT}
00361 
00362 
00363 /** PIO PARALLEL CAPTURE */
00364 /** Parallel Capture Mode Data Enable1 */
00365 #define PIN_PIODCEN1 PIO_PA15
00366 /** Parallel Capture Mode Data Enable2 */
00367 #define PIN_PIODCEN2 PIO_PA16
00368 
00369 /** TWI version 3.xx */
00370 #define TWI_V3XX
00371 /** TWI0 data pin */
00372 #define PIN_TWI_TWD0 {PIO_PA3A_TWD0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
00373 /** TWI0 clock pin */
00374 #define PIN_TWI_TWCK0 {PIO_PA4A_TWCK0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
00375 /** TWI0 pins */
00376 #define PINS_TWI0  {PIN_TWI_TWD0, PIN_TWI_TWCK0}
00377 
00378 /** TWI1 data pin */
00379 #define PIN_TWI_TWD1 {PIO_PB4A_TWD1, PIOB, ID_PIOB, PIO_PERIPH_A, PIO_DEFAULT}
00380 /** TWI1 clock pin */
00381 #define PIN_TWI_TWCK1 {PIO_PB5A_TWCK1, PIOB, ID_PIOB, PIO_PERIPH_A,PIO_DEFAULT}
00382 /** TWI1 pins */
00383 #define PINS_TWI1  {PIN_TWI_TWD1, PIN_TWI_TWCK1}
00384 
00385 /** USART0 pin RX */
00386 #define PIN_USART0_RXD {PIO_PB0C_RXD0, PIOB, ID_PIOB, PIO_PERIPH_C, PIO_DEFAULT}
00387 /** USART0 pin TX */
00388 #define PIN_USART0_TXD {PIO_PB1C_TXD0, PIOB, ID_PIOB, PIO_PERIPH_C, PIO_DEFAULT}
00389 /** USART0 pin CTS */
00390 #define PIN_USART0_CTS {PIO_PB2C_CTS0, PIOB, ID_PIOB, PIO_PERIPH_C, PIO_DEFAULT}
00391 /** USART0 pin RTS */
00392 #define PIN_USART0_RTS {PIO_PB3C_RTS0, PIOB, ID_PIOB, PIO_PERIPH_C, PIO_DEFAULT}
00393 /** USART0 pin SCK */
00394 #define PIN_USART0_SCK {PIO_PB13C_SCK0, PIOB, ID_PIOB, PIO_PERIPH_C,PIO_DEFAULT}
00395 
00396 /** USART1 pin RX */
00397 #define PIN_USART1_RXD {PIO_PA21A_RXD1, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
00398 /** USART1 pin TX */
00399 #define PIN_USART1_TXD {PIO_PB4D_TXD1, PIOB, ID_PIOB, PIO_PERIPH_D, PIO_DEFAULT}
00400 /** USART1 pin CTS */
00401 #define PIN_USART1_CTS {PIO_PA25A_CTS1, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
00402 /** USART1 pin RTS */
00403 #define PIN_USART1_RTS {PIO_PA24A_RTS1, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
00404 /** USART1 pin ENABLE */
00405 #define PIN_USART1_EN {PIO_PA23A_SCK1, PIOA, ID_PIOA, PIO_OUTPUT_0, PIO_DEFAULT}
00406 /** USART1 pin SCK */
00407 #define PIN_USART1_SCK {PIO_PA23A_SCK1, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
00408 
00409 /** USART2 pin RX */
00410 #define PIN_USART2_RXD {PIO_PD15B_RXD2, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00411 /** USART2 pin TX */
00412 #define PIN_USART2_TXD {PIO_PD16B_TXD2, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00413 /** USART2 pin CTS */
00414 #define PIN_USART2_CTS {PIO_PD19B_CTS2, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00415 /** USART2 pin RTS */
00416 #define PIN_USART2_RTS {PIO_PD18B_RTS2, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00417 /** USART2 pin SCK */
00418 #define PIN_USART2_SCK {PIO_PD17B_SCK2, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00419 
00420 /*Pins for USART0 as 7816 mode*/
00421 /** PIN used for reset the smartcard */
00422 #define PIN_ISO7816_RSTMC  {PIO_PB2C_CTS0, PIOB, ID_PIOB, PIO_OUTPUT_0, PIO_DEFAULT}
00423 /** Pins used for connect the smartcard */
00424 #define PINS_ISO7816        PIN_USART0_TXD, PIN_USART0_SCK,PIN_ISO7816_RSTMC
00425 
00426 /** MCAN0 pin Transmit Data (TXD) */
00427 #define PIN_MCAN0_TXD {PIO_PB2A_CANTX0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
00428 /** MCAN0 pin Receive Data (RXD) */
00429 #define PIN_MCAN0_RXD {PIO_PB3A_CANRX0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
00430 
00431 /** MCAN1 pin Transmit Data (TXD) */
00432 #define PIN_MCAN1_TXD {PIO_PC14C_CANTX1, PIOC, ID_PIOC, PIO_PERIPH_C, PIO_DEFAULT}
00433 /** MCAN1 pin Receive Data (RXD) */
00434 #define PIN_MCAN1_RXD {PIO_PC12C_CANRX1, PIOC, ID_PIOC, PIO_PERIPH_C, PIO_DEFAULT}
00435 
00436 /*----------------------------------------------------------------------------*/
00437 /**
00438  * \page samv7_Xplained_ultra_gmac "SAM V71 Xplained Ultra - GMAC"
00439  * \section GMAC
00440  * - \ref BOARD_GMAC_PHY_ADDR
00441  * - \ref BOARD_GMAC_PHY_COMP_KSZ8061RNB
00442  * - \ref BOARD_GMAC_MODE_RMII
00443  * - \ref BOARD_GMAC_PINS
00444  * - \ref BOARD_GMAC_RESET_PIN
00445  *
00446  */
00447 /** PHY address */
00448 #define BOARD_GMAC_PHY_ADDR             1
00449 /** PHY Component */
00450 #define BOARD_GMAC_PHY_COMP_KSZ8061RNB  1
00451 /** Board GMAC power control - ALWAYS ON */
00452 #define BOARD_GMAC_POWER_ALWAYS_ON
00453 /** Board GMAC work mode - RMII/MII (1 / 0) */
00454 #define BOARD_GMAC_MODE_RMII            1
00455 
00456 /** The PIN list of PIO for GMAC */
00457 #define BOARD_GMAC_PINS \
00458     { (PIO_PD0A_GTXCK | PIO_PD1A_GTXEN | PIO_PD2A_GTX0 | PIO_PD3A_GTX1 \
00459         | PIO_PD4A_GRXDV | PIO_PD5A_GRX0 | PIO_PD6A_GRX1 | PIO_PD7A_GRXER \
00460         | PIO_PD8A_GMDC | PIO_PD9A_GMDIO),PIOD, ID_PIOD, PIO_PERIPH_A, PIO_DEFAULT}, \
00461     {PIO_PC30, PIOC, ID_PIOC, PIO_INPUT,    PIO_PULLUP},\
00462     {PIO_PA29, PIOA, ID_PIOA, PIO_INPUT,    PIO_DEFAULT}
00463 
00464 /** The PIN list of PIO for GMAC */
00465 #define BOARD_GMAC_RESET_PIN {PIO_PC10, PIOC, ID_PIOC, PIO_OUTPUT_1, PIO_PULLUP}
00466 
00467 /** The runtime pin configure list for GMAC */
00468 #define BOARD_GMAC_RUN_PINS  BOARD_GMAC_PINS
00469 
00470 
00471 /*----------------------------------------------------------------------------*/
00472 /**
00473  * \page samv7_Xplained_ultra_isi "SAM V71 Xplained Ultra - ISI"
00474  * This page lists all the IO definitions connected to ISI module.
00475  * ISI
00476  * - \ref PIN_ISI_D0
00477  * - \ref PIN_ISI_D1
00478  * - \ref PIN_ISI_D2
00479  * - \ref PIN_ISI_D3
00480  * - \ref PIN_ISI_D4
00481  * - \ref PIN_ISI_D5
00482  * - \ref PIN_ISI_D6
00483  * - \ref PIN_ISI_D7
00484  * - \ref PIN_ISI_D8
00485  * - \ref PIN_ISI_D9
00486  * - \ref BOARD_ISI_VSYNC
00487  * - \ref BOARD_ISI_HSYNC
00488  * - \ref BOARD_ISI_PCK
00489  * - \ref BOARD_ISI_PINS
00490  *
00491  */
00492 #define PIN_ISI_D0  {PIO_PD22D_ISI_D0,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}
00493 #define PIN_ISI_D1  {PIO_PD21D_ISI_D1,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}
00494 #define PIN_ISI_D2  {PIO_PB3D_ISI_D2,   PIOB, ID_PIOB, PIO_PERIPH_D, PIO_PULLUP}
00495 #define PIN_ISI_D3  {PIO_PA9B_ISI_D3,   PIOA, ID_PIOA, PIO_PERIPH_B, PIO_PULLUP}
00496 #define PIN_ISI_D4  {PIO_PA5B_ISI_D4,   PIOA, ID_PIOA, PIO_PERIPH_B, PIO_PULLUP}
00497 #define PIN_ISI_D5  {PIO_PD11D_ISI_D5,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}
00498 #define PIN_ISI_D6  {PIO_PD12D_ISI_D6,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}
00499 #define PIN_ISI_D7  {PIO_PA27D_ISI_D7,  PIOA, ID_PIOA, PIO_PERIPH_D, PIO_PULLUP}
00500 #define PIN_ISI_D8  {PIO_PD27D_ISI_D8,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}
00501 #define PIN_ISI_D9  {PIO_PD28D_ISI_D9,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}
00502 
00503 #define BOARD_ISI_VSYNC {PIO_PD25D_ISI_VSYNC, PIOD, ID_PIOD, PIO_PERIPH_D, PIO_DEFAULT}
00504 #define BOARD_ISI_HSYNC {PIO_PD24D_ISI_HSYNC, PIOD, ID_PIOD, PIO_PERIPH_D, PIO_DEFAULT}
00505 #define BOARD_ISI_PCK   {PIO_PA24D_ISI_PCK, PIOA, ID_PIOA, PIO_PERIPH_D, PIO_DEFAULT}
00506 
00507 #define BOARD_ISI_PCK0  { PIO_PA6B_PCK0,  PIOA, ID_PIOA, PIO_PERIPH_B, PIO_DEFAULT }
00508 #define BOARD_ISI_RST   { 1 << 13, PIOB, ID_PIOB, PIO_OUTPUT_1, PIO_DEFAULT }
00509 #define BOARD_ISI_PWD   { 1 << 19,  PIOC, ID_PIOC, PIO_OUTPUT_1, PIO_DEFAULT }
00510 
00511 #define BOARD_ISI_PINS \
00512     PIN_ISI_D0, PIN_ISI_D1, PIN_ISI_D2,PIN_ISI_D3,PIN_ISI_D4, PIN_ISI_D5,\
00513     PIN_ISI_D6,PIN_ISI_D7,PIN_ISI_D8, PIN_ISI_D9,BOARD_ISI_VSYNC ,\
00514     BOARD_ISI_HSYNC ,BOARD_ISI_PCK, BOARD_ISI_RST, BOARD_ISI_PWD,BOARD_ISI_PCK0
00515 
00516 /*----------------------------------------------------------------------------*/
00517 /**
00518  * \page samv7_Xplained_ultra_usb "SAM V71 Xplained Ultra - USB device"
00519  *
00520  * \section Definitions
00521  * - \ref BOARD_USB_BMATTRIBUTES
00522  *
00523  * \section vBus
00524  * - \ref PIN_USB_VBUS
00525  *
00526  */
00527 
00528 /**
00529  * USB attributes configuration descriptor (bus or self powered,
00530  * remote wakeup)
00531  */
00532 #define BOARD_USB_BMATTRIBUTES USBConfigurationDescriptor_SELFPOWERED_NORWAKEUP
00533 
00534 /** USB VBus monitoring pin definition. */
00535 #define PIN_USB_VBUS {PIO_PC16, PIOC, ID_PIOC, PIO_INPUT, PIO_DEFAULT}
00536 
00537 
00538 /*----------------------------------------------------------------------------*/
00539 /**
00540  * \page samv7_Xplained_ultra_extcomp "SAM V71 Xplained Ultra - External components"
00541  * This page lists the definitions related to external on-board components
00542  * located in the board.h file for the SAM V71 Xplained Ultra board.
00543  *
00544  * LCD
00545  */
00546 /** Indicates board has an ILI9325 external component to manage LCD. */
00547 #define BOARD_LCD_ILI9488
00548 //#define BOARD_LCD_SPI_EXT1
00549 #define BOARD_LCD_SPI_EXT2
00550 
00551 /** SPI pin definition for LCD */
00552 #if defined (BOARD_LCD_SPI_EXT1)
00553 /** SPI MISO pin definition. */
00554 #define LCD_SPI_MISO {PIO_PD20B_SPI0_MISO, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00555 /** SPI MOSI pin definition. */
00556 #define LCD_SPI_MOSI {PIO_PD21B_SPI0_MOSI, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00557 /** SPI SPCK pin definition. */
00558 #define LCD_SPI_SPCK {PIO_PD22B_SPI0_SPCK, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00559 /** SPI chip select pin definition. */
00560 #define LCD_SPI_NPCS {PIO_PD27B_SPI0_NPCS3, PIOD, ID_PIOD, PIO_PERIPH_B,PIO_DEFAULT}
00561 
00562 /** SPI chip select pin definition. */
00563 #define LCD_SPI_NPCS    {PIO_PD25B_SPI0_NPCS1, PIOD, ID_PIOD, PIO_PERIPH_B,PIO_DEFAULT}
00564 
00565 /** LCD pins definition. */
00566 #define BOARD_SPI_LCD_PINS  {LCD_SPI_MISO, LCD_SPI_MOSI, LCD_SPI_SPCK, LCD_SPI_NPCS}
00567 
00568 /** Back-light pin definition. */
00569 
00570 #define BOARD_SPI_LCD_BACKLIGHT_PIN  \
00571     {PIO_PA0A_PWMC0_PWMH0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
00572 
00573 /** PWMC PWM0 pin definition: Output Low. */
00574 #define LCD_SPI_PIN_RESET   {PIO_PD28, PIOD, ID_PIOD, PIO_OUTPUT_1, PIO_DEFAULT}
00575 
00576 /** PWM channel for LED0 */
00577 #define CHANNEL_PWM_LCD 0
00578 
00579 #endif
00580 /*ENDIF BOARD_LCD_SPI_EXT1 */
00581 
00582 #if defined (BOARD_LCD_SPI_EXT2)
00583 /** SPI MISO pin definition. */
00584 #define LCD_SPI_MISO {PIO_PD20B_SPI0_MISO, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00585 /** SPI MOSI pin definition. */
00586 #define LCD_SPI_MOSI {PIO_PD21B_SPI0_MOSI, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00587 /** SPI SPCK pin definition. */
00588 #define LCD_SPI_SPCK {PIO_PD22B_SPI0_SPCK, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
00589 /** SPI chip select pin definition. */
00590 #define LCD_SPI_NPCS {PIO_PD27B_SPI0_NPCS3, PIOD, ID_PIOD, PIO_PERIPH_B,PIO_DEFAULT}
00591 
00592 /** LCD pins definition. */
00593 #define BOARD_SPI_LCD_PINS  {LCD_SPI_MISO, LCD_SPI_MOSI, LCD_SPI_SPCK, LCD_SPI_NPCS}
00594 
00595 /** Back-light pin definition. */
00596 
00597 #define BOARD_SPI_LCD_PIN_BACKLIGHT  \
00598     {PIO_PC19B_PWMC0_PWMH2, PIOC, ID_PIOC, PIO_OUTPUT_1, PIO_DEFAULT}
00599 
00600 /** PWMC PWM0 pin definition: Output Low. */
00601 #define LCD_SPI_PIN_RESET   {PIO_PA24, PIOA, ID_PIOA, PIO_OUTPUT_1, PIO_DEFAULT}
00602 
00603 /** LCD command/data select pin */
00604 #define BOARD_SPI_LCD_PIN_CDS   {PIO_PA6, PIOA, ID_PIOA, PIO_OUTPUT_1, PIO_DEFAULT}
00605 
00606 /** PWM channel for LED0 */
00607 #define CHANNEL_PWM_LCD 2
00608 
00609 #endif
00610 /*ENDIF BOARD_LCD_SPI_EXT2 */
00611 
00612 /** SMC pin definition for LCD */
00613 /** LCD data pin */
00614 #define PIN_EBI_LCD_DATAL           {0xFF, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}
00615 #define PIN_EBI_LCD_DATAH_0         {0x3F, PIOE, ID_PIOE, PIO_PERIPH_A, PIO_PULLUP}
00616 #define PIN_EBI_LCD_DATAH_1         {PIO_PA15A_D14|PIO_PA16A_D15, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_PULLUP}
00617 /** LCD WE pin */
00618 #define PIN_EBI_LCD_NWE             {PIO_PC8A_NWE,  PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}
00619 /** LCD RD pin */
00620 #define PIN_EBI_LCD_NRD             {PIO_PC11A_NRD, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}
00621 /* LCD CS pin (NCS3) */
00622 #define PIN_EBI_LCD_CS              {PIO_PD19A_NCS3, PIOD, ID_PIOD, PIO_PERIPH_A, PIO_PULLUP}
00623 /** LCD command/data select pin */
00624 #define BOARD_EBI_LCD_PIN_CDS       {PIO_PC30, PIOC, ID_PIOC, PIO_OUTPUT_1, PIO_DEFAULT}
00625 /** Back-light pin definition. */
00626 #define BOARD_EBI_LCD_PIN_BACKLIGHT {PIO_PC9B_TIOB7, PIOC, ID_PIOC, PIO_PERIPH_B, PIO_DEFAULT}
00627 /** LCD reset pin */
00628 #define LCD_EBI_PIN_RESET           {PIO_PC13, PIOC, ID_PIOC, PIO_OUTPUT_1, PIO_DEFAULT}
00629 
00630 /** LCD pins definition. */
00631 #define BOARD_EBI_LCD_PINS          \
00632     {PIN_EBI_LCD_DATAL, PIN_EBI_LCD_DATAH_0, PIN_EBI_LCD_DATAH_1, \
00633         PIN_EBI_LCD_NWE,PIN_EBI_LCD_NRD,PIN_EBI_LCD_CS}
00634 
00635 
00636 /** Display width in pixels. */
00637 #define BOARD_LCD_WIDTH             320
00638 /** Display height in pixels. */
00639 #define BOARD_LCD_HEIGHT            480
00640 
00641 
00642 /*----------------------------------------------------------------------------*/
00643 /**
00644  * \page samv7_Xplained_ultra_mem "SAM V71 Xplained Ultra - Memories"
00645  * This page lists definitions related to internal & external on-board memories.
00646  * \section SDRAM
00647  * - \ref PIN_SDRAM_D0_7
00648  * - \ref PIN_SDRAM_D8_13
00649  * - \ref PIN_SDRAM_D14_15
00650  * - \ref PIN_SDRAM_A0_9
00651  * - \ref PIN_SDRAM_SDA10
00652  * - \ref PIN_SDRAM_CAS
00653  * - \ref PIN_SDRAM_RAS
00654  * - \ref PIN_SDRAM_SDCKE
00655  * - \ref PIN_SDRAM_SDCK
00656  * - \ref PIN_SDRAM_SDSC
00657  * - \ref PIN_SDRAM_NBS0
00658  * - \ref PIN_SDRAM_NBS1
00659  * - \ref PIN_SDRAM_SDWE
00660  * - \ref PIN_SDRAM_BA0
00661  *
00662  * \section SDMMC
00663  * - \ref BOARD_MCI_PIN_CD
00664  * - \ref BOARD_MCI_PIN_CK
00665  * - \ref BOARD_MCI_PINS_SLOTA
00666  * - \ref BOARD_SD_PINS
00667  *
00668  * \section QSPI
00669  * - \ref PINS_QSPI_IO
00670  * - \ref PINS_QSPI_IO3
00671  * - \ref PINS_QSPI
00672  */
00673 
00674 /** List of all SDRAM pin definitions. */
00675 #define BOARD_SDRAM_SIZE  (2*1024*1024)
00676 #define PIN_SDRAM_D0_7    {0x000000FF, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_DEFAULT}
00677 #define PIN_SDRAM_D8_13   {0x0000003F, PIOE, ID_PIOE, PIO_PERIPH_A, PIO_DEFAULT}
00678 #define PIN_SDRAM_D14_15  {0x00018000, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
00679 #define PIN_SDRAM_A0_9    {0x3FF00000, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_DEFAULT}
00680 #define PIN_SDRAM_SDA10   {0x00002000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}
00681 
00682 #define PIN_SDRAM_CAS     {0x00020000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}
00683 #define PIN_SDRAM_RAS     {0x00010000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}
00684 #define PIN_SDRAM_SDCKE   {0x00004000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}
00685 #define PIN_SDRAM_SDCK    {0x00800000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}
00686 #define PIN_SDRAM_SDSC    {0x00008000, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_DEFAULT}
00687 #define PIN_SDRAM_NBS0    {0x00040000, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_DEFAULT}
00688 #define PIN_SDRAM_NBS1    {0x00008000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}
00689 #define PIN_SDRAM_SDWE    {0x20000000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}
00690 #define PIN_SDRAM_BA0     {0x00100000, PIOA, ID_PIOA, PIO_PERIPH_C, PIO_DEFAULT}
00691 
00692 #define BOARD_SDRAM_PINS PIN_SDRAM_D0_7, PIN_SDRAM_D8_13 , PIN_SDRAM_D14_15,\
00693     PIN_SDRAM_A0_9, PIN_SDRAM_SDA10, PIN_SDRAM_BA0, \
00694     PIN_SDRAM_CAS, PIN_SDRAM_RAS, PIN_SDRAM_SDCKE,PIN_SDRAM_SDCK,\
00695     PIN_SDRAM_SDSC,PIN_SDRAM_NBS0 ,PIN_SDRAM_NBS1,PIN_SDRAM_SDWE
00696 
00697 
00698 /** List of all MCI pin definitions. */
00699 
00700 /** MCI0 Card detect pin definition. (PE5) */
00701 #define BOARD_MCI_PIN_CD  {PIO_PD18, PIOD, ID_PIOD, PIO_INPUT, PIO_PULLUP}
00702 /** MCI0 Clock . */
00703 #define BOARD_MCI_PIN_CK  {PIO_PA25D_MCCK, PIOA, ID_PIOA, PIO_PERIPH_D, PIO_DEFAULT}
00704 
00705 /** MCI0 Solt A IO pins definition. (PC4-PC13) */
00706 #define BOARD_MCI_PINS_SLOTA \
00707     {(PIO_PA30C_MCDA0 | PIO_PA31C_MCDA1 | PIO_PA26C_MCDA2 | PIO_PA27C_MCDA3 | PIO_PA28C_MCCDA),\
00708         PIOA, ID_PIOA, PIO_PERIPH_C, PIO_DEFAULT}
00709 
00710 /** MCI pins that shall be configured to access the SD card. */
00711 #define BOARD_SD_PINS     {BOARD_MCI_PINS_SLOTA, BOARD_MCI_PIN_CK}
00712 /** MCI Card Detect pin. */
00713 #define BOARD_SD_PIN_CD   BOARD_MCI_PIN_CD
00714 /** Total number of MCI interface */
00715 #define BOARD_NUM_MCI     1
00716 
00717 /** List of all SQPI pin definitions. */
00718 #define PINS_QSPI_IO   \
00719     {(PIO_PA11A_QCS | PIO_PA13A_QIO0 | PIO_PA12A_QIO1 | PIO_PA17A_QIO2 | PIO_PA14A_QSCK),\
00720         PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
00721 #define PINS_QSPI_IO3   {PIO_PD31A_QIO3, PIOD, ID_PIOD, PIO_PERIPH_A, PIO_DEFAULT}
00722 #define PINS_QSPI      {PINS_QSPI_IO, PINS_QSPI_IO3}
00723 
00724 /*----------------------------------------------------------------------------*/
00725 /**
00726  * \page samv7_Xplained_ultra_chipdef "SAM V71 Xplained Ultra - Individual chip definition"
00727  * This page lists the definitions related to different chip's definition
00728  *
00729  * \section USART
00730  * - \ref BOARD_PIN_USART_RXD
00731  * - \ref BOARD_PIN_USART_TXD
00732  * - \ref BOARD_PIN_USART_CTS
00733  * - \ref BOARD_PIN_USART_RTS
00734  * - \ref BOARD_PIN_USART_EN
00735  * - \ref BOARD_USART_BASE
00736  * - \ref BOARD_ID_USART
00737  */
00738 
00739 /** Rtc */
00740 #define BOARD_RTC_ID   ID_RTC
00741 
00742 /** TWI ID for QTouch application to use */
00743 #define BOARD_ID_TWI_AT42    ID_TWI0
00744 /** TWI Base for QTouch application to use */
00745 #define BOARD_BASE_TWI_AT42  TWI0
00746 /** TWI pins for QTouch application to use */
00747 #define BOARD_PINS_TWI_AT42  PINS_TWI0
00748 
00749 /** USART RX pin for application */
00750 #define BOARD_PIN_USART_RXD  PIN_USART1_RXD
00751 /** USART TX pin for application */
00752 #define BOARD_PIN_USART_TXD  PIN_USART1_TXD
00753 /** USART CTS pin for application */
00754 #define BOARD_PIN_USART_CTS  PIN_USART1_CTS
00755 /** USART RTS pin for application */
00756 #define BOARD_PIN_USART_RTS  PIN_USART1_RTS
00757 /** USART ENABLE pin for application */
00758 #define BOARD_PIN_USART_EN  PIN_USART1_EN
00759 /** USART Base for application */
00760 #define BOARD_USART_BASE  USART1
00761 /** USART ID for application */
00762 #define BOARD_ID_USART   ID_USART1
00763 
00764 
00765 
00766 /*----------------------------------------------------------------------------*/
00767 /*
00768 * USB pins
00769 */
00770 #define PINS_VBUS_EN   {PIO_PC16, PIOC, ID_PIOC, PIO_OUTPUT_1, PIO_DEFAULT}
00771 #endif /* #ifndef _BOARD_V71_XULT_H_ */
00772 
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Defines