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