Back to home page

LXR

 
 

    


File indexing completed on 2025-05-11 08:22:44

0001 /* ---------------------------------------------------------------------------- */
0002 /*                  Atmel Microcontroller Software Support                      */
0003 /*                       SAM Software Package License                           */
0004 /* ---------------------------------------------------------------------------- */
0005 /* Copyright (c) 2015, Atmel Corporation                                        */
0006 /*                                                                              */
0007 /* All rights reserved.                                                         */
0008 /*                                                                              */
0009 /* Redistribution and use in source and binary forms, with or without           */
0010 /* modification, are permitted provided that the following condition is met:    */
0011 /*                                                                              */
0012 /* - Redistributions of source code must retain the above copyright notice,     */
0013 /* this list of conditions and the disclaimer below.                            */
0014 /*                                                                              */
0015 /* Atmel's name may not be used to endorse or promote products derived from     */
0016 /* this software without specific prior written permission.                     */
0017 /*                                                                              */
0018 /* DISCLAIMER:  THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR   */
0019 /* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF */
0020 /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE   */
0021 /* DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,      */
0022 /* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT */
0023 /* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,  */
0024 /* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF    */
0025 /* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING         */
0026 /* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, */
0027 /* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.                           */
0028 /* ---------------------------------------------------------------------------- */
0029 
0030 /**
0031  * \page samv7_Xplained_ultra_board_desc SAM V71 Xplained Ultra - Board
0032  * Description
0033  *
0034  * @ingroup RTEMSBSPsARM
0035  *
0036  * \section Purpose
0037  *
0038  * This file is dedicated to describe the SAM V71 Xplained Ultra board.
0039  *
0040  * \section Contents
0041  *
0042  *  - For SAM V71 Xplained Ultra board information, see
0043  *    \subpage samv7_Xplained_ultra_board_info.
0044  *  - For operating frequency information, see \subpage samv7_Xplained_ultra_opfreq.
0045  *  - For using portable PIO definitions, see \subpage samv7_Xplained_ultra_piodef.
0046  *  - For using GMAC PIO definitions, see \subpage samv7_Xplained_ultra_gmac.
0047  *  - For using ISI definitions, see \subpage samv7_Xplained_ultra_isi.
0048  *  - For on-board memories, see \subpage samv7_Xplained_ultra_mem.
0049  *  - Several USB definitions are included here,
0050  *    see \subpage samv7_Xplained_ultra_usb.
0051  *  - For External components, see \subpage samv7_Xplained_ultra_extcomp.
0052  *  - For Individual chip definition, see \subpage samv7_Xplained_ultra_chipdef.
0053  *
0054  * To get more software details and the full list of parameters related to the
0055  * SAM V71 Xplained Ultra board configuration, please have a look at the source
0056  * file:
0057  * \ref board.h, \ref board_v71_xult.h\n
0058  *
0059  * \section Usage
0060  *
0061  *  - The code for booting the board is provided by startup_samv71.c and
0062  *    board_lowlevel.c.
0063  *  - For using board PIOs, board characteristics (clock, etc.) and external
0064  *    components, see board.h, board_v71_xult.h.
0065  *  - For manipulating memories, see board_memories.h.
0066  *
0067  * This file can be used as a template and modified to fit a custom board, with
0068  * specific PIOs usage or memory connections.
0069  */
0070 
0071 /**
0072  *  \file board.h
0073  *
0074  *  Definition of SAM V71 Xplained Ultra board characteristics, PIOs and
0075  *  external components interface.
0076  */
0077 
0078 #ifndef _BOARD_V71_XULT_H_
0079 #define _BOARD_V71_XULT_H_
0080 
0081 /*----------------------------------------------------------------------------
0082  *        Headers
0083  *----------------------------------------------------------------------------*/
0084 
0085 #include "chip.h"
0086 
0087 #include "include/board_lowlevel.h"
0088 #include "include/board_memories.h"
0089 #include "include/led.h"
0090 #include "include/gmii.h"
0091 #include "include/gmacb_phy.h"
0092 #include "include/dbg_console.h"
0093 #include "include/bmp.h"
0094 #include "include/lcdd.h"
0095 #include "include/ili9488.h"
0096 #include "include/ili9488_reg.h"
0097 #include "include/ili9488_spi.h"
0098 #include "include/ili9488_ebi.h"
0099 #include "include/ili9488_dma.h"
0100 #include "include/ili9488_spi_dma.h"
0101 #include "include/ili9488_ebi_dma.h"
0102 #include "include/frame_buffer.h"
0103 #include "include/lcd_color.h"
0104 #include "include/lcd_draw.h"
0105 #include "include/lcd_font10x14.h"
0106 #include "include/lcd_font.h"
0107 #include "include/lcd_gimp_image.h"
0108 #include "include/rtc_calib.h"
0109 #include "include/wm8904.h"
0110 #include "include/cs2100.h"
0111 #include "include/s25fl1.h"
0112 #include "include/image_sensor_inf.h"
0113 #include "include/iso7816_4.h"
0114 
0115 #ifndef __rtems__
0116 #if defined (__GNUC__)
0117     #include "include/syscalls.h"
0118 #endif
0119 #endif /* __rtems__ */
0120 /*----------------------------------------------------------------------------
0121  *        Definitions
0122  *----------------------------------------------------------------------------*/
0123 
0124 /*----------------------------------------------------------------------------*/
0125 /**
0126  * \page samv7_Xplained_ultra_board_info "SAM V71 Xplained Ultra - Board informations"
0127  * This page lists several definition related to the board description.
0128  *
0129  * \section Definitions
0130  * - \ref BOARD_NAME
0131  */
0132 
0133 /** Name of the board */
0134 #define BOARD_NAME "SAM V71 Xplained Ultra"
0135 #define NO_PUSHBUTTON
0136 #ifndef __rtems__
0137 /*----------------------------------------------------------------------------*/
0138 /**
0139  *  \page samv7_Xplained_ultra_opfreq "SAM V71 Xplained Ultra - Operating frequencies"
0140  *  This page lists several definition related to the board operating frequency
0141  *  (when using the initialization done by board_lowlevel.c).
0142  *
0143  *  \section Definitions
0144  *  - \ref BOARD_MAINOSC
0145  *  - \ref BOARD_MCK
0146  */
0147 
0148 /** Frequency of the board main oscillator */
0149 #define BOARD_MAINOSC    12000000
0150 
0151 /** Master clock frequency (when using board_lowlevel.c) */
0152 
0153 #ifdef MCK_123MHZ
0154     #define BOARD_MCK    123000000
0155 #else
0156     #define BOARD_MCK    150000000
0157 #endif
0158 
0159 #if (BOARD_MCK==123000000)
0160 
0161     #define PLL_MUL    0x16
0162     #define PLL_DIV    0x01
0163 
0164 #else   // 300MHz(PCK) and 150MHz(MCK) by default
0165 
0166     #define PLL_MUL    0x19
0167     #define PLL_DIV    0x01
0168 
0169 #endif
0170 #else /* __rtems__ */
0171 #include <bsp/atsam-clock-config.h>
0172 #endif /* __rtems__ */
0173 
0174 /*----------------------------------------------------------------------------*/
0175 /**
0176  * \page samv7_Xplained_ultra_piodef "SAM V71 Xplained Ultra - PIO definitions"
0177  * This pages lists all the PIOs definitions contained in board.h. The constants
0178  * are named using the following convention: PIN_* for a constant which defines
0179  * a single Pin instance (but may include several PIOs sharing the same
0180  * controller), and PINS_* for a list of Pin instances.
0181  *
0182  * UART0
0183  * - \ref PINS_UART0
0184  *
0185  * UART4
0186  * - \ref PINS_UART4
0187  *
0188  * LEDs
0189  * - \ref PIN_LED_0
0190  * - \ref PIN_LED_1
0191  * - \ref PINS_LEDS
0192  *
0193  * Push buttons
0194  * - \ref PIN_PUSHBUTTON_0
0195  * - \ref PIN_PUSHBUTTON_1
0196  * - \ref PINS_PUSHBUTTONS
0197  * - \ref PUSHBUTTON_BP0
0198  * - \ref PUSHBUTTON_BP1
0199  *
0200  * PWMC
0201  * - \ref PIN_PWMC_PWMH0
0202  * - \ref PIN_PWMC_PWMH1
0203  * - \ref PIN_PWM_LED0
0204  * - \ref PIN_PWM_LED1
0205  * - \ref CHANNEL_PWM_LED0
0206  * - \ref CHANNEL_PWM_LED1
0207  *
0208  * SPI
0209  * - \ref PIN_SPI_MISO
0210  * - \ref PIN_SPI_MOSI
0211  * - \ref PIN_SPI_SPCK
0212  * - \ref PINS_SPI
0213  *
0214  * PCK0
0215  * - \ref PIN_PCK0
0216  * - \ref PIN_PCK1
0217  * - \ref PIN_PCK2
0218  *
0219  * PIO PARALLEL CAPTURE
0220  * - \ref PIN_PIODCEN1
0221  * - \ref PIN_PIODCEN2
0222  *
0223  * TWI
0224  * - \ref TWI_V3XX
0225  * - \ref PIN_TWI_TWD0
0226  * - \ref PIN_TWI_TWCK0
0227  * - \ref PINS_TWI0
0228  * - \ref PIN_TWI_TWD1
0229  * - \ref PIN_TWI_TWCK1
0230  * - \ref PINS_TWI1
0231  *
0232  * USART0
0233  * - \ref PIN_USART0_RXD
0234  * - \ref PIN_USART0_TXD
0235  * - \ref PIN_USART0_CTS
0236  * - \ref PIN_USART0_RTS
0237  * - \ref PIN_USART0_SCK
0238  *
0239  * USART1
0240  * - \ref PIN_USART1_RXD
0241  * - \ref PIN_USART1_TXD
0242  * - \ref PIN_USART1_CTS
0243  * - \ref PIN_USART1_RTS
0244  * - \ref PIN_USART1_SCK
0245  *
0246  * USART2
0247  * - \ref PIN_USART2_RXD
0248  * - \ref PIN_USART2_TXD
0249  * - \ref PIN_USART2_CTS
0250  * - \ref PIN_USART2_RTS
0251  * - \ref PIN_USART2_SCK
0252  *
0253  * SSC
0254  * - \ref PIN_SSC_TD
0255  * - \ref PIN_SSC_TK
0256  * - \ref PIN_SSC_TF
0257  * - \ref PIN_SSC_RD
0258  * - \ref PIN_SSC_RK
0259  * - \ref PIN_SSC_RF
0260  * - \ref PIN_SSC_TD
0261  * - \ref PINS_SSC_CODEC
0262  *
0263  * MCAN
0264  * - \ref PIN_MCAN0_TXD
0265  * - \ref PIN_MCAN0_RXD
0266  * - \ref PIN_MCAN1_TXD
0267  * - \ref PIN_MCAN1_RXD
0268  */
0269 
0270 /** SSC pin Transmitter Data (TD) */
0271 #define PIN_SSC_TD  {PIO_PD26B_TD, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0272 /** SSC pin Transmitter Clock (TK) */
0273 #define PIN_SSC_TK  {PIO_PB1D_TK, PIOB, ID_PIOB, PIO_PERIPH_D, PIO_DEFAULT}
0274 /** SSC pin Transmitter FrameSync (TF) */
0275 #define PIN_SSC_TF  {PIO_PB0D_TF, PIOB, ID_PIOB, PIO_PERIPH_D, PIO_DEFAULT}
0276 /** SSC pin RD */
0277 #define PIN_SSC_RD  {PIO_PA10C_RD, PIOA, ID_PIOA, PIO_PERIPH_C, PIO_DEFAULT}
0278 /** SSC pin RK */
0279 #define PIN_SSC_RK  {PIO_PA22A_RK, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
0280 /** SSC pin RF */
0281 #define PIN_SSC_RF  {PIO_PD24B_RF, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0282 
0283 /** SSC pins definition for codec. */
0284 #define PINS_SSC_CODEC \
0285     {PIN_SSC_TD,  PIN_SSC_TK, PIN_SSC_TF, PIN_SSC_RD,  PIN_SSC_RK, PIN_SSC_RF}
0286 
0287 /** UART pins (UTXD0 and URXD0) definitions, PA9,10. */
0288 #define PINS_UART0  \
0289     {PIO_PA9A_URXD0 | PIO_PA10A_UTXD0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
0290 /** UART pins (UTXD4 and URXD4) definitions, PD19,18. */
0291 #define PINS_UART4 \
0292     {PIO_PD18C_URXD4 | PIO_PD19C_UTXD4, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}
0293 
0294 /* LED pins definitions */
0295 #define LED_YELLOW0  0
0296 #define LED_YELLOW1  1
0297 
0298 /** LED #0 pin definition (YELLOW). */
0299 #define PIN_LED_0  {PIO_PC9, PIOC, ID_PIOC, PIO_OUTPUT_1, PIO_DEFAULT}
0300 /** LED #1 pin definition (YELLOW). */
0301 #define PIN_LED_1  {PIO_PA23, PIOA, ID_PIOA, PIO_OUTPUT_1, PIO_DEFAULT}
0302 
0303 /** List of all LEDs definitions. */
0304 #define PINS_LEDS  {PIN_LED_0, PIN_LED_1}
0305 
0306 /** Number of LEDs */
0307 #define LED_NUM  2
0308 
0309 /**
0310  * Push button #0 definition.
0311  * Attributes = pull-up + debounce + interrupt on rising edge.
0312  */
0313 #define PIN_PUSHBUTTON_0 \
0314     {PIO_PA9, PIOA, ID_PIOA, PIO_INPUT, PIO_PULLUP | PIO_DEBOUNCE | PIO_IT_FALL_EDGE}
0315 /**
0316  * Push button #1 definition.
0317  * Attributes = pull-up + debounce + interrupt on rising edge.
0318  */
0319 #define PIN_PUSHBUTTON_1 \
0320     {PIO_PB12, PIOB, ID_PIOB, PIO_INPUT, PIO_PULLUP | PIO_DEBOUNCE | PIO_IT_FALL_EDGE}
0321 
0322 /** List of all push button definitions. */
0323 #define PINS_PUSHBUTTONS {PIN_PUSHBUTTON_0, PIN_PUSHBUTTON_1}
0324 
0325 /** Push button #0 index. */
0326 #define PUSHBUTTON_BP0  0
0327 /** Push button #1 index. */
0328 #define PUSHBUTTON_BP1  1
0329 
0330 /** Number of Buttons */
0331 #define BUTTON_NUM  2
0332 
0333 /** Index of wakeup source */
0334 #define WKUP_IDX    6
0335 
0336 /** PWMC PWM0 pin definition: Output High. */
0337 #define PIN_PWMC_PWMH0  {PIO_PD20A_PWMH0, PIOD, ID_PIOD, PIO_PERIPH_A, PIO_DEFAULT}
0338 /** PWMC PWM1 pin definition: Output High. */
0339 #define PIN_PWMC_PWMH1  {PIO_PD21A_PWMH1, PIOD, ID_PIOD, PIO_PERIPH_A, PIO_DEFAULT}
0340 /** PWM pins definition for LED0 */
0341 #define PIN_PWM_LED0  PIN_PWMC_PWMH0
0342 /** PWM pins definition for LED1 */
0343 #define PIN_PWM_LED1  PIN_PWMC_PWMH1
0344 /** PWM channel for LED0 */
0345 #define CHANNEL_PWM_LED0 0
0346 /** PWM channel for LED1 */
0347 #define CHANNEL_PWM_LED1 1
0348 
0349 /** SPI MISO pin definition. */
0350 #define PIN_SPI_MISO {PIO_PD20B_SPI0_MISO, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0351 /** SPI MOSI pin definition. */
0352 #define PIN_SPI_MOSI {PIO_PD21B_SPI0_MOSI, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0353 /** SPI SPCK pin definition. */
0354 #define PIN_SPI_SPCK {PIO_PD22B_SPI0_SPCK, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0355 /** SPI chip select pin definition. */
0356 #define PIN_SPI_NPCS0 {PIO_PB2D_SPI0_NPCS0, PIOB, ID_PIOB, PIO_PERIPH_D, PIO_DEFAULT}
0357 #define PIN_SPI_NPCS1 {PIO_PD25B_SPI0_NPCS1, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0358 #define PIN_SPI_NPCS3 {PIO_PD27B_SPI0_NPCS3, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0359 
0360 /** List of SPI pin definitions (MISO, MOSI & SPCK). */
0361 #define PINS_SPI  PIN_SPI_MISO, PIN_SPI_MOSI, PIN_SPI_SPCK
0362 
0363 /** PCK0 */
0364 #define PIN_PCK0  {PIO_PB13B_PCK0, PIOB, ID_PIOB, PIO_PERIPH_B, PIO_DEFAULT}
0365 /** PCK1 */
0366 #define PIN_PCK1  {PIO_PA17B_PCK1, PIOB, ID_PIOB, PIO_PERIPH_B, PIO_DEFAULT}
0367 /** PCK2 */
0368 #define PIN_PCK2   {PIO_PA18B_PCK2, PIOA, ID_PIOA, PIO_PERIPH_B, PIO_DEFAULT}
0369 
0370 
0371 /** PIO PARALLEL CAPTURE */
0372 /** Parallel Capture Mode Data Enable1 */
0373 #define PIN_PIODCEN1 PIO_PA15
0374 /** Parallel Capture Mode Data Enable2 */
0375 #define PIN_PIODCEN2 PIO_PA16
0376 
0377 /** TWI version 3.xx */
0378 #define TWI_V3XX
0379 /** TWI0 data pin */
0380 #define PIN_TWI_TWD0 {PIO_PA3A_TWD0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
0381 /** TWI0 clock pin */
0382 #define PIN_TWI_TWCK0 {PIO_PA4A_TWCK0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
0383 /** TWI0 pins */
0384 #define PINS_TWI0  {PIN_TWI_TWD0, PIN_TWI_TWCK0}
0385 
0386 /** TWI1 data pin */
0387 #define PIN_TWI_TWD1 {PIO_PB4A_TWD1, PIOB, ID_PIOB, PIO_PERIPH_A, PIO_DEFAULT}
0388 /** TWI1 clock pin */
0389 #define PIN_TWI_TWCK1 {PIO_PB5A_TWCK1, PIOB, ID_PIOB, PIO_PERIPH_A,PIO_DEFAULT}
0390 /** TWI1 pins */
0391 #define PINS_TWI1  {PIN_TWI_TWD1, PIN_TWI_TWCK1}
0392 
0393 /** USART0 pin RX */
0394 #define PIN_USART0_RXD {PIO_PB0C_RXD0, PIOB, ID_PIOB, PIO_PERIPH_C, PIO_DEFAULT}
0395 /** USART0 pin TX */
0396 #define PIN_USART0_TXD {PIO_PB1C_TXD0, PIOB, ID_PIOB, PIO_PERIPH_C, PIO_DEFAULT}
0397 /** USART0 pin CTS */
0398 #define PIN_USART0_CTS {PIO_PB2C_CTS0, PIOB, ID_PIOB, PIO_PERIPH_C, PIO_DEFAULT}
0399 /** USART0 pin RTS */
0400 #define PIN_USART0_RTS {PIO_PB3C_RTS0, PIOB, ID_PIOB, PIO_PERIPH_C, PIO_DEFAULT}
0401 /** USART0 pin SCK */
0402 #define PIN_USART0_SCK {PIO_PB13C_SCK0, PIOB, ID_PIOB, PIO_PERIPH_C,PIO_DEFAULT}
0403 
0404 /** USART1 pin RX */
0405 #define PIN_USART1_RXD {PIO_PA21A_RXD1, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
0406 /** USART1 pin TX */
0407 #define PIN_USART1_TXD {PIO_PB4D_TXD1, PIOB, ID_PIOB, PIO_PERIPH_D, PIO_DEFAULT}
0408 /** USART1 pin CTS */
0409 #define PIN_USART1_CTS {PIO_PA25A_CTS1, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
0410 /** USART1 pin RTS */
0411 #define PIN_USART1_RTS {PIO_PA24A_RTS1, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
0412 /** USART1 pin ENABLE */
0413 #define PIN_USART1_EN {PIO_PA23A_SCK1, PIOA, ID_PIOA, PIO_OUTPUT_0, PIO_DEFAULT}
0414 /** USART1 pin SCK */
0415 #define PIN_USART1_SCK {PIO_PA23A_SCK1, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
0416 
0417 /** USART2 pin RX */
0418 #define PIN_USART2_RXD {PIO_PD15B_RXD2, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0419 /** USART2 pin TX */
0420 #define PIN_USART2_TXD {PIO_PD16B_TXD2, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0421 /** USART2 pin CTS */
0422 #define PIN_USART2_CTS {PIO_PD19B_CTS2, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0423 /** USART2 pin RTS */
0424 #define PIN_USART2_RTS {PIO_PD18B_RTS2, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0425 /** USART2 pin SCK */
0426 #define PIN_USART2_SCK {PIO_PD17B_SCK2, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0427 
0428 /*Pins for USART0 as 7816 mode*/
0429 /** PIN used for reset the smartcard */
0430 #define PIN_ISO7816_RSTMC  {PIO_PB2C_CTS0, PIOB, ID_PIOB, PIO_OUTPUT_0, PIO_DEFAULT}
0431 /** Pins used for connect the smartcard */
0432 #define PINS_ISO7816        PIN_USART0_TXD, PIN_USART0_SCK,PIN_ISO7816_RSTMC
0433 
0434 /** MCAN0 pin Transmit Data (TXD) */
0435 #define PIN_MCAN0_TXD {PIO_PB2A_CANTX0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
0436 /** MCAN0 pin Receive Data (RXD) */
0437 #define PIN_MCAN0_RXD {PIO_PB3A_CANRX0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
0438 
0439 /** MCAN1 pin Transmit Data (TXD) */
0440 #define PIN_MCAN1_TXD {PIO_PC14C_CANTX1, PIOC, ID_PIOC, PIO_PERIPH_C, PIO_DEFAULT}
0441 /** MCAN1 pin Receive Data (RXD) */
0442 #define PIN_MCAN1_RXD {PIO_PC12C_CANRX1, PIOC, ID_PIOC, PIO_PERIPH_C, PIO_DEFAULT}
0443 
0444 /*----------------------------------------------------------------------------*/
0445 /**
0446  * \page samv7_Xplained_ultra_gmac "SAM V71 Xplained Ultra - GMAC"
0447  * \section GMAC
0448  * - \ref BOARD_GMAC_PHY_ADDR
0449  * - \ref BOARD_GMAC_PHY_COMP_KSZ8061RNB
0450  * - \ref BOARD_GMAC_MODE_RMII
0451  * - \ref BOARD_GMAC_PINS
0452  * - \ref BOARD_GMAC_RESET_PIN
0453  *
0454  */
0455 /** PHY address */
0456 #define BOARD_GMAC_PHY_ADDR             1
0457 /** PHY Component */
0458 #define BOARD_GMAC_PHY_COMP_KSZ8061RNB  1
0459 /** Board GMAC power control - ALWAYS ON */
0460 #define BOARD_GMAC_POWER_ALWAYS_ON
0461 /** Board GMAC work mode - RMII/MII (1 / 0) */
0462 #define BOARD_GMAC_MODE_RMII            1
0463 
0464 /** The PIN list of PIO for GMAC */
0465 #define BOARD_GMAC_PINS \
0466     { (PIO_PD0A_GTXCK | PIO_PD1A_GTXEN | PIO_PD2A_GTX0 | PIO_PD3A_GTX1 \
0467         | PIO_PD4A_GRXDV | PIO_PD5A_GRX0 | PIO_PD6A_GRX1 | PIO_PD7A_GRXER \
0468         | PIO_PD8A_GMDC | PIO_PD9A_GMDIO),PIOD, ID_PIOD, PIO_PERIPH_A, PIO_DEFAULT}, \
0469     {PIO_PC30, PIOC, ID_PIOC, PIO_INPUT,    PIO_PULLUP},\
0470     {PIO_PA29, PIOA, ID_PIOA, PIO_INPUT,    PIO_DEFAULT}
0471 
0472 /** The PIN list of PIO for GMAC */
0473 #define BOARD_GMAC_RESET_PIN {PIO_PC10, PIOC, ID_PIOC, PIO_OUTPUT_1, PIO_PULLUP}
0474 
0475 /** The runtime pin configure list for GMAC */
0476 #define BOARD_GMAC_RUN_PINS  BOARD_GMAC_PINS
0477 
0478 
0479 /*----------------------------------------------------------------------------*/
0480 /**
0481  * \page samv7_Xplained_ultra_isi "SAM V71 Xplained Ultra - ISI"
0482  * This page lists all the IO definitions connected to ISI module.
0483  * ISI
0484  * - \ref PIN_ISI_D0
0485  * - \ref PIN_ISI_D1
0486  * - \ref PIN_ISI_D2
0487  * - \ref PIN_ISI_D3
0488  * - \ref PIN_ISI_D4
0489  * - \ref PIN_ISI_D5
0490  * - \ref PIN_ISI_D6
0491  * - \ref PIN_ISI_D7
0492  * - \ref PIN_ISI_D8
0493  * - \ref PIN_ISI_D9
0494  * - \ref BOARD_ISI_VSYNC
0495  * - \ref BOARD_ISI_HSYNC
0496  * - \ref BOARD_ISI_PCK
0497  * - \ref BOARD_ISI_PINS
0498  *
0499  */
0500 #define PIN_ISI_D0  {PIO_PD22D_ISI_D0,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}
0501 #define PIN_ISI_D1  {PIO_PD21D_ISI_D1,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}
0502 #define PIN_ISI_D2  {PIO_PB3D_ISI_D2,   PIOB, ID_PIOB, PIO_PERIPH_D, PIO_PULLUP}
0503 #define PIN_ISI_D3  {PIO_PA9B_ISI_D3,   PIOA, ID_PIOA, PIO_PERIPH_B, PIO_PULLUP}
0504 #define PIN_ISI_D4  {PIO_PA5B_ISI_D4,   PIOA, ID_PIOA, PIO_PERIPH_B, PIO_PULLUP}
0505 #define PIN_ISI_D5  {PIO_PD11D_ISI_D5,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}
0506 #define PIN_ISI_D6  {PIO_PD12D_ISI_D6,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}
0507 #define PIN_ISI_D7  {PIO_PA27D_ISI_D7,  PIOA, ID_PIOA, PIO_PERIPH_D, PIO_PULLUP}
0508 #define PIN_ISI_D8  {PIO_PD27D_ISI_D8,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}
0509 #define PIN_ISI_D9  {PIO_PD28D_ISI_D9,  PIOD, ID_PIOD, PIO_PERIPH_D, PIO_PULLUP}
0510 
0511 #define BOARD_ISI_VSYNC {PIO_PD25D_ISI_VSYNC, PIOD, ID_PIOD, PIO_PERIPH_D, PIO_DEFAULT}
0512 #define BOARD_ISI_HSYNC {PIO_PD24D_ISI_HSYNC, PIOD, ID_PIOD, PIO_PERIPH_D, PIO_DEFAULT}
0513 #define BOARD_ISI_PCK   {PIO_PA24D_ISI_PCK, PIOA, ID_PIOA, PIO_PERIPH_D, PIO_DEFAULT}
0514 
0515 #define BOARD_ISI_PCK0  { PIO_PA6B_PCK0,  PIOA, ID_PIOA, PIO_PERIPH_B, PIO_DEFAULT }
0516 #define BOARD_ISI_RST   { 1 << 13, PIOB, ID_PIOB, PIO_OUTPUT_1, PIO_DEFAULT }
0517 #define BOARD_ISI_PWD   { 1 << 19,  PIOC, ID_PIOC, PIO_OUTPUT_1, PIO_DEFAULT }
0518 
0519 #define BOARD_ISI_PINS \
0520     PIN_ISI_D0, PIN_ISI_D1, PIN_ISI_D2,PIN_ISI_D3,PIN_ISI_D4, PIN_ISI_D5,\
0521     PIN_ISI_D6,PIN_ISI_D7,PIN_ISI_D8, PIN_ISI_D9,BOARD_ISI_VSYNC ,\
0522     BOARD_ISI_HSYNC ,BOARD_ISI_PCK, BOARD_ISI_RST, BOARD_ISI_PWD,BOARD_ISI_PCK0
0523 
0524 /*----------------------------------------------------------------------------*/
0525 /**
0526  * \page samv7_Xplained_ultra_usb "SAM V71 Xplained Ultra - USB device"
0527  *
0528  * \section Definitions
0529  * - \ref BOARD_USB_BMATTRIBUTES
0530  *
0531  * \section vBus
0532  * - \ref PIN_USB_VBUS
0533  *
0534  */
0535 
0536 /**
0537  * USB attributes configuration descriptor (bus or self powered,
0538  * remote wakeup)
0539  */
0540 #define BOARD_USB_BMATTRIBUTES USBConfigurationDescriptor_SELFPOWERED_NORWAKEUP
0541 
0542 /** USB VBus monitoring pin definition. */
0543 #define PIN_USB_VBUS {PIO_PC16, PIOC, ID_PIOC, PIO_INPUT, PIO_DEFAULT}
0544 
0545 
0546 /*----------------------------------------------------------------------------*/
0547 /**
0548  * \page samv7_Xplained_ultra_extcomp "SAM V71 Xplained Ultra - External components"
0549  * This page lists the definitions related to external on-board components
0550  * located in the board.h file for the SAM V71 Xplained Ultra board.
0551  *
0552  * LCD
0553  */
0554 /** Indicates board has an ILI9325 external component to manage LCD. */
0555 #define BOARD_LCD_ILI9488
0556 //#define BOARD_LCD_SPI_EXT1
0557 #define BOARD_LCD_SPI_EXT2
0558 
0559 /** SPI pin definition for LCD */
0560 #if defined (BOARD_LCD_SPI_EXT1)
0561 /** SPI MISO pin definition. */
0562 #define LCD_SPI_MISO {PIO_PD20B_SPI0_MISO, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0563 /** SPI MOSI pin definition. */
0564 #define LCD_SPI_MOSI {PIO_PD21B_SPI0_MOSI, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0565 /** SPI SPCK pin definition. */
0566 #define LCD_SPI_SPCK {PIO_PD22B_SPI0_SPCK, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0567 /** SPI chip select pin definition. */
0568 #define LCD_SPI_NPCS {PIO_PD27B_SPI0_NPCS3, PIOD, ID_PIOD, PIO_PERIPH_B,PIO_DEFAULT}
0569 
0570 /** SPI chip select pin definition. */
0571 #define LCD_SPI_NPCS    {PIO_PD25B_SPI0_NPCS1, PIOD, ID_PIOD, PIO_PERIPH_B,PIO_DEFAULT}
0572 
0573 /** LCD pins definition. */
0574 #define BOARD_SPI_LCD_PINS  {LCD_SPI_MISO, LCD_SPI_MOSI, LCD_SPI_SPCK, LCD_SPI_NPCS}
0575 
0576 /** Back-light pin definition. */
0577 
0578 #define BOARD_SPI_LCD_BACKLIGHT_PIN  \
0579     {PIO_PA0A_PWMC0_PWMH0, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
0580 
0581 /** PWMC PWM0 pin definition: Output Low. */
0582 #define LCD_SPI_PIN_RESET   {PIO_PD28, PIOD, ID_PIOD, PIO_OUTPUT_1, PIO_DEFAULT}
0583 
0584 /** PWM channel for LED0 */
0585 #define CHANNEL_PWM_LCD 0
0586 
0587 #endif
0588 /*ENDIF BOARD_LCD_SPI_EXT1 */
0589 
0590 #if defined (BOARD_LCD_SPI_EXT2)
0591 /** SPI MISO pin definition. */
0592 #define LCD_SPI_MISO {PIO_PD20B_SPI0_MISO, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0593 /** SPI MOSI pin definition. */
0594 #define LCD_SPI_MOSI {PIO_PD21B_SPI0_MOSI, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0595 /** SPI SPCK pin definition. */
0596 #define LCD_SPI_SPCK {PIO_PD22B_SPI0_SPCK, PIOD, ID_PIOD, PIO_PERIPH_B, PIO_DEFAULT}
0597 /** SPI chip select pin definition. */
0598 #define LCD_SPI_NPCS {PIO_PD27B_SPI0_NPCS3, PIOD, ID_PIOD, PIO_PERIPH_B,PIO_DEFAULT}
0599 
0600 /** LCD pins definition. */
0601 #define BOARD_SPI_LCD_PINS  {LCD_SPI_MISO, LCD_SPI_MOSI, LCD_SPI_SPCK, LCD_SPI_NPCS}
0602 
0603 /** Back-light pin definition. */
0604 
0605 #define BOARD_SPI_LCD_PIN_BACKLIGHT  \
0606     {PIO_PC19B_PWMC0_PWMH2, PIOC, ID_PIOC, PIO_OUTPUT_1, PIO_DEFAULT}
0607 
0608 /** PWMC PWM0 pin definition: Output Low. */
0609 #define LCD_SPI_PIN_RESET   {PIO_PA24, PIOA, ID_PIOA, PIO_OUTPUT_1, PIO_DEFAULT}
0610 
0611 /** LCD command/data select pin */
0612 #define BOARD_SPI_LCD_PIN_CDS   {PIO_PA6, PIOA, ID_PIOA, PIO_OUTPUT_1, PIO_DEFAULT}
0613 
0614 /** PWM channel for LED0 */
0615 #define CHANNEL_PWM_LCD 2
0616 
0617 #endif
0618 /*ENDIF BOARD_LCD_SPI_EXT2 */
0619 
0620 /** SMC pin definition for LCD */
0621 /** LCD data pin */
0622 #define PIN_EBI_LCD_DATAL           {0xFF, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}
0623 #define PIN_EBI_LCD_DATAH_0         {0x3F, PIOE, ID_PIOE, PIO_PERIPH_A, PIO_PULLUP}
0624 #define PIN_EBI_LCD_DATAH_1         {PIO_PA15A_D14|PIO_PA16A_D15, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_PULLUP}
0625 /** LCD WE pin */
0626 #define PIN_EBI_LCD_NWE             {PIO_PC8A_NWE,  PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}
0627 /** LCD RD pin */
0628 #define PIN_EBI_LCD_NRD             {PIO_PC11A_NRD, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_PULLUP}
0629 /* LCD CS pin (NCS3) */
0630 #define PIN_EBI_LCD_CS              {PIO_PD19A_NCS3, PIOD, ID_PIOD, PIO_PERIPH_A, PIO_PULLUP}
0631 /** LCD command/data select pin */
0632 #define BOARD_EBI_LCD_PIN_CDS       {PIO_PC30, PIOC, ID_PIOC, PIO_OUTPUT_1, PIO_DEFAULT}
0633 /** Back-light pin definition. */
0634 #define BOARD_EBI_LCD_PIN_BACKLIGHT {PIO_PC9B_TIOB7, PIOC, ID_PIOC, PIO_PERIPH_B, PIO_DEFAULT}
0635 /** LCD reset pin */
0636 #define LCD_EBI_PIN_RESET           {PIO_PC13, PIOC, ID_PIOC, PIO_OUTPUT_1, PIO_DEFAULT}
0637 
0638 /** LCD pins definition. */
0639 #define BOARD_EBI_LCD_PINS          \
0640     {PIN_EBI_LCD_DATAL, PIN_EBI_LCD_DATAH_0, PIN_EBI_LCD_DATAH_1, \
0641         PIN_EBI_LCD_NWE,PIN_EBI_LCD_NRD,PIN_EBI_LCD_CS}
0642 
0643 
0644 /** Display width in pixels. */
0645 #define BOARD_LCD_WIDTH             320
0646 /** Display height in pixels. */
0647 #define BOARD_LCD_HEIGHT            480
0648 
0649 
0650 /*----------------------------------------------------------------------------*/
0651 /**
0652  * \page samv7_Xplained_ultra_mem "SAM V71 Xplained Ultra - Memories"
0653  * This page lists definitions related to internal & external on-board memories.
0654  * \section SDRAM
0655  * - \ref PIN_SDRAM_D0_7
0656  * - \ref PIN_SDRAM_D8_13
0657  * - \ref PIN_SDRAM_D14_15
0658  * - \ref PIN_SDRAM_A0_9
0659  * - \ref PIN_SDRAM_SDA10
0660  * - \ref PIN_SDRAM_CAS
0661  * - \ref PIN_SDRAM_RAS
0662  * - \ref PIN_SDRAM_SDCKE
0663  * - \ref PIN_SDRAM_SDCK
0664  * - \ref PIN_SDRAM_SDSC
0665  * - \ref PIN_SDRAM_NBS0
0666  * - \ref PIN_SDRAM_NBS1
0667  * - \ref PIN_SDRAM_SDWE
0668  * - \ref PIN_SDRAM_BA0
0669  *
0670  * \section SDMMC
0671  * - \ref BOARD_MCI_PIN_CD
0672  * - \ref BOARD_MCI_PIN_CK
0673  * - \ref BOARD_MCI_PINS_SLOTA
0674  * - \ref BOARD_SD_PINS
0675  *
0676  * \section QSPI
0677  * - \ref PINS_QSPI_IO
0678  * - \ref PINS_QSPI_IO3
0679  * - \ref PINS_QSPI
0680  */
0681 
0682 /** List of all SDRAM pin definitions. */
0683 #define BOARD_SDRAM_SIZE  (2*1024*1024)
0684 #define PIN_SDRAM_D0_7    {0x000000FF, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_DEFAULT}
0685 #define PIN_SDRAM_D8_13   {0x0000003F, PIOE, ID_PIOE, PIO_PERIPH_A, PIO_DEFAULT}
0686 #define PIN_SDRAM_D14_15  {0x00018000, PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
0687 #define PIN_SDRAM_A0_9    {0x3FF00000, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_DEFAULT}
0688 #define PIN_SDRAM_SDA10   {0x00002000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}
0689 
0690 #define PIN_SDRAM_CAS     {0x00020000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}
0691 #define PIN_SDRAM_RAS     {0x00010000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}
0692 #define PIN_SDRAM_SDCKE   {0x00004000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}
0693 #define PIN_SDRAM_SDCK    {0x00800000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}
0694 #define PIN_SDRAM_SDSC    {0x00008000, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_DEFAULT}
0695 #define PIN_SDRAM_NBS0    {0x00040000, PIOC, ID_PIOC, PIO_PERIPH_A, PIO_DEFAULT}
0696 #define PIN_SDRAM_NBS1    {0x00008000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}
0697 #define PIN_SDRAM_SDWE    {0x20000000, PIOD, ID_PIOD, PIO_PERIPH_C, PIO_DEFAULT}
0698 #define PIN_SDRAM_BA0     {0x00100000, PIOA, ID_PIOA, PIO_PERIPH_C, PIO_DEFAULT}
0699 
0700 #define BOARD_SDRAM_PINS PIN_SDRAM_D0_7, PIN_SDRAM_D8_13 , PIN_SDRAM_D14_15,\
0701     PIN_SDRAM_A0_9, PIN_SDRAM_SDA10, PIN_SDRAM_BA0, \
0702     PIN_SDRAM_CAS, PIN_SDRAM_RAS, PIN_SDRAM_SDCKE,PIN_SDRAM_SDCK,\
0703     PIN_SDRAM_SDSC,PIN_SDRAM_NBS0 ,PIN_SDRAM_NBS1,PIN_SDRAM_SDWE
0704 
0705 
0706 /** List of all MCI pin definitions. */
0707 
0708 /** MCI0 Card detect pin definition. (PE5) */
0709 #define BOARD_MCI_PIN_CD  {PIO_PD18, PIOD, ID_PIOD, PIO_INPUT, PIO_PULLUP}
0710 /** MCI0 Clock . */
0711 #define BOARD_MCI_PIN_CK  {PIO_PA25D_MCCK, PIOA, ID_PIOA, PIO_PERIPH_D, PIO_DEFAULT}
0712 
0713 /** MCI0 Solt A IO pins definition. (PC4-PC13) */
0714 #define BOARD_MCI_PINS_SLOTA \
0715     {(PIO_PA30C_MCDA0 | PIO_PA31C_MCDA1 | PIO_PA26C_MCDA2 | PIO_PA27C_MCDA3 | PIO_PA28C_MCCDA),\
0716         PIOA, ID_PIOA, PIO_PERIPH_C, PIO_DEFAULT}
0717 
0718 /** MCI pins that shall be configured to access the SD card. */
0719 #define BOARD_SD_PINS     {BOARD_MCI_PINS_SLOTA, BOARD_MCI_PIN_CK}
0720 /** MCI Card Detect pin. */
0721 #define BOARD_SD_PIN_CD   BOARD_MCI_PIN_CD
0722 /** Total number of MCI interface */
0723 #define BOARD_NUM_MCI     1
0724 
0725 /** List of all SQPI pin definitions. */
0726 #define PINS_QSPI_IO   \
0727     {(PIO_PA11A_QCS | PIO_PA13A_QIO0 | PIO_PA12A_QIO1 | PIO_PA17A_QIO2 | PIO_PA14A_QSCK),\
0728         PIOA, ID_PIOA, PIO_PERIPH_A, PIO_DEFAULT}
0729 #define PINS_QSPI_IO3   {PIO_PD31A_QIO3, PIOD, ID_PIOD, PIO_PERIPH_A, PIO_DEFAULT}
0730 #define PINS_QSPI      {PINS_QSPI_IO, PINS_QSPI_IO3}
0731 
0732 /*----------------------------------------------------------------------------*/
0733 /**
0734  * \page samv7_Xplained_ultra_chipdef "SAM V71 Xplained Ultra - Individual chip definition"
0735  * This page lists the definitions related to different chip's definition
0736  *
0737  * \section USART
0738  * - \ref BOARD_PIN_USART_RXD
0739  * - \ref BOARD_PIN_USART_TXD
0740  * - \ref BOARD_PIN_USART_CTS
0741  * - \ref BOARD_PIN_USART_RTS
0742  * - \ref BOARD_PIN_USART_EN
0743  * - \ref BOARD_USART_BASE
0744  * - \ref BOARD_ID_USART
0745  */
0746 
0747 /** Rtc */
0748 #define BOARD_RTC_ID   ID_RTC
0749 
0750 /** TWI ID for QTouch application to use */
0751 #define BOARD_ID_TWI_AT42    ID_TWI0
0752 /** TWI Base for QTouch application to use */
0753 #define BOARD_BASE_TWI_AT42  TWI0
0754 /** TWI pins for QTouch application to use */
0755 #define BOARD_PINS_TWI_AT42  PINS_TWI0
0756 
0757 /** USART RX pin for application */
0758 #define BOARD_PIN_USART_RXD  PIN_USART1_RXD
0759 /** USART TX pin for application */
0760 #define BOARD_PIN_USART_TXD  PIN_USART1_TXD
0761 /** USART CTS pin for application */
0762 #define BOARD_PIN_USART_CTS  PIN_USART1_CTS
0763 /** USART RTS pin for application */
0764 #define BOARD_PIN_USART_RTS  PIN_USART1_RTS
0765 /** USART ENABLE pin for application */
0766 #define BOARD_PIN_USART_EN  PIN_USART1_EN
0767 /** USART Base for application */
0768 #define BOARD_USART_BASE  USART1
0769 /** USART ID for application */
0770 #define BOARD_ID_USART   ID_USART1
0771 
0772 
0773 
0774 /*----------------------------------------------------------------------------*/
0775 /*
0776 * USB pins
0777 */
0778 #define PINS_VBUS_EN   {PIO_PC16, PIOC, ID_PIOC, PIO_OUTPUT_1, PIO_DEFAULT}
0779 #endif /* #ifndef _BOARD_V71_XULT_H_ */
0780