1 /** 2 * \file 3 * 4 * \brief Header file for SAME53N20A 5 * 6 * Copyright (c) 2019 Microchip Technology Inc. 7 * 8 * \asf_license_start 9 * 10 * \page License 11 * 12 * SPDX-License-Identifier: Apache-2.0 13 * 14 * Licensed under the Apache License, Version 2.0 (the "License"); you may 15 * not use this file except in compliance with the License. 16 * You may obtain a copy of the Licence at 17 * 18 * http://www.apache.org/licenses/LICENSE-2.0 19 * 20 * Unless required by applicable law or agreed to in writing, software 21 * distributed under the License is distributed on an AS IS BASIS, WITHOUT 22 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 23 * See the License for the specific language governing permissions and 24 * limitations under the License. 25 * 26 * \asf_license_stop 27 * 28 */ 29 30 #ifndef _SAME53N20A_ 31 #define _SAME53N20A_ 32 33 /** 34 * \ingroup SAME53_definitions 35 * \addtogroup SAME53N20A_definitions SAME53N20A definitions 36 * This file defines all structures and symbols for SAME53N20A: 37 * - registers and bitfields 38 * - peripheral base address 39 * - peripheral ID 40 * - PIO definitions 41 */ 42 /*@{*/ 43 44 #ifdef __cplusplus 45 extern "C" { 46 #endif 47 48 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) 49 #include <stdint.h> 50 #ifndef __cplusplus 51 typedef volatile const uint32_t RoReg; /**< Read only 32-bit register (volatile const unsigned int) */ 52 typedef volatile const uint16_t RoReg16; /**< Read only 16-bit register (volatile const unsigned int) */ 53 typedef volatile const uint8_t RoReg8; /**< Read only 8-bit register (volatile const unsigned int) */ 54 #else 55 typedef volatile uint32_t RoReg; /**< Read only 32-bit register (volatile const unsigned int) */ 56 typedef volatile uint16_t RoReg16; /**< Read only 16-bit register (volatile const unsigned int) */ 57 typedef volatile uint8_t RoReg8; /**< Read only 8-bit register (volatile const unsigned int) */ 58 #endif 59 typedef volatile uint32_t WoReg; /**< Write only 32-bit register (volatile unsigned int) */ 60 typedef volatile uint16_t WoReg16; /**< Write only 16-bit register (volatile unsigned int) */ 61 typedef volatile uint8_t WoReg8; /**< Write only 8-bit register (volatile unsigned int) */ 62 typedef volatile uint32_t RwReg; /**< Read-Write 32-bit register (volatile unsigned int) */ 63 typedef volatile uint16_t RwReg16; /**< Read-Write 16-bit register (volatile unsigned int) */ 64 typedef volatile uint8_t RwReg8; /**< Read-Write 8-bit register (volatile unsigned int) */ 65 #endif 66 67 #if !defined(SKIP_INTEGER_LITERALS) 68 #if defined(_U_) || defined(_L_) || defined(_UL_) 69 #error "Integer Literals macros already defined elsewhere" 70 #endif 71 72 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) 73 /* Macros that deal with adding suffixes to integer literal constants for C/C++ */ 74 #define _U_(x) x ## U /**< C code: Unsigned integer literal constant value */ 75 #define _L_(x) x ## L /**< C code: Long integer literal constant value */ 76 #define _UL_(x) x ## UL /**< C code: Unsigned Long integer literal constant value */ 77 #else /* Assembler */ 78 #define _U_(x) x /**< Assembler: Unsigned integer literal constant value */ 79 #define _L_(x) x /**< Assembler: Long integer literal constant value */ 80 #define _UL_(x) x /**< Assembler: Unsigned Long integer literal constant value */ 81 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */ 82 #endif /* SKIP_INTEGER_LITERALS */ 83 84 /* ************************************************************************** */ 85 /** CMSIS DEFINITIONS FOR SAME53N20A */ 86 /* ************************************************************************** */ 87 /** \defgroup SAME53N20A_cmsis CMSIS Definitions */ 88 /*@{*/ 89 90 /** Interrupt Number Definition */ 91 typedef enum IRQn 92 { 93 /****** Cortex-M4 Processor Exceptions Numbers *******************/ 94 NonMaskableInt_IRQn = -14,/**< 2 Non Maskable Interrupt */ 95 HardFault_IRQn = -13,/**< 3 Hard Fault Interrupt */ 96 MemoryManagement_IRQn = -12,/**< 4 Memory Management Interrupt */ 97 BusFault_IRQn = -11,/**< 5 Bus Fault Interrupt */ 98 UsageFault_IRQn = -10,/**< 6 Usage Fault Interrupt */ 99 SVCall_IRQn = -5, /**< 11 SV Call Interrupt */ 100 DebugMonitor_IRQn = -4, /**< 12 Debug Monitor Interrupt */ 101 PendSV_IRQn = -2, /**< 14 Pend SV Interrupt */ 102 SysTick_IRQn = -1, /**< 15 System Tick Interrupt */ 103 /****** SAME53N20A-specific Interrupt Numbers *********************/ 104 PM_IRQn = 0, /**< 0 SAME53N20A Power Manager (PM) */ 105 MCLK_IRQn = 1, /**< 1 SAME53N20A Main Clock (MCLK) */ 106 OSCCTRL_0_IRQn = 2, /**< 2 SAME53N20A Oscillators Control (OSCCTRL) IRQ 0 */ 107 OSCCTRL_1_IRQn = 3, /**< 3 SAME53N20A Oscillators Control (OSCCTRL) IRQ 1 */ 108 OSCCTRL_2_IRQn = 4, /**< 4 SAME53N20A Oscillators Control (OSCCTRL) IRQ 2 */ 109 OSCCTRL_3_IRQn = 5, /**< 5 SAME53N20A Oscillators Control (OSCCTRL) IRQ 3 */ 110 OSCCTRL_4_IRQn = 6, /**< 6 SAME53N20A Oscillators Control (OSCCTRL) IRQ 4 */ 111 OSC32KCTRL_IRQn = 7, /**< 7 SAME53N20A 32kHz Oscillators Control (OSC32KCTRL) */ 112 SUPC_0_IRQn = 8, /**< 8 SAME53N20A Supply Controller (SUPC) IRQ 0 */ 113 SUPC_1_IRQn = 9, /**< 9 SAME53N20A Supply Controller (SUPC) IRQ 1 */ 114 WDT_IRQn = 10, /**< 10 SAME53N20A Watchdog Timer (WDT) */ 115 RTC_IRQn = 11, /**< 11 SAME53N20A Real-Time Counter (RTC) */ 116 EIC_0_IRQn = 12, /**< 12 SAME53N20A External Interrupt Controller (EIC) IRQ 0 */ 117 EIC_1_IRQn = 13, /**< 13 SAME53N20A External Interrupt Controller (EIC) IRQ 1 */ 118 EIC_2_IRQn = 14, /**< 14 SAME53N20A External Interrupt Controller (EIC) IRQ 2 */ 119 EIC_3_IRQn = 15, /**< 15 SAME53N20A External Interrupt Controller (EIC) IRQ 3 */ 120 EIC_4_IRQn = 16, /**< 16 SAME53N20A External Interrupt Controller (EIC) IRQ 4 */ 121 EIC_5_IRQn = 17, /**< 17 SAME53N20A External Interrupt Controller (EIC) IRQ 5 */ 122 EIC_6_IRQn = 18, /**< 18 SAME53N20A External Interrupt Controller (EIC) IRQ 6 */ 123 EIC_7_IRQn = 19, /**< 19 SAME53N20A External Interrupt Controller (EIC) IRQ 7 */ 124 EIC_8_IRQn = 20, /**< 20 SAME53N20A External Interrupt Controller (EIC) IRQ 8 */ 125 EIC_9_IRQn = 21, /**< 21 SAME53N20A External Interrupt Controller (EIC) IRQ 9 */ 126 EIC_10_IRQn = 22, /**< 22 SAME53N20A External Interrupt Controller (EIC) IRQ 10 */ 127 EIC_11_IRQn = 23, /**< 23 SAME53N20A External Interrupt Controller (EIC) IRQ 11 */ 128 EIC_12_IRQn = 24, /**< 24 SAME53N20A External Interrupt Controller (EIC) IRQ 12 */ 129 EIC_13_IRQn = 25, /**< 25 SAME53N20A External Interrupt Controller (EIC) IRQ 13 */ 130 EIC_14_IRQn = 26, /**< 26 SAME53N20A External Interrupt Controller (EIC) IRQ 14 */ 131 EIC_15_IRQn = 27, /**< 27 SAME53N20A External Interrupt Controller (EIC) IRQ 15 */ 132 FREQM_IRQn = 28, /**< 28 SAME53N20A Frequency Meter (FREQM) */ 133 NVMCTRL_0_IRQn = 29, /**< 29 SAME53N20A Non-Volatile Memory Controller (NVMCTRL) IRQ 0 */ 134 NVMCTRL_1_IRQn = 30, /**< 30 SAME53N20A Non-Volatile Memory Controller (NVMCTRL) IRQ 1 */ 135 DMAC_0_IRQn = 31, /**< 31 SAME53N20A Direct Memory Access Controller (DMAC) IRQ 0 */ 136 DMAC_1_IRQn = 32, /**< 32 SAME53N20A Direct Memory Access Controller (DMAC) IRQ 1 */ 137 DMAC_2_IRQn = 33, /**< 33 SAME53N20A Direct Memory Access Controller (DMAC) IRQ 2 */ 138 DMAC_3_IRQn = 34, /**< 34 SAME53N20A Direct Memory Access Controller (DMAC) IRQ 3 */ 139 DMAC_4_IRQn = 35, /**< 35 SAME53N20A Direct Memory Access Controller (DMAC) IRQ 4 */ 140 EVSYS_0_IRQn = 36, /**< 36 SAME53N20A Event System Interface (EVSYS) IRQ 0 */ 141 EVSYS_1_IRQn = 37, /**< 37 SAME53N20A Event System Interface (EVSYS) IRQ 1 */ 142 EVSYS_2_IRQn = 38, /**< 38 SAME53N20A Event System Interface (EVSYS) IRQ 2 */ 143 EVSYS_3_IRQn = 39, /**< 39 SAME53N20A Event System Interface (EVSYS) IRQ 3 */ 144 EVSYS_4_IRQn = 40, /**< 40 SAME53N20A Event System Interface (EVSYS) IRQ 4 */ 145 PAC_IRQn = 41, /**< 41 SAME53N20A Peripheral Access Controller (PAC) */ 146 RAMECC_IRQn = 45, /**< 45 SAME53N20A RAM ECC (RAMECC) */ 147 SERCOM0_0_IRQn = 46, /**< 46 SAME53N20A Serial Communication Interface 0 (SERCOM0) IRQ 0 */ 148 SERCOM0_1_IRQn = 47, /**< 47 SAME53N20A Serial Communication Interface 0 (SERCOM0) IRQ 1 */ 149 SERCOM0_2_IRQn = 48, /**< 48 SAME53N20A Serial Communication Interface 0 (SERCOM0) IRQ 2 */ 150 SERCOM0_3_IRQn = 49, /**< 49 SAME53N20A Serial Communication Interface 0 (SERCOM0) IRQ 3 */ 151 SERCOM1_0_IRQn = 50, /**< 50 SAME53N20A Serial Communication Interface 1 (SERCOM1) IRQ 0 */ 152 SERCOM1_1_IRQn = 51, /**< 51 SAME53N20A Serial Communication Interface 1 (SERCOM1) IRQ 1 */ 153 SERCOM1_2_IRQn = 52, /**< 52 SAME53N20A Serial Communication Interface 1 (SERCOM1) IRQ 2 */ 154 SERCOM1_3_IRQn = 53, /**< 53 SAME53N20A Serial Communication Interface 1 (SERCOM1) IRQ 3 */ 155 SERCOM2_0_IRQn = 54, /**< 54 SAME53N20A Serial Communication Interface 2 (SERCOM2) IRQ 0 */ 156 SERCOM2_1_IRQn = 55, /**< 55 SAME53N20A Serial Communication Interface 2 (SERCOM2) IRQ 1 */ 157 SERCOM2_2_IRQn = 56, /**< 56 SAME53N20A Serial Communication Interface 2 (SERCOM2) IRQ 2 */ 158 SERCOM2_3_IRQn = 57, /**< 57 SAME53N20A Serial Communication Interface 2 (SERCOM2) IRQ 3 */ 159 SERCOM3_0_IRQn = 58, /**< 58 SAME53N20A Serial Communication Interface 3 (SERCOM3) IRQ 0 */ 160 SERCOM3_1_IRQn = 59, /**< 59 SAME53N20A Serial Communication Interface 3 (SERCOM3) IRQ 1 */ 161 SERCOM3_2_IRQn = 60, /**< 60 SAME53N20A Serial Communication Interface 3 (SERCOM3) IRQ 2 */ 162 SERCOM3_3_IRQn = 61, /**< 61 SAME53N20A Serial Communication Interface 3 (SERCOM3) IRQ 3 */ 163 SERCOM4_0_IRQn = 62, /**< 62 SAME53N20A Serial Communication Interface 4 (SERCOM4) IRQ 0 */ 164 SERCOM4_1_IRQn = 63, /**< 63 SAME53N20A Serial Communication Interface 4 (SERCOM4) IRQ 1 */ 165 SERCOM4_2_IRQn = 64, /**< 64 SAME53N20A Serial Communication Interface 4 (SERCOM4) IRQ 2 */ 166 SERCOM4_3_IRQn = 65, /**< 65 SAME53N20A Serial Communication Interface 4 (SERCOM4) IRQ 3 */ 167 SERCOM5_0_IRQn = 66, /**< 66 SAME53N20A Serial Communication Interface 5 (SERCOM5) IRQ 0 */ 168 SERCOM5_1_IRQn = 67, /**< 67 SAME53N20A Serial Communication Interface 5 (SERCOM5) IRQ 1 */ 169 SERCOM5_2_IRQn = 68, /**< 68 SAME53N20A Serial Communication Interface 5 (SERCOM5) IRQ 2 */ 170 SERCOM5_3_IRQn = 69, /**< 69 SAME53N20A Serial Communication Interface 5 (SERCOM5) IRQ 3 */ 171 SERCOM6_0_IRQn = 70, /**< 70 SAME53N20A Serial Communication Interface 6 (SERCOM6) IRQ 0 */ 172 SERCOM6_1_IRQn = 71, /**< 71 SAME53N20A Serial Communication Interface 6 (SERCOM6) IRQ 1 */ 173 SERCOM6_2_IRQn = 72, /**< 72 SAME53N20A Serial Communication Interface 6 (SERCOM6) IRQ 2 */ 174 SERCOM6_3_IRQn = 73, /**< 73 SAME53N20A Serial Communication Interface 6 (SERCOM6) IRQ 3 */ 175 SERCOM7_0_IRQn = 74, /**< 74 SAME53N20A Serial Communication Interface 7 (SERCOM7) IRQ 0 */ 176 SERCOM7_1_IRQn = 75, /**< 75 SAME53N20A Serial Communication Interface 7 (SERCOM7) IRQ 1 */ 177 SERCOM7_2_IRQn = 76, /**< 76 SAME53N20A Serial Communication Interface 7 (SERCOM7) IRQ 2 */ 178 SERCOM7_3_IRQn = 77, /**< 77 SAME53N20A Serial Communication Interface 7 (SERCOM7) IRQ 3 */ 179 USB_0_IRQn = 80, /**< 80 SAME53N20A Universal Serial Bus (USB) IRQ 0 */ 180 USB_1_IRQn = 81, /**< 81 SAME53N20A Universal Serial Bus (USB) IRQ 1 */ 181 USB_2_IRQn = 82, /**< 82 SAME53N20A Universal Serial Bus (USB) IRQ 2 */ 182 USB_3_IRQn = 83, /**< 83 SAME53N20A Universal Serial Bus (USB) IRQ 3 */ 183 GMAC_IRQn = 84, /**< 84 SAME53N20A Ethernet MAC (GMAC) */ 184 TCC0_0_IRQn = 85, /**< 85 SAME53N20A Timer Counter Control 0 (TCC0) IRQ 0 */ 185 TCC0_1_IRQn = 86, /**< 86 SAME53N20A Timer Counter Control 0 (TCC0) IRQ 1 */ 186 TCC0_2_IRQn = 87, /**< 87 SAME53N20A Timer Counter Control 0 (TCC0) IRQ 2 */ 187 TCC0_3_IRQn = 88, /**< 88 SAME53N20A Timer Counter Control 0 (TCC0) IRQ 3 */ 188 TCC0_4_IRQn = 89, /**< 89 SAME53N20A Timer Counter Control 0 (TCC0) IRQ 4 */ 189 TCC0_5_IRQn = 90, /**< 90 SAME53N20A Timer Counter Control 0 (TCC0) IRQ 5 */ 190 TCC0_6_IRQn = 91, /**< 91 SAME53N20A Timer Counter Control 0 (TCC0) IRQ 6 */ 191 TCC1_0_IRQn = 92, /**< 92 SAME53N20A Timer Counter Control 1 (TCC1) IRQ 0 */ 192 TCC1_1_IRQn = 93, /**< 93 SAME53N20A Timer Counter Control 1 (TCC1) IRQ 1 */ 193 TCC1_2_IRQn = 94, /**< 94 SAME53N20A Timer Counter Control 1 (TCC1) IRQ 2 */ 194 TCC1_3_IRQn = 95, /**< 95 SAME53N20A Timer Counter Control 1 (TCC1) IRQ 3 */ 195 TCC1_4_IRQn = 96, /**< 96 SAME53N20A Timer Counter Control 1 (TCC1) IRQ 4 */ 196 TCC2_0_IRQn = 97, /**< 97 SAME53N20A Timer Counter Control 2 (TCC2) IRQ 0 */ 197 TCC2_1_IRQn = 98, /**< 98 SAME53N20A Timer Counter Control 2 (TCC2) IRQ 1 */ 198 TCC2_2_IRQn = 99, /**< 99 SAME53N20A Timer Counter Control 2 (TCC2) IRQ 2 */ 199 TCC2_3_IRQn = 100, /**< 100 SAME53N20A Timer Counter Control 2 (TCC2) IRQ 3 */ 200 TCC3_0_IRQn = 101, /**< 101 SAME53N20A Timer Counter Control 3 (TCC3) IRQ 0 */ 201 TCC3_1_IRQn = 102, /**< 102 SAME53N20A Timer Counter Control 3 (TCC3) IRQ 1 */ 202 TCC3_2_IRQn = 103, /**< 103 SAME53N20A Timer Counter Control 3 (TCC3) IRQ 2 */ 203 TCC4_0_IRQn = 104, /**< 104 SAME53N20A Timer Counter Control 4 (TCC4) IRQ 0 */ 204 TCC4_1_IRQn = 105, /**< 105 SAME53N20A Timer Counter Control 4 (TCC4) IRQ 1 */ 205 TCC4_2_IRQn = 106, /**< 106 SAME53N20A Timer Counter Control 4 (TCC4) IRQ 2 */ 206 TC0_IRQn = 107, /**< 107 SAME53N20A Basic Timer Counter 0 (TC0) */ 207 TC1_IRQn = 108, /**< 108 SAME53N20A Basic Timer Counter 1 (TC1) */ 208 TC2_IRQn = 109, /**< 109 SAME53N20A Basic Timer Counter 2 (TC2) */ 209 TC3_IRQn = 110, /**< 110 SAME53N20A Basic Timer Counter 3 (TC3) */ 210 TC4_IRQn = 111, /**< 111 SAME53N20A Basic Timer Counter 4 (TC4) */ 211 TC5_IRQn = 112, /**< 112 SAME53N20A Basic Timer Counter 5 (TC5) */ 212 TC6_IRQn = 113, /**< 113 SAME53N20A Basic Timer Counter 6 (TC6) */ 213 TC7_IRQn = 114, /**< 114 SAME53N20A Basic Timer Counter 7 (TC7) */ 214 PDEC_0_IRQn = 115, /**< 115 SAME53N20A Quadrature Decodeur (PDEC) IRQ 0 */ 215 PDEC_1_IRQn = 116, /**< 116 SAME53N20A Quadrature Decodeur (PDEC) IRQ 1 */ 216 PDEC_2_IRQn = 117, /**< 117 SAME53N20A Quadrature Decodeur (PDEC) IRQ 2 */ 217 ADC0_0_IRQn = 118, /**< 118 SAME53N20A Analog Digital Converter 0 (ADC0) IRQ 0 */ 218 ADC0_1_IRQn = 119, /**< 119 SAME53N20A Analog Digital Converter 0 (ADC0) IRQ 1 */ 219 ADC1_0_IRQn = 120, /**< 120 SAME53N20A Analog Digital Converter 1 (ADC1) IRQ 0 */ 220 ADC1_1_IRQn = 121, /**< 121 SAME53N20A Analog Digital Converter 1 (ADC1) IRQ 1 */ 221 AC_IRQn = 122, /**< 122 SAME53N20A Analog Comparators (AC) */ 222 DAC_0_IRQn = 123, /**< 123 SAME53N20A Digital-to-Analog Converter (DAC) IRQ 0 */ 223 DAC_1_IRQn = 124, /**< 124 SAME53N20A Digital-to-Analog Converter (DAC) IRQ 1 */ 224 DAC_2_IRQn = 125, /**< 125 SAME53N20A Digital-to-Analog Converter (DAC) IRQ 2 */ 225 DAC_3_IRQn = 126, /**< 126 SAME53N20A Digital-to-Analog Converter (DAC) IRQ 3 */ 226 DAC_4_IRQn = 127, /**< 127 SAME53N20A Digital-to-Analog Converter (DAC) IRQ 4 */ 227 I2S_IRQn = 128, /**< 128 SAME53N20A Inter-IC Sound Interface (I2S) */ 228 PCC_IRQn = 129, /**< 129 SAME53N20A Parallel Capture Controller (PCC) */ 229 AES_IRQn = 130, /**< 130 SAME53N20A Advanced Encryption Standard (AES) */ 230 TRNG_IRQn = 131, /**< 131 SAME53N20A True Random Generator (TRNG) */ 231 ICM_IRQn = 132, /**< 132 SAME53N20A Integrity Check Monitor (ICM) */ 232 PUKCC_IRQn = 133, /**< 133 SAME53N20A PUblic-Key Cryptography Controller (PUKCC) */ 233 QSPI_IRQn = 134, /**< 134 SAME53N20A Quad SPI interface (QSPI) */ 234 SDHC0_IRQn = 135, /**< 135 SAME53N20A SD/MMC Host Controller 0 (SDHC0) */ 235 SDHC1_IRQn = 136, /**< 136 SAME53N20A SD/MMC Host Controller 1 (SDHC1) */ 236 237 PERIPH_COUNT_IRQn = 137 /**< Number of peripheral IDs */ 238 } IRQn_Type; 239 240 typedef struct _DeviceVectors 241 { 242 /* Stack pointer */ 243 void* pvStack; 244 245 /* Cortex-M handlers */ 246 void* pfnReset_Handler; 247 void* pfnNonMaskableInt_Handler; 248 void* pfnHardFault_Handler; 249 void* pfnMemManagement_Handler; 250 void* pfnBusFault_Handler; 251 void* pfnUsageFault_Handler; 252 void* pvReservedM9; 253 void* pvReservedM8; 254 void* pvReservedM7; 255 void* pvReservedM6; 256 void* pfnSVCall_Handler; 257 void* pfnDebugMonitor_Handler; 258 void* pvReservedM3; 259 void* pfnPendSV_Handler; 260 void* pfnSysTick_Handler; 261 262 /* Peripheral handlers */ 263 void* pfnPM_Handler; /* 0 Power Manager */ 264 void* pfnMCLK_Handler; /* 1 Main Clock */ 265 void* pfnOSCCTRL_0_Handler; /* 2 Oscillators Control IRQ 0 */ 266 void* pfnOSCCTRL_1_Handler; /* 3 Oscillators Control IRQ 1 */ 267 void* pfnOSCCTRL_2_Handler; /* 4 Oscillators Control IRQ 2 */ 268 void* pfnOSCCTRL_3_Handler; /* 5 Oscillators Control IRQ 3 */ 269 void* pfnOSCCTRL_4_Handler; /* 6 Oscillators Control IRQ 4 */ 270 void* pfnOSC32KCTRL_Handler; /* 7 32kHz Oscillators Control */ 271 void* pfnSUPC_0_Handler; /* 8 Supply Controller IRQ 0 */ 272 void* pfnSUPC_1_Handler; /* 9 Supply Controller IRQ 1 */ 273 void* pfnWDT_Handler; /* 10 Watchdog Timer */ 274 void* pfnRTC_Handler; /* 11 Real-Time Counter */ 275 void* pfnEIC_0_Handler; /* 12 External Interrupt Controller IRQ 0 */ 276 void* pfnEIC_1_Handler; /* 13 External Interrupt Controller IRQ 1 */ 277 void* pfnEIC_2_Handler; /* 14 External Interrupt Controller IRQ 2 */ 278 void* pfnEIC_3_Handler; /* 15 External Interrupt Controller IRQ 3 */ 279 void* pfnEIC_4_Handler; /* 16 External Interrupt Controller IRQ 4 */ 280 void* pfnEIC_5_Handler; /* 17 External Interrupt Controller IRQ 5 */ 281 void* pfnEIC_6_Handler; /* 18 External Interrupt Controller IRQ 6 */ 282 void* pfnEIC_7_Handler; /* 19 External Interrupt Controller IRQ 7 */ 283 void* pfnEIC_8_Handler; /* 20 External Interrupt Controller IRQ 8 */ 284 void* pfnEIC_9_Handler; /* 21 External Interrupt Controller IRQ 9 */ 285 void* pfnEIC_10_Handler; /* 22 External Interrupt Controller IRQ 10 */ 286 void* pfnEIC_11_Handler; /* 23 External Interrupt Controller IRQ 11 */ 287 void* pfnEIC_12_Handler; /* 24 External Interrupt Controller IRQ 12 */ 288 void* pfnEIC_13_Handler; /* 25 External Interrupt Controller IRQ 13 */ 289 void* pfnEIC_14_Handler; /* 26 External Interrupt Controller IRQ 14 */ 290 void* pfnEIC_15_Handler; /* 27 External Interrupt Controller IRQ 15 */ 291 void* pfnFREQM_Handler; /* 28 Frequency Meter */ 292 void* pfnNVMCTRL_0_Handler; /* 29 Non-Volatile Memory Controller IRQ 0 */ 293 void* pfnNVMCTRL_1_Handler; /* 30 Non-Volatile Memory Controller IRQ 1 */ 294 void* pfnDMAC_0_Handler; /* 31 Direct Memory Access Controller IRQ 0 */ 295 void* pfnDMAC_1_Handler; /* 32 Direct Memory Access Controller IRQ 1 */ 296 void* pfnDMAC_2_Handler; /* 33 Direct Memory Access Controller IRQ 2 */ 297 void* pfnDMAC_3_Handler; /* 34 Direct Memory Access Controller IRQ 3 */ 298 void* pfnDMAC_4_Handler; /* 35 Direct Memory Access Controller IRQ 4 */ 299 void* pfnEVSYS_0_Handler; /* 36 Event System Interface IRQ 0 */ 300 void* pfnEVSYS_1_Handler; /* 37 Event System Interface IRQ 1 */ 301 void* pfnEVSYS_2_Handler; /* 38 Event System Interface IRQ 2 */ 302 void* pfnEVSYS_3_Handler; /* 39 Event System Interface IRQ 3 */ 303 void* pfnEVSYS_4_Handler; /* 40 Event System Interface IRQ 4 */ 304 void* pfnPAC_Handler; /* 41 Peripheral Access Controller */ 305 void* pvReserved42; 306 void* pvReserved43; 307 void* pvReserved44; 308 void* pfnRAMECC_Handler; /* 45 RAM ECC */ 309 void* pfnSERCOM0_0_Handler; /* 46 Serial Communication Interface 0 IRQ 0 */ 310 void* pfnSERCOM0_1_Handler; /* 47 Serial Communication Interface 0 IRQ 1 */ 311 void* pfnSERCOM0_2_Handler; /* 48 Serial Communication Interface 0 IRQ 2 */ 312 void* pfnSERCOM0_3_Handler; /* 49 Serial Communication Interface 0 IRQ 3 */ 313 void* pfnSERCOM1_0_Handler; /* 50 Serial Communication Interface 1 IRQ 0 */ 314 void* pfnSERCOM1_1_Handler; /* 51 Serial Communication Interface 1 IRQ 1 */ 315 void* pfnSERCOM1_2_Handler; /* 52 Serial Communication Interface 1 IRQ 2 */ 316 void* pfnSERCOM1_3_Handler; /* 53 Serial Communication Interface 1 IRQ 3 */ 317 void* pfnSERCOM2_0_Handler; /* 54 Serial Communication Interface 2 IRQ 0 */ 318 void* pfnSERCOM2_1_Handler; /* 55 Serial Communication Interface 2 IRQ 1 */ 319 void* pfnSERCOM2_2_Handler; /* 56 Serial Communication Interface 2 IRQ 2 */ 320 void* pfnSERCOM2_3_Handler; /* 57 Serial Communication Interface 2 IRQ 3 */ 321 void* pfnSERCOM3_0_Handler; /* 58 Serial Communication Interface 3 IRQ 0 */ 322 void* pfnSERCOM3_1_Handler; /* 59 Serial Communication Interface 3 IRQ 1 */ 323 void* pfnSERCOM3_2_Handler; /* 60 Serial Communication Interface 3 IRQ 2 */ 324 void* pfnSERCOM3_3_Handler; /* 61 Serial Communication Interface 3 IRQ 3 */ 325 void* pfnSERCOM4_0_Handler; /* 62 Serial Communication Interface 4 IRQ 0 */ 326 void* pfnSERCOM4_1_Handler; /* 63 Serial Communication Interface 4 IRQ 1 */ 327 void* pfnSERCOM4_2_Handler; /* 64 Serial Communication Interface 4 IRQ 2 */ 328 void* pfnSERCOM4_3_Handler; /* 65 Serial Communication Interface 4 IRQ 3 */ 329 void* pfnSERCOM5_0_Handler; /* 66 Serial Communication Interface 5 IRQ 0 */ 330 void* pfnSERCOM5_1_Handler; /* 67 Serial Communication Interface 5 IRQ 1 */ 331 void* pfnSERCOM5_2_Handler; /* 68 Serial Communication Interface 5 IRQ 2 */ 332 void* pfnSERCOM5_3_Handler; /* 69 Serial Communication Interface 5 IRQ 3 */ 333 void* pfnSERCOM6_0_Handler; /* 70 Serial Communication Interface 6 IRQ 0 */ 334 void* pfnSERCOM6_1_Handler; /* 71 Serial Communication Interface 6 IRQ 1 */ 335 void* pfnSERCOM6_2_Handler; /* 72 Serial Communication Interface 6 IRQ 2 */ 336 void* pfnSERCOM6_3_Handler; /* 73 Serial Communication Interface 6 IRQ 3 */ 337 void* pfnSERCOM7_0_Handler; /* 74 Serial Communication Interface 7 IRQ 0 */ 338 void* pfnSERCOM7_1_Handler; /* 75 Serial Communication Interface 7 IRQ 1 */ 339 void* pfnSERCOM7_2_Handler; /* 76 Serial Communication Interface 7 IRQ 2 */ 340 void* pfnSERCOM7_3_Handler; /* 77 Serial Communication Interface 7 IRQ 3 */ 341 void* pvReserved78; 342 void* pvReserved79; 343 void* pfnUSB_0_Handler; /* 80 Universal Serial Bus IRQ 0 */ 344 void* pfnUSB_1_Handler; /* 81 Universal Serial Bus IRQ 1 */ 345 void* pfnUSB_2_Handler; /* 82 Universal Serial Bus IRQ 2 */ 346 void* pfnUSB_3_Handler; /* 83 Universal Serial Bus IRQ 3 */ 347 void* pfnGMAC_Handler; /* 84 Ethernet MAC */ 348 void* pfnTCC0_0_Handler; /* 85 Timer Counter Control 0 IRQ 0 */ 349 void* pfnTCC0_1_Handler; /* 86 Timer Counter Control 0 IRQ 1 */ 350 void* pfnTCC0_2_Handler; /* 87 Timer Counter Control 0 IRQ 2 */ 351 void* pfnTCC0_3_Handler; /* 88 Timer Counter Control 0 IRQ 3 */ 352 void* pfnTCC0_4_Handler; /* 89 Timer Counter Control 0 IRQ 4 */ 353 void* pfnTCC0_5_Handler; /* 90 Timer Counter Control 0 IRQ 5 */ 354 void* pfnTCC0_6_Handler; /* 91 Timer Counter Control 0 IRQ 6 */ 355 void* pfnTCC1_0_Handler; /* 92 Timer Counter Control 1 IRQ 0 */ 356 void* pfnTCC1_1_Handler; /* 93 Timer Counter Control 1 IRQ 1 */ 357 void* pfnTCC1_2_Handler; /* 94 Timer Counter Control 1 IRQ 2 */ 358 void* pfnTCC1_3_Handler; /* 95 Timer Counter Control 1 IRQ 3 */ 359 void* pfnTCC1_4_Handler; /* 96 Timer Counter Control 1 IRQ 4 */ 360 void* pfnTCC2_0_Handler; /* 97 Timer Counter Control 2 IRQ 0 */ 361 void* pfnTCC2_1_Handler; /* 98 Timer Counter Control 2 IRQ 1 */ 362 void* pfnTCC2_2_Handler; /* 99 Timer Counter Control 2 IRQ 2 */ 363 void* pfnTCC2_3_Handler; /* 100 Timer Counter Control 2 IRQ 3 */ 364 void* pfnTCC3_0_Handler; /* 101 Timer Counter Control 3 IRQ 0 */ 365 void* pfnTCC3_1_Handler; /* 102 Timer Counter Control 3 IRQ 1 */ 366 void* pfnTCC3_2_Handler; /* 103 Timer Counter Control 3 IRQ 2 */ 367 void* pfnTCC4_0_Handler; /* 104 Timer Counter Control 4 IRQ 0 */ 368 void* pfnTCC4_1_Handler; /* 105 Timer Counter Control 4 IRQ 1 */ 369 void* pfnTCC4_2_Handler; /* 106 Timer Counter Control 4 IRQ 2 */ 370 void* pfnTC0_Handler; /* 107 Basic Timer Counter 0 */ 371 void* pfnTC1_Handler; /* 108 Basic Timer Counter 1 */ 372 void* pfnTC2_Handler; /* 109 Basic Timer Counter 2 */ 373 void* pfnTC3_Handler; /* 110 Basic Timer Counter 3 */ 374 void* pfnTC4_Handler; /* 111 Basic Timer Counter 4 */ 375 void* pfnTC5_Handler; /* 112 Basic Timer Counter 5 */ 376 void* pfnTC6_Handler; /* 113 Basic Timer Counter 6 */ 377 void* pfnTC7_Handler; /* 114 Basic Timer Counter 7 */ 378 void* pfnPDEC_0_Handler; /* 115 Quadrature Decodeur IRQ 0 */ 379 void* pfnPDEC_1_Handler; /* 116 Quadrature Decodeur IRQ 1 */ 380 void* pfnPDEC_2_Handler; /* 117 Quadrature Decodeur IRQ 2 */ 381 void* pfnADC0_0_Handler; /* 118 Analog Digital Converter 0 IRQ 0 */ 382 void* pfnADC0_1_Handler; /* 119 Analog Digital Converter 0 IRQ 1 */ 383 void* pfnADC1_0_Handler; /* 120 Analog Digital Converter 1 IRQ 0 */ 384 void* pfnADC1_1_Handler; /* 121 Analog Digital Converter 1 IRQ 1 */ 385 void* pfnAC_Handler; /* 122 Analog Comparators */ 386 void* pfnDAC_0_Handler; /* 123 Digital-to-Analog Converter IRQ 0 */ 387 void* pfnDAC_1_Handler; /* 124 Digital-to-Analog Converter IRQ 1 */ 388 void* pfnDAC_2_Handler; /* 125 Digital-to-Analog Converter IRQ 2 */ 389 void* pfnDAC_3_Handler; /* 126 Digital-to-Analog Converter IRQ 3 */ 390 void* pfnDAC_4_Handler; /* 127 Digital-to-Analog Converter IRQ 4 */ 391 void* pfnI2S_Handler; /* 128 Inter-IC Sound Interface */ 392 void* pfnPCC_Handler; /* 129 Parallel Capture Controller */ 393 void* pfnAES_Handler; /* 130 Advanced Encryption Standard */ 394 void* pfnTRNG_Handler; /* 131 True Random Generator */ 395 void* pfnICM_Handler; /* 132 Integrity Check Monitor */ 396 void* pfnPUKCC_Handler; /* 133 PUblic-Key Cryptography Controller */ 397 void* pfnQSPI_Handler; /* 134 Quad SPI interface */ 398 void* pfnSDHC0_Handler; /* 135 SD/MMC Host Controller 0 */ 399 void* pfnSDHC1_Handler; /* 136 SD/MMC Host Controller 1 */ 400 } DeviceVectors; 401 402 /* Cortex-M4 processor handlers */ 403 void Reset_Handler ( void ); 404 void NonMaskableInt_Handler ( void ); 405 void HardFault_Handler ( void ); 406 void MemManagement_Handler ( void ); 407 void BusFault_Handler ( void ); 408 void UsageFault_Handler ( void ); 409 void SVCall_Handler ( void ); 410 void DebugMonitor_Handler ( void ); 411 void PendSV_Handler ( void ); 412 void SysTick_Handler ( void ); 413 414 /* Peripherals handlers */ 415 void PM_Handler ( void ); 416 void MCLK_Handler ( void ); 417 void OSCCTRL_0_Handler ( void ); 418 void OSCCTRL_1_Handler ( void ); 419 void OSCCTRL_2_Handler ( void ); 420 void OSCCTRL_3_Handler ( void ); 421 void OSCCTRL_4_Handler ( void ); 422 void OSC32KCTRL_Handler ( void ); 423 void SUPC_0_Handler ( void ); 424 void SUPC_1_Handler ( void ); 425 void WDT_Handler ( void ); 426 void RTC_Handler ( void ); 427 void EIC_0_Handler ( void ); 428 void EIC_1_Handler ( void ); 429 void EIC_2_Handler ( void ); 430 void EIC_3_Handler ( void ); 431 void EIC_4_Handler ( void ); 432 void EIC_5_Handler ( void ); 433 void EIC_6_Handler ( void ); 434 void EIC_7_Handler ( void ); 435 void EIC_8_Handler ( void ); 436 void EIC_9_Handler ( void ); 437 void EIC_10_Handler ( void ); 438 void EIC_11_Handler ( void ); 439 void EIC_12_Handler ( void ); 440 void EIC_13_Handler ( void ); 441 void EIC_14_Handler ( void ); 442 void EIC_15_Handler ( void ); 443 void FREQM_Handler ( void ); 444 void NVMCTRL_0_Handler ( void ); 445 void NVMCTRL_1_Handler ( void ); 446 void DMAC_0_Handler ( void ); 447 void DMAC_1_Handler ( void ); 448 void DMAC_2_Handler ( void ); 449 void DMAC_3_Handler ( void ); 450 void DMAC_4_Handler ( void ); 451 void EVSYS_0_Handler ( void ); 452 void EVSYS_1_Handler ( void ); 453 void EVSYS_2_Handler ( void ); 454 void EVSYS_3_Handler ( void ); 455 void EVSYS_4_Handler ( void ); 456 void PAC_Handler ( void ); 457 void RAMECC_Handler ( void ); 458 void SERCOM0_0_Handler ( void ); 459 void SERCOM0_1_Handler ( void ); 460 void SERCOM0_2_Handler ( void ); 461 void SERCOM0_3_Handler ( void ); 462 void SERCOM1_0_Handler ( void ); 463 void SERCOM1_1_Handler ( void ); 464 void SERCOM1_2_Handler ( void ); 465 void SERCOM1_3_Handler ( void ); 466 void SERCOM2_0_Handler ( void ); 467 void SERCOM2_1_Handler ( void ); 468 void SERCOM2_2_Handler ( void ); 469 void SERCOM2_3_Handler ( void ); 470 void SERCOM3_0_Handler ( void ); 471 void SERCOM3_1_Handler ( void ); 472 void SERCOM3_2_Handler ( void ); 473 void SERCOM3_3_Handler ( void ); 474 void SERCOM4_0_Handler ( void ); 475 void SERCOM4_1_Handler ( void ); 476 void SERCOM4_2_Handler ( void ); 477 void SERCOM4_3_Handler ( void ); 478 void SERCOM5_0_Handler ( void ); 479 void SERCOM5_1_Handler ( void ); 480 void SERCOM5_2_Handler ( void ); 481 void SERCOM5_3_Handler ( void ); 482 void SERCOM6_0_Handler ( void ); 483 void SERCOM6_1_Handler ( void ); 484 void SERCOM6_2_Handler ( void ); 485 void SERCOM6_3_Handler ( void ); 486 void SERCOM7_0_Handler ( void ); 487 void SERCOM7_1_Handler ( void ); 488 void SERCOM7_2_Handler ( void ); 489 void SERCOM7_3_Handler ( void ); 490 void USB_0_Handler ( void ); 491 void USB_1_Handler ( void ); 492 void USB_2_Handler ( void ); 493 void USB_3_Handler ( void ); 494 void GMAC_Handler ( void ); 495 void TCC0_0_Handler ( void ); 496 void TCC0_1_Handler ( void ); 497 void TCC0_2_Handler ( void ); 498 void TCC0_3_Handler ( void ); 499 void TCC0_4_Handler ( void ); 500 void TCC0_5_Handler ( void ); 501 void TCC0_6_Handler ( void ); 502 void TCC1_0_Handler ( void ); 503 void TCC1_1_Handler ( void ); 504 void TCC1_2_Handler ( void ); 505 void TCC1_3_Handler ( void ); 506 void TCC1_4_Handler ( void ); 507 void TCC2_0_Handler ( void ); 508 void TCC2_1_Handler ( void ); 509 void TCC2_2_Handler ( void ); 510 void TCC2_3_Handler ( void ); 511 void TCC3_0_Handler ( void ); 512 void TCC3_1_Handler ( void ); 513 void TCC3_2_Handler ( void ); 514 void TCC4_0_Handler ( void ); 515 void TCC4_1_Handler ( void ); 516 void TCC4_2_Handler ( void ); 517 void TC0_Handler ( void ); 518 void TC1_Handler ( void ); 519 void TC2_Handler ( void ); 520 void TC3_Handler ( void ); 521 void TC4_Handler ( void ); 522 void TC5_Handler ( void ); 523 void TC6_Handler ( void ); 524 void TC7_Handler ( void ); 525 void PDEC_0_Handler ( void ); 526 void PDEC_1_Handler ( void ); 527 void PDEC_2_Handler ( void ); 528 void ADC0_0_Handler ( void ); 529 void ADC0_1_Handler ( void ); 530 void ADC1_0_Handler ( void ); 531 void ADC1_1_Handler ( void ); 532 void AC_Handler ( void ); 533 void DAC_0_Handler ( void ); 534 void DAC_1_Handler ( void ); 535 void DAC_2_Handler ( void ); 536 void DAC_3_Handler ( void ); 537 void DAC_4_Handler ( void ); 538 void I2S_Handler ( void ); 539 void PCC_Handler ( void ); 540 void AES_Handler ( void ); 541 void TRNG_Handler ( void ); 542 void ICM_Handler ( void ); 543 void PUKCC_Handler ( void ); 544 void QSPI_Handler ( void ); 545 void SDHC0_Handler ( void ); 546 void SDHC1_Handler ( void ); 547 548 /* 549 * \brief Configuration of the Cortex-M4 Processor and Core Peripherals 550 */ 551 552 #define __CM4_REV 1 /*!< Core revision r0p1 */ 553 #define __DEBUG_LVL 3 /*!< Full debug plus DWT data matching */ 554 #define __FPU_PRESENT 1 /*!< FPU present or not */ 555 #define __MPU_PRESENT 1 /*!< MPU present or not */ 556 #define __NVIC_PRIO_BITS 3 /*!< Number of bits used for Priority Levels */ 557 #define __TRACE_LVL 2 /*!< Full trace: ITM, DWT triggers and counters, ETM */ 558 #define __VTOR_PRESENT 1 /*!< VTOR present or not */ 559 #define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ 560 561 /** 562 * \brief CMSIS includes 563 */ 564 565 #include <core_cm4.h> 566 #if !defined DONT_USE_CMSIS_INIT 567 #include "system_same53.h" 568 #endif /* DONT_USE_CMSIS_INIT */ 569 570 /*@}*/ 571 572 /* ************************************************************************** */ 573 /** SOFTWARE PERIPHERAL API DEFINITION FOR SAME53N20A */ 574 /* ************************************************************************** */ 575 /** \defgroup SAME53N20A_api Peripheral Software API */ 576 /*@{*/ 577 578 #include "component/ac.h" 579 #include "component/adc.h" 580 #include "component/aes.h" 581 #include "component/ccl.h" 582 #include "component/cmcc.h" 583 #include "component/dac.h" 584 #include "component/dmac.h" 585 #include "component/dsu.h" 586 #include "component/eic.h" 587 #include "component/evsys.h" 588 #include "component/freqm.h" 589 #include "component/gclk.h" 590 #include "component/gmac.h" 591 #include "component/hmatrixb.h" 592 #include "component/icm.h" 593 #include "component/i2s.h" 594 #include "component/mclk.h" 595 #include "component/nvmctrl.h" 596 #include "component/oscctrl.h" 597 #include "component/osc32kctrl.h" 598 #include "component/pac.h" 599 #include "component/pcc.h" 600 #include "component/pdec.h" 601 #include "component/pm.h" 602 #include "component/port.h" 603 #include "component/qspi.h" 604 #include "component/ramecc.h" 605 #include "component/rstc.h" 606 #include "component/rtc.h" 607 #include "component/sdhc.h" 608 #include "component/sercom.h" 609 #include "component/supc.h" 610 #include "component/tc.h" 611 #include "component/tcc.h" 612 #include "component/trng.h" 613 #include "component/usb.h" 614 #include "component/wdt.h" 615 /*@}*/ 616 617 /* ************************************************************************** */ 618 /** REGISTERS ACCESS DEFINITIONS FOR SAME53N20A */ 619 /* ************************************************************************** */ 620 /** \defgroup SAME53N20A_reg Registers Access Definitions */ 621 /*@{*/ 622 623 #include "instance/ac.h" 624 #include "instance/adc0.h" 625 #include "instance/adc1.h" 626 #include "instance/aes.h" 627 #include "instance/ccl.h" 628 #include "instance/cmcc.h" 629 #include "instance/dac.h" 630 #include "instance/dmac.h" 631 #include "instance/dsu.h" 632 #include "instance/eic.h" 633 #include "instance/evsys.h" 634 #include "instance/freqm.h" 635 #include "instance/gclk.h" 636 #include "instance/gmac.h" 637 #include "instance/hmatrix.h" 638 #include "instance/icm.h" 639 #include "instance/i2s.h" 640 #include "instance/mclk.h" 641 #include "instance/nvmctrl.h" 642 #include "instance/oscctrl.h" 643 #include "instance/osc32kctrl.h" 644 #include "instance/pac.h" 645 #include "instance/pcc.h" 646 #include "instance/pdec.h" 647 #include "instance/pm.h" 648 #include "instance/port.h" 649 #include "instance/pukcc.h" 650 #include "instance/qspi.h" 651 #include "instance/ramecc.h" 652 #include "instance/rstc.h" 653 #include "instance/rtc.h" 654 #include "instance/sdhc0.h" 655 #include "instance/sdhc1.h" 656 #include "instance/sercom0.h" 657 #include "instance/sercom1.h" 658 #include "instance/sercom2.h" 659 #include "instance/sercom3.h" 660 #include "instance/sercom4.h" 661 #include "instance/sercom5.h" 662 #include "instance/sercom6.h" 663 #include "instance/sercom7.h" 664 #include "instance/supc.h" 665 #include "instance/tc0.h" 666 #include "instance/tc1.h" 667 #include "instance/tc2.h" 668 #include "instance/tc3.h" 669 #include "instance/tc4.h" 670 #include "instance/tc5.h" 671 #include "instance/tc6.h" 672 #include "instance/tc7.h" 673 #include "instance/tcc0.h" 674 #include "instance/tcc1.h" 675 #include "instance/tcc2.h" 676 #include "instance/tcc3.h" 677 #include "instance/tcc4.h" 678 #include "instance/trng.h" 679 #include "instance/usb.h" 680 #include "instance/wdt.h" 681 /*@}*/ 682 683 /* ************************************************************************** */ 684 /** PERIPHERAL ID DEFINITIONS FOR SAME53N20A */ 685 /* ************************************************************************** */ 686 /** \defgroup SAME53N20A_id Peripheral Ids Definitions */ 687 /*@{*/ 688 689 // Peripheral instances on HPB0 bridge 690 #define ID_PAC 0 /**< \brief Peripheral Access Controller (PAC) */ 691 #define ID_PM 1 /**< \brief Power Manager (PM) */ 692 #define ID_MCLK 2 /**< \brief Main Clock (MCLK) */ 693 #define ID_RSTC 3 /**< \brief Reset Controller (RSTC) */ 694 #define ID_OSCCTRL 4 /**< \brief Oscillators Control (OSCCTRL) */ 695 #define ID_OSC32KCTRL 5 /**< \brief 32kHz Oscillators Control (OSC32KCTRL) */ 696 #define ID_SUPC 6 /**< \brief Supply Controller (SUPC) */ 697 #define ID_GCLK 7 /**< \brief Generic Clock Generator (GCLK) */ 698 #define ID_WDT 8 /**< \brief Watchdog Timer (WDT) */ 699 #define ID_RTC 9 /**< \brief Real-Time Counter (RTC) */ 700 #define ID_EIC 10 /**< \brief External Interrupt Controller (EIC) */ 701 #define ID_FREQM 11 /**< \brief Frequency Meter (FREQM) */ 702 #define ID_SERCOM0 12 /**< \brief Serial Communication Interface 0 (SERCOM0) */ 703 #define ID_SERCOM1 13 /**< \brief Serial Communication Interface 1 (SERCOM1) */ 704 #define ID_TC0 14 /**< \brief Basic Timer Counter 0 (TC0) */ 705 #define ID_TC1 15 /**< \brief Basic Timer Counter 1 (TC1) */ 706 707 // Peripheral instances on HPB1 bridge 708 #define ID_USB 32 /**< \brief Universal Serial Bus (USB) */ 709 #define ID_DSU 33 /**< \brief Device Service Unit (DSU) */ 710 #define ID_NVMCTRL 34 /**< \brief Non-Volatile Memory Controller (NVMCTRL) */ 711 #define ID_CMCC 35 /**< \brief Cortex M Cache Controller (CMCC) */ 712 #define ID_PORT 36 /**< \brief Port Module (PORT) */ 713 #define ID_DMAC 37 /**< \brief Direct Memory Access Controller (DMAC) */ 714 #define ID_HMATRIX 38 /**< \brief HSB Matrix (HMATRIX) */ 715 #define ID_EVSYS 39 /**< \brief Event System Interface (EVSYS) */ 716 #define ID_SERCOM2 41 /**< \brief Serial Communication Interface 2 (SERCOM2) */ 717 #define ID_SERCOM3 42 /**< \brief Serial Communication Interface 3 (SERCOM3) */ 718 #define ID_TCC0 43 /**< \brief Timer Counter Control 0 (TCC0) */ 719 #define ID_TCC1 44 /**< \brief Timer Counter Control 1 (TCC1) */ 720 #define ID_TC2 45 /**< \brief Basic Timer Counter 2 (TC2) */ 721 #define ID_TC3 46 /**< \brief Basic Timer Counter 3 (TC3) */ 722 #define ID_RAMECC 48 /**< \brief RAM ECC (RAMECC) */ 723 724 // Peripheral instances on HPB2 bridge 725 #define ID_GMAC 66 /**< \brief Ethernet MAC (GMAC) */ 726 #define ID_TCC2 67 /**< \brief Timer Counter Control 2 (TCC2) */ 727 #define ID_TCC3 68 /**< \brief Timer Counter Control 3 (TCC3) */ 728 #define ID_TC4 69 /**< \brief Basic Timer Counter 4 (TC4) */ 729 #define ID_TC5 70 /**< \brief Basic Timer Counter 5 (TC5) */ 730 #define ID_PDEC 71 /**< \brief Quadrature Decodeur (PDEC) */ 731 #define ID_AC 72 /**< \brief Analog Comparators (AC) */ 732 #define ID_AES 73 /**< \brief Advanced Encryption Standard (AES) */ 733 #define ID_TRNG 74 /**< \brief True Random Generator (TRNG) */ 734 #define ID_ICM 75 /**< \brief Integrity Check Monitor (ICM) */ 735 #define ID_PUKCC 76 /**< \brief PUblic-Key Cryptography Controller (PUKCC) */ 736 #define ID_QSPI 77 /**< \brief Quad SPI interface (QSPI) */ 737 #define ID_CCL 78 /**< \brief Configurable Custom Logic (CCL) */ 738 739 // Peripheral instances on HPB3 bridge 740 #define ID_SERCOM4 96 /**< \brief Serial Communication Interface 4 (SERCOM4) */ 741 #define ID_SERCOM5 97 /**< \brief Serial Communication Interface 5 (SERCOM5) */ 742 #define ID_SERCOM6 98 /**< \brief Serial Communication Interface 6 (SERCOM6) */ 743 #define ID_SERCOM7 99 /**< \brief Serial Communication Interface 7 (SERCOM7) */ 744 #define ID_TCC4 100 /**< \brief Timer Counter Control 4 (TCC4) */ 745 #define ID_TC6 101 /**< \brief Basic Timer Counter 6 (TC6) */ 746 #define ID_TC7 102 /**< \brief Basic Timer Counter 7 (TC7) */ 747 #define ID_ADC0 103 /**< \brief Analog Digital Converter 0 (ADC0) */ 748 #define ID_ADC1 104 /**< \brief Analog Digital Converter 1 (ADC1) */ 749 #define ID_DAC 105 /**< \brief Digital-to-Analog Converter (DAC) */ 750 #define ID_I2S 106 /**< \brief Inter-IC Sound Interface (I2S) */ 751 #define ID_PCC 107 /**< \brief Parallel Capture Controller (PCC) */ 752 753 // Peripheral instances on AHB (as if on bridge 4) 754 #define ID_SDHC0 128 /**< \brief SD/MMC Host Controller (SDHC0) */ 755 #define ID_SDHC1 129 /**< \brief SD/MMC Host Controller (SDHC1) */ 756 757 #define ID_PERIPH_COUNT 130 /**< \brief Max number of peripheral IDs */ 758 /*@}*/ 759 760 /* ************************************************************************** */ 761 /** BASE ADDRESS DEFINITIONS FOR SAME53N20A */ 762 /* ************************************************************************** */ 763 /** \defgroup SAME53N20A_base Peripheral Base Address Definitions */ 764 /*@{*/ 765 766 #if defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__) 767 #define AC (0x42002000) /**< \brief (AC) APB Base Address */ 768 #define ADC0 (0x43001C00) /**< \brief (ADC0) APB Base Address */ 769 #define ADC1 (0x43002000) /**< \brief (ADC1) APB Base Address */ 770 #define AES (0x42002400) /**< \brief (AES) APB Base Address */ 771 #define CCL (0x42003800) /**< \brief (CCL) APB Base Address */ 772 #define CMCC (0x41006000) /**< \brief (CMCC) APB Base Address */ 773 #define CMCC_AHB (0x03000000) /**< \brief (CMCC) AHB Base Address */ 774 #define DAC (0x43002400) /**< \brief (DAC) APB Base Address */ 775 #define DMAC (0x4100A000) /**< \brief (DMAC) APB Base Address */ 776 #define DSU (0x41002000) /**< \brief (DSU) APB Base Address */ 777 #define EIC (0x40002800) /**< \brief (EIC) APB Base Address */ 778 #define EVSYS (0x4100E000) /**< \brief (EVSYS) APB Base Address */ 779 #define FREQM (0x40002C00) /**< \brief (FREQM) APB Base Address */ 780 #define GCLK (0x40001C00) /**< \brief (GCLK) APB Base Address */ 781 #define GMAC (0x42000800) /**< \brief (GMAC) APB Base Address */ 782 #define HMATRIX (0x4100C000) /**< \brief (HMATRIX) APB Base Address */ 783 #define ICM (0x42002C00) /**< \brief (ICM) APB Base Address */ 784 #define I2S (0x43002800) /**< \brief (I2S) APB Base Address */ 785 #define MCLK (0x40000800) /**< \brief (MCLK) APB Base Address */ 786 #define NVMCTRL (0x41004000) /**< \brief (NVMCTRL) APB Base Address */ 787 #define NVMCTRL_SW0 (0x00800080) /**< \brief (NVMCTRL) SW0 Base Address */ 788 #define NVMCTRL_TEMP_LOG (0x00800100) /**< \brief (NVMCTRL) TEMP_LOG Base Address */ 789 #define NVMCTRL_USER (0x00804000) /**< \brief (NVMCTRL) USER Base Address */ 790 #define OSCCTRL (0x40001000) /**< \brief (OSCCTRL) APB Base Address */ 791 #define OSC32KCTRL (0x40001400) /**< \brief (OSC32KCTRL) APB Base Address */ 792 #define PAC (0x40000000) /**< \brief (PAC) APB Base Address */ 793 #define PCC (0x43002C00) /**< \brief (PCC) APB Base Address */ 794 #define PDEC (0x42001C00) /**< \brief (PDEC) APB Base Address */ 795 #define PM (0x40000400) /**< \brief (PM) APB Base Address */ 796 #define PORT (0x41008000) /**< \brief (PORT) APB Base Address */ 797 #define PUKCC (0x42003000) /**< \brief (PUKCC) APB Base Address */ 798 #define PUKCC_AHB (0x02000000) /**< \brief (PUKCC) AHB Base Address */ 799 #define QSPI (0x42003400) /**< \brief (QSPI) APB Base Address */ 800 #define QSPI_AHB (0x04000000) /**< \brief (QSPI) AHB Base Address */ 801 #define RAMECC (0x41020000) /**< \brief (RAMECC) APB Base Address */ 802 #define RSTC (0x40000C00) /**< \brief (RSTC) APB Base Address */ 803 #define RTC (0x40002400) /**< \brief (RTC) APB Base Address */ 804 #define SDHC0 (0x45000000) /**< \brief (SDHC0) AHB Base Address */ 805 #define SDHC1 (0x46000000) /**< \brief (SDHC1) AHB Base Address */ 806 #define SERCOM0 (0x40003000) /**< \brief (SERCOM0) APB Base Address */ 807 #define SERCOM1 (0x40003400) /**< \brief (SERCOM1) APB Base Address */ 808 #define SERCOM2 (0x41012000) /**< \brief (SERCOM2) APB Base Address */ 809 #define SERCOM3 (0x41014000) /**< \brief (SERCOM3) APB Base Address */ 810 #define SERCOM4 (0x43000000) /**< \brief (SERCOM4) APB Base Address */ 811 #define SERCOM5 (0x43000400) /**< \brief (SERCOM5) APB Base Address */ 812 #define SERCOM6 (0x43000800) /**< \brief (SERCOM6) APB Base Address */ 813 #define SERCOM7 (0x43000C00) /**< \brief (SERCOM7) APB Base Address */ 814 #define SUPC (0x40001800) /**< \brief (SUPC) APB Base Address */ 815 #define TC0 (0x40003800) /**< \brief (TC0) APB Base Address */ 816 #define TC1 (0x40003C00) /**< \brief (TC1) APB Base Address */ 817 #define TC2 (0x4101A000) /**< \brief (TC2) APB Base Address */ 818 #define TC3 (0x4101C000) /**< \brief (TC3) APB Base Address */ 819 #define TC4 (0x42001400) /**< \brief (TC4) APB Base Address */ 820 #define TC5 (0x42001800) /**< \brief (TC5) APB Base Address */ 821 #define TC6 (0x43001400) /**< \brief (TC6) APB Base Address */ 822 #define TC7 (0x43001800) /**< \brief (TC7) APB Base Address */ 823 #define TCC0 (0x41016000) /**< \brief (TCC0) APB Base Address */ 824 #define TCC1 (0x41018000) /**< \brief (TCC1) APB Base Address */ 825 #define TCC2 (0x42000C00) /**< \brief (TCC2) APB Base Address */ 826 #define TCC3 (0x42001000) /**< \brief (TCC3) APB Base Address */ 827 #define TCC4 (0x43001000) /**< \brief (TCC4) APB Base Address */ 828 #define TRNG (0x42002800) /**< \brief (TRNG) APB Base Address */ 829 #define USB (0x41000000) /**< \brief (USB) APB Base Address */ 830 #define WDT (0x40002000) /**< \brief (WDT) APB Base Address */ 831 #else 832 #define AC ((Ac *)0x42002000UL) /**< \brief (AC) APB Base Address */ 833 #define AC_INST_NUM 1 /**< \brief (AC) Number of instances */ 834 #define AC_INSTS { AC } /**< \brief (AC) Instances List */ 835 836 #define ADC0 ((Adc *)0x43001C00UL) /**< \brief (ADC0) APB Base Address */ 837 #define ADC1 ((Adc *)0x43002000UL) /**< \brief (ADC1) APB Base Address */ 838 #define ADC_INST_NUM 2 /**< \brief (ADC) Number of instances */ 839 #define ADC_INSTS { ADC0, ADC1 } /**< \brief (ADC) Instances List */ 840 841 #define AES ((Aes *)0x42002400UL) /**< \brief (AES) APB Base Address */ 842 #define AES_INST_NUM 1 /**< \brief (AES) Number of instances */ 843 #define AES_INSTS { AES } /**< \brief (AES) Instances List */ 844 845 #define CCL ((Ccl *)0x42003800UL) /**< \brief (CCL) APB Base Address */ 846 #define CCL_INST_NUM 1 /**< \brief (CCL) Number of instances */ 847 #define CCL_INSTS { CCL } /**< \brief (CCL) Instances List */ 848 849 #define CMCC ((Cmcc *)0x41006000UL) /**< \brief (CMCC) APB Base Address */ 850 #define CMCC_AHB (0x03000000UL) /**< \brief (CMCC) AHB Base Address */ 851 #define CMCC_INST_NUM 1 /**< \brief (CMCC) Number of instances */ 852 #define CMCC_INSTS { CMCC } /**< \brief (CMCC) Instances List */ 853 854 #define DAC ((Dac *)0x43002400UL) /**< \brief (DAC) APB Base Address */ 855 #define DAC_INST_NUM 1 /**< \brief (DAC) Number of instances */ 856 #define DAC_INSTS { DAC } /**< \brief (DAC) Instances List */ 857 858 #define DMAC ((Dmac *)0x4100A000UL) /**< \brief (DMAC) APB Base Address */ 859 #define DMAC_INST_NUM 1 /**< \brief (DMAC) Number of instances */ 860 #define DMAC_INSTS { DMAC } /**< \brief (DMAC) Instances List */ 861 862 #define DSU ((Dsu *)0x41002000UL) /**< \brief (DSU) APB Base Address */ 863 #define DSU_INST_NUM 1 /**< \brief (DSU) Number of instances */ 864 #define DSU_INSTS { DSU } /**< \brief (DSU) Instances List */ 865 866 #define EIC ((Eic *)0x40002800UL) /**< \brief (EIC) APB Base Address */ 867 #define EIC_INST_NUM 1 /**< \brief (EIC) Number of instances */ 868 #define EIC_INSTS { EIC } /**< \brief (EIC) Instances List */ 869 870 #define EVSYS ((Evsys *)0x4100E000UL) /**< \brief (EVSYS) APB Base Address */ 871 #define EVSYS_INST_NUM 1 /**< \brief (EVSYS) Number of instances */ 872 #define EVSYS_INSTS { EVSYS } /**< \brief (EVSYS) Instances List */ 873 874 #define FREQM ((Freqm *)0x40002C00UL) /**< \brief (FREQM) APB Base Address */ 875 #define FREQM_INST_NUM 1 /**< \brief (FREQM) Number of instances */ 876 #define FREQM_INSTS { FREQM } /**< \brief (FREQM) Instances List */ 877 878 #define GCLK ((Gclk *)0x40001C00UL) /**< \brief (GCLK) APB Base Address */ 879 #define GCLK_INST_NUM 1 /**< \brief (GCLK) Number of instances */ 880 #define GCLK_INSTS { GCLK } /**< \brief (GCLK) Instances List */ 881 882 #define GMAC ((Gmac *)0x42000800UL) /**< \brief (GMAC) APB Base Address */ 883 #define GMAC_INST_NUM 1 /**< \brief (GMAC) Number of instances */ 884 #define GMAC_INSTS { GMAC } /**< \brief (GMAC) Instances List */ 885 886 #define HMATRIX ((Hmatrixb *)0x4100C000UL) /**< \brief (HMATRIX) APB Base Address */ 887 #define HMATRIXB_INST_NUM 1 /**< \brief (HMATRIXB) Number of instances */ 888 #define HMATRIXB_INSTS { HMATRIX } /**< \brief (HMATRIXB) Instances List */ 889 890 #define ICM ((Icm *)0x42002C00UL) /**< \brief (ICM) APB Base Address */ 891 #define ICM_INST_NUM 1 /**< \brief (ICM) Number of instances */ 892 #define ICM_INSTS { ICM } /**< \brief (ICM) Instances List */ 893 894 #define I2S ((I2s *)0x43002800UL) /**< \brief (I2S) APB Base Address */ 895 #define I2S_INST_NUM 1 /**< \brief (I2S) Number of instances */ 896 #define I2S_INSTS { I2S } /**< \brief (I2S) Instances List */ 897 898 #define MCLK ((Mclk *)0x40000800UL) /**< \brief (MCLK) APB Base Address */ 899 #define MCLK_INST_NUM 1 /**< \brief (MCLK) Number of instances */ 900 #define MCLK_INSTS { MCLK } /**< \brief (MCLK) Instances List */ 901 902 #define NVMCTRL ((Nvmctrl *)0x41004000UL) /**< \brief (NVMCTRL) APB Base Address */ 903 #define NVMCTRL_SW0 (0x00800080UL) /**< \brief (NVMCTRL) SW0 Base Address */ 904 #define NVMCTRL_TEMP_LOG (0x00800100UL) /**< \brief (NVMCTRL) TEMP_LOG Base Address */ 905 #define NVMCTRL_USER (0x00804000UL) /**< \brief (NVMCTRL) USER Base Address */ 906 #define NVMCTRL_INST_NUM 1 /**< \brief (NVMCTRL) Number of instances */ 907 #define NVMCTRL_INSTS { NVMCTRL } /**< \brief (NVMCTRL) Instances List */ 908 909 #define OSCCTRL ((Oscctrl *)0x40001000UL) /**< \brief (OSCCTRL) APB Base Address */ 910 #define OSCCTRL_INST_NUM 1 /**< \brief (OSCCTRL) Number of instances */ 911 #define OSCCTRL_INSTS { OSCCTRL } /**< \brief (OSCCTRL) Instances List */ 912 913 #define OSC32KCTRL ((Osc32kctrl *)0x40001400UL) /**< \brief (OSC32KCTRL) APB Base Address */ 914 #define OSC32KCTRL_INST_NUM 1 /**< \brief (OSC32KCTRL) Number of instances */ 915 #define OSC32KCTRL_INSTS { OSC32KCTRL } /**< \brief (OSC32KCTRL) Instances List */ 916 917 #define PAC ((Pac *)0x40000000UL) /**< \brief (PAC) APB Base Address */ 918 #define PAC_INST_NUM 1 /**< \brief (PAC) Number of instances */ 919 #define PAC_INSTS { PAC } /**< \brief (PAC) Instances List */ 920 921 #define PCC ((Pcc *)0x43002C00UL) /**< \brief (PCC) APB Base Address */ 922 #define PCC_INST_NUM 1 /**< \brief (PCC) Number of instances */ 923 #define PCC_INSTS { PCC } /**< \brief (PCC) Instances List */ 924 925 #define PDEC ((Pdec *)0x42001C00UL) /**< \brief (PDEC) APB Base Address */ 926 #define PDEC_INST_NUM 1 /**< \brief (PDEC) Number of instances */ 927 #define PDEC_INSTS { PDEC } /**< \brief (PDEC) Instances List */ 928 929 #define PM ((Pm *)0x40000400UL) /**< \brief (PM) APB Base Address */ 930 #define PM_INST_NUM 1 /**< \brief (PM) Number of instances */ 931 #define PM_INSTS { PM } /**< \brief (PM) Instances List */ 932 933 #define PORT ((Port *)0x41008000UL) /**< \brief (PORT) APB Base Address */ 934 #define PORT_INST_NUM 1 /**< \brief (PORT) Number of instances */ 935 #define PORT_INSTS { PORT } /**< \brief (PORT) Instances List */ 936 937 #define PUKCC ((void *)0x42003000UL) /**< \brief (PUKCC) APB Base Address */ 938 #define PUKCC_AHB ((void *)0x02000000UL) /**< \brief (PUKCC) AHB Base Address */ 939 #define PUKCC_INST_NUM 1 /**< \brief (PUKCC) Number of instances */ 940 #define PUKCC_INSTS { PUKCC } /**< \brief (PUKCC) Instances List */ 941 942 #define QSPI ((Qspi *)0x42003400UL) /**< \brief (QSPI) APB Base Address */ 943 #define QSPI_AHB (0x04000000UL) /**< \brief (QSPI) AHB Base Address */ 944 #define QSPI_INST_NUM 1 /**< \brief (QSPI) Number of instances */ 945 #define QSPI_INSTS { QSPI } /**< \brief (QSPI) Instances List */ 946 947 #define RAMECC ((Ramecc *)0x41020000UL) /**< \brief (RAMECC) APB Base Address */ 948 #define RAMECC_INST_NUM 1 /**< \brief (RAMECC) Number of instances */ 949 #define RAMECC_INSTS { RAMECC } /**< \brief (RAMECC) Instances List */ 950 951 #define RSTC ((Rstc *)0x40000C00UL) /**< \brief (RSTC) APB Base Address */ 952 #define RSTC_INST_NUM 1 /**< \brief (RSTC) Number of instances */ 953 #define RSTC_INSTS { RSTC } /**< \brief (RSTC) Instances List */ 954 955 #define RTC ((Rtc *)0x40002400UL) /**< \brief (RTC) APB Base Address */ 956 #define RTC_INST_NUM 1 /**< \brief (RTC) Number of instances */ 957 #define RTC_INSTS { RTC } /**< \brief (RTC) Instances List */ 958 959 #define SDHC0 ((Sdhc *)0x45000000UL) /**< \brief (SDHC0) AHB Base Address */ 960 #define SDHC1 ((Sdhc *)0x46000000UL) /**< \brief (SDHC1) AHB Base Address */ 961 #define SDHC_INST_NUM 2 /**< \brief (SDHC) Number of instances */ 962 #define SDHC_INSTS { SDHC0, SDHC1 } /**< \brief (SDHC) Instances List */ 963 964 #define SERCOM0 ((Sercom *)0x40003000UL) /**< \brief (SERCOM0) APB Base Address */ 965 #define SERCOM1 ((Sercom *)0x40003400UL) /**< \brief (SERCOM1) APB Base Address */ 966 #define SERCOM2 ((Sercom *)0x41012000UL) /**< \brief (SERCOM2) APB Base Address */ 967 #define SERCOM3 ((Sercom *)0x41014000UL) /**< \brief (SERCOM3) APB Base Address */ 968 #define SERCOM4 ((Sercom *)0x43000000UL) /**< \brief (SERCOM4) APB Base Address */ 969 #define SERCOM5 ((Sercom *)0x43000400UL) /**< \brief (SERCOM5) APB Base Address */ 970 #define SERCOM6 ((Sercom *)0x43000800UL) /**< \brief (SERCOM6) APB Base Address */ 971 #define SERCOM7 ((Sercom *)0x43000C00UL) /**< \brief (SERCOM7) APB Base Address */ 972 #define SERCOM_INST_NUM 8 /**< \brief (SERCOM) Number of instances */ 973 #define SERCOM_INSTS { SERCOM0, SERCOM1, SERCOM2, SERCOM3, SERCOM4, SERCOM5, SERCOM6, SERCOM7 } /**< \brief (SERCOM) Instances List */ 974 975 #define SUPC ((Supc *)0x40001800UL) /**< \brief (SUPC) APB Base Address */ 976 #define SUPC_INST_NUM 1 /**< \brief (SUPC) Number of instances */ 977 #define SUPC_INSTS { SUPC } /**< \brief (SUPC) Instances List */ 978 979 #define TC0 ((Tc *)0x40003800UL) /**< \brief (TC0) APB Base Address */ 980 #define TC1 ((Tc *)0x40003C00UL) /**< \brief (TC1) APB Base Address */ 981 #define TC2 ((Tc *)0x4101A000UL) /**< \brief (TC2) APB Base Address */ 982 #define TC3 ((Tc *)0x4101C000UL) /**< \brief (TC3) APB Base Address */ 983 #define TC4 ((Tc *)0x42001400UL) /**< \brief (TC4) APB Base Address */ 984 #define TC5 ((Tc *)0x42001800UL) /**< \brief (TC5) APB Base Address */ 985 #define TC6 ((Tc *)0x43001400UL) /**< \brief (TC6) APB Base Address */ 986 #define TC7 ((Tc *)0x43001800UL) /**< \brief (TC7) APB Base Address */ 987 #define TC_INST_NUM 8 /**< \brief (TC) Number of instances */ 988 #define TC_INSTS { TC0, TC1, TC2, TC3, TC4, TC5, TC6, TC7 } /**< \brief (TC) Instances List */ 989 990 #define TCC0 ((Tcc *)0x41016000UL) /**< \brief (TCC0) APB Base Address */ 991 #define TCC1 ((Tcc *)0x41018000UL) /**< \brief (TCC1) APB Base Address */ 992 #define TCC2 ((Tcc *)0x42000C00UL) /**< \brief (TCC2) APB Base Address */ 993 #define TCC3 ((Tcc *)0x42001000UL) /**< \brief (TCC3) APB Base Address */ 994 #define TCC4 ((Tcc *)0x43001000UL) /**< \brief (TCC4) APB Base Address */ 995 #define TCC_INST_NUM 5 /**< \brief (TCC) Number of instances */ 996 #define TCC_INSTS { TCC0, TCC1, TCC2, TCC3, TCC4 } /**< \brief (TCC) Instances List */ 997 998 #define TRNG ((Trng *)0x42002800UL) /**< \brief (TRNG) APB Base Address */ 999 #define TRNG_INST_NUM 1 /**< \brief (TRNG) Number of instances */ 1000 #define TRNG_INSTS { TRNG } /**< \brief (TRNG) Instances List */ 1001 1002 #define USB ((Usb *)0x41000000UL) /**< \brief (USB) APB Base Address */ 1003 #define USB_INST_NUM 1 /**< \brief (USB) Number of instances */ 1004 #define USB_INSTS { USB } /**< \brief (USB) Instances List */ 1005 1006 #define WDT ((Wdt *)0x40002000UL) /**< \brief (WDT) APB Base Address */ 1007 #define WDT_INST_NUM 1 /**< \brief (WDT) Number of instances */ 1008 #define WDT_INSTS { WDT } /**< \brief (WDT) Instances List */ 1009 1010 #endif /* (defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */ 1011 /*@}*/ 1012 1013 /* ************************************************************************** */ 1014 /** PORT DEFINITIONS FOR SAME53N20A */ 1015 /* ************************************************************************** */ 1016 /** \defgroup SAME53N20A_port PORT Definitions */ 1017 /*@{*/ 1018 1019 #include "pio/same53n20a.h" 1020 /*@}*/ 1021 1022 /* ************************************************************************** */ 1023 /** MEMORY MAPPING DEFINITIONS FOR SAME53N20A */ 1024 /* ************************************************************************** */ 1025 1026 #define HSRAM_SIZE _UL_(0x00040000) /* 256 kB */ 1027 #define FLASH_SIZE _UL_(0x00100000) /* 1024 kB */ 1028 #define FLASH_PAGE_SIZE 512 1029 #define FLASH_NB_OF_PAGES 2048 1030 #define FLASH_USER_PAGE_SIZE 512 1031 #define BKUPRAM_SIZE _UL_(0x00002000) /* 8 kB */ 1032 #define QSPI_SIZE _UL_(0x01000000) /* 16384 kB */ 1033 1034 #define FLASH_ADDR _UL_(0x00000000) /**< FLASH base address */ 1035 #define CMCC_DATARAM_ADDR _UL_(0x03000000) /**< CMCC_DATARAM base address */ 1036 #define CMCC_DATARAM_SIZE _UL_(0x00001000) /**< CMCC_DATARAM size */ 1037 #define CMCC_TAGRAM_ADDR _UL_(0x03001000) /**< CMCC_TAGRAM base address */ 1038 #define CMCC_TAGRAM_SIZE _UL_(0x00000400) /**< CMCC_TAGRAM size */ 1039 #define CMCC_VALIDRAM_ADDR _UL_(0x03002000) /**< CMCC_VALIDRAM base address */ 1040 #define CMCC_VALIDRAM_SIZE _UL_(0x00000040) /**< CMCC_VALIDRAM size */ 1041 #define HSRAM_ADDR _UL_(0x20000000) /**< HSRAM base address */ 1042 #define HSRAM_ETB_ADDR _UL_(0x20000000) /**< HSRAM_ETB base address */ 1043 #define HSRAM_ETB_SIZE _UL_(0x00008000) /**< HSRAM_ETB size */ 1044 #define HSRAM_RET1_ADDR _UL_(0x20000000) /**< HSRAM_RET1 base address */ 1045 #define HSRAM_RET1_SIZE _UL_(0x00008000) /**< HSRAM_RET1 size */ 1046 #define HPB0_ADDR _UL_(0x40000000) /**< HPB0 base address */ 1047 #define HPB1_ADDR _UL_(0x41000000) /**< HPB1 base address */ 1048 #define HPB2_ADDR _UL_(0x42000000) /**< HPB2 base address */ 1049 #define HPB3_ADDR _UL_(0x43000000) /**< HPB3 base address */ 1050 #define SEEPROM_ADDR _UL_(0x44000000) /**< SEEPROM base address */ 1051 #define BKUPRAM_ADDR _UL_(0x47000000) /**< BKUPRAM base address */ 1052 #define PPB_ADDR _UL_(0xE0000000) /**< PPB base address */ 1053 1054 #define DSU_DID_RESETVALUE _UL_(0x61830302) 1055 #define ADC0_TOUCH_LINES_NUM 32 1056 #define PORT_GROUPS 3 1057 1058 /* ************************************************************************** */ 1059 /** ELECTRICAL DEFINITIONS FOR SAME53N20A */ 1060 /* ************************************************************************** */ 1061 1062 1063 #ifdef __cplusplus 1064 } 1065 #endif 1066 1067 /*@}*/ 1068 1069 #endif /* SAME53N20A_H */ 1070