1 /**
2  * \file
3  *
4  * \brief Component description for TAL
5  *
6  * Copyright (c) 2016 Atmel Corporation,
7  *                    a wholly owned subsidiary of Microchip Technology Inc.
8  *
9  * \asf_license_start
10  *
11  * \page License
12  *
13  * Licensed under the Apache License, Version 2.0 (the "License");
14  * you may not use this file except in compliance with the License.
15  * You may obtain a copy of the Licence at
16  *
17  *     http://www.apache.org/licenses/LICENSE-2.0
18  *
19  * Unless required by applicable law or agreed to in writing, software
20  * distributed under the License is distributed on an "AS IS" BASIS,
21  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
22  * See the License for the specific language governing permissions and
23  * limitations under the License.
24  *
25  * \asf_license_stop
26  *
27  */
28 
29 #ifndef _SAML21_TAL_COMPONENT_
30 #define _SAML21_TAL_COMPONENT_
31 
32 /* ========================================================================== */
33 /**  SOFTWARE API DEFINITION FOR TAL */
34 /* ========================================================================== */
35 /** \addtogroup SAML21_TAL Trigger Allocator */
36 /*@{*/
37 
38 #define TAL_U2253
39 #define REV_TAL                     0x102
40 
41 /* -------- TAL_CTRLA : (TAL Offset: 0x00) (R/W  8) Control A -------- */
42 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
43 typedef union {
44   struct {
45     uint8_t  SWRST:1;          /*!< bit:      0  Software Reset                     */
46     uint8_t  ENABLE:1;         /*!< bit:      1  Enable                             */
47     uint8_t  :6;               /*!< bit:  2.. 7  Reserved                           */
48   } bit;                       /*!< Structure used for bit  access                  */
49   uint8_t reg;                 /*!< Type      used for register access              */
50 } TAL_CTRLA_Type;
51 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
52 
53 #define TAL_CTRLA_OFFSET            0x00         /**< \brief (TAL_CTRLA offset) Control A */
54 #define TAL_CTRLA_RESETVALUE        _U(0x00)     /**< \brief (TAL_CTRLA reset_value) Control A */
55 
56 #define TAL_CTRLA_SWRST_Pos         0            /**< \brief (TAL_CTRLA) Software Reset */
57 #define TAL_CTRLA_SWRST             (_U(0x1) << TAL_CTRLA_SWRST_Pos)
58 #define TAL_CTRLA_ENABLE_Pos        1            /**< \brief (TAL_CTRLA) Enable */
59 #define TAL_CTRLA_ENABLE            (_U(0x1) << TAL_CTRLA_ENABLE_Pos)
60 #define TAL_CTRLA_MASK              _U(0x03)     /**< \brief (TAL_CTRLA) MASK Register */
61 
62 /* -------- TAL_RSTCTRL : (TAL Offset: 0x04) (R/W  8) Reset Control -------- */
63 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
64 typedef union {
65   uint8_t reg;                 /*!< Type      used for register access              */
66 } TAL_RSTCTRL_Type;
67 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
68 
69 #define TAL_RSTCTRL_OFFSET          0x04         /**< \brief (TAL_RSTCTRL offset) Reset Control */
70 #define TAL_RSTCTRL_RESETVALUE      _U(0x00)     /**< \brief (TAL_RSTCTRL reset_value) Reset Control */
71 #define TAL_RSTCTRL_MASK            _U(0x00)     /**< \brief (TAL_RSTCTRL) MASK Register */
72 
73 /* -------- TAL_EXTCTRL : (TAL Offset: 0x05) (R/W  8) External Break Control -------- */
74 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
75 typedef union {
76   struct {
77     uint8_t  ENABLE:1;         /*!< bit:      0  Enable BRK Pin                     */
78     uint8_t  INV:1;            /*!< bit:      1  Invert BRK Pin                     */
79     uint8_t  :6;               /*!< bit:  2.. 7  Reserved                           */
80   } bit;                       /*!< Structure used for bit  access                  */
81   uint8_t reg;                 /*!< Type      used for register access              */
82 } TAL_EXTCTRL_Type;
83 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
84 
85 #define TAL_EXTCTRL_OFFSET          0x05         /**< \brief (TAL_EXTCTRL offset) External Break Control */
86 #define TAL_EXTCTRL_RESETVALUE      _U(0x00)     /**< \brief (TAL_EXTCTRL reset_value) External Break Control */
87 
88 #define TAL_EXTCTRL_ENABLE_Pos      0            /**< \brief (TAL_EXTCTRL) Enable BRK Pin */
89 #define TAL_EXTCTRL_ENABLE          (_U(0x1) << TAL_EXTCTRL_ENABLE_Pos)
90 #define TAL_EXTCTRL_INV_Pos         1            /**< \brief (TAL_EXTCTRL) Invert BRK Pin */
91 #define TAL_EXTCTRL_INV             (_U(0x1) << TAL_EXTCTRL_INV_Pos)
92 #define TAL_EXTCTRL_MASK            _U(0x03)     /**< \brief (TAL_EXTCTRL) MASK Register */
93 
94 /* -------- TAL_EVCTRL : (TAL Offset: 0x06) (R/W  8) Event Control -------- */
95 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
96 typedef union {
97   struct {
98     uint8_t  BRKEI:1;          /*!< bit:      0  Break Input Event Enable           */
99     uint8_t  BRKEO:1;          /*!< bit:      1  Break Output Event Enable          */
100     uint8_t  :6;               /*!< bit:  2.. 7  Reserved                           */
101   } bit;                       /*!< Structure used for bit  access                  */
102   uint8_t reg;                 /*!< Type      used for register access              */
103 } TAL_EVCTRL_Type;
104 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
105 
106 #define TAL_EVCTRL_OFFSET           0x06         /**< \brief (TAL_EVCTRL offset) Event Control */
107 #define TAL_EVCTRL_RESETVALUE       _U(0x00)     /**< \brief (TAL_EVCTRL reset_value) Event Control */
108 
109 #define TAL_EVCTRL_BRKEI_Pos        0            /**< \brief (TAL_EVCTRL) Break Input Event Enable */
110 #define TAL_EVCTRL_BRKEI            (_U(0x1) << TAL_EVCTRL_BRKEI_Pos)
111 #define TAL_EVCTRL_BRKEO_Pos        1            /**< \brief (TAL_EVCTRL) Break Output Event Enable */
112 #define TAL_EVCTRL_BRKEO            (_U(0x1) << TAL_EVCTRL_BRKEO_Pos)
113 #define TAL_EVCTRL_MASK             _U(0x03)     /**< \brief (TAL_EVCTRL) MASK Register */
114 
115 /* -------- TAL_INTENCLR : (TAL Offset: 0x08) (R/W  8) Interrupt Enable Clear -------- */
116 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
117 typedef union {
118   struct {
119     uint8_t  BRK:1;            /*!< bit:      0  Break Interrupt Enable             */
120     uint8_t  :7;               /*!< bit:  1.. 7  Reserved                           */
121   } bit;                       /*!< Structure used for bit  access                  */
122   uint8_t reg;                 /*!< Type      used for register access              */
123 } TAL_INTENCLR_Type;
124 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
125 
126 #define TAL_INTENCLR_OFFSET         0x08         /**< \brief (TAL_INTENCLR offset) Interrupt Enable Clear */
127 #define TAL_INTENCLR_RESETVALUE     _U(0x00)     /**< \brief (TAL_INTENCLR reset_value) Interrupt Enable Clear */
128 
129 #define TAL_INTENCLR_BRK_Pos        0            /**< \brief (TAL_INTENCLR) Break Interrupt Enable */
130 #define TAL_INTENCLR_BRK            (_U(0x1) << TAL_INTENCLR_BRK_Pos)
131 #define TAL_INTENCLR_MASK           _U(0x01)     /**< \brief (TAL_INTENCLR) MASK Register */
132 
133 /* -------- TAL_INTENSET : (TAL Offset: 0x09) (R/W  8) Interrupt Enable Set -------- */
134 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
135 typedef union {
136   struct {
137     uint8_t  BRK:1;            /*!< bit:      0  Break Interrupt Enable             */
138     uint8_t  :7;               /*!< bit:  1.. 7  Reserved                           */
139   } bit;                       /*!< Structure used for bit  access                  */
140   uint8_t reg;                 /*!< Type      used for register access              */
141 } TAL_INTENSET_Type;
142 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
143 
144 #define TAL_INTENSET_OFFSET         0x09         /**< \brief (TAL_INTENSET offset) Interrupt Enable Set */
145 #define TAL_INTENSET_RESETVALUE     _U(0x00)     /**< \brief (TAL_INTENSET reset_value) Interrupt Enable Set */
146 
147 #define TAL_INTENSET_BRK_Pos        0            /**< \brief (TAL_INTENSET) Break Interrupt Enable */
148 #define TAL_INTENSET_BRK            (_U(0x1) << TAL_INTENSET_BRK_Pos)
149 #define TAL_INTENSET_MASK           _U(0x01)     /**< \brief (TAL_INTENSET) MASK Register */
150 
151 /* -------- TAL_INTFLAG : (TAL Offset: 0x0A) (R/W  8) Interrupt Flag Status and Clear -------- */
152 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
153 typedef union { // __I to avoid read-modify-write on write-to-clear register
154   struct {
155     __I uint8_t  BRK:1;            /*!< bit:      0  Break                              */
156     __I uint8_t  :7;               /*!< bit:  1.. 7  Reserved                           */
157   } bit;                       /*!< Structure used for bit  access                  */
158   uint8_t reg;                 /*!< Type      used for register access              */
159 } TAL_INTFLAG_Type;
160 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
161 
162 #define TAL_INTFLAG_OFFSET          0x0A         /**< \brief (TAL_INTFLAG offset) Interrupt Flag Status and Clear */
163 #define TAL_INTFLAG_RESETVALUE      _U(0x00)     /**< \brief (TAL_INTFLAG reset_value) Interrupt Flag Status and Clear */
164 
165 #define TAL_INTFLAG_BRK_Pos         0            /**< \brief (TAL_INTFLAG) Break */
166 #define TAL_INTFLAG_BRK             (_U(0x1) << TAL_INTFLAG_BRK_Pos)
167 #define TAL_INTFLAG_MASK            _U(0x01)     /**< \brief (TAL_INTFLAG) MASK Register */
168 
169 /* -------- TAL_GLOBMASK : (TAL Offset: 0x0B) (R/W  8) Global Break Requests Mask -------- */
170 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
171 typedef union {
172   struct {
173     uint8_t  CM0P:1;           /*!< bit:      0  CM0P Break Master                  */
174     uint8_t  PPP:1;            /*!< bit:      1  PPP Break Master                   */
175     uint8_t  :4;               /*!< bit:  2.. 5  Reserved                           */
176     uint8_t  EVBRK:1;          /*!< bit:      6  Event Break Master                 */
177     uint8_t  EXTBRK:1;         /*!< bit:      7  External Break Master              */
178   } bit;                       /*!< Structure used for bit  access                  */
179   uint8_t reg;                 /*!< Type      used for register access              */
180 } TAL_GLOBMASK_Type;
181 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
182 
183 #define TAL_GLOBMASK_OFFSET         0x0B         /**< \brief (TAL_GLOBMASK offset) Global Break Requests Mask */
184 #define TAL_GLOBMASK_RESETVALUE     _U(0x00)     /**< \brief (TAL_GLOBMASK reset_value) Global Break Requests Mask */
185 
186 #define TAL_GLOBMASK_CM0P_Pos       0            /**< \brief (TAL_GLOBMASK) CM0P Break Master */
187 #define TAL_GLOBMASK_CM0P           (_U(0x1) << TAL_GLOBMASK_CM0P_Pos)
188 #define TAL_GLOBMASK_PPP_Pos        1            /**< \brief (TAL_GLOBMASK) PPP Break Master */
189 #define TAL_GLOBMASK_PPP            (_U(0x1) << TAL_GLOBMASK_PPP_Pos)
190 #define TAL_GLOBMASK_EVBRK_Pos      6            /**< \brief (TAL_GLOBMASK) Event Break Master */
191 #define TAL_GLOBMASK_EVBRK          (_U(0x1) << TAL_GLOBMASK_EVBRK_Pos)
192 #define TAL_GLOBMASK_EXTBRK_Pos     7            /**< \brief (TAL_GLOBMASK) External Break Master */
193 #define TAL_GLOBMASK_EXTBRK         (_U(0x1) << TAL_GLOBMASK_EXTBRK_Pos)
194 #define TAL_GLOBMASK_MASK           _U(0xC3)     /**< \brief (TAL_GLOBMASK) MASK Register */
195 
196 /* -------- TAL_HALT : (TAL Offset: 0x0C) ( /W  8) Debug Halt Request -------- */
197 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
198 typedef union {
199   struct {
200     uint8_t  CM0P:1;           /*!< bit:      0  CM0P Break Master                  */
201     uint8_t  PPP:1;            /*!< bit:      1  PPP Break Master                   */
202     uint8_t  :4;               /*!< bit:  2.. 5  Reserved                           */
203     uint8_t  EVBRK:1;          /*!< bit:      6  Event Break Master                 */
204     uint8_t  EXTBRK:1;         /*!< bit:      7  External Break Master              */
205   } bit;                       /*!< Structure used for bit  access                  */
206   uint8_t reg;                 /*!< Type      used for register access              */
207 } TAL_HALT_Type;
208 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
209 
210 #define TAL_HALT_OFFSET             0x0C         /**< \brief (TAL_HALT offset) Debug Halt Request */
211 #define TAL_HALT_RESETVALUE         _U(0x00)     /**< \brief (TAL_HALT reset_value) Debug Halt Request */
212 
213 #define TAL_HALT_CM0P_Pos           0            /**< \brief (TAL_HALT) CM0P Break Master */
214 #define TAL_HALT_CM0P               (_U(0x1) << TAL_HALT_CM0P_Pos)
215 #define TAL_HALT_PPP_Pos            1            /**< \brief (TAL_HALT) PPP Break Master */
216 #define TAL_HALT_PPP                (_U(0x1) << TAL_HALT_PPP_Pos)
217 #define TAL_HALT_EVBRK_Pos          6            /**< \brief (TAL_HALT) Event Break Master */
218 #define TAL_HALT_EVBRK              (_U(0x1) << TAL_HALT_EVBRK_Pos)
219 #define TAL_HALT_EXTBRK_Pos         7            /**< \brief (TAL_HALT) External Break Master */
220 #define TAL_HALT_EXTBRK             (_U(0x1) << TAL_HALT_EXTBRK_Pos)
221 #define TAL_HALT_MASK               _U(0xC3)     /**< \brief (TAL_HALT) MASK Register */
222 
223 /* -------- TAL_RESTART : (TAL Offset: 0x0D) ( /W  8) Debug Restart Request -------- */
224 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
225 typedef union {
226   struct {
227     uint8_t  CM0P:1;           /*!< bit:      0  CM0P Break Master                  */
228     uint8_t  PPP:1;            /*!< bit:      1  PPP Break Master                   */
229     uint8_t  :5;               /*!< bit:  2.. 6  Reserved                           */
230     uint8_t  EXTBRK:1;         /*!< bit:      7  External Break Master              */
231   } bit;                       /*!< Structure used for bit  access                  */
232   uint8_t reg;                 /*!< Type      used for register access              */
233 } TAL_RESTART_Type;
234 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
235 
236 #define TAL_RESTART_OFFSET          0x0D         /**< \brief (TAL_RESTART offset) Debug Restart Request */
237 #define TAL_RESTART_RESETVALUE      _U(0x00)     /**< \brief (TAL_RESTART reset_value) Debug Restart Request */
238 
239 #define TAL_RESTART_CM0P_Pos        0            /**< \brief (TAL_RESTART) CM0P Break Master */
240 #define TAL_RESTART_CM0P            (_U(0x1) << TAL_RESTART_CM0P_Pos)
241 #define TAL_RESTART_PPP_Pos         1            /**< \brief (TAL_RESTART) PPP Break Master */
242 #define TAL_RESTART_PPP             (_U(0x1) << TAL_RESTART_PPP_Pos)
243 #define TAL_RESTART_EXTBRK_Pos      7            /**< \brief (TAL_RESTART) External Break Master */
244 #define TAL_RESTART_EXTBRK          (_U(0x1) << TAL_RESTART_EXTBRK_Pos)
245 #define TAL_RESTART_MASK            _U(0x83)     /**< \brief (TAL_RESTART) MASK Register */
246 
247 /* -------- TAL_BRKSTATUS : (TAL Offset: 0x0E) (R/  16) Break Request Status -------- */
248 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
249 typedef union {
250   struct {
251     uint16_t CM0P:2;           /*!< bit:  0.. 1  CM0P Break Request                 */
252     uint16_t PPP:2;            /*!< bit:  2.. 3  PPP Break Request                  */
253     uint16_t :8;               /*!< bit:  4..11  Reserved                           */
254     uint16_t EVBRK:2;          /*!< bit: 12..13  Event Break Request                */
255     uint16_t EXTBRK:2;         /*!< bit: 14..15  External Break Request             */
256   } bit;                       /*!< Structure used for bit  access                  */
257   uint16_t reg;                /*!< Type      used for register access              */
258 } TAL_BRKSTATUS_Type;
259 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
260 
261 #define TAL_BRKSTATUS_OFFSET        0x0E         /**< \brief (TAL_BRKSTATUS offset) Break Request Status */
262 #define TAL_BRKSTATUS_RESETVALUE    _U(0x0000)   /**< \brief (TAL_BRKSTATUS reset_value) Break Request Status */
263 
264 #define TAL_BRKSTATUS_CM0P_Pos      0            /**< \brief (TAL_BRKSTATUS) CM0P Break Request */
265 #define TAL_BRKSTATUS_CM0P_Msk      (_U(0x3) << TAL_BRKSTATUS_CM0P_Pos)
266 #define TAL_BRKSTATUS_CM0P(value)   (TAL_BRKSTATUS_CM0P_Msk & ((value) << TAL_BRKSTATUS_CM0P_Pos))
267 #define TAL_BRKSTATUS_PPP_Pos       2            /**< \brief (TAL_BRKSTATUS) PPP Break Request */
268 #define TAL_BRKSTATUS_PPP_Msk       (_U(0x3) << TAL_BRKSTATUS_PPP_Pos)
269 #define TAL_BRKSTATUS_PPP(value)    (TAL_BRKSTATUS_PPP_Msk & ((value) << TAL_BRKSTATUS_PPP_Pos))
270 #define TAL_BRKSTATUS_EVBRK_Pos     12           /**< \brief (TAL_BRKSTATUS) Event Break Request */
271 #define TAL_BRKSTATUS_EVBRK_Msk     (_U(0x3) << TAL_BRKSTATUS_EVBRK_Pos)
272 #define TAL_BRKSTATUS_EVBRK(value)  (TAL_BRKSTATUS_EVBRK_Msk & ((value) << TAL_BRKSTATUS_EVBRK_Pos))
273 #define TAL_BRKSTATUS_EXTBRK_Pos    14           /**< \brief (TAL_BRKSTATUS) External Break Request */
274 #define TAL_BRKSTATUS_EXTBRK_Msk    (_U(0x3) << TAL_BRKSTATUS_EXTBRK_Pos)
275 #define TAL_BRKSTATUS_EXTBRK(value) (TAL_BRKSTATUS_EXTBRK_Msk & ((value) << TAL_BRKSTATUS_EXTBRK_Pos))
276 #define TAL_BRKSTATUS_MASK          _U(0xF00F)   /**< \brief (TAL_BRKSTATUS) MASK Register */
277 
278 /* -------- TAL_CTICTRLA : (TAL Offset: 0x10) (R/W  8) CTIS Cross-Trigger Interface n Control A -------- */
279 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
280 typedef union {
281   struct {
282     uint8_t  ACTION:2;         /*!< bit:  0.. 1  Action when global break issued    */
283     uint8_t  RESTART:1;        /*!< bit:      2  Action when global restart issued  */
284     uint8_t  :5;               /*!< bit:  3.. 7  Reserved                           */
285   } bit;                       /*!< Structure used for bit  access                  */
286   uint8_t reg;                 /*!< Type      used for register access              */
287 } TAL_CTICTRLA_Type;
288 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
289 
290 #define TAL_CTICTRLA_OFFSET         0x10         /**< \brief (TAL_CTICTRLA offset) Cross-Trigger Interface n Control A */
291 #define TAL_CTICTRLA_RESETVALUE     _U(0x00)     /**< \brief (TAL_CTICTRLA reset_value) Cross-Trigger Interface n Control A */
292 
293 #define TAL_CTICTRLA_ACTION_Pos     0            /**< \brief (TAL_CTICTRLA) Action when global break issued */
294 #define TAL_CTICTRLA_ACTION_Msk     (_U(0x3) << TAL_CTICTRLA_ACTION_Pos)
295 #define TAL_CTICTRLA_ACTION(value)  (TAL_CTICTRLA_ACTION_Msk & ((value) << TAL_CTICTRLA_ACTION_Pos))
296 #define   TAL_CTICTRLA_ACTION_BREAK_Val   _U(0x0)   /**< \brief (TAL_CTICTRLA) Break when requested */
297 #define   TAL_CTICTRLA_ACTION_INTERRUPT_Val _U(0x1)   /**< \brief (TAL_CTICTRLA) Trigger DBG interrupt instead of break */
298 #define   TAL_CTICTRLA_ACTION_IGNORE_Val  _U(0x2)   /**< \brief (TAL_CTICTRLA) Ignore break request */
299 #define TAL_CTICTRLA_ACTION_BREAK   (TAL_CTICTRLA_ACTION_BREAK_Val << TAL_CTICTRLA_ACTION_Pos)
300 #define TAL_CTICTRLA_ACTION_INTERRUPT (TAL_CTICTRLA_ACTION_INTERRUPT_Val << TAL_CTICTRLA_ACTION_Pos)
301 #define TAL_CTICTRLA_ACTION_IGNORE  (TAL_CTICTRLA_ACTION_IGNORE_Val << TAL_CTICTRLA_ACTION_Pos)
302 #define TAL_CTICTRLA_RESTART_Pos    2            /**< \brief (TAL_CTICTRLA) Action when global restart issued */
303 #define TAL_CTICTRLA_RESTART        (_U(0x1) << TAL_CTICTRLA_RESTART_Pos)
304 #define TAL_CTICTRLA_MASK           _U(0x07)     /**< \brief (TAL_CTICTRLA) MASK Register */
305 
306 /* -------- TAL_CTIMASK : (TAL Offset: 0x11) (R/W  8) CTIS Cross-Trigger Interface n Mask -------- */
307 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
308 typedef union {
309   struct {
310     uint8_t  CM0P:1;           /*!< bit:      0  CM0P Break Master                  */
311     uint8_t  PPP:1;            /*!< bit:      1  PPP Break Master                   */
312     uint8_t  :4;               /*!< bit:  2.. 5  Reserved                           */
313     uint8_t  EVBRK:1;          /*!< bit:      6  Event Break Master                 */
314     uint8_t  EXTBRK:1;         /*!< bit:      7  External Break Master              */
315   } bit;                       /*!< Structure used for bit  access                  */
316   uint8_t reg;                 /*!< Type      used for register access              */
317 } TAL_CTIMASK_Type;
318 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
319 
320 #define TAL_CTIMASK_OFFSET          0x11         /**< \brief (TAL_CTIMASK offset) Cross-Trigger Interface n Mask */
321 #define TAL_CTIMASK_RESETVALUE      _U(0x00)     /**< \brief (TAL_CTIMASK reset_value) Cross-Trigger Interface n Mask */
322 
323 #define TAL_CTIMASK_CM0P_Pos        0            /**< \brief (TAL_CTIMASK) CM0P Break Master */
324 #define TAL_CTIMASK_CM0P            (_U(0x1) << TAL_CTIMASK_CM0P_Pos)
325 #define TAL_CTIMASK_PPP_Pos         1            /**< \brief (TAL_CTIMASK) PPP Break Master */
326 #define TAL_CTIMASK_PPP             (_U(0x1) << TAL_CTIMASK_PPP_Pos)
327 #define TAL_CTIMASK_EVBRK_Pos       6            /**< \brief (TAL_CTIMASK) Event Break Master */
328 #define TAL_CTIMASK_EVBRK           (_U(0x1) << TAL_CTIMASK_EVBRK_Pos)
329 #define TAL_CTIMASK_EXTBRK_Pos      7            /**< \brief (TAL_CTIMASK) External Break Master */
330 #define TAL_CTIMASK_EXTBRK          (_U(0x1) << TAL_CTIMASK_EXTBRK_Pos)
331 #define TAL_CTIMASK_MASK            _U(0xC3)     /**< \brief (TAL_CTIMASK) MASK Register */
332 
333 /* -------- TAL_INTSTATUS : (TAL Offset: 0x20) (R/   8) Interrupt n Status -------- */
334 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
335 typedef union {
336   struct {
337     uint8_t  IRQ0:1;           /*!< bit:      0  Interrupt Status for Interrupt Request 0 within Interrupt n */
338     uint8_t  IRQ1:1;           /*!< bit:      1  Interrupt Status for Interrupt Request 1 within Interrupt n */
339     uint8_t  IRQ2:1;           /*!< bit:      2  Interrupt Status for Interrupt Request 2 within Interrupt n */
340     uint8_t  IRQ3:1;           /*!< bit:      3  Interrupt Status for Interrupt Request 3 within Interrupt n */
341     uint8_t  IRQ4:1;           /*!< bit:      4  Interrupt Status for Interrupt Request 4 within Interrupt n */
342     uint8_t  IRQ5:1;           /*!< bit:      5  Interrupt Status for Interrupt Request 5 within Interrupt n */
343     uint8_t  IRQ6:1;           /*!< bit:      6  Interrupt Status for Interrupt Request 6 within Interrupt n */
344     uint8_t  IRQ7:1;           /*!< bit:      7  Interrupt Status for Interrupt Request 7 within Interrupt n */
345   } bit;                       /*!< Structure used for bit  access                  */
346   struct {
347     uint8_t  IRQ:8;            /*!< bit:  0.. 7  Interrupt Status for Interrupt Request x within Interrupt n */
348   } vec;                       /*!< Structure used for vec  access                  */
349   uint8_t reg;                 /*!< Type      used for register access              */
350 } TAL_INTSTATUS_Type;
351 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
352 
353 #define TAL_INTSTATUS_OFFSET        0x20         /**< \brief (TAL_INTSTATUS offset) Interrupt n Status */
354 #define TAL_INTSTATUS_RESETVALUE    _U(0x00)     /**< \brief (TAL_INTSTATUS reset_value) Interrupt n Status */
355 
356 #define TAL_INTSTATUS_IRQ0_Pos      0            /**< \brief (TAL_INTSTATUS) Interrupt Status for Interrupt Request 0 within Interrupt n */
357 #define TAL_INTSTATUS_IRQ0          (1 << TAL_INTSTATUS_IRQ0_Pos)
358 #define TAL_INTSTATUS_IRQ1_Pos      1            /**< \brief (TAL_INTSTATUS) Interrupt Status for Interrupt Request 1 within Interrupt n */
359 #define TAL_INTSTATUS_IRQ1          (1 << TAL_INTSTATUS_IRQ1_Pos)
360 #define TAL_INTSTATUS_IRQ2_Pos      2            /**< \brief (TAL_INTSTATUS) Interrupt Status for Interrupt Request 2 within Interrupt n */
361 #define TAL_INTSTATUS_IRQ2          (1 << TAL_INTSTATUS_IRQ2_Pos)
362 #define TAL_INTSTATUS_IRQ3_Pos      3            /**< \brief (TAL_INTSTATUS) Interrupt Status for Interrupt Request 3 within Interrupt n */
363 #define TAL_INTSTATUS_IRQ3          (1 << TAL_INTSTATUS_IRQ3_Pos)
364 #define TAL_INTSTATUS_IRQ4_Pos      4            /**< \brief (TAL_INTSTATUS) Interrupt Status for Interrupt Request 4 within Interrupt n */
365 #define TAL_INTSTATUS_IRQ4          (1 << TAL_INTSTATUS_IRQ4_Pos)
366 #define TAL_INTSTATUS_IRQ5_Pos      5            /**< \brief (TAL_INTSTATUS) Interrupt Status for Interrupt Request 5 within Interrupt n */
367 #define TAL_INTSTATUS_IRQ5          (1 << TAL_INTSTATUS_IRQ5_Pos)
368 #define TAL_INTSTATUS_IRQ6_Pos      6            /**< \brief (TAL_INTSTATUS) Interrupt Status for Interrupt Request 6 within Interrupt n */
369 #define TAL_INTSTATUS_IRQ6          (1 << TAL_INTSTATUS_IRQ6_Pos)
370 #define TAL_INTSTATUS_IRQ7_Pos      7            /**< \brief (TAL_INTSTATUS) Interrupt Status for Interrupt Request 7 within Interrupt n */
371 #define TAL_INTSTATUS_IRQ7          (1 << TAL_INTSTATUS_IRQ7_Pos)
372 #define TAL_INTSTATUS_IRQ_Pos       0            /**< \brief (TAL_INTSTATUS) Interrupt Status for Interrupt Request x within Interrupt n */
373 #define TAL_INTSTATUS_IRQ_Msk       (_U(0xFF) << TAL_INTSTATUS_IRQ_Pos)
374 #define TAL_INTSTATUS_IRQ(value)    (TAL_INTSTATUS_IRQ_Msk & ((value) << TAL_INTSTATUS_IRQ_Pos))
375 #define TAL_INTSTATUS_MASK          _U(0xFF)     /**< \brief (TAL_INTSTATUS) MASK Register */
376 
377 /* -------- TAL_DMACPUSEL0 : (TAL Offset: 0x40) (R/W 32) DMA Channel Interrupts CPU Select 0 -------- */
378 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
379 typedef union {
380   struct {
381     uint32_t CH0:1;            /*!< bit:      0  DMA Channel 0 Interrupt CPU Select */
382     uint32_t :1;               /*!< bit:      1  Reserved                           */
383     uint32_t CH1:1;            /*!< bit:      2  DMA Channel 1 Interrupt CPU Select */
384     uint32_t :1;               /*!< bit:      3  Reserved                           */
385     uint32_t CH2:1;            /*!< bit:      4  DMA Channel 2 Interrupt CPU Select */
386     uint32_t :1;               /*!< bit:      5  Reserved                           */
387     uint32_t CH3:1;            /*!< bit:      6  DMA Channel 3 Interrupt CPU Select */
388     uint32_t :1;               /*!< bit:      7  Reserved                           */
389     uint32_t CH4:1;            /*!< bit:      8  DMA Channel 4 Interrupt CPU Select */
390     uint32_t :1;               /*!< bit:      9  Reserved                           */
391     uint32_t CH5:1;            /*!< bit:     10  DMA Channel 5 Interrupt CPU Select */
392     uint32_t :1;               /*!< bit:     11  Reserved                           */
393     uint32_t CH6:1;            /*!< bit:     12  DMA Channel 6 Interrupt CPU Select */
394     uint32_t :1;               /*!< bit:     13  Reserved                           */
395     uint32_t CH7:1;            /*!< bit:     14  DMA Channel 7 Interrupt CPU Select */
396     uint32_t :1;               /*!< bit:     15  Reserved                           */
397     uint32_t CH8:1;            /*!< bit:     16  DMA Channel 8 Interrupt CPU Select */
398     uint32_t :1;               /*!< bit:     17  Reserved                           */
399     uint32_t CH9:1;            /*!< bit:     18  DMA Channel 9 Interrupt CPU Select */
400     uint32_t :1;               /*!< bit:     19  Reserved                           */
401     uint32_t CH10:1;           /*!< bit:     20  DMA Channel 10 Interrupt CPU Select */
402     uint32_t :1;               /*!< bit:     21  Reserved                           */
403     uint32_t CH11:1;           /*!< bit:     22  DMA Channel 11 Interrupt CPU Select */
404     uint32_t :1;               /*!< bit:     23  Reserved                           */
405     uint32_t CH12:1;           /*!< bit:     24  DMA Channel 12 Interrupt CPU Select */
406     uint32_t :1;               /*!< bit:     25  Reserved                           */
407     uint32_t CH13:1;           /*!< bit:     26  DMA Channel 13 Interrupt CPU Select */
408     uint32_t :1;               /*!< bit:     27  Reserved                           */
409     uint32_t CH14:1;           /*!< bit:     28  DMA Channel 14 Interrupt CPU Select */
410     uint32_t :1;               /*!< bit:     29  Reserved                           */
411     uint32_t CH15:1;           /*!< bit:     30  DMA Channel 15 Interrupt CPU Select */
412     uint32_t :1;               /*!< bit:     31  Reserved                           */
413   } bit;                       /*!< Structure used for bit  access                  */
414   uint32_t reg;                /*!< Type      used for register access              */
415 } TAL_DMACPUSEL0_Type;
416 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
417 
418 #define TAL_DMACPUSEL0_OFFSET       0x40         /**< \brief (TAL_DMACPUSEL0 offset) DMA Channel Interrupts CPU Select 0 */
419 #define TAL_DMACPUSEL0_RESETVALUE   _U(0x00000000) /**< \brief (TAL_DMACPUSEL0 reset_value) DMA Channel Interrupts CPU Select 0 */
420 
421 #define TAL_DMACPUSEL0_CH0_Pos      0            /**< \brief (TAL_DMACPUSEL0) DMA Channel 0 Interrupt CPU Select */
422 #define TAL_DMACPUSEL0_CH0_Msk      (_U(0x1) << TAL_DMACPUSEL0_CH0_Pos)
423 #define TAL_DMACPUSEL0_CH0(value)   (TAL_DMACPUSEL0_CH0_Msk & ((value) << TAL_DMACPUSEL0_CH0_Pos))
424 #define TAL_DMACPUSEL0_CH1_Pos      2            /**< \brief (TAL_DMACPUSEL0) DMA Channel 1 Interrupt CPU Select */
425 #define TAL_DMACPUSEL0_CH1_Msk      (_U(0x1) << TAL_DMACPUSEL0_CH1_Pos)
426 #define TAL_DMACPUSEL0_CH1(value)   (TAL_DMACPUSEL0_CH1_Msk & ((value) << TAL_DMACPUSEL0_CH1_Pos))
427 #define TAL_DMACPUSEL0_CH2_Pos      4            /**< \brief (TAL_DMACPUSEL0) DMA Channel 2 Interrupt CPU Select */
428 #define TAL_DMACPUSEL0_CH2_Msk      (_U(0x1) << TAL_DMACPUSEL0_CH2_Pos)
429 #define TAL_DMACPUSEL0_CH2(value)   (TAL_DMACPUSEL0_CH2_Msk & ((value) << TAL_DMACPUSEL0_CH2_Pos))
430 #define TAL_DMACPUSEL0_CH3_Pos      6            /**< \brief (TAL_DMACPUSEL0) DMA Channel 3 Interrupt CPU Select */
431 #define TAL_DMACPUSEL0_CH3_Msk      (_U(0x1) << TAL_DMACPUSEL0_CH3_Pos)
432 #define TAL_DMACPUSEL0_CH3(value)   (TAL_DMACPUSEL0_CH3_Msk & ((value) << TAL_DMACPUSEL0_CH3_Pos))
433 #define TAL_DMACPUSEL0_CH4_Pos      8            /**< \brief (TAL_DMACPUSEL0) DMA Channel 4 Interrupt CPU Select */
434 #define TAL_DMACPUSEL0_CH4_Msk      (_U(0x1) << TAL_DMACPUSEL0_CH4_Pos)
435 #define TAL_DMACPUSEL0_CH4(value)   (TAL_DMACPUSEL0_CH4_Msk & ((value) << TAL_DMACPUSEL0_CH4_Pos))
436 #define TAL_DMACPUSEL0_CH5_Pos      10           /**< \brief (TAL_DMACPUSEL0) DMA Channel 5 Interrupt CPU Select */
437 #define TAL_DMACPUSEL0_CH5_Msk      (_U(0x1) << TAL_DMACPUSEL0_CH5_Pos)
438 #define TAL_DMACPUSEL0_CH5(value)   (TAL_DMACPUSEL0_CH5_Msk & ((value) << TAL_DMACPUSEL0_CH5_Pos))
439 #define TAL_DMACPUSEL0_CH6_Pos      12           /**< \brief (TAL_DMACPUSEL0) DMA Channel 6 Interrupt CPU Select */
440 #define TAL_DMACPUSEL0_CH6_Msk      (_U(0x1) << TAL_DMACPUSEL0_CH6_Pos)
441 #define TAL_DMACPUSEL0_CH6(value)   (TAL_DMACPUSEL0_CH6_Msk & ((value) << TAL_DMACPUSEL0_CH6_Pos))
442 #define TAL_DMACPUSEL0_CH7_Pos      14           /**< \brief (TAL_DMACPUSEL0) DMA Channel 7 Interrupt CPU Select */
443 #define TAL_DMACPUSEL0_CH7_Msk      (_U(0x1) << TAL_DMACPUSEL0_CH7_Pos)
444 #define TAL_DMACPUSEL0_CH7(value)   (TAL_DMACPUSEL0_CH7_Msk & ((value) << TAL_DMACPUSEL0_CH7_Pos))
445 #define TAL_DMACPUSEL0_CH8_Pos      16           /**< \brief (TAL_DMACPUSEL0) DMA Channel 8 Interrupt CPU Select */
446 #define TAL_DMACPUSEL0_CH8_Msk      (_U(0x1) << TAL_DMACPUSEL0_CH8_Pos)
447 #define TAL_DMACPUSEL0_CH8(value)   (TAL_DMACPUSEL0_CH8_Msk & ((value) << TAL_DMACPUSEL0_CH8_Pos))
448 #define TAL_DMACPUSEL0_CH9_Pos      18           /**< \brief (TAL_DMACPUSEL0) DMA Channel 9 Interrupt CPU Select */
449 #define TAL_DMACPUSEL0_CH9_Msk      (_U(0x1) << TAL_DMACPUSEL0_CH9_Pos)
450 #define TAL_DMACPUSEL0_CH9(value)   (TAL_DMACPUSEL0_CH9_Msk & ((value) << TAL_DMACPUSEL0_CH9_Pos))
451 #define TAL_DMACPUSEL0_CH10_Pos     20           /**< \brief (TAL_DMACPUSEL0) DMA Channel 10 Interrupt CPU Select */
452 #define TAL_DMACPUSEL0_CH10_Msk     (_U(0x1) << TAL_DMACPUSEL0_CH10_Pos)
453 #define TAL_DMACPUSEL0_CH10(value)  (TAL_DMACPUSEL0_CH10_Msk & ((value) << TAL_DMACPUSEL0_CH10_Pos))
454 #define TAL_DMACPUSEL0_CH11_Pos     22           /**< \brief (TAL_DMACPUSEL0) DMA Channel 11 Interrupt CPU Select */
455 #define TAL_DMACPUSEL0_CH11_Msk     (_U(0x1) << TAL_DMACPUSEL0_CH11_Pos)
456 #define TAL_DMACPUSEL0_CH11(value)  (TAL_DMACPUSEL0_CH11_Msk & ((value) << TAL_DMACPUSEL0_CH11_Pos))
457 #define TAL_DMACPUSEL0_CH12_Pos     24           /**< \brief (TAL_DMACPUSEL0) DMA Channel 12 Interrupt CPU Select */
458 #define TAL_DMACPUSEL0_CH12_Msk     (_U(0x1) << TAL_DMACPUSEL0_CH12_Pos)
459 #define TAL_DMACPUSEL0_CH12(value)  (TAL_DMACPUSEL0_CH12_Msk & ((value) << TAL_DMACPUSEL0_CH12_Pos))
460 #define TAL_DMACPUSEL0_CH13_Pos     26           /**< \brief (TAL_DMACPUSEL0) DMA Channel 13 Interrupt CPU Select */
461 #define TAL_DMACPUSEL0_CH13_Msk     (_U(0x1) << TAL_DMACPUSEL0_CH13_Pos)
462 #define TAL_DMACPUSEL0_CH13(value)  (TAL_DMACPUSEL0_CH13_Msk & ((value) << TAL_DMACPUSEL0_CH13_Pos))
463 #define TAL_DMACPUSEL0_CH14_Pos     28           /**< \brief (TAL_DMACPUSEL0) DMA Channel 14 Interrupt CPU Select */
464 #define TAL_DMACPUSEL0_CH14_Msk     (_U(0x1) << TAL_DMACPUSEL0_CH14_Pos)
465 #define TAL_DMACPUSEL0_CH14(value)  (TAL_DMACPUSEL0_CH14_Msk & ((value) << TAL_DMACPUSEL0_CH14_Pos))
466 #define TAL_DMACPUSEL0_CH15_Pos     30           /**< \brief (TAL_DMACPUSEL0) DMA Channel 15 Interrupt CPU Select */
467 #define TAL_DMACPUSEL0_CH15_Msk     (_U(0x1) << TAL_DMACPUSEL0_CH15_Pos)
468 #define TAL_DMACPUSEL0_CH15(value)  (TAL_DMACPUSEL0_CH15_Msk & ((value) << TAL_DMACPUSEL0_CH15_Pos))
469 #define TAL_DMACPUSEL0_MASK         _U(0x55555555) /**< \brief (TAL_DMACPUSEL0) MASK Register */
470 
471 /* -------- TAL_EVCPUSEL0 : (TAL Offset: 0x48) (R/W 32) EVSYS Channel Interrupts CPU Select 0 -------- */
472 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
473 typedef union {
474   struct {
475     uint32_t CH0:1;            /*!< bit:      0  Event Channel 0 Interrupt CPU Select */
476     uint32_t :1;               /*!< bit:      1  Reserved                           */
477     uint32_t CH1:1;            /*!< bit:      2  Event Channel 1 Interrupt CPU Select */
478     uint32_t :1;               /*!< bit:      3  Reserved                           */
479     uint32_t CH2:1;            /*!< bit:      4  Event Channel 2 Interrupt CPU Select */
480     uint32_t :1;               /*!< bit:      5  Reserved                           */
481     uint32_t CH3:1;            /*!< bit:      6  Event Channel 3 Interrupt CPU Select */
482     uint32_t :1;               /*!< bit:      7  Reserved                           */
483     uint32_t CH4:1;            /*!< bit:      8  Event Channel 4 Interrupt CPU Select */
484     uint32_t :1;               /*!< bit:      9  Reserved                           */
485     uint32_t CH5:1;            /*!< bit:     10  Event Channel 5 Interrupt CPU Select */
486     uint32_t :1;               /*!< bit:     11  Reserved                           */
487     uint32_t CH6:1;            /*!< bit:     12  Event Channel 6 Interrupt CPU Select */
488     uint32_t :1;               /*!< bit:     13  Reserved                           */
489     uint32_t CH7:1;            /*!< bit:     14  Event Channel 7 Interrupt CPU Select */
490     uint32_t :1;               /*!< bit:     15  Reserved                           */
491     uint32_t CH8:1;            /*!< bit:     16  Event Channel 8 Interrupt CPU Select */
492     uint32_t :1;               /*!< bit:     17  Reserved                           */
493     uint32_t CH9:1;            /*!< bit:     18  Event Channel 9 Interrupt CPU Select */
494     uint32_t :1;               /*!< bit:     19  Reserved                           */
495     uint32_t CH10:1;           /*!< bit:     20  Event Channel 10 Interrupt CPU Select */
496     uint32_t :1;               /*!< bit:     21  Reserved                           */
497     uint32_t CH11:1;           /*!< bit:     22  Event Channel 11 Interrupt CPU Select */
498     uint32_t :9;               /*!< bit: 23..31  Reserved                           */
499   } bit;                       /*!< Structure used for bit  access                  */
500   uint32_t reg;                /*!< Type      used for register access              */
501 } TAL_EVCPUSEL0_Type;
502 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
503 
504 #define TAL_EVCPUSEL0_OFFSET        0x48         /**< \brief (TAL_EVCPUSEL0 offset) EVSYS Channel Interrupts CPU Select 0 */
505 #define TAL_EVCPUSEL0_RESETVALUE    _U(0x00000000) /**< \brief (TAL_EVCPUSEL0 reset_value) EVSYS Channel Interrupts CPU Select 0 */
506 
507 #define TAL_EVCPUSEL0_CH0_Pos       0            /**< \brief (TAL_EVCPUSEL0) Event Channel 0 Interrupt CPU Select */
508 #define TAL_EVCPUSEL0_CH0_Msk       (_U(0x1) << TAL_EVCPUSEL0_CH0_Pos)
509 #define TAL_EVCPUSEL0_CH0(value)    (TAL_EVCPUSEL0_CH0_Msk & ((value) << TAL_EVCPUSEL0_CH0_Pos))
510 #define TAL_EVCPUSEL0_CH1_Pos       2            /**< \brief (TAL_EVCPUSEL0) Event Channel 1 Interrupt CPU Select */
511 #define TAL_EVCPUSEL0_CH1_Msk       (_U(0x1) << TAL_EVCPUSEL0_CH1_Pos)
512 #define TAL_EVCPUSEL0_CH1(value)    (TAL_EVCPUSEL0_CH1_Msk & ((value) << TAL_EVCPUSEL0_CH1_Pos))
513 #define TAL_EVCPUSEL0_CH2_Pos       4            /**< \brief (TAL_EVCPUSEL0) Event Channel 2 Interrupt CPU Select */
514 #define TAL_EVCPUSEL0_CH2_Msk       (_U(0x1) << TAL_EVCPUSEL0_CH2_Pos)
515 #define TAL_EVCPUSEL0_CH2(value)    (TAL_EVCPUSEL0_CH2_Msk & ((value) << TAL_EVCPUSEL0_CH2_Pos))
516 #define TAL_EVCPUSEL0_CH3_Pos       6            /**< \brief (TAL_EVCPUSEL0) Event Channel 3 Interrupt CPU Select */
517 #define TAL_EVCPUSEL0_CH3_Msk       (_U(0x1) << TAL_EVCPUSEL0_CH3_Pos)
518 #define TAL_EVCPUSEL0_CH3(value)    (TAL_EVCPUSEL0_CH3_Msk & ((value) << TAL_EVCPUSEL0_CH3_Pos))
519 #define TAL_EVCPUSEL0_CH4_Pos       8            /**< \brief (TAL_EVCPUSEL0) Event Channel 4 Interrupt CPU Select */
520 #define TAL_EVCPUSEL0_CH4_Msk       (_U(0x1) << TAL_EVCPUSEL0_CH4_Pos)
521 #define TAL_EVCPUSEL0_CH4(value)    (TAL_EVCPUSEL0_CH4_Msk & ((value) << TAL_EVCPUSEL0_CH4_Pos))
522 #define TAL_EVCPUSEL0_CH5_Pos       10           /**< \brief (TAL_EVCPUSEL0) Event Channel 5 Interrupt CPU Select */
523 #define TAL_EVCPUSEL0_CH5_Msk       (_U(0x1) << TAL_EVCPUSEL0_CH5_Pos)
524 #define TAL_EVCPUSEL0_CH5(value)    (TAL_EVCPUSEL0_CH5_Msk & ((value) << TAL_EVCPUSEL0_CH5_Pos))
525 #define TAL_EVCPUSEL0_CH6_Pos       12           /**< \brief (TAL_EVCPUSEL0) Event Channel 6 Interrupt CPU Select */
526 #define TAL_EVCPUSEL0_CH6_Msk       (_U(0x1) << TAL_EVCPUSEL0_CH6_Pos)
527 #define TAL_EVCPUSEL0_CH6(value)    (TAL_EVCPUSEL0_CH6_Msk & ((value) << TAL_EVCPUSEL0_CH6_Pos))
528 #define TAL_EVCPUSEL0_CH7_Pos       14           /**< \brief (TAL_EVCPUSEL0) Event Channel 7 Interrupt CPU Select */
529 #define TAL_EVCPUSEL0_CH7_Msk       (_U(0x1) << TAL_EVCPUSEL0_CH7_Pos)
530 #define TAL_EVCPUSEL0_CH7(value)    (TAL_EVCPUSEL0_CH7_Msk & ((value) << TAL_EVCPUSEL0_CH7_Pos))
531 #define TAL_EVCPUSEL0_CH8_Pos       16           /**< \brief (TAL_EVCPUSEL0) Event Channel 8 Interrupt CPU Select */
532 #define TAL_EVCPUSEL0_CH8_Msk       (_U(0x1) << TAL_EVCPUSEL0_CH8_Pos)
533 #define TAL_EVCPUSEL0_CH8(value)    (TAL_EVCPUSEL0_CH8_Msk & ((value) << TAL_EVCPUSEL0_CH8_Pos))
534 #define TAL_EVCPUSEL0_CH9_Pos       18           /**< \brief (TAL_EVCPUSEL0) Event Channel 9 Interrupt CPU Select */
535 #define TAL_EVCPUSEL0_CH9_Msk       (_U(0x1) << TAL_EVCPUSEL0_CH9_Pos)
536 #define TAL_EVCPUSEL0_CH9(value)    (TAL_EVCPUSEL0_CH9_Msk & ((value) << TAL_EVCPUSEL0_CH9_Pos))
537 #define TAL_EVCPUSEL0_CH10_Pos      20           /**< \brief (TAL_EVCPUSEL0) Event Channel 10 Interrupt CPU Select */
538 #define TAL_EVCPUSEL0_CH10_Msk      (_U(0x1) << TAL_EVCPUSEL0_CH10_Pos)
539 #define TAL_EVCPUSEL0_CH10(value)   (TAL_EVCPUSEL0_CH10_Msk & ((value) << TAL_EVCPUSEL0_CH10_Pos))
540 #define TAL_EVCPUSEL0_CH11_Pos      22           /**< \brief (TAL_EVCPUSEL0) Event Channel 11 Interrupt CPU Select */
541 #define TAL_EVCPUSEL0_CH11_Msk      (_U(0x1) << TAL_EVCPUSEL0_CH11_Pos)
542 #define TAL_EVCPUSEL0_CH11(value)   (TAL_EVCPUSEL0_CH11_Msk & ((value) << TAL_EVCPUSEL0_CH11_Pos))
543 #define TAL_EVCPUSEL0_MASK          _U(0x00555555) /**< \brief (TAL_EVCPUSEL0) MASK Register */
544 
545 /* -------- TAL_EICCPUSEL0 : (TAL Offset: 0x50) (R/W 32) EIC External Interrupts CPU Select 0 -------- */
546 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
547 typedef union {
548   struct {
549     uint32_t EXTINT0:1;        /*!< bit:      0  External Interrupt 0 CPU Select    */
550     uint32_t :1;               /*!< bit:      1  Reserved                           */
551     uint32_t EXTINT1:1;        /*!< bit:      2  External Interrupt 1 CPU Select    */
552     uint32_t :1;               /*!< bit:      3  Reserved                           */
553     uint32_t EXTINT2:1;        /*!< bit:      4  External Interrupt 2 CPU Select    */
554     uint32_t :1;               /*!< bit:      5  Reserved                           */
555     uint32_t EXTINT3:1;        /*!< bit:      6  External Interrupt 3 CPU Select    */
556     uint32_t :1;               /*!< bit:      7  Reserved                           */
557     uint32_t EXTINT4:1;        /*!< bit:      8  External Interrupt 4 CPU Select    */
558     uint32_t :1;               /*!< bit:      9  Reserved                           */
559     uint32_t EXTINT5:1;        /*!< bit:     10  External Interrupt 5 CPU Select    */
560     uint32_t :1;               /*!< bit:     11  Reserved                           */
561     uint32_t EXTINT6:1;        /*!< bit:     12  External Interrupt 6 CPU Select    */
562     uint32_t :1;               /*!< bit:     13  Reserved                           */
563     uint32_t EXTINT7:1;        /*!< bit:     14  External Interrupt 7 CPU Select    */
564     uint32_t :1;               /*!< bit:     15  Reserved                           */
565     uint32_t EXTINT8:1;        /*!< bit:     16  External Interrupt 8 CPU Select    */
566     uint32_t :1;               /*!< bit:     17  Reserved                           */
567     uint32_t EXTINT9:1;        /*!< bit:     18  External Interrupt 9 CPU Select    */
568     uint32_t :1;               /*!< bit:     19  Reserved                           */
569     uint32_t EXTINT10:1;       /*!< bit:     20  External Interrupt 10 CPU Select   */
570     uint32_t :1;               /*!< bit:     21  Reserved                           */
571     uint32_t EXTINT11:1;       /*!< bit:     22  External Interrupt 11 CPU Select   */
572     uint32_t :1;               /*!< bit:     23  Reserved                           */
573     uint32_t EXTINT12:1;       /*!< bit:     24  External Interrupt 12 CPU Select   */
574     uint32_t :1;               /*!< bit:     25  Reserved                           */
575     uint32_t EXTINT13:1;       /*!< bit:     26  External Interrupt 13 CPU Select   */
576     uint32_t :1;               /*!< bit:     27  Reserved                           */
577     uint32_t EXTINT14:1;       /*!< bit:     28  External Interrupt 14 CPU Select   */
578     uint32_t :1;               /*!< bit:     29  Reserved                           */
579     uint32_t EXTINT15:1;       /*!< bit:     30  External Interrupt 15 CPU Select   */
580     uint32_t :1;               /*!< bit:     31  Reserved                           */
581   } bit;                       /*!< Structure used for bit  access                  */
582   uint32_t reg;                /*!< Type      used for register access              */
583 } TAL_EICCPUSEL0_Type;
584 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
585 
586 #define TAL_EICCPUSEL0_OFFSET       0x50         /**< \brief (TAL_EICCPUSEL0 offset) EIC External Interrupts CPU Select 0 */
587 #define TAL_EICCPUSEL0_RESETVALUE   _U(0x00000000) /**< \brief (TAL_EICCPUSEL0 reset_value) EIC External Interrupts CPU Select 0 */
588 
589 #define TAL_EICCPUSEL0_EXTINT0_Pos  0            /**< \brief (TAL_EICCPUSEL0) External Interrupt 0 CPU Select */
590 #define TAL_EICCPUSEL0_EXTINT0_Msk  (_U(0x1) << TAL_EICCPUSEL0_EXTINT0_Pos)
591 #define TAL_EICCPUSEL0_EXTINT0(value) (TAL_EICCPUSEL0_EXTINT0_Msk & ((value) << TAL_EICCPUSEL0_EXTINT0_Pos))
592 #define TAL_EICCPUSEL0_EXTINT1_Pos  2            /**< \brief (TAL_EICCPUSEL0) External Interrupt 1 CPU Select */
593 #define TAL_EICCPUSEL0_EXTINT1_Msk  (_U(0x1) << TAL_EICCPUSEL0_EXTINT1_Pos)
594 #define TAL_EICCPUSEL0_EXTINT1(value) (TAL_EICCPUSEL0_EXTINT1_Msk & ((value) << TAL_EICCPUSEL0_EXTINT1_Pos))
595 #define TAL_EICCPUSEL0_EXTINT2_Pos  4            /**< \brief (TAL_EICCPUSEL0) External Interrupt 2 CPU Select */
596 #define TAL_EICCPUSEL0_EXTINT2_Msk  (_U(0x1) << TAL_EICCPUSEL0_EXTINT2_Pos)
597 #define TAL_EICCPUSEL0_EXTINT2(value) (TAL_EICCPUSEL0_EXTINT2_Msk & ((value) << TAL_EICCPUSEL0_EXTINT2_Pos))
598 #define TAL_EICCPUSEL0_EXTINT3_Pos  6            /**< \brief (TAL_EICCPUSEL0) External Interrupt 3 CPU Select */
599 #define TAL_EICCPUSEL0_EXTINT3_Msk  (_U(0x1) << TAL_EICCPUSEL0_EXTINT3_Pos)
600 #define TAL_EICCPUSEL0_EXTINT3(value) (TAL_EICCPUSEL0_EXTINT3_Msk & ((value) << TAL_EICCPUSEL0_EXTINT3_Pos))
601 #define TAL_EICCPUSEL0_EXTINT4_Pos  8            /**< \brief (TAL_EICCPUSEL0) External Interrupt 4 CPU Select */
602 #define TAL_EICCPUSEL0_EXTINT4_Msk  (_U(0x1) << TAL_EICCPUSEL0_EXTINT4_Pos)
603 #define TAL_EICCPUSEL0_EXTINT4(value) (TAL_EICCPUSEL0_EXTINT4_Msk & ((value) << TAL_EICCPUSEL0_EXTINT4_Pos))
604 #define TAL_EICCPUSEL0_EXTINT5_Pos  10           /**< \brief (TAL_EICCPUSEL0) External Interrupt 5 CPU Select */
605 #define TAL_EICCPUSEL0_EXTINT5_Msk  (_U(0x1) << TAL_EICCPUSEL0_EXTINT5_Pos)
606 #define TAL_EICCPUSEL0_EXTINT5(value) (TAL_EICCPUSEL0_EXTINT5_Msk & ((value) << TAL_EICCPUSEL0_EXTINT5_Pos))
607 #define TAL_EICCPUSEL0_EXTINT6_Pos  12           /**< \brief (TAL_EICCPUSEL0) External Interrupt 6 CPU Select */
608 #define TAL_EICCPUSEL0_EXTINT6_Msk  (_U(0x1) << TAL_EICCPUSEL0_EXTINT6_Pos)
609 #define TAL_EICCPUSEL0_EXTINT6(value) (TAL_EICCPUSEL0_EXTINT6_Msk & ((value) << TAL_EICCPUSEL0_EXTINT6_Pos))
610 #define TAL_EICCPUSEL0_EXTINT7_Pos  14           /**< \brief (TAL_EICCPUSEL0) External Interrupt 7 CPU Select */
611 #define TAL_EICCPUSEL0_EXTINT7_Msk  (_U(0x1) << TAL_EICCPUSEL0_EXTINT7_Pos)
612 #define TAL_EICCPUSEL0_EXTINT7(value) (TAL_EICCPUSEL0_EXTINT7_Msk & ((value) << TAL_EICCPUSEL0_EXTINT7_Pos))
613 #define TAL_EICCPUSEL0_EXTINT8_Pos  16           /**< \brief (TAL_EICCPUSEL0) External Interrupt 8 CPU Select */
614 #define TAL_EICCPUSEL0_EXTINT8_Msk  (_U(0x1) << TAL_EICCPUSEL0_EXTINT8_Pos)
615 #define TAL_EICCPUSEL0_EXTINT8(value) (TAL_EICCPUSEL0_EXTINT8_Msk & ((value) << TAL_EICCPUSEL0_EXTINT8_Pos))
616 #define TAL_EICCPUSEL0_EXTINT9_Pos  18           /**< \brief (TAL_EICCPUSEL0) External Interrupt 9 CPU Select */
617 #define TAL_EICCPUSEL0_EXTINT9_Msk  (_U(0x1) << TAL_EICCPUSEL0_EXTINT9_Pos)
618 #define TAL_EICCPUSEL0_EXTINT9(value) (TAL_EICCPUSEL0_EXTINT9_Msk & ((value) << TAL_EICCPUSEL0_EXTINT9_Pos))
619 #define TAL_EICCPUSEL0_EXTINT10_Pos 20           /**< \brief (TAL_EICCPUSEL0) External Interrupt 10 CPU Select */
620 #define TAL_EICCPUSEL0_EXTINT10_Msk (_U(0x1) << TAL_EICCPUSEL0_EXTINT10_Pos)
621 #define TAL_EICCPUSEL0_EXTINT10(value) (TAL_EICCPUSEL0_EXTINT10_Msk & ((value) << TAL_EICCPUSEL0_EXTINT10_Pos))
622 #define TAL_EICCPUSEL0_EXTINT11_Pos 22           /**< \brief (TAL_EICCPUSEL0) External Interrupt 11 CPU Select */
623 #define TAL_EICCPUSEL0_EXTINT11_Msk (_U(0x1) << TAL_EICCPUSEL0_EXTINT11_Pos)
624 #define TAL_EICCPUSEL0_EXTINT11(value) (TAL_EICCPUSEL0_EXTINT11_Msk & ((value) << TAL_EICCPUSEL0_EXTINT11_Pos))
625 #define TAL_EICCPUSEL0_EXTINT12_Pos 24           /**< \brief (TAL_EICCPUSEL0) External Interrupt 12 CPU Select */
626 #define TAL_EICCPUSEL0_EXTINT12_Msk (_U(0x1) << TAL_EICCPUSEL0_EXTINT12_Pos)
627 #define TAL_EICCPUSEL0_EXTINT12(value) (TAL_EICCPUSEL0_EXTINT12_Msk & ((value) << TAL_EICCPUSEL0_EXTINT12_Pos))
628 #define TAL_EICCPUSEL0_EXTINT13_Pos 26           /**< \brief (TAL_EICCPUSEL0) External Interrupt 13 CPU Select */
629 #define TAL_EICCPUSEL0_EXTINT13_Msk (_U(0x1) << TAL_EICCPUSEL0_EXTINT13_Pos)
630 #define TAL_EICCPUSEL0_EXTINT13(value) (TAL_EICCPUSEL0_EXTINT13_Msk & ((value) << TAL_EICCPUSEL0_EXTINT13_Pos))
631 #define TAL_EICCPUSEL0_EXTINT14_Pos 28           /**< \brief (TAL_EICCPUSEL0) External Interrupt 14 CPU Select */
632 #define TAL_EICCPUSEL0_EXTINT14_Msk (_U(0x1) << TAL_EICCPUSEL0_EXTINT14_Pos)
633 #define TAL_EICCPUSEL0_EXTINT14(value) (TAL_EICCPUSEL0_EXTINT14_Msk & ((value) << TAL_EICCPUSEL0_EXTINT14_Pos))
634 #define TAL_EICCPUSEL0_EXTINT15_Pos 30           /**< \brief (TAL_EICCPUSEL0) External Interrupt 15 CPU Select */
635 #define TAL_EICCPUSEL0_EXTINT15_Msk (_U(0x1) << TAL_EICCPUSEL0_EXTINT15_Pos)
636 #define TAL_EICCPUSEL0_EXTINT15(value) (TAL_EICCPUSEL0_EXTINT15_Msk & ((value) << TAL_EICCPUSEL0_EXTINT15_Pos))
637 #define TAL_EICCPUSEL0_MASK         _U(0x55555555) /**< \brief (TAL_EICCPUSEL0) MASK Register */
638 
639 /* -------- TAL_INTCPUSEL0 : (TAL Offset: 0x58) (R/W 32) Interrupts CPU Select 0 -------- */
640 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
641 typedef union {
642   struct {
643     uint32_t SYSTEM:1;         /*!< bit:      0  SYSTEM Interrupt CPU Select        */
644     uint32_t :1;               /*!< bit:      1  Reserved                           */
645     uint32_t WDT:1;            /*!< bit:      2  WDT Interrupt CPU Select           */
646     uint32_t :1;               /*!< bit:      3  Reserved                           */
647     uint32_t RTC:1;            /*!< bit:      4  RTC Interrupt CPU Select           */
648     uint32_t :3;               /*!< bit:  5.. 7  Reserved                           */
649     uint32_t NVMCTRL:1;        /*!< bit:      8  NVMCTRL Interrupt CPU Select       */
650     uint32_t :3;               /*!< bit:  9..11  Reserved                           */
651     uint32_t USB:1;            /*!< bit:     12  USB Interrupt CPU Select           */
652     uint32_t :3;               /*!< bit: 13..15  Reserved                           */
653     uint32_t SERCOM0:1;        /*!< bit:     16  SERCOM0 Interrupt CPU Select       */
654     uint32_t :1;               /*!< bit:     17  Reserved                           */
655     uint32_t SERCOM1:1;        /*!< bit:     18  SERCOM1 Interrupt CPU Select       */
656     uint32_t :1;               /*!< bit:     19  Reserved                           */
657     uint32_t SERCOM2:1;        /*!< bit:     20  SERCOM2 Interrupt CPU Select       */
658     uint32_t :1;               /*!< bit:     21  Reserved                           */
659     uint32_t SERCOM3:1;        /*!< bit:     22  SERCOM3 Interrupt CPU Select       */
660     uint32_t :1;               /*!< bit:     23  Reserved                           */
661     uint32_t SERCOM4:1;        /*!< bit:     24  SERCOM4 Interrupt CPU Select       */
662     uint32_t :1;               /*!< bit:     25  Reserved                           */
663     uint32_t SERCOM5:1;        /*!< bit:     26  SERCOM5 Interrupt CPU Select       */
664     uint32_t :1;               /*!< bit:     27  Reserved                           */
665     uint32_t TCC0:1;           /*!< bit:     28  TCC0 Interrupt CPU Select          */
666     uint32_t :1;               /*!< bit:     29  Reserved                           */
667     uint32_t TCC1:1;           /*!< bit:     30  TCC1 Interrupt CPU Select          */
668     uint32_t :1;               /*!< bit:     31  Reserved                           */
669   } bit;                       /*!< Structure used for bit  access                  */
670   uint32_t reg;                /*!< Type      used for register access              */
671 } TAL_INTCPUSEL0_Type;
672 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
673 
674 #define TAL_INTCPUSEL0_OFFSET       0x58         /**< \brief (TAL_INTCPUSEL0 offset) Interrupts CPU Select 0 */
675 #define TAL_INTCPUSEL0_RESETVALUE   _U(0x00000000) /**< \brief (TAL_INTCPUSEL0 reset_value) Interrupts CPU Select 0 */
676 
677 #define TAL_INTCPUSEL0_SYSTEM_Pos   0            /**< \brief (TAL_INTCPUSEL0) SYSTEM Interrupt CPU Select */
678 #define TAL_INTCPUSEL0_SYSTEM_Msk   (_U(0x1) << TAL_INTCPUSEL0_SYSTEM_Pos)
679 #define TAL_INTCPUSEL0_SYSTEM(value) (TAL_INTCPUSEL0_SYSTEM_Msk & ((value) << TAL_INTCPUSEL0_SYSTEM_Pos))
680 #define TAL_INTCPUSEL0_WDT_Pos      2            /**< \brief (TAL_INTCPUSEL0) WDT Interrupt CPU Select */
681 #define TAL_INTCPUSEL0_WDT_Msk      (_U(0x1) << TAL_INTCPUSEL0_WDT_Pos)
682 #define TAL_INTCPUSEL0_WDT(value)   (TAL_INTCPUSEL0_WDT_Msk & ((value) << TAL_INTCPUSEL0_WDT_Pos))
683 #define TAL_INTCPUSEL0_RTC_Pos      4            /**< \brief (TAL_INTCPUSEL0) RTC Interrupt CPU Select */
684 #define TAL_INTCPUSEL0_RTC_Msk      (_U(0x1) << TAL_INTCPUSEL0_RTC_Pos)
685 #define TAL_INTCPUSEL0_RTC(value)   (TAL_INTCPUSEL0_RTC_Msk & ((value) << TAL_INTCPUSEL0_RTC_Pos))
686 #define TAL_INTCPUSEL0_NVMCTRL_Pos  8            /**< \brief (TAL_INTCPUSEL0) NVMCTRL Interrupt CPU Select */
687 #define TAL_INTCPUSEL0_NVMCTRL_Msk  (_U(0x1) << TAL_INTCPUSEL0_NVMCTRL_Pos)
688 #define TAL_INTCPUSEL0_NVMCTRL(value) (TAL_INTCPUSEL0_NVMCTRL_Msk & ((value) << TAL_INTCPUSEL0_NVMCTRL_Pos))
689 #define TAL_INTCPUSEL0_USB_Pos      12           /**< \brief (TAL_INTCPUSEL0) USB Interrupt CPU Select */
690 #define TAL_INTCPUSEL0_USB_Msk      (_U(0x1) << TAL_INTCPUSEL0_USB_Pos)
691 #define TAL_INTCPUSEL0_USB(value)   (TAL_INTCPUSEL0_USB_Msk & ((value) << TAL_INTCPUSEL0_USB_Pos))
692 #define TAL_INTCPUSEL0_SERCOM0_Pos  16           /**< \brief (TAL_INTCPUSEL0) SERCOM0 Interrupt CPU Select */
693 #define TAL_INTCPUSEL0_SERCOM0_Msk  (_U(0x1) << TAL_INTCPUSEL0_SERCOM0_Pos)
694 #define TAL_INTCPUSEL0_SERCOM0(value) (TAL_INTCPUSEL0_SERCOM0_Msk & ((value) << TAL_INTCPUSEL0_SERCOM0_Pos))
695 #define TAL_INTCPUSEL0_SERCOM1_Pos  18           /**< \brief (TAL_INTCPUSEL0) SERCOM1 Interrupt CPU Select */
696 #define TAL_INTCPUSEL0_SERCOM1_Msk  (_U(0x1) << TAL_INTCPUSEL0_SERCOM1_Pos)
697 #define TAL_INTCPUSEL0_SERCOM1(value) (TAL_INTCPUSEL0_SERCOM1_Msk & ((value) << TAL_INTCPUSEL0_SERCOM1_Pos))
698 #define TAL_INTCPUSEL0_SERCOM2_Pos  20           /**< \brief (TAL_INTCPUSEL0) SERCOM2 Interrupt CPU Select */
699 #define TAL_INTCPUSEL0_SERCOM2_Msk  (_U(0x1) << TAL_INTCPUSEL0_SERCOM2_Pos)
700 #define TAL_INTCPUSEL0_SERCOM2(value) (TAL_INTCPUSEL0_SERCOM2_Msk & ((value) << TAL_INTCPUSEL0_SERCOM2_Pos))
701 #define TAL_INTCPUSEL0_SERCOM3_Pos  22           /**< \brief (TAL_INTCPUSEL0) SERCOM3 Interrupt CPU Select */
702 #define TAL_INTCPUSEL0_SERCOM3_Msk  (_U(0x1) << TAL_INTCPUSEL0_SERCOM3_Pos)
703 #define TAL_INTCPUSEL0_SERCOM3(value) (TAL_INTCPUSEL0_SERCOM3_Msk & ((value) << TAL_INTCPUSEL0_SERCOM3_Pos))
704 #define TAL_INTCPUSEL0_SERCOM4_Pos  24           /**< \brief (TAL_INTCPUSEL0) SERCOM4 Interrupt CPU Select */
705 #define TAL_INTCPUSEL0_SERCOM4_Msk  (_U(0x1) << TAL_INTCPUSEL0_SERCOM4_Pos)
706 #define TAL_INTCPUSEL0_SERCOM4(value) (TAL_INTCPUSEL0_SERCOM4_Msk & ((value) << TAL_INTCPUSEL0_SERCOM4_Pos))
707 #define TAL_INTCPUSEL0_SERCOM5_Pos  26           /**< \brief (TAL_INTCPUSEL0) SERCOM5 Interrupt CPU Select */
708 #define TAL_INTCPUSEL0_SERCOM5_Msk  (_U(0x1) << TAL_INTCPUSEL0_SERCOM5_Pos)
709 #define TAL_INTCPUSEL0_SERCOM5(value) (TAL_INTCPUSEL0_SERCOM5_Msk & ((value) << TAL_INTCPUSEL0_SERCOM5_Pos))
710 #define TAL_INTCPUSEL0_TCC0_Pos     28           /**< \brief (TAL_INTCPUSEL0) TCC0 Interrupt CPU Select */
711 #define TAL_INTCPUSEL0_TCC0_Msk     (_U(0x1) << TAL_INTCPUSEL0_TCC0_Pos)
712 #define TAL_INTCPUSEL0_TCC0(value)  (TAL_INTCPUSEL0_TCC0_Msk & ((value) << TAL_INTCPUSEL0_TCC0_Pos))
713 #define TAL_INTCPUSEL0_TCC1_Pos     30           /**< \brief (TAL_INTCPUSEL0) TCC1 Interrupt CPU Select */
714 #define TAL_INTCPUSEL0_TCC1_Msk     (_U(0x1) << TAL_INTCPUSEL0_TCC1_Pos)
715 #define TAL_INTCPUSEL0_TCC1(value)  (TAL_INTCPUSEL0_TCC1_Msk & ((value) << TAL_INTCPUSEL0_TCC1_Pos))
716 #define TAL_INTCPUSEL0_MASK         _U(0x55551115) /**< \brief (TAL_INTCPUSEL0) MASK Register */
717 
718 /* -------- TAL_INTCPUSEL1 : (TAL Offset: 0x5C) (R/W 32) Interrupts CPU Select 1 -------- */
719 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
720 typedef union {
721   struct {
722     uint32_t TCC2:1;           /*!< bit:      0  TCC2 Interrupt CPU Select          */
723     uint32_t :1;               /*!< bit:      1  Reserved                           */
724     uint32_t TC0:1;            /*!< bit:      2  TC0 Interrupt CPU Select           */
725     uint32_t :1;               /*!< bit:      3  Reserved                           */
726     uint32_t TC1:1;            /*!< bit:      4  TC1 Interrupt CPU Select           */
727     uint32_t :1;               /*!< bit:      5  Reserved                           */
728     uint32_t TC2:1;            /*!< bit:      6  TC2 Interrupt CPU Select           */
729     uint32_t :1;               /*!< bit:      7  Reserved                           */
730     uint32_t TC3:1;            /*!< bit:      8  TC3 Interrupt CPU Select           */
731     uint32_t :1;               /*!< bit:      9  Reserved                           */
732     uint32_t TC4:1;            /*!< bit:     10  TC4 Interrupt CPU Select           */
733     uint32_t :1;               /*!< bit:     11  Reserved                           */
734     uint32_t ADC:1;            /*!< bit:     12  ADC Interrupt CPU Select           */
735     uint32_t :1;               /*!< bit:     13  Reserved                           */
736     uint32_t AC:1;             /*!< bit:     14  AC Interrupt CPU Select            */
737     uint32_t :1;               /*!< bit:     15  Reserved                           */
738     uint32_t DAC:1;            /*!< bit:     16  DAC Interrupt CPU Select           */
739     uint32_t :1;               /*!< bit:     17  Reserved                           */
740     uint32_t PTC:1;            /*!< bit:     18  PTC Interrupt CPU Select           */
741     uint32_t :1;               /*!< bit:     19  Reserved                           */
742     uint32_t AES:1;            /*!< bit:     20  AES Interrupt CPU Select           */
743     uint32_t :1;               /*!< bit:     21  Reserved                           */
744     uint32_t TRNG:1;           /*!< bit:     22  TRNG Interrupt CPU Select          */
745     uint32_t :1;               /*!< bit:     23  Reserved                           */
746     uint32_t PICOP:1;          /*!< bit:     24  PICOP Interrupt CPU Select         */
747     uint32_t :7;               /*!< bit: 25..31  Reserved                           */
748   } bit;                       /*!< Structure used for bit  access                  */
749   uint32_t reg;                /*!< Type      used for register access              */
750 } TAL_INTCPUSEL1_Type;
751 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
752 
753 #define TAL_INTCPUSEL1_OFFSET       0x5C         /**< \brief (TAL_INTCPUSEL1 offset) Interrupts CPU Select 1 */
754 #define TAL_INTCPUSEL1_RESETVALUE   _U(0x00000000) /**< \brief (TAL_INTCPUSEL1 reset_value) Interrupts CPU Select 1 */
755 
756 #define TAL_INTCPUSEL1_TCC2_Pos     0            /**< \brief (TAL_INTCPUSEL1) TCC2 Interrupt CPU Select */
757 #define TAL_INTCPUSEL1_TCC2_Msk     (_U(0x1) << TAL_INTCPUSEL1_TCC2_Pos)
758 #define TAL_INTCPUSEL1_TCC2(value)  (TAL_INTCPUSEL1_TCC2_Msk & ((value) << TAL_INTCPUSEL1_TCC2_Pos))
759 #define TAL_INTCPUSEL1_TC0_Pos      2            /**< \brief (TAL_INTCPUSEL1) TC0 Interrupt CPU Select */
760 #define TAL_INTCPUSEL1_TC0_Msk      (_U(0x1) << TAL_INTCPUSEL1_TC0_Pos)
761 #define TAL_INTCPUSEL1_TC0(value)   (TAL_INTCPUSEL1_TC0_Msk & ((value) << TAL_INTCPUSEL1_TC0_Pos))
762 #define TAL_INTCPUSEL1_TC1_Pos      4            /**< \brief (TAL_INTCPUSEL1) TC1 Interrupt CPU Select */
763 #define TAL_INTCPUSEL1_TC1_Msk      (_U(0x1) << TAL_INTCPUSEL1_TC1_Pos)
764 #define TAL_INTCPUSEL1_TC1(value)   (TAL_INTCPUSEL1_TC1_Msk & ((value) << TAL_INTCPUSEL1_TC1_Pos))
765 #define TAL_INTCPUSEL1_TC2_Pos      6            /**< \brief (TAL_INTCPUSEL1) TC2 Interrupt CPU Select */
766 #define TAL_INTCPUSEL1_TC2_Msk      (_U(0x1) << TAL_INTCPUSEL1_TC2_Pos)
767 #define TAL_INTCPUSEL1_TC2(value)   (TAL_INTCPUSEL1_TC2_Msk & ((value) << TAL_INTCPUSEL1_TC2_Pos))
768 #define TAL_INTCPUSEL1_TC3_Pos      8            /**< \brief (TAL_INTCPUSEL1) TC3 Interrupt CPU Select */
769 #define TAL_INTCPUSEL1_TC3_Msk      (_U(0x1) << TAL_INTCPUSEL1_TC3_Pos)
770 #define TAL_INTCPUSEL1_TC3(value)   (TAL_INTCPUSEL1_TC3_Msk & ((value) << TAL_INTCPUSEL1_TC3_Pos))
771 #define TAL_INTCPUSEL1_TC4_Pos      10           /**< \brief (TAL_INTCPUSEL1) TC4 Interrupt CPU Select */
772 #define TAL_INTCPUSEL1_TC4_Msk      (_U(0x1) << TAL_INTCPUSEL1_TC4_Pos)
773 #define TAL_INTCPUSEL1_TC4(value)   (TAL_INTCPUSEL1_TC4_Msk & ((value) << TAL_INTCPUSEL1_TC4_Pos))
774 #define TAL_INTCPUSEL1_ADC_Pos      12           /**< \brief (TAL_INTCPUSEL1) ADC Interrupt CPU Select */
775 #define TAL_INTCPUSEL1_ADC_Msk      (_U(0x1) << TAL_INTCPUSEL1_ADC_Pos)
776 #define TAL_INTCPUSEL1_ADC(value)   (TAL_INTCPUSEL1_ADC_Msk & ((value) << TAL_INTCPUSEL1_ADC_Pos))
777 #define TAL_INTCPUSEL1_AC_Pos       14           /**< \brief (TAL_INTCPUSEL1) AC Interrupt CPU Select */
778 #define TAL_INTCPUSEL1_AC_Msk       (_U(0x1) << TAL_INTCPUSEL1_AC_Pos)
779 #define TAL_INTCPUSEL1_AC(value)    (TAL_INTCPUSEL1_AC_Msk & ((value) << TAL_INTCPUSEL1_AC_Pos))
780 #define TAL_INTCPUSEL1_DAC_Pos      16           /**< \brief (TAL_INTCPUSEL1) DAC Interrupt CPU Select */
781 #define TAL_INTCPUSEL1_DAC_Msk      (_U(0x1) << TAL_INTCPUSEL1_DAC_Pos)
782 #define TAL_INTCPUSEL1_DAC(value)   (TAL_INTCPUSEL1_DAC_Msk & ((value) << TAL_INTCPUSEL1_DAC_Pos))
783 #define TAL_INTCPUSEL1_PTC_Pos      18           /**< \brief (TAL_INTCPUSEL1) PTC Interrupt CPU Select */
784 #define TAL_INTCPUSEL1_PTC_Msk      (_U(0x1) << TAL_INTCPUSEL1_PTC_Pos)
785 #define TAL_INTCPUSEL1_PTC(value)   (TAL_INTCPUSEL1_PTC_Msk & ((value) << TAL_INTCPUSEL1_PTC_Pos))
786 #define TAL_INTCPUSEL1_AES_Pos      20           /**< \brief (TAL_INTCPUSEL1) AES Interrupt CPU Select */
787 #define TAL_INTCPUSEL1_AES_Msk      (_U(0x1) << TAL_INTCPUSEL1_AES_Pos)
788 #define TAL_INTCPUSEL1_AES(value)   (TAL_INTCPUSEL1_AES_Msk & ((value) << TAL_INTCPUSEL1_AES_Pos))
789 #define TAL_INTCPUSEL1_TRNG_Pos     22           /**< \brief (TAL_INTCPUSEL1) TRNG Interrupt CPU Select */
790 #define TAL_INTCPUSEL1_TRNG_Msk     (_U(0x1) << TAL_INTCPUSEL1_TRNG_Pos)
791 #define TAL_INTCPUSEL1_TRNG(value)  (TAL_INTCPUSEL1_TRNG_Msk & ((value) << TAL_INTCPUSEL1_TRNG_Pos))
792 #define TAL_INTCPUSEL1_PICOP_Pos    24           /**< \brief (TAL_INTCPUSEL1) PICOP Interrupt CPU Select */
793 #define TAL_INTCPUSEL1_PICOP_Msk    (_U(0x1) << TAL_INTCPUSEL1_PICOP_Pos)
794 #define TAL_INTCPUSEL1_PICOP(value) (TAL_INTCPUSEL1_PICOP_Msk & ((value) << TAL_INTCPUSEL1_PICOP_Pos))
795 #define TAL_INTCPUSEL1_MASK         _U(0x01555555) /**< \brief (TAL_INTCPUSEL1) MASK Register */
796 
797 /* -------- TAL_IRQTRIG : (TAL Offset: 0x60) (R/W 16) Interrupt Trigger -------- */
798 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
799 typedef union {
800   struct {
801     uint16_t ENABLE:1;         /*!< bit:      0  Trigger Enable                     */
802     uint16_t IRQNUM:5;         /*!< bit:  1.. 5  Interrupt Request Number           */
803     uint16_t :2;               /*!< bit:  6.. 7  Reserved                           */
804     uint16_t OVERRIDE:8;       /*!< bit:  8..15  Interrupt Request Override Value   */
805   } bit;                       /*!< Structure used for bit  access                  */
806   uint16_t reg;                /*!< Type      used for register access              */
807 } TAL_IRQTRIG_Type;
808 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
809 
810 #define TAL_IRQTRIG_OFFSET          0x60         /**< \brief (TAL_IRQTRIG offset) Interrupt Trigger */
811 #define TAL_IRQTRIG_RESETVALUE      _U(0x0000)   /**< \brief (TAL_IRQTRIG reset_value) Interrupt Trigger */
812 
813 #define TAL_IRQTRIG_ENABLE_Pos      0            /**< \brief (TAL_IRQTRIG) Trigger Enable */
814 #define TAL_IRQTRIG_ENABLE          (_U(0x1) << TAL_IRQTRIG_ENABLE_Pos)
815 #define TAL_IRQTRIG_IRQNUM_Pos      1            /**< \brief (TAL_IRQTRIG) Interrupt Request Number */
816 #define TAL_IRQTRIG_IRQNUM_Msk      (_U(0x1F) << TAL_IRQTRIG_IRQNUM_Pos)
817 #define TAL_IRQTRIG_IRQNUM(value)   (TAL_IRQTRIG_IRQNUM_Msk & ((value) << TAL_IRQTRIG_IRQNUM_Pos))
818 #define TAL_IRQTRIG_OVERRIDE_Pos    8            /**< \brief (TAL_IRQTRIG) Interrupt Request Override Value */
819 #define TAL_IRQTRIG_OVERRIDE_Msk    (_U(0xFF) << TAL_IRQTRIG_OVERRIDE_Pos)
820 #define TAL_IRQTRIG_OVERRIDE(value) (TAL_IRQTRIG_OVERRIDE_Msk & ((value) << TAL_IRQTRIG_OVERRIDE_Pos))
821 #define TAL_IRQTRIG_MASK            _U(0xFF3F)   /**< \brief (TAL_IRQTRIG) MASK Register */
822 
823 /* -------- TAL_CPUIRQS : (TAL Offset: 0x64) (R/  32) Interrupt Status for CPU n -------- */
824 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
825 typedef union {
826   struct {
827     uint32_t CPUIRQS:29;       /*!< bit:  0..28  Interrupt Requests for CPU n       */
828     uint32_t :3;               /*!< bit: 29..31  Reserved                           */
829   } bit;                       /*!< Structure used for bit  access                  */
830   uint32_t reg;                /*!< Type      used for register access              */
831 } TAL_CPUIRQS_Type;
832 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
833 
834 #define TAL_CPUIRQS_OFFSET          0x64         /**< \brief (TAL_CPUIRQS offset) Interrupt Status for CPU n */
835 #define TAL_CPUIRQS_RESETVALUE      _U(0x00000000) /**< \brief (TAL_CPUIRQS reset_value) Interrupt Status for CPU n */
836 
837 #define TAL_CPUIRQS_CPUIRQS_Pos     0            /**< \brief (TAL_CPUIRQS) Interrupt Requests for CPU n */
838 #define TAL_CPUIRQS_CPUIRQS_Msk     (_U(0x1FFFFFFF) << TAL_CPUIRQS_CPUIRQS_Pos)
839 #define TAL_CPUIRQS_CPUIRQS(value)  (TAL_CPUIRQS_CPUIRQS_Msk & ((value) << TAL_CPUIRQS_CPUIRQS_Pos))
840 #define TAL_CPUIRQS_MASK            _U(0x1FFFFFFF) /**< \brief (TAL_CPUIRQS) MASK Register */
841 
842 /** \brief TalCtis hardware registers */
843 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
844 typedef struct {
845   __IO TAL_CTICTRLA_Type         CTICTRLA;    /**< \brief Offset: 0x00 (R/W  8) Cross-Trigger Interface n Control A */
846   __IO TAL_CTIMASK_Type          CTIMASK;     /**< \brief Offset: 0x01 (R/W  8) Cross-Trigger Interface n Mask */
847 } TalCtis;
848 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
849 
850 /** \brief TAL hardware registers */
851 #if !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__))
852 typedef struct {
853   __IO TAL_CTRLA_Type            CTRLA;       /**< \brief Offset: 0x00 (R/W  8) Control A */
854        RoReg8                    Reserved1[0x3];
855   __IO TAL_RSTCTRL_Type          RSTCTRL;     /**< \brief Offset: 0x04 (R/W  8) Reset Control */
856   __IO TAL_EXTCTRL_Type          EXTCTRL;     /**< \brief Offset: 0x05 (R/W  8) External Break Control */
857   __IO TAL_EVCTRL_Type           EVCTRL;      /**< \brief Offset: 0x06 (R/W  8) Event Control */
858        RoReg8                    Reserved2[0x1];
859   __IO TAL_INTENCLR_Type         INTENCLR;    /**< \brief Offset: 0x08 (R/W  8) Interrupt Enable Clear */
860   __IO TAL_INTENSET_Type         INTENSET;    /**< \brief Offset: 0x09 (R/W  8) Interrupt Enable Set */
861   __IO TAL_INTFLAG_Type          INTFLAG;     /**< \brief Offset: 0x0A (R/W  8) Interrupt Flag Status and Clear */
862   __IO TAL_GLOBMASK_Type         GLOBMASK;    /**< \brief Offset: 0x0B (R/W  8) Global Break Requests Mask */
863   __O  TAL_HALT_Type             HALT;        /**< \brief Offset: 0x0C ( /W  8) Debug Halt Request */
864   __O  TAL_RESTART_Type          RESTART;     /**< \brief Offset: 0x0D ( /W  8) Debug Restart Request */
865   __I  TAL_BRKSTATUS_Type        BRKSTATUS;   /**< \brief Offset: 0x0E (R/  16) Break Request Status */
866        TalCtis                   Ctis[4];     /**< \brief Offset: 0x10 TalCtis groups [CTI_NUM] */
867        RoReg8                    Reserved3[0x8];
868   __I  TAL_INTSTATUS_Type        INTSTATUS[29]; /**< \brief Offset: 0x20 (R/   8) Interrupt n Status */
869        RoReg8                    Reserved4[0x3];
870   __IO TAL_DMACPUSEL0_Type       DMACPUSEL0;  /**< \brief Offset: 0x40 (R/W 32) DMA Channel Interrupts CPU Select 0 */
871        RoReg8                    Reserved5[0x4];
872   __IO TAL_EVCPUSEL0_Type        EVCPUSEL0;   /**< \brief Offset: 0x48 (R/W 32) EVSYS Channel Interrupts CPU Select 0 */
873        RoReg8                    Reserved6[0x4];
874   __IO TAL_EICCPUSEL0_Type       EICCPUSEL0;  /**< \brief Offset: 0x50 (R/W 32) EIC External Interrupts CPU Select 0 */
875        RoReg8                    Reserved7[0x4];
876   __IO TAL_INTCPUSEL0_Type       INTCPUSEL0;  /**< \brief Offset: 0x58 (R/W 32) Interrupts CPU Select 0 */
877   __IO TAL_INTCPUSEL1_Type       INTCPUSEL1;  /**< \brief Offset: 0x5C (R/W 32) Interrupts CPU Select 1 */
878   __IO TAL_IRQTRIG_Type          IRQTRIG;     /**< \brief Offset: 0x60 (R/W 16) Interrupt Trigger */
879        RoReg8                    Reserved8[0x2];
880   __I  TAL_CPUIRQS_Type          CPUIRQS[2];  /**< \brief Offset: 0x64 (R/  32) Interrupt Status for CPU n */
881 } Tal;
882 #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */
883 
884 /*@}*/
885 
886 #endif /* _SAML21_TAL_COMPONENT_ */
887