core_cm4.h 92.6 KB
Newer Older
Y
yanmowudi 已提交
1
/**************************************************************************/ /**
W
whsj2 已提交
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
 * @file     core_cm4.h
 * @brief    CMSIS Cortex-M4 Core Peripheral Access Layer Header File
 * @version  V4.00
 * @date     22. August 2014
 *
 * @note
 *
 ******************************************************************************/
/* Copyright (c) 2009 - 2014 ARM LIMITED

   All rights reserved.
   Redistribution and use in source and binary forms, with or without
   modification, are permitted provided that the following conditions are met:
   - Redistributions of source code must retain the above copyright
     notice, this list of conditions and the following disclaimer.
   - Redistributions in binary form must reproduce the above copyright
     notice, this list of conditions and the following disclaimer in the
     documentation and/or other materials provided with the distribution.
   - Neither the name of ARM nor the names of its contributors may be used
     to endorse or promote products derived from this software without
     specific prior written permission.
   *
   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
   AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
   IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
   ARE DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDERS AND CONTRIBUTORS BE
   LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
   CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
   SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
   INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
   CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
   ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
   POSSIBILITY OF SUCH DAMAGE.
   ---------------------------------------------------------------------------*/

Y
yanmowudi 已提交
37 38
#if defined(__ICCARM__)
#pragma system_include /* treat file as system include file for MISRA check */
W
whsj2 已提交
39 40 41 42 43 44
#endif

#ifndef __CORE_CM4_H_GENERIC
#define __CORE_CM4_H_GENERIC

#ifdef __cplusplus
Y
yanmowudi 已提交
45 46
extern "C"
{
W
whsj2 已提交
47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69
#endif

/** \page CMSIS_MISRA_Exceptions  MISRA-C:2004 Compliance Exceptions
  CMSIS violates the following MISRA-C:2004 rules:

   \li Required Rule 8.5, object/function definition in header file.<br>
     Function definitions in header files are used to allow 'inlining'.

   \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.<br>
     Unions are used for effective representation of core registers.

   \li Advisory Rule 19.7, Function-like macro defined.<br>
     Function-like macros are used to allow more efficient code.
 */

/*******************************************************************************
 *                 CMSIS definitions
 ******************************************************************************/
/** \ingroup Cortex_M4
  @{
 */

/*  CMSIS CM4 definitions */
Y
yanmowudi 已提交
70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105
#define __CM4_CMSIS_VERSION_MAIN (0x04) /*!< [31:16] CMSIS HAL main version   */
#define __CM4_CMSIS_VERSION_SUB (0x00)  /*!< [15:0]  CMSIS HAL sub version    */
#define __CM4_CMSIS_VERSION ((__CM4_CMSIS_VERSION_MAIN << 16) | \
                             __CM4_CMSIS_VERSION_SUB) /*!< CMSIS HAL version number         */

#define __CORTEX_M (0x04) /*!< Cortex-M Core                    */

#if defined(__CC_ARM)
#define __ASM __asm       /*!< asm keyword for ARM Compiler          */
#define __INLINE __inline /*!< inline keyword for ARM Compiler       */
#define __STATIC_INLINE static __inline

#elif defined(__GNUC__)
#define __ASM __asm     /*!< asm keyword for GNU Compiler          */
#define __INLINE inline /*!< inline keyword for GNU Compiler       */
#define __STATIC_INLINE static inline

#elif defined(__ICCARM__)
#define __ASM __asm     /*!< asm keyword for IAR Compiler          */
#define __INLINE inline /*!< inline keyword for IAR Compiler. Only available in High optimization mode! */
#define __STATIC_INLINE static inline

#elif defined(__TMS470__)
#define __ASM __asm /*!< asm keyword for TI CCS Compiler       */
#define __STATIC_INLINE static inline

#elif defined(__TASKING__)
#define __ASM __asm     /*!< asm keyword for TASKING Compiler      */
#define __INLINE inline /*!< inline keyword for TASKING Compiler   */
#define __STATIC_INLINE static inline

#elif defined(__CSMC__)
#define __packed
#define __ASM _asm      /*!< asm keyword for COSMIC Compiler      */
#define __INLINE inline /*use -pc99 on compile line !< inline keyword for COSMIC Compiler   */
#define __STATIC_INLINE static inline
W
whsj2 已提交
106

Y
yanmowudi 已提交
107
#endif
W
whsj2 已提交
108

Y
yanmowudi 已提交
109 110 111 112 113 114 115 116 117 118 119 120 121 122
/** __FPU_USED indicates whether an FPU is used or not.
    For this, __FPU_PRESENT has to be checked prior to making use of FPU specific registers and functions.
*/
#if defined(__CC_ARM)
#if defined __TARGET_FPU_VFP
#if (__FPU_PRESENT == 1)
#define __FPU_USED 1
#else
#warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#define __FPU_USED 0
#endif
#else
#define __FPU_USED 0
#endif
W
whsj2 已提交
123

Y
yanmowudi 已提交
124 125 126 127 128 129 130 131 132 133 134
#elif defined(__GNUC__)
#if defined(__VFP_FP__) && !defined(__SOFTFP__)
#if (__FPU_PRESENT == 1)
#define __FPU_USED 1
#else
#warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#define __FPU_USED 0
#endif
#else
#define __FPU_USED 0
#endif
W
whsj2 已提交
135

Y
yanmowudi 已提交
136 137 138 139 140 141 142 143 144 145 146
#elif defined(__ICCARM__)
#if defined __ARMVFP__
#if (__FPU_PRESENT == 1)
#define __FPU_USED 1
#else
#warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#define __FPU_USED 0
#endif
#else
#define __FPU_USED 0
#endif
W
whsj2 已提交
147

Y
yanmowudi 已提交
148 149 150 151 152 153 154 155 156 157 158
#elif defined(__TMS470__)
#if defined __TI_VFP_SUPPORT__
#if (__FPU_PRESENT == 1)
#define __FPU_USED 1
#else
#warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#define __FPU_USED 0
#endif
#else
#define __FPU_USED 0
#endif
W
whsj2 已提交
159

Y
yanmowudi 已提交
160 161 162 163 164 165 166 167 168 169
#elif defined(__TASKING__)
#if defined __FPU_VFP__
#if (__FPU_PRESENT == 1)
#define __FPU_USED 1
#else
#error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#define __FPU_USED 0
#endif
#else
#define __FPU_USED 0
W
whsj2 已提交
170 171
#endif

Y
yanmowudi 已提交
172 173 174 175 176 177 178 179 180 181 182
#elif defined(__CSMC__) /* Cosmic */
#if (__CSMC__ & 0x400)  // FPU present for parser
#if (__FPU_PRESENT == 1)
#define __FPU_USED 1
#else
#error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)"
#define __FPU_USED 0
#endif
#else
#define __FPU_USED 0
#endif
W
whsj2 已提交
183 184
#endif

Y
yanmowudi 已提交
185 186 187 188
#include <stdint.h>       /* standard types definitions                      */
#include <core_cmInstr.h> /* Core Instruction Access                         */
#include <core_cmFunc.h>  /* Core Function Access                            */
#include <core_cmSimd.h>  /* Compiler specific SIMD Intrinsics               */
W
whsj2 已提交
189 190 191 192 193 194 195 196 197 198 199 200 201

#ifdef __cplusplus
}
#endif

#endif /* __CORE_CM4_H_GENERIC */

#ifndef __CMSIS_GENERIC

#ifndef __CORE_CM4_H_DEPENDANT
#define __CORE_CM4_H_DEPENDANT

#ifdef __cplusplus
Y
yanmowudi 已提交
202 203
extern "C"
{
W
whsj2 已提交
204 205 206 207
#endif

/* check device defines and use defaults */
#if defined __CHECK_DEVICE_DEFINES
Y
yanmowudi 已提交
208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231
#ifndef __CM4_REV
#define __CM4_REV 0x0000
#warning "__CM4_REV not defined in device header file; using default!"
#endif

#ifndef __FPU_PRESENT
#define __FPU_PRESENT 0
#warning "__FPU_PRESENT not defined in device header file; using default!"
#endif

#ifndef __MPU_PRESENT
#define __MPU_PRESENT 0
#warning "__MPU_PRESENT not defined in device header file; using default!"
#endif

#ifndef __NVIC_PRIO_BITS
#define __NVIC_PRIO_BITS 4
#warning "__NVIC_PRIO_BITS not defined in device header file; using default!"
#endif

#ifndef __Vendor_SysTickConfig
#define __Vendor_SysTickConfig 0
#warning "__Vendor_SysTickConfig not defined in device header file; using default!"
#endif
W
whsj2 已提交
232 233 234 235 236 237 238 239 240 241 242
#endif

/* IO definitions (access restrictions to peripheral registers) */
/**
    \defgroup CMSIS_glob_defs CMSIS Global Defines

    <strong>IO Type Qualifiers</strong> are used
    \li to specify the access to peripheral variables.
    \li for automatic generation of peripheral register debug information.
*/
#ifdef __cplusplus
Y
yanmowudi 已提交
243
#define __I volatile /*!< Defines 'read only' permissions                 */
W
whsj2 已提交
244
#else
Y
yanmowudi 已提交
245
#define __I volatile const /*!< Defines 'read only' permissions                 */
W
whsj2 已提交
246
#endif
Y
yanmowudi 已提交
247 248
#define __O volatile  /*!< Defines 'write only' permissions                */
#define __IO volatile /*!< Defines 'read / write' permissions              */
W
whsj2 已提交
249

Y
yanmowudi 已提交
250
    /*@} end of group Cortex_M4 */
W
whsj2 已提交
251

Y
yanmowudi 已提交
252
    /*******************************************************************************
W
whsj2 已提交
253 254 255 256 257 258 259 260 261 262
 *                 Register Abstraction
  Core Register contain:
  - Core Register
  - Core NVIC Register
  - Core SCB Register
  - Core SysTick Register
  - Core Debug Register
  - Core MPU Register
  - Core FPU Register
 ******************************************************************************/
Y
yanmowudi 已提交
263
    /** \defgroup CMSIS_core_register Defines and Type Definitions
W
whsj2 已提交
264 265 266
    \brief Type definitions and defines for Cortex-M processor based devices.
*/

Y
yanmowudi 已提交
267
    /** \ingroup    CMSIS_core_register
W
whsj2 已提交
268 269 270 271 272
    \defgroup   CMSIS_CORE  Status and Control Registers
    \brief  Core Register type definitions.
  @{
 */

Y
yanmowudi 已提交
273
    /** \brief  Union type to access the Application Program Status Register (APSR).
W
whsj2 已提交
274
 */
Y
yanmowudi 已提交
275 276 277 278
    typedef union
    {
        struct
        {
W
whsj2 已提交
279
#if (__CORTEX_M != 0x04)
Y
yanmowudi 已提交
280
            uint32_t _reserved0 : 27; /*!< bit:  0..26  Reserved                           */
W
whsj2 已提交
281
#else
Y
yanmowudi 已提交
282 283 284
        uint32_t _reserved0 : 16; /*!< bit:  0..15  Reserved                           */
        uint32_t GE : 4;          /*!< bit: 16..19  Greater than or Equal flags        */
        uint32_t _reserved1 : 7;  /*!< bit: 20..26  Reserved                           */
W
whsj2 已提交
285
#endif
Y
yanmowudi 已提交
286 287 288 289 290 291 292 293 294 295
            uint32_t Q : 1; /*!< bit:     27  Saturation condition flag          */
            uint32_t V : 1; /*!< bit:     28  Overflow condition code flag       */
            uint32_t C : 1; /*!< bit:     29  Carry condition code flag          */
            uint32_t Z : 1; /*!< bit:     30  Zero condition code flag           */
            uint32_t N : 1; /*!< bit:     31  Negative condition code flag       */
        } b;                /*!< Structure used for bit  access                  */
        uint32_t w;         /*!< Type      used for word access                  */
    } APSR_Type;

    /** \brief  Union type to access the Interrupt Program Status Register (IPSR).
W
whsj2 已提交
296
 */
Y
yanmowudi 已提交
297 298 299 300 301 302 303 304 305 306 307
    typedef union
    {
        struct
        {
            uint32_t ISR : 9;         /*!< bit:  0.. 8  Exception number                   */
            uint32_t _reserved0 : 23; /*!< bit:  9..31  Reserved                           */
        } b;                          /*!< Structure used for bit  access                  */
        uint32_t w;                   /*!< Type      used for word access                  */
    } IPSR_Type;

    /** \brief  Union type to access the Special-Purpose Program Status Registers (xPSR).
W
whsj2 已提交
308
 */
Y
yanmowudi 已提交
309 310 311 312 313
    typedef union
    {
        struct
        {
            uint32_t ISR : 9; /*!< bit:  0.. 8  Exception number                   */
W
whsj2 已提交
314
#if (__CORTEX_M != 0x04)
Y
yanmowudi 已提交
315
            uint32_t _reserved0 : 15; /*!< bit:  9..23  Reserved                           */
W
whsj2 已提交
316
#else
Y
yanmowudi 已提交
317 318 319
        uint32_t _reserved0 : 7;  /*!< bit:  9..15  Reserved                           */
        uint32_t GE : 4;          /*!< bit: 16..19  Greater than or Equal flags        */
        uint32_t _reserved1 : 4;  /*!< bit: 20..23  Reserved                           */
W
whsj2 已提交
320
#endif
Y
yanmowudi 已提交
321 322 323 324 325 326 327 328 329 330 331 332
            uint32_t T : 1;  /*!< bit:     24  Thumb bit        (read 0)          */
            uint32_t IT : 2; /*!< bit: 25..26  saved IT state   (read 0)          */
            uint32_t Q : 1;  /*!< bit:     27  Saturation condition flag          */
            uint32_t V : 1;  /*!< bit:     28  Overflow condition code flag       */
            uint32_t C : 1;  /*!< bit:     29  Carry condition code flag          */
            uint32_t Z : 1;  /*!< bit:     30  Zero condition code flag           */
            uint32_t N : 1;  /*!< bit:     31  Negative condition code flag       */
        } b;                 /*!< Structure used for bit  access                  */
        uint32_t w;          /*!< Type      used for word access                  */
    } xPSR_Type;

    /** \brief  Union type to access the Control Registers (CONTROL).
W
whsj2 已提交
333
 */
Y
yanmowudi 已提交
334 335 336 337 338 339 340 341 342 343 344 345 346 347 348
    typedef union
    {
        struct
        {
            uint32_t nPRIV : 1;       /*!< bit:      0  Execution privilege in Thread mode */
            uint32_t SPSEL : 1;       /*!< bit:      1  Stack to be used                   */
            uint32_t FPCA : 1;        /*!< bit:      2  FP extension active flag           */
            uint32_t _reserved0 : 29; /*!< bit:  3..31  Reserved                           */
        } b;                          /*!< Structure used for bit  access                  */
        uint32_t w;                   /*!< Type      used for word access                  */
    } CONTROL_Type;

    /*@} end of group CMSIS_CORE */

    /** \ingroup    CMSIS_core_register
W
whsj2 已提交
349 350 351 352 353
    \defgroup   CMSIS_NVIC  Nested Vectored Interrupt Controller (NVIC)
    \brief      Type definitions for the NVIC Registers
  @{
 */

Y
yanmowudi 已提交
354
    /** \brief  Structure type to access the Nested Vectored Interrupt Controller (NVIC).
W
whsj2 已提交
355
 */
Y
yanmowudi 已提交
356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371
    typedef struct
    {
        __IO uint32_t ISER[8]; /*!< Offset: 0x000 (R/W)  Interrupt Set Enable Register           */
        uint32_t RESERVED0[24];
        __IO uint32_t ICER[8]; /*!< Offset: 0x080 (R/W)  Interrupt Clear Enable Register         */
        uint32_t RSERVED1[24];
        __IO uint32_t ISPR[8]; /*!< Offset: 0x100 (R/W)  Interrupt Set Pending Register          */
        uint32_t RESERVED2[24];
        __IO uint32_t ICPR[8]; /*!< Offset: 0x180 (R/W)  Interrupt Clear Pending Register        */
        uint32_t RESERVED3[24];
        __IO uint32_t IABR[8]; /*!< Offset: 0x200 (R/W)  Interrupt Active bit Register           */
        uint32_t RESERVED4[56];
        __IO uint8_t IP[240]; /*!< Offset: 0x300 (R/W)  Interrupt Priority Register (8Bit wide) */
        uint32_t RESERVED5[644];
        __O uint32_t STIR; /*!< Offset: 0xE00 ( /W)  Software Trigger Interrupt Register     */
    } NVIC_Type;
W
whsj2 已提交
372 373

/* Software Triggered Interrupt Register Definitions */
Y
yanmowudi 已提交
374 375
#define NVIC_STIR_INTID_Pos 0                                /*!< STIR: INTLINESNUM Position */
#define NVIC_STIR_INTID_Msk (0x1FFUL << NVIC_STIR_INTID_Pos) /*!< STIR: INTLINESNUM Mask */
W
whsj2 已提交
376

Y
yanmowudi 已提交
377
    /*@} end of group CMSIS_NVIC */
W
whsj2 已提交
378

Y
yanmowudi 已提交
379
    /** \ingroup  CMSIS_core_register
W
whsj2 已提交
380 381 382 383 384
    \defgroup CMSIS_SCB     System Control Block (SCB)
    \brief      Type definitions for the System Control Block Registers
  @{
 */

Y
yanmowudi 已提交
385
    /** \brief  Structure type to access the System Control Block (SCB).
W
whsj2 已提交
386
 */
Y
yanmowudi 已提交
387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410
    typedef struct
    {
        __I uint32_t CPUID;   /*!< Offset: 0x000 (R/ )  CPUID Base Register                                   */
        __IO uint32_t ICSR;   /*!< Offset: 0x004 (R/W)  Interrupt Control and State Register                  */
        __IO uint32_t VTOR;   /*!< Offset: 0x008 (R/W)  Vector Table Offset Register                          */
        __IO uint32_t AIRCR;  /*!< Offset: 0x00C (R/W)  Application Interrupt and Reset Control Register      */
        __IO uint32_t SCR;    /*!< Offset: 0x010 (R/W)  System Control Register                               */
        __IO uint32_t CCR;    /*!< Offset: 0x014 (R/W)  Configuration Control Register                        */
        __IO uint8_t SHP[12]; /*!< Offset: 0x018 (R/W)  System Handlers Priority Registers (4-7, 8-11, 12-15) */
        __IO uint32_t SHCSR;  /*!< Offset: 0x024 (R/W)  System Handler Control and State Register             */
        __IO uint32_t CFSR;   /*!< Offset: 0x028 (R/W)  Configurable Fault Status Register                    */
        __IO uint32_t HFSR;   /*!< Offset: 0x02C (R/W)  HardFault Status Register                             */
        __IO uint32_t DFSR;   /*!< Offset: 0x030 (R/W)  Debug Fault Status Register                           */
        __IO uint32_t MMFAR;  /*!< Offset: 0x034 (R/W)  MemManage Fault Address Register                      */
        __IO uint32_t BFAR;   /*!< Offset: 0x038 (R/W)  BusFault Address Register                             */
        __IO uint32_t AFSR;   /*!< Offset: 0x03C (R/W)  Auxiliary Fault Status Register                       */
        __I uint32_t PFR[2];  /*!< Offset: 0x040 (R/ )  Processor Feature Register                            */
        __I uint32_t DFR;     /*!< Offset: 0x048 (R/ )  Debug Feature Register                                */
        __I uint32_t ADR;     /*!< Offset: 0x04C (R/ )  Auxiliary Feature Register                            */
        __I uint32_t MMFR[4]; /*!< Offset: 0x050 (R/ )  Memory Model Feature Register                         */
        __I uint32_t ISAR[5]; /*!< Offset: 0x060 (R/ )  Instruction Set Attributes Register                   */
        uint32_t RESERVED0[5];
        __IO uint32_t CPACR; /*!< Offset: 0x088 (R/W)  Coprocessor Access Control Register                   */
    } SCB_Type;
W
whsj2 已提交
411 412

/* SCB CPUID Register Definitions */
Y
yanmowudi 已提交
413 414
#define SCB_CPUID_IMPLEMENTER_Pos 24                                    /*!< SCB CPUID: IMPLEMENTER Position */
#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */
W
whsj2 已提交
415

Y
yanmowudi 已提交
416 417
#define SCB_CPUID_VARIANT_Pos 20                               /*!< SCB CPUID: VARIANT Position */
#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */
W
whsj2 已提交
418

Y
yanmowudi 已提交
419 420
#define SCB_CPUID_ARCHITECTURE_Pos 16                                    /*!< SCB CPUID: ARCHITECTURE Position */
#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */
W
whsj2 已提交
421

Y
yanmowudi 已提交
422 423
#define SCB_CPUID_PARTNO_Pos 4                                 /*!< SCB CPUID: PARTNO Position */
#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */
W
whsj2 已提交
424

Y
yanmowudi 已提交
425 426
#define SCB_CPUID_REVISION_Pos 0                                 /*!< SCB CPUID: REVISION Position */
#define SCB_CPUID_REVISION_Msk (0xFUL << SCB_CPUID_REVISION_Pos) /*!< SCB CPUID: REVISION Mask */
W
whsj2 已提交
427 428

/* SCB Interrupt Control State Register Definitions */
Y
yanmowudi 已提交
429 430
#define SCB_ICSR_NMIPENDSET_Pos 31                               /*!< SCB ICSR: NMIPENDSET Position */
#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */
W
whsj2 已提交
431

Y
yanmowudi 已提交
432 433
#define SCB_ICSR_PENDSVSET_Pos 28                              /*!< SCB ICSR: PENDSVSET Position */
#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */
W
whsj2 已提交
434

Y
yanmowudi 已提交
435 436
#define SCB_ICSR_PENDSVCLR_Pos 27                              /*!< SCB ICSR: PENDSVCLR Position */
#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */
W
whsj2 已提交
437

Y
yanmowudi 已提交
438 439
#define SCB_ICSR_PENDSTSET_Pos 26                              /*!< SCB ICSR: PENDSTSET Position */
#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */
W
whsj2 已提交
440

Y
yanmowudi 已提交
441 442
#define SCB_ICSR_PENDSTCLR_Pos 25                              /*!< SCB ICSR: PENDSTCLR Position */
#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */
W
whsj2 已提交
443

Y
yanmowudi 已提交
444 445
#define SCB_ICSR_ISRPREEMPT_Pos 23                               /*!< SCB ICSR: ISRPREEMPT Position */
#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */
W
whsj2 已提交
446

Y
yanmowudi 已提交
447 448
#define SCB_ICSR_ISRPENDING_Pos 22                               /*!< SCB ICSR: ISRPENDING Position */
#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */
W
whsj2 已提交
449

Y
yanmowudi 已提交
450 451
#define SCB_ICSR_VECTPENDING_Pos 12                                    /*!< SCB ICSR: VECTPENDING Position */
#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */
W
whsj2 已提交
452

Y
yanmowudi 已提交
453 454
#define SCB_ICSR_RETTOBASE_Pos 11                              /*!< SCB ICSR: RETTOBASE Position */
#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */
W
whsj2 已提交
455

Y
yanmowudi 已提交
456 457
#define SCB_ICSR_VECTACTIVE_Pos 0                                    /*!< SCB ICSR: VECTACTIVE Position */
#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL << SCB_ICSR_VECTACTIVE_Pos) /*!< SCB ICSR: VECTACTIVE Mask */
W
whsj2 已提交
458 459

/* SCB Vector Table Offset Register Definitions */
Y
yanmowudi 已提交
460 461
#define SCB_VTOR_TBLOFF_Pos 7                                    /*!< SCB VTOR: TBLOFF Position */
#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */
W
whsj2 已提交
462 463

/* SCB Application Interrupt and Reset Control Register Definitions */
Y
yanmowudi 已提交
464 465
#define SCB_AIRCR_VECTKEY_Pos 16                                  /*!< SCB AIRCR: VECTKEY Position */
#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */
W
whsj2 已提交
466

Y
yanmowudi 已提交
467 468
#define SCB_AIRCR_VECTKEYSTAT_Pos 16                                      /*!< SCB AIRCR: VECTKEYSTAT Position */
#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */
W
whsj2 已提交
469

Y
yanmowudi 已提交
470 471
#define SCB_AIRCR_ENDIANESS_Pos 15                               /*!< SCB AIRCR: ENDIANESS Position */
#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */
W
whsj2 已提交
472

Y
yanmowudi 已提交
473 474
#define SCB_AIRCR_PRIGROUP_Pos 8                               /*!< SCB AIRCR: PRIGROUP Position */
#define SCB_AIRCR_PRIGROUP_Msk (7UL << SCB_AIRCR_PRIGROUP_Pos) /*!< SCB AIRCR: PRIGROUP Mask */
W
whsj2 已提交
475

Y
yanmowudi 已提交
476 477
#define SCB_AIRCR_SYSRESETREQ_Pos 2                                  /*!< SCB AIRCR: SYSRESETREQ Position */
#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */
W
whsj2 已提交
478

Y
yanmowudi 已提交
479 480
#define SCB_AIRCR_VECTCLRACTIVE_Pos 1                                    /*!< SCB AIRCR: VECTCLRACTIVE Position */
#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */
W
whsj2 已提交
481

Y
yanmowudi 已提交
482 483
#define SCB_AIRCR_VECTRESET_Pos 0                                /*!< SCB AIRCR: VECTRESET Position */
#define SCB_AIRCR_VECTRESET_Msk (1UL << SCB_AIRCR_VECTRESET_Pos) /*!< SCB AIRCR: VECTRESET Mask */
W
whsj2 已提交
484 485

/* SCB System Control Register Definitions */
Y
yanmowudi 已提交
486 487
#define SCB_SCR_SEVONPEND_Pos 4                              /*!< SCB SCR: SEVONPEND Position */
#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */
W
whsj2 已提交
488

Y
yanmowudi 已提交
489 490
#define SCB_SCR_SLEEPDEEP_Pos 2                              /*!< SCB SCR: SLEEPDEEP Position */
#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */
W
whsj2 已提交
491

Y
yanmowudi 已提交
492 493
#define SCB_SCR_SLEEPONEXIT_Pos 1                                /*!< SCB SCR: SLEEPONEXIT Position */
#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */
W
whsj2 已提交
494 495

/* SCB Configuration Control Register Definitions */
Y
yanmowudi 已提交
496 497
#define SCB_CCR_STKALIGN_Pos 9                             /*!< SCB CCR: STKALIGN Position */
#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */
W
whsj2 已提交
498

Y
yanmowudi 已提交
499 500
#define SCB_CCR_BFHFNMIGN_Pos 8                              /*!< SCB CCR: BFHFNMIGN Position */
#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */
W
whsj2 已提交
501

Y
yanmowudi 已提交
502 503
#define SCB_CCR_DIV_0_TRP_Pos 4                              /*!< SCB CCR: DIV_0_TRP Position */
#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */
W
whsj2 已提交
504

Y
yanmowudi 已提交
505 506
#define SCB_CCR_UNALIGN_TRP_Pos 3                                /*!< SCB CCR: UNALIGN_TRP Position */
#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */
W
whsj2 已提交
507

Y
yanmowudi 已提交
508 509
#define SCB_CCR_USERSETMPEND_Pos 1                                 /*!< SCB CCR: USERSETMPEND Position */
#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */
W
whsj2 已提交
510

Y
yanmowudi 已提交
511 512
#define SCB_CCR_NONBASETHRDENA_Pos 0                                   /*!< SCB CCR: NONBASETHRDENA Position */
#define SCB_CCR_NONBASETHRDENA_Msk (1UL << SCB_CCR_NONBASETHRDENA_Pos) /*!< SCB CCR: NONBASETHRDENA Mask */
W
whsj2 已提交
513 514

/* SCB System Handler Control and State Register Definitions */
Y
yanmowudi 已提交
515 516
#define SCB_SHCSR_USGFAULTENA_Pos 18                                 /*!< SCB SHCSR: USGFAULTENA Position */
#define SCB_SHCSR_USGFAULTENA_Msk (1UL << SCB_SHCSR_USGFAULTENA_Pos) /*!< SCB SHCSR: USGFAULTENA Mask */
W
whsj2 已提交
517

Y
yanmowudi 已提交
518 519
#define SCB_SHCSR_BUSFAULTENA_Pos 17                                 /*!< SCB SHCSR: BUSFAULTENA Position */
#define SCB_SHCSR_BUSFAULTENA_Msk (1UL << SCB_SHCSR_BUSFAULTENA_Pos) /*!< SCB SHCSR: BUSFAULTENA Mask */
W
whsj2 已提交
520

Y
yanmowudi 已提交
521 522
#define SCB_SHCSR_MEMFAULTENA_Pos 16                                 /*!< SCB SHCSR: MEMFAULTENA Position */
#define SCB_SHCSR_MEMFAULTENA_Msk (1UL << SCB_SHCSR_MEMFAULTENA_Pos) /*!< SCB SHCSR: MEMFAULTENA Mask */
W
whsj2 已提交
523

Y
yanmowudi 已提交
524 525
#define SCB_SHCSR_SVCALLPENDED_Pos 15                                  /*!< SCB SHCSR: SVCALLPENDED Position */
#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */
W
whsj2 已提交
526

Y
yanmowudi 已提交
527 528
#define SCB_SHCSR_BUSFAULTPENDED_Pos 14                                    /*!< SCB SHCSR: BUSFAULTPENDED Position */
#define SCB_SHCSR_BUSFAULTPENDED_Msk (1UL << SCB_SHCSR_BUSFAULTPENDED_Pos) /*!< SCB SHCSR: BUSFAULTPENDED Mask */
W
whsj2 已提交
529

Y
yanmowudi 已提交
530 531
#define SCB_SHCSR_MEMFAULTPENDED_Pos 13                                    /*!< SCB SHCSR: MEMFAULTPENDED Position */
#define SCB_SHCSR_MEMFAULTPENDED_Msk (1UL << SCB_SHCSR_MEMFAULTPENDED_Pos) /*!< SCB SHCSR: MEMFAULTPENDED Mask */
W
whsj2 已提交
532

Y
yanmowudi 已提交
533 534
#define SCB_SHCSR_USGFAULTPENDED_Pos 12                                    /*!< SCB SHCSR: USGFAULTPENDED Position */
#define SCB_SHCSR_USGFAULTPENDED_Msk (1UL << SCB_SHCSR_USGFAULTPENDED_Pos) /*!< SCB SHCSR: USGFAULTPENDED Mask */
W
whsj2 已提交
535

Y
yanmowudi 已提交
536 537
#define SCB_SHCSR_SYSTICKACT_Pos 11                                /*!< SCB SHCSR: SYSTICKACT Position */
#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */
W
whsj2 已提交
538

Y
yanmowudi 已提交
539 540
#define SCB_SHCSR_PENDSVACT_Pos 10                               /*!< SCB SHCSR: PENDSVACT Position */
#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */
W
whsj2 已提交
541

Y
yanmowudi 已提交
542 543
#define SCB_SHCSR_MONITORACT_Pos 8                                 /*!< SCB SHCSR: MONITORACT Position */
#define SCB_SHCSR_MONITORACT_Msk (1UL << SCB_SHCSR_MONITORACT_Pos) /*!< SCB SHCSR: MONITORACT Mask */
W
whsj2 已提交
544

Y
yanmowudi 已提交
545 546
#define SCB_SHCSR_SVCALLACT_Pos 7                                /*!< SCB SHCSR: SVCALLACT Position */
#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */
W
whsj2 已提交
547

Y
yanmowudi 已提交
548 549
#define SCB_SHCSR_USGFAULTACT_Pos 3                                  /*!< SCB SHCSR: USGFAULTACT Position */
#define SCB_SHCSR_USGFAULTACT_Msk (1UL << SCB_SHCSR_USGFAULTACT_Pos) /*!< SCB SHCSR: USGFAULTACT Mask */
W
whsj2 已提交
550

Y
yanmowudi 已提交
551 552
#define SCB_SHCSR_BUSFAULTACT_Pos 1                                  /*!< SCB SHCSR: BUSFAULTACT Position */
#define SCB_SHCSR_BUSFAULTACT_Msk (1UL << SCB_SHCSR_BUSFAULTACT_Pos) /*!< SCB SHCSR: BUSFAULTACT Mask */
W
whsj2 已提交
553

Y
yanmowudi 已提交
554 555
#define SCB_SHCSR_MEMFAULTACT_Pos 0                                  /*!< SCB SHCSR: MEMFAULTACT Position */
#define SCB_SHCSR_MEMFAULTACT_Msk (1UL << SCB_SHCSR_MEMFAULTACT_Pos) /*!< SCB SHCSR: MEMFAULTACT Mask */
W
whsj2 已提交
556 557

/* SCB Configurable Fault Status Registers Definitions */
Y
yanmowudi 已提交
558 559
#define SCB_CFSR_USGFAULTSR_Pos 16                                    /*!< SCB CFSR: Usage Fault Status Register Position */
#define SCB_CFSR_USGFAULTSR_Msk (0xFFFFUL << SCB_CFSR_USGFAULTSR_Pos) /*!< SCB CFSR: Usage Fault Status Register Mask */
W
whsj2 已提交
560

Y
yanmowudi 已提交
561 562
#define SCB_CFSR_BUSFAULTSR_Pos 8                                   /*!< SCB CFSR: Bus Fault Status Register Position */
#define SCB_CFSR_BUSFAULTSR_Msk (0xFFUL << SCB_CFSR_BUSFAULTSR_Pos) /*!< SCB CFSR: Bus Fault Status Register Mask */
W
whsj2 已提交
563

Y
yanmowudi 已提交
564 565
#define SCB_CFSR_MEMFAULTSR_Pos 0                                   /*!< SCB CFSR: Memory Manage Fault Status Register Position */
#define SCB_CFSR_MEMFAULTSR_Msk (0xFFUL << SCB_CFSR_MEMFAULTSR_Pos) /*!< SCB CFSR: Memory Manage Fault Status Register Mask */
W
whsj2 已提交
566 567

/* SCB Hard Fault Status Registers Definitions */
Y
yanmowudi 已提交
568 569
#define SCB_HFSR_DEBUGEVT_Pos 31                             /*!< SCB HFSR: DEBUGEVT Position */
#define SCB_HFSR_DEBUGEVT_Msk (1UL << SCB_HFSR_DEBUGEVT_Pos) /*!< SCB HFSR: DEBUGEVT Mask */
W
whsj2 已提交
570

Y
yanmowudi 已提交
571 572
#define SCB_HFSR_FORCED_Pos 30                           /*!< SCB HFSR: FORCED Position */
#define SCB_HFSR_FORCED_Msk (1UL << SCB_HFSR_FORCED_Pos) /*!< SCB HFSR: FORCED Mask */
W
whsj2 已提交
573

Y
yanmowudi 已提交
574 575
#define SCB_HFSR_VECTTBL_Pos 1                             /*!< SCB HFSR: VECTTBL Position */
#define SCB_HFSR_VECTTBL_Msk (1UL << SCB_HFSR_VECTTBL_Pos) /*!< SCB HFSR: VECTTBL Mask */
W
whsj2 已提交
576 577

/* SCB Debug Fault Status Register Definitions */
Y
yanmowudi 已提交
578 579
#define SCB_DFSR_EXTERNAL_Pos 4                              /*!< SCB DFSR: EXTERNAL Position */
#define SCB_DFSR_EXTERNAL_Msk (1UL << SCB_DFSR_EXTERNAL_Pos) /*!< SCB DFSR: EXTERNAL Mask */
W
whsj2 已提交
580

Y
yanmowudi 已提交
581 582
#define SCB_DFSR_VCATCH_Pos 3                            /*!< SCB DFSR: VCATCH Position */
#define SCB_DFSR_VCATCH_Msk (1UL << SCB_DFSR_VCATCH_Pos) /*!< SCB DFSR: VCATCH Mask */
W
whsj2 已提交
583

Y
yanmowudi 已提交
584 585
#define SCB_DFSR_DWTTRAP_Pos 2                             /*!< SCB DFSR: DWTTRAP Position */
#define SCB_DFSR_DWTTRAP_Msk (1UL << SCB_DFSR_DWTTRAP_Pos) /*!< SCB DFSR: DWTTRAP Mask */
W
whsj2 已提交
586

Y
yanmowudi 已提交
587 588
#define SCB_DFSR_BKPT_Pos 1                          /*!< SCB DFSR: BKPT Position */
#define SCB_DFSR_BKPT_Msk (1UL << SCB_DFSR_BKPT_Pos) /*!< SCB DFSR: BKPT Mask */
W
whsj2 已提交
589

Y
yanmowudi 已提交
590 591
#define SCB_DFSR_HALTED_Pos 0                            /*!< SCB DFSR: HALTED Position */
#define SCB_DFSR_HALTED_Msk (1UL << SCB_DFSR_HALTED_Pos) /*!< SCB DFSR: HALTED Mask */
W
whsj2 已提交
592

Y
yanmowudi 已提交
593
    /*@} end of group CMSIS_SCB */
W
whsj2 已提交
594

Y
yanmowudi 已提交
595
    /** \ingroup  CMSIS_core_register
W
whsj2 已提交
596 597 598 599 600
    \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB)
    \brief      Type definitions for the System Control and ID Register not in the SCB
  @{
 */

Y
yanmowudi 已提交
601
    /** \brief  Structure type to access the System Control and ID Register not in the SCB.
W
whsj2 已提交
602
 */
Y
yanmowudi 已提交
603 604 605 606 607 608
    typedef struct
    {
        uint32_t RESERVED0[1];
        __I uint32_t ICTR;   /*!< Offset: 0x004 (R/ )  Interrupt Controller Type Register      */
        __IO uint32_t ACTLR; /*!< Offset: 0x008 (R/W)  Auxiliary Control Register              */
    } SCnSCB_Type;
W
whsj2 已提交
609 610

/* Interrupt Controller Type Register Definitions */
Y
yanmowudi 已提交
611 612
#define SCnSCB_ICTR_INTLINESNUM_Pos 0                                      /*!< ICTR: INTLINESNUM Position */
#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL << SCnSCB_ICTR_INTLINESNUM_Pos) /*!< ICTR: INTLINESNUM Mask */
W
whsj2 已提交
613 614

/* Auxiliary Control Register Definitions */
Y
yanmowudi 已提交
615 616
#define SCnSCB_ACTLR_DISOOFP_Pos 9                                 /*!< ACTLR: DISOOFP Position */
#define SCnSCB_ACTLR_DISOOFP_Msk (1UL << SCnSCB_ACTLR_DISOOFP_Pos) /*!< ACTLR: DISOOFP Mask */
W
whsj2 已提交
617

Y
yanmowudi 已提交
618 619
#define SCnSCB_ACTLR_DISFPCA_Pos 8                                 /*!< ACTLR: DISFPCA Position */
#define SCnSCB_ACTLR_DISFPCA_Msk (1UL << SCnSCB_ACTLR_DISFPCA_Pos) /*!< ACTLR: DISFPCA Mask */
W
whsj2 已提交
620

Y
yanmowudi 已提交
621 622
#define SCnSCB_ACTLR_DISFOLD_Pos 2                                 /*!< ACTLR: DISFOLD Position */
#define SCnSCB_ACTLR_DISFOLD_Msk (1UL << SCnSCB_ACTLR_DISFOLD_Pos) /*!< ACTLR: DISFOLD Mask */
W
whsj2 已提交
623

Y
yanmowudi 已提交
624 625
#define SCnSCB_ACTLR_DISDEFWBUF_Pos 1                                    /*!< ACTLR: DISDEFWBUF Position */
#define SCnSCB_ACTLR_DISDEFWBUF_Msk (1UL << SCnSCB_ACTLR_DISDEFWBUF_Pos) /*!< ACTLR: DISDEFWBUF Mask */
W
whsj2 已提交
626

Y
yanmowudi 已提交
627 628
#define SCnSCB_ACTLR_DISMCYCINT_Pos 0                                    /*!< ACTLR: DISMCYCINT Position */
#define SCnSCB_ACTLR_DISMCYCINT_Msk (1UL << SCnSCB_ACTLR_DISMCYCINT_Pos) /*!< ACTLR: DISMCYCINT Mask */
W
whsj2 已提交
629

Y
yanmowudi 已提交
630
    /*@} end of group CMSIS_SCnotSCB */
W
whsj2 已提交
631

Y
yanmowudi 已提交
632
    /** \ingroup  CMSIS_core_register
W
whsj2 已提交
633 634 635 636 637
    \defgroup CMSIS_SysTick     System Tick Timer (SysTick)
    \brief      Type definitions for the System Timer Registers.
  @{
 */

Y
yanmowudi 已提交
638
    /** \brief  Structure type to access the System Timer (SysTick).
W
whsj2 已提交
639
 */
Y
yanmowudi 已提交
640 641 642 643 644 645 646
    typedef struct
    {
        __IO uint32_t CTRL; /*!< Offset: 0x000 (R/W)  SysTick Control and Status Register */
        __IO uint32_t LOAD; /*!< Offset: 0x004 (R/W)  SysTick Reload Value Register       */
        __IO uint32_t VAL;  /*!< Offset: 0x008 (R/W)  SysTick Current Value Register      */
        __I uint32_t CALIB; /*!< Offset: 0x00C (R/ )  SysTick Calibration Register        */
    } SysTick_Type;
W
whsj2 已提交
647 648

/* SysTick Control / Status Register Definitions */
Y
yanmowudi 已提交
649 650
#define SysTick_CTRL_COUNTFLAG_Pos 16                                  /*!< SysTick CTRL: COUNTFLAG Position */
#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */
W
whsj2 已提交
651

Y
yanmowudi 已提交
652 653
#define SysTick_CTRL_CLKSOURCE_Pos 2                                   /*!< SysTick CTRL: CLKSOURCE Position */
#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */
W
whsj2 已提交
654

Y
yanmowudi 已提交
655 656
#define SysTick_CTRL_TICKINT_Pos 1                                 /*!< SysTick CTRL: TICKINT Position */
#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */
W
whsj2 已提交
657

Y
yanmowudi 已提交
658 659
#define SysTick_CTRL_ENABLE_Pos 0                                /*!< SysTick CTRL: ENABLE Position */
#define SysTick_CTRL_ENABLE_Msk (1UL << SysTick_CTRL_ENABLE_Pos) /*!< SysTick CTRL: ENABLE Mask */
W
whsj2 已提交
660 661

/* SysTick Reload Register Definitions */
Y
yanmowudi 已提交
662 663
#define SysTick_LOAD_RELOAD_Pos 0                                       /*!< SysTick LOAD: RELOAD Position */
#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL << SysTick_LOAD_RELOAD_Pos) /*!< SysTick LOAD: RELOAD Mask */
W
whsj2 已提交
664 665

/* SysTick Current Register Definitions */
Y
yanmowudi 已提交
666 667
#define SysTick_VAL_CURRENT_Pos 0                                       /*!< SysTick VAL: CURRENT Position */
#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL << SysTick_VAL_CURRENT_Pos) /*!< SysTick VAL: CURRENT Mask */
W
whsj2 已提交
668 669

/* SysTick Calibration Register Definitions */
Y
yanmowudi 已提交
670 671
#define SysTick_CALIB_NOREF_Pos 31                               /*!< SysTick CALIB: NOREF Position */
#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */
W
whsj2 已提交
672

Y
yanmowudi 已提交
673 674
#define SysTick_CALIB_SKEW_Pos 30                              /*!< SysTick CALIB: SKEW Position */
#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */
W
whsj2 已提交
675

Y
yanmowudi 已提交
676 677
#define SysTick_CALIB_TENMS_Pos 0                                       /*!< SysTick CALIB: TENMS Position */
#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL << SysTick_CALIB_TENMS_Pos) /*!< SysTick CALIB: TENMS Mask */
W
whsj2 已提交
678

Y
yanmowudi 已提交
679
    /*@} end of group CMSIS_SysTick */
W
whsj2 已提交
680

Y
yanmowudi 已提交
681
    /** \ingroup  CMSIS_core_register
W
whsj2 已提交
682 683 684 685 686
    \defgroup CMSIS_ITM     Instrumentation Trace Macrocell (ITM)
    \brief      Type definitions for the Instrumentation Trace Macrocell (ITM)
  @{
 */

Y
yanmowudi 已提交
687
    /** \brief  Structure type to access the Instrumentation Trace Macrocell Register (ITM).
W
whsj2 已提交
688
 */
Y
yanmowudi 已提交
689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723
    typedef struct
    {
        __O union
        {
            __O uint8_t u8;   /*!< Offset: 0x000 ( /W)  ITM Stimulus Port 8-bit                   */
            __O uint16_t u16; /*!< Offset: 0x000 ( /W)  ITM Stimulus Port 16-bit                  */
            __O uint32_t u32; /*!< Offset: 0x000 ( /W)  ITM Stimulus Port 32-bit                  */
        } PORT[32];           /*!< Offset: 0x000 ( /W)  ITM Stimulus Port Registers               */
        uint32_t RESERVED0[864];
        __IO uint32_t TER; /*!< Offset: 0xE00 (R/W)  ITM Trace Enable Register                 */
        uint32_t RESERVED1[15];
        __IO uint32_t TPR; /*!< Offset: 0xE40 (R/W)  ITM Trace Privilege Register              */
        uint32_t RESERVED2[15];
        __IO uint32_t TCR; /*!< Offset: 0xE80 (R/W)  ITM Trace Control Register                */
        uint32_t RESERVED3[29];
        __O uint32_t IWR;   /*!< Offset: 0xEF8 ( /W)  ITM Integration Write Register            */
        __I uint32_t IRR;   /*!< Offset: 0xEFC (R/ )  ITM Integration Read Register             */
        __IO uint32_t IMCR; /*!< Offset: 0xF00 (R/W)  ITM Integration Mode Control Register     */
        uint32_t RESERVED4[43];
        __O uint32_t LAR; /*!< Offset: 0xFB0 ( /W)  ITM Lock Access Register                  */
        __I uint32_t LSR; /*!< Offset: 0xFB4 (R/ )  ITM Lock Status Register                  */
        uint32_t RESERVED5[6];
        __I uint32_t PID4; /*!< Offset: 0xFD0 (R/ )  ITM Peripheral Identification Register #4 */
        __I uint32_t PID5; /*!< Offset: 0xFD4 (R/ )  ITM Peripheral Identification Register #5 */
        __I uint32_t PID6; /*!< Offset: 0xFD8 (R/ )  ITM Peripheral Identification Register #6 */
        __I uint32_t PID7; /*!< Offset: 0xFDC (R/ )  ITM Peripheral Identification Register #7 */
        __I uint32_t PID0; /*!< Offset: 0xFE0 (R/ )  ITM Peripheral Identification Register #0 */
        __I uint32_t PID1; /*!< Offset: 0xFE4 (R/ )  ITM Peripheral Identification Register #1 */
        __I uint32_t PID2; /*!< Offset: 0xFE8 (R/ )  ITM Peripheral Identification Register #2 */
        __I uint32_t PID3; /*!< Offset: 0xFEC (R/ )  ITM Peripheral Identification Register #3 */
        __I uint32_t CID0; /*!< Offset: 0xFF0 (R/ )  ITM Component  Identification Register #0 */
        __I uint32_t CID1; /*!< Offset: 0xFF4 (R/ )  ITM Component  Identification Register #1 */
        __I uint32_t CID2; /*!< Offset: 0xFF8 (R/ )  ITM Component  Identification Register #2 */
        __I uint32_t CID3; /*!< Offset: 0xFFC (R/ )  ITM Component  Identification Register #3 */
    } ITM_Type;
W
whsj2 已提交
724 725

/* ITM Trace Privilege Register Definitions */
Y
yanmowudi 已提交
726 727
#define ITM_TPR_PRIVMASK_Pos 0                               /*!< ITM TPR: PRIVMASK Position */
#define ITM_TPR_PRIVMASK_Msk (0xFUL << ITM_TPR_PRIVMASK_Pos) /*!< ITM TPR: PRIVMASK Mask */
W
whsj2 已提交
728 729

/* ITM Trace Control Register Definitions */
Y
yanmowudi 已提交
730 731
#define ITM_TCR_BUSY_Pos 23                        /*!< ITM TCR: BUSY Position */
#define ITM_TCR_BUSY_Msk (1UL << ITM_TCR_BUSY_Pos) /*!< ITM TCR: BUSY Mask */
W
whsj2 已提交
732

Y
yanmowudi 已提交
733 734
#define ITM_TCR_TraceBusID_Pos 16                                 /*!< ITM TCR: ATBID Position */
#define ITM_TCR_TraceBusID_Msk (0x7FUL << ITM_TCR_TraceBusID_Pos) /*!< ITM TCR: ATBID Mask */
W
whsj2 已提交
735

Y
yanmowudi 已提交
736 737
#define ITM_TCR_GTSFREQ_Pos 10                           /*!< ITM TCR: Global timestamp frequency Position */
#define ITM_TCR_GTSFREQ_Msk (3UL << ITM_TCR_GTSFREQ_Pos) /*!< ITM TCR: Global timestamp frequency Mask */
W
whsj2 已提交
738

Y
yanmowudi 已提交
739 740
#define ITM_TCR_TSPrescale_Pos 8                               /*!< ITM TCR: TSPrescale Position */
#define ITM_TCR_TSPrescale_Msk (3UL << ITM_TCR_TSPrescale_Pos) /*!< ITM TCR: TSPrescale Mask */
W
whsj2 已提交
741

Y
yanmowudi 已提交
742 743
#define ITM_TCR_SWOENA_Pos 4                           /*!< ITM TCR: SWOENA Position */
#define ITM_TCR_SWOENA_Msk (1UL << ITM_TCR_SWOENA_Pos) /*!< ITM TCR: SWOENA Mask */
W
whsj2 已提交
744

Y
yanmowudi 已提交
745 746
#define ITM_TCR_DWTENA_Pos 3                           /*!< ITM TCR: DWTENA Position */
#define ITM_TCR_DWTENA_Msk (1UL << ITM_TCR_DWTENA_Pos) /*!< ITM TCR: DWTENA Mask */
W
whsj2 已提交
747

Y
yanmowudi 已提交
748 749
#define ITM_TCR_SYNCENA_Pos 2                            /*!< ITM TCR: SYNCENA Position */
#define ITM_TCR_SYNCENA_Msk (1UL << ITM_TCR_SYNCENA_Pos) /*!< ITM TCR: SYNCENA Mask */
W
whsj2 已提交
750

Y
yanmowudi 已提交
751 752
#define ITM_TCR_TSENA_Pos 1                          /*!< ITM TCR: TSENA Position */
#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos) /*!< ITM TCR: TSENA Mask */
W
whsj2 已提交
753

Y
yanmowudi 已提交
754 755
#define ITM_TCR_ITMENA_Pos 0                           /*!< ITM TCR: ITM Enable bit Position */
#define ITM_TCR_ITMENA_Msk (1UL << ITM_TCR_ITMENA_Pos) /*!< ITM TCR: ITM Enable bit Mask */
W
whsj2 已提交
756 757

/* ITM Integration Write Register Definitions */
Y
yanmowudi 已提交
758 759
#define ITM_IWR_ATVALIDM_Pos 0                             /*!< ITM IWR: ATVALIDM Position */
#define ITM_IWR_ATVALIDM_Msk (1UL << ITM_IWR_ATVALIDM_Pos) /*!< ITM IWR: ATVALIDM Mask */
W
whsj2 已提交
760 761

/* ITM Integration Read Register Definitions */
Y
yanmowudi 已提交
762 763
#define ITM_IRR_ATREADYM_Pos 0                             /*!< ITM IRR: ATREADYM Position */
#define ITM_IRR_ATREADYM_Msk (1UL << ITM_IRR_ATREADYM_Pos) /*!< ITM IRR: ATREADYM Mask */
W
whsj2 已提交
764 765

/* ITM Integration Mode Control Register Definitions */
Y
yanmowudi 已提交
766 767
#define ITM_IMCR_INTEGRATION_Pos 0                                 /*!< ITM IMCR: INTEGRATION Position */
#define ITM_IMCR_INTEGRATION_Msk (1UL << ITM_IMCR_INTEGRATION_Pos) /*!< ITM IMCR: INTEGRATION Mask */
W
whsj2 已提交
768 769

/* ITM Lock Status Register Definitions */
Y
yanmowudi 已提交
770 771
#define ITM_LSR_ByteAcc_Pos 2                            /*!< ITM LSR: ByteAcc Position */
#define ITM_LSR_ByteAcc_Msk (1UL << ITM_LSR_ByteAcc_Pos) /*!< ITM LSR: ByteAcc Mask */
W
whsj2 已提交
772

Y
yanmowudi 已提交
773 774
#define ITM_LSR_Access_Pos 1                           /*!< ITM LSR: Access Position */
#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos) /*!< ITM LSR: Access Mask */
W
whsj2 已提交
775

Y
yanmowudi 已提交
776 777
#define ITM_LSR_Present_Pos 0                            /*!< ITM LSR: Present Position */
#define ITM_LSR_Present_Msk (1UL << ITM_LSR_Present_Pos) /*!< ITM LSR: Present Mask */
W
whsj2 已提交
778

Y
yanmowudi 已提交
779
    /*@}*/ /* end of group CMSIS_ITM */
W
whsj2 已提交
780

Y
yanmowudi 已提交
781
    /** \ingroup  CMSIS_core_register
W
whsj2 已提交
782 783 784 785 786
    \defgroup CMSIS_DWT     Data Watchpoint and Trace (DWT)
    \brief      Type definitions for the Data Watchpoint and Trace (DWT)
  @{
 */

Y
yanmowudi 已提交
787
    /** \brief  Structure type to access the Data Watchpoint and Trace Register (DWT).
W
whsj2 已提交
788
 */
Y
yanmowudi 已提交
789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814
    typedef struct
    {
        __IO uint32_t CTRL;      /*!< Offset: 0x000 (R/W)  Control Register                          */
        __IO uint32_t CYCCNT;    /*!< Offset: 0x004 (R/W)  Cycle Count Register                      */
        __IO uint32_t CPICNT;    /*!< Offset: 0x008 (R/W)  CPI Count Register                        */
        __IO uint32_t EXCCNT;    /*!< Offset: 0x00C (R/W)  Exception Overhead Count Register         */
        __IO uint32_t SLEEPCNT;  /*!< Offset: 0x010 (R/W)  Sleep Count Register                      */
        __IO uint32_t LSUCNT;    /*!< Offset: 0x014 (R/W)  LSU Count Register                        */
        __IO uint32_t FOLDCNT;   /*!< Offset: 0x018 (R/W)  Folded-instruction Count Register         */
        __I uint32_t PCSR;       /*!< Offset: 0x01C (R/ )  Program Counter Sample Register           */
        __IO uint32_t COMP0;     /*!< Offset: 0x020 (R/W)  Comparator Register 0                     */
        __IO uint32_t MASK0;     /*!< Offset: 0x024 (R/W)  Mask Register 0                           */
        __IO uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W)  Function Register 0                       */
        uint32_t RESERVED0[1];
        __IO uint32_t COMP1;     /*!< Offset: 0x030 (R/W)  Comparator Register 1                     */
        __IO uint32_t MASK1;     /*!< Offset: 0x034 (R/W)  Mask Register 1                           */
        __IO uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W)  Function Register 1                       */
        uint32_t RESERVED1[1];
        __IO uint32_t COMP2;     /*!< Offset: 0x040 (R/W)  Comparator Register 2                     */
        __IO uint32_t MASK2;     /*!< Offset: 0x044 (R/W)  Mask Register 2                           */
        __IO uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W)  Function Register 2                       */
        uint32_t RESERVED2[1];
        __IO uint32_t COMP3;     /*!< Offset: 0x050 (R/W)  Comparator Register 3                     */
        __IO uint32_t MASK3;     /*!< Offset: 0x054 (R/W)  Mask Register 3                           */
        __IO uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W)  Function Register 3                       */
    } DWT_Type;
W
whsj2 已提交
815 816

/* DWT Control Register Definitions */
Y
yanmowudi 已提交
817 818
#define DWT_CTRL_NUMCOMP_Pos 28                              /*!< DWT CTRL: NUMCOMP Position */
#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */
W
whsj2 已提交
819

Y
yanmowudi 已提交
820 821
#define DWT_CTRL_NOTRCPKT_Pos 27                               /*!< DWT CTRL: NOTRCPKT Position */
#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */
W
whsj2 已提交
822

Y
yanmowudi 已提交
823 824
#define DWT_CTRL_NOEXTTRIG_Pos 26                                /*!< DWT CTRL: NOEXTTRIG Position */
#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */
W
whsj2 已提交
825

Y
yanmowudi 已提交
826 827
#define DWT_CTRL_NOCYCCNT_Pos 25                               /*!< DWT CTRL: NOCYCCNT Position */
#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */
W
whsj2 已提交
828

Y
yanmowudi 已提交
829 830
#define DWT_CTRL_NOPRFCNT_Pos 24                               /*!< DWT CTRL: NOPRFCNT Position */
#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */
W
whsj2 已提交
831

Y
yanmowudi 已提交
832 833
#define DWT_CTRL_CYCEVTENA_Pos 22                                /*!< DWT CTRL: CYCEVTENA Position */
#define DWT_CTRL_CYCEVTENA_Msk (0x1UL << DWT_CTRL_CYCEVTENA_Pos) /*!< DWT CTRL: CYCEVTENA Mask */
W
whsj2 已提交
834

Y
yanmowudi 已提交
835 836
#define DWT_CTRL_FOLDEVTENA_Pos 21                                 /*!< DWT CTRL: FOLDEVTENA Position */
#define DWT_CTRL_FOLDEVTENA_Msk (0x1UL << DWT_CTRL_FOLDEVTENA_Pos) /*!< DWT CTRL: FOLDEVTENA Mask */
W
whsj2 已提交
837

Y
yanmowudi 已提交
838 839
#define DWT_CTRL_LSUEVTENA_Pos 20                                /*!< DWT CTRL: LSUEVTENA Position */
#define DWT_CTRL_LSUEVTENA_Msk (0x1UL << DWT_CTRL_LSUEVTENA_Pos) /*!< DWT CTRL: LSUEVTENA Mask */
W
whsj2 已提交
840

Y
yanmowudi 已提交
841 842
#define DWT_CTRL_SLEEPEVTENA_Pos 19                                  /*!< DWT CTRL: SLEEPEVTENA Position */
#define DWT_CTRL_SLEEPEVTENA_Msk (0x1UL << DWT_CTRL_SLEEPEVTENA_Pos) /*!< DWT CTRL: SLEEPEVTENA Mask */
W
whsj2 已提交
843

Y
yanmowudi 已提交
844 845
#define DWT_CTRL_EXCEVTENA_Pos 18                                /*!< DWT CTRL: EXCEVTENA Position */
#define DWT_CTRL_EXCEVTENA_Msk (0x1UL << DWT_CTRL_EXCEVTENA_Pos) /*!< DWT CTRL: EXCEVTENA Mask */
W
whsj2 已提交
846

Y
yanmowudi 已提交
847 848
#define DWT_CTRL_CPIEVTENA_Pos 17                                /*!< DWT CTRL: CPIEVTENA Position */
#define DWT_CTRL_CPIEVTENA_Msk (0x1UL << DWT_CTRL_CPIEVTENA_Pos) /*!< DWT CTRL: CPIEVTENA Mask */
W
whsj2 已提交
849

Y
yanmowudi 已提交
850 851
#define DWT_CTRL_EXCTRCENA_Pos 16                                /*!< DWT CTRL: EXCTRCENA Position */
#define DWT_CTRL_EXCTRCENA_Msk (0x1UL << DWT_CTRL_EXCTRCENA_Pos) /*!< DWT CTRL: EXCTRCENA Mask */
W
whsj2 已提交
852

Y
yanmowudi 已提交
853 854
#define DWT_CTRL_PCSAMPLENA_Pos 12                                 /*!< DWT CTRL: PCSAMPLENA Position */
#define DWT_CTRL_PCSAMPLENA_Msk (0x1UL << DWT_CTRL_PCSAMPLENA_Pos) /*!< DWT CTRL: PCSAMPLENA Mask */
W
whsj2 已提交
855

Y
yanmowudi 已提交
856 857
#define DWT_CTRL_SYNCTAP_Pos 10                              /*!< DWT CTRL: SYNCTAP Position */
#define DWT_CTRL_SYNCTAP_Msk (0x3UL << DWT_CTRL_SYNCTAP_Pos) /*!< DWT CTRL: SYNCTAP Mask */
W
whsj2 已提交
858

Y
yanmowudi 已提交
859 860
#define DWT_CTRL_CYCTAP_Pos 9                              /*!< DWT CTRL: CYCTAP Position */
#define DWT_CTRL_CYCTAP_Msk (0x1UL << DWT_CTRL_CYCTAP_Pos) /*!< DWT CTRL: CYCTAP Mask */
W
whsj2 已提交
861

Y
yanmowudi 已提交
862 863
#define DWT_CTRL_POSTINIT_Pos 5                                /*!< DWT CTRL: POSTINIT Position */
#define DWT_CTRL_POSTINIT_Msk (0xFUL << DWT_CTRL_POSTINIT_Pos) /*!< DWT CTRL: POSTINIT Mask */
W
whsj2 已提交
864

Y
yanmowudi 已提交
865 866
#define DWT_CTRL_POSTPRESET_Pos 1                                  /*!< DWT CTRL: POSTPRESET Position */
#define DWT_CTRL_POSTPRESET_Msk (0xFUL << DWT_CTRL_POSTPRESET_Pos) /*!< DWT CTRL: POSTPRESET Mask */
W
whsj2 已提交
867

Y
yanmowudi 已提交
868 869
#define DWT_CTRL_CYCCNTENA_Pos 0                                 /*!< DWT CTRL: CYCCNTENA Position */
#define DWT_CTRL_CYCCNTENA_Msk (0x1UL << DWT_CTRL_CYCCNTENA_Pos) /*!< DWT CTRL: CYCCNTENA Mask */
W
whsj2 已提交
870 871

/* DWT CPI Count Register Definitions */
Y
yanmowudi 已提交
872 873
#define DWT_CPICNT_CPICNT_Pos 0                                 /*!< DWT CPICNT: CPICNT Position */
#define DWT_CPICNT_CPICNT_Msk (0xFFUL << DWT_CPICNT_CPICNT_Pos) /*!< DWT CPICNT: CPICNT Mask */
W
whsj2 已提交
874 875

/* DWT Exception Overhead Count Register Definitions */
Y
yanmowudi 已提交
876 877
#define DWT_EXCCNT_EXCCNT_Pos 0                                 /*!< DWT EXCCNT: EXCCNT Position */
#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL << DWT_EXCCNT_EXCCNT_Pos) /*!< DWT EXCCNT: EXCCNT Mask */
W
whsj2 已提交
878 879

/* DWT Sleep Count Register Definitions */
Y
yanmowudi 已提交
880 881
#define DWT_SLEEPCNT_SLEEPCNT_Pos 0                                     /*!< DWT SLEEPCNT: SLEEPCNT Position */
#define DWT_SLEEPCNT_SLEEPCNT_Msk (0xFFUL << DWT_SLEEPCNT_SLEEPCNT_Pos) /*!< DWT SLEEPCNT: SLEEPCNT Mask */
W
whsj2 已提交
882 883

/* DWT LSU Count Register Definitions */
Y
yanmowudi 已提交
884 885
#define DWT_LSUCNT_LSUCNT_Pos 0                                 /*!< DWT LSUCNT: LSUCNT Position */
#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL << DWT_LSUCNT_LSUCNT_Pos) /*!< DWT LSUCNT: LSUCNT Mask */
W
whsj2 已提交
886 887

/* DWT Folded-instruction Count Register Definitions */
Y
yanmowudi 已提交
888 889
#define DWT_FOLDCNT_FOLDCNT_Pos 0                                   /*!< DWT FOLDCNT: FOLDCNT Position */
#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL << DWT_FOLDCNT_FOLDCNT_Pos) /*!< DWT FOLDCNT: FOLDCNT Mask */
W
whsj2 已提交
890 891

/* DWT Comparator Mask Register Definitions */
Y
yanmowudi 已提交
892 893
#define DWT_MASK_MASK_Pos 0                             /*!< DWT MASK: MASK Position */
#define DWT_MASK_MASK_Msk (0x1FUL << DWT_MASK_MASK_Pos) /*!< DWT MASK: MASK Mask */
W
whsj2 已提交
894 895

/* DWT Comparator Function Register Definitions */
Y
yanmowudi 已提交
896 897
#define DWT_FUNCTION_MATCHED_Pos 24                                  /*!< DWT FUNCTION: MATCHED Position */
#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */
W
whsj2 已提交
898

Y
yanmowudi 已提交
899 900
#define DWT_FUNCTION_DATAVADDR1_Pos 16                                     /*!< DWT FUNCTION: DATAVADDR1 Position */
#define DWT_FUNCTION_DATAVADDR1_Msk (0xFUL << DWT_FUNCTION_DATAVADDR1_Pos) /*!< DWT FUNCTION: DATAVADDR1 Mask */
W
whsj2 已提交
901

Y
yanmowudi 已提交
902 903
#define DWT_FUNCTION_DATAVADDR0_Pos 12                                     /*!< DWT FUNCTION: DATAVADDR0 Position */
#define DWT_FUNCTION_DATAVADDR0_Msk (0xFUL << DWT_FUNCTION_DATAVADDR0_Pos) /*!< DWT FUNCTION: DATAVADDR0 Mask */
W
whsj2 已提交
904

Y
yanmowudi 已提交
905 906
#define DWT_FUNCTION_DATAVSIZE_Pos 10                                    /*!< DWT FUNCTION: DATAVSIZE Position */
#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */
W
whsj2 已提交
907

Y
yanmowudi 已提交
908 909
#define DWT_FUNCTION_LNK1ENA_Pos 9                                   /*!< DWT FUNCTION: LNK1ENA Position */
#define DWT_FUNCTION_LNK1ENA_Msk (0x1UL << DWT_FUNCTION_LNK1ENA_Pos) /*!< DWT FUNCTION: LNK1ENA Mask */
W
whsj2 已提交
910

Y
yanmowudi 已提交
911 912
#define DWT_FUNCTION_DATAVMATCH_Pos 8                                      /*!< DWT FUNCTION: DATAVMATCH Position */
#define DWT_FUNCTION_DATAVMATCH_Msk (0x1UL << DWT_FUNCTION_DATAVMATCH_Pos) /*!< DWT FUNCTION: DATAVMATCH Mask */
W
whsj2 已提交
913

Y
yanmowudi 已提交
914 915
#define DWT_FUNCTION_CYCMATCH_Pos 7                                    /*!< DWT FUNCTION: CYCMATCH Position */
#define DWT_FUNCTION_CYCMATCH_Msk (0x1UL << DWT_FUNCTION_CYCMATCH_Pos) /*!< DWT FUNCTION: CYCMATCH Mask */
W
whsj2 已提交
916

Y
yanmowudi 已提交
917 918
#define DWT_FUNCTION_EMITRANGE_Pos 5                                     /*!< DWT FUNCTION: EMITRANGE Position */
#define DWT_FUNCTION_EMITRANGE_Msk (0x1UL << DWT_FUNCTION_EMITRANGE_Pos) /*!< DWT FUNCTION: EMITRANGE Mask */
W
whsj2 已提交
919

Y
yanmowudi 已提交
920 921
#define DWT_FUNCTION_FUNCTION_Pos 0                                    /*!< DWT FUNCTION: FUNCTION Position */
#define DWT_FUNCTION_FUNCTION_Msk (0xFUL << DWT_FUNCTION_FUNCTION_Pos) /*!< DWT FUNCTION: FUNCTION Mask */
W
whsj2 已提交
922

Y
yanmowudi 已提交
923
    /*@}*/ /* end of group CMSIS_DWT */
W
whsj2 已提交
924

Y
yanmowudi 已提交
925
    /** \ingroup  CMSIS_core_register
W
whsj2 已提交
926 927 928 929 930
    \defgroup CMSIS_TPI     Trace Port Interface (TPI)
    \brief      Type definitions for the Trace Port Interface (TPI)
  @{
 */

Y
yanmowudi 已提交
931
    /** \brief  Structure type to access the Trace Port Interface Register (TPI).
W
whsj2 已提交
932
 */
Y
yanmowudi 已提交
933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959
    typedef struct
    {
        __IO uint32_t SSPSR; /*!< Offset: 0x000 (R/ )  Supported Parallel Port Size Register     */
        __IO uint32_t CSPSR; /*!< Offset: 0x004 (R/W)  Current Parallel Port Size Register */
        uint32_t RESERVED0[2];
        __IO uint32_t ACPR; /*!< Offset: 0x010 (R/W)  Asynchronous Clock Prescaler Register */
        uint32_t RESERVED1[55];
        __IO uint32_t SPPR; /*!< Offset: 0x0F0 (R/W)  Selected Pin Protocol Register */
        uint32_t RESERVED2[131];
        __I uint32_t FFSR;  /*!< Offset: 0x300 (R/ )  Formatter and Flush Status Register */
        __IO uint32_t FFCR; /*!< Offset: 0x304 (R/W)  Formatter and Flush Control Register */
        __I uint32_t FSCR;  /*!< Offset: 0x308 (R/ )  Formatter Synchronization Counter Register */
        uint32_t RESERVED3[759];
        __I uint32_t TRIGGER;   /*!< Offset: 0xEE8 (R/ )  TRIGGER */
        __I uint32_t FIFO0;     /*!< Offset: 0xEEC (R/ )  Integration ETM Data */
        __I uint32_t ITATBCTR2; /*!< Offset: 0xEF0 (R/ )  ITATBCTR2 */
        uint32_t RESERVED4[1];
        __I uint32_t ITATBCTR0; /*!< Offset: 0xEF8 (R/ )  ITATBCTR0 */
        __I uint32_t FIFO1;     /*!< Offset: 0xEFC (R/ )  Integration ITM Data */
        __IO uint32_t ITCTRL;   /*!< Offset: 0xF00 (R/W)  Integration Mode Control */
        uint32_t RESERVED5[39];
        __IO uint32_t CLAIMSET; /*!< Offset: 0xFA0 (R/W)  Claim tag set */
        __IO uint32_t CLAIMCLR; /*!< Offset: 0xFA4 (R/W)  Claim tag clear */
        uint32_t RESERVED7[8];
        __I uint32_t DEVID;   /*!< Offset: 0xFC8 (R/ )  TPIU_DEVID */
        __I uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ )  TPIU_DEVTYPE */
    } TPI_Type;
W
whsj2 已提交
960 961

/* TPI Asynchronous Clock Prescaler Register Definitions */
Y
yanmowudi 已提交
962 963
#define TPI_ACPR_PRESCALER_Pos 0                                    /*!< TPI ACPR: PRESCALER Position */
#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL << TPI_ACPR_PRESCALER_Pos) /*!< TPI ACPR: PRESCALER Mask */
W
whsj2 已提交
964 965

/* TPI Selected Pin Protocol Register Definitions */
Y
yanmowudi 已提交
966 967
#define TPI_SPPR_TXMODE_Pos 0                              /*!< TPI SPPR: TXMODE Position */
#define TPI_SPPR_TXMODE_Msk (0x3UL << TPI_SPPR_TXMODE_Pos) /*!< TPI SPPR: TXMODE Mask */
W
whsj2 已提交
968 969

/* TPI Formatter and Flush Status Register Definitions */
Y
yanmowudi 已提交
970 971
#define TPI_FFSR_FtNonStop_Pos 3                                 /*!< TPI FFSR: FtNonStop Position */
#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */
W
whsj2 已提交
972

Y
yanmowudi 已提交
973 974
#define TPI_FFSR_TCPresent_Pos 2                                 /*!< TPI FFSR: TCPresent Position */
#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */
W
whsj2 已提交
975

Y
yanmowudi 已提交
976 977
#define TPI_FFSR_FtStopped_Pos 1                                 /*!< TPI FFSR: FtStopped Position */
#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */
W
whsj2 已提交
978

Y
yanmowudi 已提交
979 980
#define TPI_FFSR_FlInProg_Pos 0                                /*!< TPI FFSR: FlInProg Position */
#define TPI_FFSR_FlInProg_Msk (0x1UL << TPI_FFSR_FlInProg_Pos) /*!< TPI FFSR: FlInProg Mask */
W
whsj2 已提交
981 982

/* TPI Formatter and Flush Control Register Definitions */
Y
yanmowudi 已提交
983 984
#define TPI_FFCR_TrigIn_Pos 8                              /*!< TPI FFCR: TrigIn Position */
#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */
W
whsj2 已提交
985

Y
yanmowudi 已提交
986 987
#define TPI_FFCR_EnFCont_Pos 1                               /*!< TPI FFCR: EnFCont Position */
#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */
W
whsj2 已提交
988 989

/* TPI TRIGGER Register Definitions */
Y
yanmowudi 已提交
990 991
#define TPI_TRIGGER_TRIGGER_Pos 0                                  /*!< TPI TRIGGER: TRIGGER Position */
#define TPI_TRIGGER_TRIGGER_Msk (0x1UL << TPI_TRIGGER_TRIGGER_Pos) /*!< TPI TRIGGER: TRIGGER Mask */
W
whsj2 已提交
992 993

/* TPI Integration ETM Data Register Definitions (FIFO0) */
Y
yanmowudi 已提交
994 995
#define TPI_FIFO0_ITM_ATVALID_Pos 29                                   /*!< TPI FIFO0: ITM_ATVALID Position */
#define TPI_FIFO0_ITM_ATVALID_Msk (0x3UL << TPI_FIFO0_ITM_ATVALID_Pos) /*!< TPI FIFO0: ITM_ATVALID Mask */
W
whsj2 已提交
996

Y
yanmowudi 已提交
997 998
#define TPI_FIFO0_ITM_bytecount_Pos 27                                     /*!< TPI FIFO0: ITM_bytecount Position */
#define TPI_FIFO0_ITM_bytecount_Msk (0x3UL << TPI_FIFO0_ITM_bytecount_Pos) /*!< TPI FIFO0: ITM_bytecount Mask */
W
whsj2 已提交
999

Y
yanmowudi 已提交
1000 1001
#define TPI_FIFO0_ETM_ATVALID_Pos 26                                   /*!< TPI FIFO0: ETM_ATVALID Position */
#define TPI_FIFO0_ETM_ATVALID_Msk (0x3UL << TPI_FIFO0_ETM_ATVALID_Pos) /*!< TPI FIFO0: ETM_ATVALID Mask */
W
whsj2 已提交
1002

Y
yanmowudi 已提交
1003 1004
#define TPI_FIFO0_ETM_bytecount_Pos 24                                     /*!< TPI FIFO0: ETM_bytecount Position */
#define TPI_FIFO0_ETM_bytecount_Msk (0x3UL << TPI_FIFO0_ETM_bytecount_Pos) /*!< TPI FIFO0: ETM_bytecount Mask */
W
whsj2 已提交
1005

Y
yanmowudi 已提交
1006 1007
#define TPI_FIFO0_ETM2_Pos 16                             /*!< TPI FIFO0: ETM2 Position */
#define TPI_FIFO0_ETM2_Msk (0xFFUL << TPI_FIFO0_ETM2_Pos) /*!< TPI FIFO0: ETM2 Mask */
W
whsj2 已提交
1008

Y
yanmowudi 已提交
1009 1010
#define TPI_FIFO0_ETM1_Pos 8                              /*!< TPI FIFO0: ETM1 Position */
#define TPI_FIFO0_ETM1_Msk (0xFFUL << TPI_FIFO0_ETM1_Pos) /*!< TPI FIFO0: ETM1 Mask */
W
whsj2 已提交
1011

Y
yanmowudi 已提交
1012 1013
#define TPI_FIFO0_ETM0_Pos 0                              /*!< TPI FIFO0: ETM0 Position */
#define TPI_FIFO0_ETM0_Msk (0xFFUL << TPI_FIFO0_ETM0_Pos) /*!< TPI FIFO0: ETM0 Mask */
W
whsj2 已提交
1014 1015

/* TPI ITATBCTR2 Register Definitions */
Y
yanmowudi 已提交
1016 1017
#define TPI_ITATBCTR2_ATREADY_Pos 0                                    /*!< TPI ITATBCTR2: ATREADY Position */
#define TPI_ITATBCTR2_ATREADY_Msk (0x1UL << TPI_ITATBCTR2_ATREADY_Pos) /*!< TPI ITATBCTR2: ATREADY Mask */
W
whsj2 已提交
1018 1019

/* TPI Integration ITM Data Register Definitions (FIFO1) */
Y
yanmowudi 已提交
1020 1021
#define TPI_FIFO1_ITM_ATVALID_Pos 29                                   /*!< TPI FIFO1: ITM_ATVALID Position */
#define TPI_FIFO1_ITM_ATVALID_Msk (0x3UL << TPI_FIFO1_ITM_ATVALID_Pos) /*!< TPI FIFO1: ITM_ATVALID Mask */
W
whsj2 已提交
1022

Y
yanmowudi 已提交
1023 1024
#define TPI_FIFO1_ITM_bytecount_Pos 27                                     /*!< TPI FIFO1: ITM_bytecount Position */
#define TPI_FIFO1_ITM_bytecount_Msk (0x3UL << TPI_FIFO1_ITM_bytecount_Pos) /*!< TPI FIFO1: ITM_bytecount Mask */
W
whsj2 已提交
1025

Y
yanmowudi 已提交
1026 1027
#define TPI_FIFO1_ETM_ATVALID_Pos 26                                   /*!< TPI FIFO1: ETM_ATVALID Position */
#define TPI_FIFO1_ETM_ATVALID_Msk (0x3UL << TPI_FIFO1_ETM_ATVALID_Pos) /*!< TPI FIFO1: ETM_ATVALID Mask */
W
whsj2 已提交
1028

Y
yanmowudi 已提交
1029 1030
#define TPI_FIFO1_ETM_bytecount_Pos 24                                     /*!< TPI FIFO1: ETM_bytecount Position */
#define TPI_FIFO1_ETM_bytecount_Msk (0x3UL << TPI_FIFO1_ETM_bytecount_Pos) /*!< TPI FIFO1: ETM_bytecount Mask */
W
whsj2 已提交
1031

Y
yanmowudi 已提交
1032 1033
#define TPI_FIFO1_ITM2_Pos 16                             /*!< TPI FIFO1: ITM2 Position */
#define TPI_FIFO1_ITM2_Msk (0xFFUL << TPI_FIFO1_ITM2_Pos) /*!< TPI FIFO1: ITM2 Mask */
W
whsj2 已提交
1034

Y
yanmowudi 已提交
1035 1036
#define TPI_FIFO1_ITM1_Pos 8                              /*!< TPI FIFO1: ITM1 Position */
#define TPI_FIFO1_ITM1_Msk (0xFFUL << TPI_FIFO1_ITM1_Pos) /*!< TPI FIFO1: ITM1 Mask */
W
whsj2 已提交
1037

Y
yanmowudi 已提交
1038 1039
#define TPI_FIFO1_ITM0_Pos 0                              /*!< TPI FIFO1: ITM0 Position */
#define TPI_FIFO1_ITM0_Msk (0xFFUL << TPI_FIFO1_ITM0_Pos) /*!< TPI FIFO1: ITM0 Mask */
W
whsj2 已提交
1040 1041

/* TPI ITATBCTR0 Register Definitions */
Y
yanmowudi 已提交
1042 1043
#define TPI_ITATBCTR0_ATREADY_Pos 0                                    /*!< TPI ITATBCTR0: ATREADY Position */
#define TPI_ITATBCTR0_ATREADY_Msk (0x1UL << TPI_ITATBCTR0_ATREADY_Pos) /*!< TPI ITATBCTR0: ATREADY Mask */
W
whsj2 已提交
1044 1045

/* TPI Integration Mode Control Register Definitions */
Y
yanmowudi 已提交
1046 1047
#define TPI_ITCTRL_Mode_Pos 0                              /*!< TPI ITCTRL: Mode Position */
#define TPI_ITCTRL_Mode_Msk (0x1UL << TPI_ITCTRL_Mode_Pos) /*!< TPI ITCTRL: Mode Mask */
W
whsj2 已提交
1048 1049

/* TPI DEVID Register Definitions */
Y
yanmowudi 已提交
1050 1051
#define TPI_DEVID_NRZVALID_Pos 11                                /*!< TPI DEVID: NRZVALID Position */
#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */
W
whsj2 已提交
1052

Y
yanmowudi 已提交
1053 1054
#define TPI_DEVID_MANCVALID_Pos 10                                 /*!< TPI DEVID: MANCVALID Position */
#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */
W
whsj2 已提交
1055

Y
yanmowudi 已提交
1056 1057
#define TPI_DEVID_PTINVALID_Pos 9                                  /*!< TPI DEVID: PTINVALID Position */
#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */
W
whsj2 已提交
1058

Y
yanmowudi 已提交
1059 1060
#define TPI_DEVID_MinBufSz_Pos 6                                 /*!< TPI DEVID: MinBufSz Position */
#define TPI_DEVID_MinBufSz_Msk (0x7UL << TPI_DEVID_MinBufSz_Pos) /*!< TPI DEVID: MinBufSz Mask */
W
whsj2 已提交
1061

Y
yanmowudi 已提交
1062 1063
#define TPI_DEVID_AsynClkIn_Pos 5                                  /*!< TPI DEVID: AsynClkIn Position */
#define TPI_DEVID_AsynClkIn_Msk (0x1UL << TPI_DEVID_AsynClkIn_Pos) /*!< TPI DEVID: AsynClkIn Mask */
W
whsj2 已提交
1064

Y
yanmowudi 已提交
1065 1066
#define TPI_DEVID_NrTraceInput_Pos 0                                      /*!< TPI DEVID: NrTraceInput Position */
#define TPI_DEVID_NrTraceInput_Msk (0x1FUL << TPI_DEVID_NrTraceInput_Pos) /*!< TPI DEVID: NrTraceInput Mask */
W
whsj2 已提交
1067 1068

/* TPI DEVTYPE Register Definitions */
Y
yanmowudi 已提交
1069 1070
#define TPI_DEVTYPE_SubType_Pos 0                                  /*!< TPI DEVTYPE: SubType Position */
#define TPI_DEVTYPE_SubType_Msk (0xFUL << TPI_DEVTYPE_SubType_Pos) /*!< TPI DEVTYPE: SubType Mask */
W
whsj2 已提交
1071

Y
yanmowudi 已提交
1072 1073
#define TPI_DEVTYPE_MajorType_Pos 4                                    /*!< TPI DEVTYPE: MajorType Position */
#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */
W
whsj2 已提交
1074

Y
yanmowudi 已提交
1075
    /*@}*/ /* end of group CMSIS_TPI */
W
whsj2 已提交
1076 1077

#if (__MPU_PRESENT == 1)
Y
yanmowudi 已提交
1078
    /** \ingroup  CMSIS_core_register
W
whsj2 已提交
1079 1080 1081 1082 1083
    \defgroup CMSIS_MPU     Memory Protection Unit (MPU)
    \brief      Type definitions for the Memory Protection Unit (MPU)
  @{
 */

Y
yanmowudi 已提交
1084
    /** \brief  Structure type to access the Memory Protection Unit (MPU).
W
whsj2 已提交
1085
 */
Y
yanmowudi 已提交
1086 1087 1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098 1099
    typedef struct
    {
        __I uint32_t TYPE;     /*!< Offset: 0x000 (R/ )  MPU Type Register                              */
        __IO uint32_t CTRL;    /*!< Offset: 0x004 (R/W)  MPU Control Register                           */
        __IO uint32_t RNR;     /*!< Offset: 0x008 (R/W)  MPU Region RNRber Register                     */
        __IO uint32_t RBAR;    /*!< Offset: 0x00C (R/W)  MPU Region Base Address Register               */
        __IO uint32_t RASR;    /*!< Offset: 0x010 (R/W)  MPU Region Attribute and Size Register         */
        __IO uint32_t RBAR_A1; /*!< Offset: 0x014 (R/W)  MPU Alias 1 Region Base Address Register       */
        __IO uint32_t RASR_A1; /*!< Offset: 0x018 (R/W)  MPU Alias 1 Region Attribute and Size Register */
        __IO uint32_t RBAR_A2; /*!< Offset: 0x01C (R/W)  MPU Alias 2 Region Base Address Register       */
        __IO uint32_t RASR_A2; /*!< Offset: 0x020 (R/W)  MPU Alias 2 Region Attribute and Size Register */
        __IO uint32_t RBAR_A3; /*!< Offset: 0x024 (R/W)  MPU Alias 3 Region Base Address Register       */
        __IO uint32_t RASR_A3; /*!< Offset: 0x028 (R/W)  MPU Alias 3 Region Attribute and Size Register */
    } MPU_Type;
W
whsj2 已提交
1100 1101

/* MPU Type Register */
Y
yanmowudi 已提交
1102 1103
#define MPU_TYPE_IREGION_Pos 16                               /*!< MPU TYPE: IREGION Position */
#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */
W
whsj2 已提交
1104

Y
yanmowudi 已提交
1105 1106
#define MPU_TYPE_DREGION_Pos 8                                /*!< MPU TYPE: DREGION Position */
#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */
W
whsj2 已提交
1107

Y
yanmowudi 已提交
1108 1109
#define MPU_TYPE_SEPARATE_Pos 0                              /*!< MPU TYPE: SEPARATE Position */
#define MPU_TYPE_SEPARATE_Msk (1UL << MPU_TYPE_SEPARATE_Pos) /*!< MPU TYPE: SEPARATE Mask */
W
whsj2 已提交
1110 1111

/* MPU Control Register */
Y
yanmowudi 已提交
1112 1113
#define MPU_CTRL_PRIVDEFENA_Pos 2                                /*!< MPU CTRL: PRIVDEFENA Position */
#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */
W
whsj2 已提交
1114

Y
yanmowudi 已提交
1115 1116
#define MPU_CTRL_HFNMIENA_Pos 1                              /*!< MPU CTRL: HFNMIENA Position */
#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */
W
whsj2 已提交
1117

Y
yanmowudi 已提交
1118 1119
#define MPU_CTRL_ENABLE_Pos 0                            /*!< MPU CTRL: ENABLE Position */
#define MPU_CTRL_ENABLE_Msk (1UL << MPU_CTRL_ENABLE_Pos) /*!< MPU CTRL: ENABLE Mask */
W
whsj2 已提交
1120 1121

/* MPU Region Number Register */
Y
yanmowudi 已提交
1122 1123
#define MPU_RNR_REGION_Pos 0                              /*!< MPU RNR: REGION Position */
#define MPU_RNR_REGION_Msk (0xFFUL << MPU_RNR_REGION_Pos) /*!< MPU RNR: REGION Mask */
W
whsj2 已提交
1124 1125

/* MPU Region Base Address Register */
Y
yanmowudi 已提交
1126 1127
#define MPU_RBAR_ADDR_Pos 5                                  /*!< MPU RBAR: ADDR Position */
#define MPU_RBAR_ADDR_Msk (0x7FFFFFFUL << MPU_RBAR_ADDR_Pos) /*!< MPU RBAR: ADDR Mask */
W
whsj2 已提交
1128

Y
yanmowudi 已提交
1129 1130
#define MPU_RBAR_VALID_Pos 4                           /*!< MPU RBAR: VALID Position */
#define MPU_RBAR_VALID_Msk (1UL << MPU_RBAR_VALID_Pos) /*!< MPU RBAR: VALID Mask */
W
whsj2 已提交
1131

Y
yanmowudi 已提交
1132 1133
#define MPU_RBAR_REGION_Pos 0                              /*!< MPU RBAR: REGION Position */
#define MPU_RBAR_REGION_Msk (0xFUL << MPU_RBAR_REGION_Pos) /*!< MPU RBAR: REGION Mask */
W
whsj2 已提交
1134 1135

/* MPU Region Attribute and Size Register */
Y
yanmowudi 已提交
1136 1137
#define MPU_RASR_ATTRS_Pos 16                               /*!< MPU RASR: MPU Region Attribute field Position */
#define MPU_RASR_ATTRS_Msk (0xFFFFUL << MPU_RASR_ATTRS_Pos) /*!< MPU RASR: MPU Region Attribute field Mask */
W
whsj2 已提交
1138

Y
yanmowudi 已提交
1139 1140
#define MPU_RASR_XN_Pos 28                       /*!< MPU RASR: ATTRS.XN Position */
#define MPU_RASR_XN_Msk (1UL << MPU_RASR_XN_Pos) /*!< MPU RASR: ATTRS.XN Mask */
W
whsj2 已提交
1141

Y
yanmowudi 已提交
1142 1143
#define MPU_RASR_AP_Pos 24                         /*!< MPU RASR: ATTRS.AP Position */
#define MPU_RASR_AP_Msk (0x7UL << MPU_RASR_AP_Pos) /*!< MPU RASR: ATTRS.AP Mask */
W
whsj2 已提交
1144

Y
yanmowudi 已提交
1145 1146
#define MPU_RASR_TEX_Pos 19                          /*!< MPU RASR: ATTRS.TEX Position */
#define MPU_RASR_TEX_Msk (0x7UL << MPU_RASR_TEX_Pos) /*!< MPU RASR: ATTRS.TEX Mask */
W
whsj2 已提交
1147

Y
yanmowudi 已提交
1148 1149
#define MPU_RASR_S_Pos 18                      /*!< MPU RASR: ATTRS.S Position */
#define MPU_RASR_S_Msk (1UL << MPU_RASR_S_Pos) /*!< MPU RASR: ATTRS.S Mask */
W
whsj2 已提交
1150

Y
yanmowudi 已提交
1151 1152
#define MPU_RASR_C_Pos 17                      /*!< MPU RASR: ATTRS.C Position */
#define MPU_RASR_C_Msk (1UL << MPU_RASR_C_Pos) /*!< MPU RASR: ATTRS.C Mask */
W
whsj2 已提交
1153

Y
yanmowudi 已提交
1154 1155
#define MPU_RASR_B_Pos 16                      /*!< MPU RASR: ATTRS.B Position */
#define MPU_RASR_B_Msk (1UL << MPU_RASR_B_Pos) /*!< MPU RASR: ATTRS.B Mask */
W
whsj2 已提交
1156

Y
yanmowudi 已提交
1157 1158
#define MPU_RASR_SRD_Pos 8                            /*!< MPU RASR: Sub-Region Disable Position */
#define MPU_RASR_SRD_Msk (0xFFUL << MPU_RASR_SRD_Pos) /*!< MPU RASR: Sub-Region Disable Mask */
W
whsj2 已提交
1159

Y
yanmowudi 已提交
1160 1161
#define MPU_RASR_SIZE_Pos 1                             /*!< MPU RASR: Region Size Field Position */
#define MPU_RASR_SIZE_Msk (0x1FUL << MPU_RASR_SIZE_Pos) /*!< MPU RASR: Region Size Field Mask */
W
whsj2 已提交
1162

Y
yanmowudi 已提交
1163 1164
#define MPU_RASR_ENABLE_Pos 0                            /*!< MPU RASR: Region enable bit Position */
#define MPU_RASR_ENABLE_Msk (1UL << MPU_RASR_ENABLE_Pos) /*!< MPU RASR: Region enable bit Disable Mask */
W
whsj2 已提交
1165 1166 1167 1168 1169

/*@} end of group CMSIS_MPU */
#endif

#if (__FPU_PRESENT == 1)
Y
yanmowudi 已提交
1170
    /** \ingroup  CMSIS_core_register
W
whsj2 已提交
1171 1172 1173 1174 1175
    \defgroup CMSIS_FPU     Floating Point Unit (FPU)
    \brief      Type definitions for the Floating Point Unit (FPU)
  @{
 */

Y
yanmowudi 已提交
1176
    /** \brief  Structure type to access the Floating Point Unit (FPU).
W
whsj2 已提交
1177
 */
Y
yanmowudi 已提交
1178 1179 1180 1181 1182 1183 1184 1185 1186
    typedef struct
    {
        uint32_t RESERVED0[1];
        __IO uint32_t FPCCR;  /*!< Offset: 0x004 (R/W)  Floating-Point Context Control Register               */
        __IO uint32_t FPCAR;  /*!< Offset: 0x008 (R/W)  Floating-Point Context Address Register               */
        __IO uint32_t FPDSCR; /*!< Offset: 0x00C (R/W)  Floating-Point Default Status Control Register        */
        __I uint32_t MVFR0;   /*!< Offset: 0x010 (R/ )  Media and FP Feature Register 0                       */
        __I uint32_t MVFR1;   /*!< Offset: 0x014 (R/ )  Media and FP Feature Register 1                       */
    } FPU_Type;
W
whsj2 已提交
1187 1188

/* Floating-Point Context Control Register */
Y
yanmowudi 已提交
1189 1190
#define FPU_FPCCR_ASPEN_Pos 31                           /*!< FPCCR: ASPEN bit Position */
#define FPU_FPCCR_ASPEN_Msk (1UL << FPU_FPCCR_ASPEN_Pos) /*!< FPCCR: ASPEN bit Mask */
W
whsj2 已提交
1191

Y
yanmowudi 已提交
1192 1193
#define FPU_FPCCR_LSPEN_Pos 30                           /*!< FPCCR: LSPEN Position */
#define FPU_FPCCR_LSPEN_Msk (1UL << FPU_FPCCR_LSPEN_Pos) /*!< FPCCR: LSPEN bit Mask */
W
whsj2 已提交
1194

Y
yanmowudi 已提交
1195 1196
#define FPU_FPCCR_MONRDY_Pos 8                             /*!< FPCCR: MONRDY Position */
#define FPU_FPCCR_MONRDY_Msk (1UL << FPU_FPCCR_MONRDY_Pos) /*!< FPCCR: MONRDY bit Mask */
W
whsj2 已提交
1197

Y
yanmowudi 已提交
1198 1199
#define FPU_FPCCR_BFRDY_Pos 6                            /*!< FPCCR: BFRDY Position */
#define FPU_FPCCR_BFRDY_Msk (1UL << FPU_FPCCR_BFRDY_Pos) /*!< FPCCR: BFRDY bit Mask */
W
whsj2 已提交
1200

Y
yanmowudi 已提交
1201 1202
#define FPU_FPCCR_MMRDY_Pos 5                            /*!< FPCCR: MMRDY Position */
#define FPU_FPCCR_MMRDY_Msk (1UL << FPU_FPCCR_MMRDY_Pos) /*!< FPCCR: MMRDY bit Mask */
W
whsj2 已提交
1203

Y
yanmowudi 已提交
1204 1205
#define FPU_FPCCR_HFRDY_Pos 4                            /*!< FPCCR: HFRDY Position */
#define FPU_FPCCR_HFRDY_Msk (1UL << FPU_FPCCR_HFRDY_Pos) /*!< FPCCR: HFRDY bit Mask */
W
whsj2 已提交
1206

Y
yanmowudi 已提交
1207 1208
#define FPU_FPCCR_THREAD_Pos 3                             /*!< FPCCR: processor mode bit Position */
#define FPU_FPCCR_THREAD_Msk (1UL << FPU_FPCCR_THREAD_Pos) /*!< FPCCR: processor mode active bit Mask */
W
whsj2 已提交
1209

Y
yanmowudi 已提交
1210 1211
#define FPU_FPCCR_USER_Pos 1                           /*!< FPCCR: privilege level bit Position */
#define FPU_FPCCR_USER_Msk (1UL << FPU_FPCCR_USER_Pos) /*!< FPCCR: privilege level bit Mask */
W
whsj2 已提交
1212

Y
yanmowudi 已提交
1213 1214
#define FPU_FPCCR_LSPACT_Pos 0                             /*!< FPCCR: Lazy state preservation active bit Position */
#define FPU_FPCCR_LSPACT_Msk (1UL << FPU_FPCCR_LSPACT_Pos) /*!< FPCCR: Lazy state preservation active bit Mask */
W
whsj2 已提交
1215 1216

/* Floating-Point Context Address Register */
Y
yanmowudi 已提交
1217 1218
#define FPU_FPCAR_ADDRESS_Pos 3                                       /*!< FPCAR: ADDRESS bit Position */
#define FPU_FPCAR_ADDRESS_Msk (0x1FFFFFFFUL << FPU_FPCAR_ADDRESS_Pos) /*!< FPCAR: ADDRESS bit Mask */
W
whsj2 已提交
1219 1220

/* Floating-Point Default Status Control Register */
Y
yanmowudi 已提交
1221 1222
#define FPU_FPDSCR_AHP_Pos 26                          /*!< FPDSCR: AHP bit Position */
#define FPU_FPDSCR_AHP_Msk (1UL << FPU_FPDSCR_AHP_Pos) /*!< FPDSCR: AHP bit Mask */
W
whsj2 已提交
1223

Y
yanmowudi 已提交
1224 1225
#define FPU_FPDSCR_DN_Pos 25                         /*!< FPDSCR: DN bit Position */
#define FPU_FPDSCR_DN_Msk (1UL << FPU_FPDSCR_DN_Pos) /*!< FPDSCR: DN bit Mask */
W
whsj2 已提交
1226

Y
yanmowudi 已提交
1227 1228
#define FPU_FPDSCR_FZ_Pos 24                         /*!< FPDSCR: FZ bit Position */
#define FPU_FPDSCR_FZ_Msk (1UL << FPU_FPDSCR_FZ_Pos) /*!< FPDSCR: FZ bit Mask */
W
whsj2 已提交
1229

Y
yanmowudi 已提交
1230 1231
#define FPU_FPDSCR_RMode_Pos 22                            /*!< FPDSCR: RMode bit Position */
#define FPU_FPDSCR_RMode_Msk (3UL << FPU_FPDSCR_RMode_Pos) /*!< FPDSCR: RMode bit Mask */
W
whsj2 已提交
1232 1233

/* Media and FP Feature Register 0 */
Y
yanmowudi 已提交
1234 1235
#define FPU_MVFR0_FP_rounding_modes_Pos 28                                         /*!< MVFR0: FP rounding modes bits Position */
#define FPU_MVFR0_FP_rounding_modes_Msk (0xFUL << FPU_MVFR0_FP_rounding_modes_Pos) /*!< MVFR0: FP rounding modes bits Mask */
W
whsj2 已提交
1236

Y
yanmowudi 已提交
1237 1238
#define FPU_MVFR0_Short_vectors_Pos 24                                     /*!< MVFR0: Short vectors bits Position */
#define FPU_MVFR0_Short_vectors_Msk (0xFUL << FPU_MVFR0_Short_vectors_Pos) /*!< MVFR0: Short vectors bits Mask */
W
whsj2 已提交
1239

Y
yanmowudi 已提交
1240 1241
#define FPU_MVFR0_Square_root_Pos 20                                   /*!< MVFR0: Square root bits Position */
#define FPU_MVFR0_Square_root_Msk (0xFUL << FPU_MVFR0_Square_root_Pos) /*!< MVFR0: Square root bits Mask */
W
whsj2 已提交
1242

Y
yanmowudi 已提交
1243 1244
#define FPU_MVFR0_Divide_Pos 16                              /*!< MVFR0: Divide bits Position */
#define FPU_MVFR0_Divide_Msk (0xFUL << FPU_MVFR0_Divide_Pos) /*!< MVFR0: Divide bits Mask */
W
whsj2 已提交
1245

Y
yanmowudi 已提交
1246 1247
#define FPU_MVFR0_FP_excep_trapping_Pos 12                                         /*!< MVFR0: FP exception trapping bits Position */
#define FPU_MVFR0_FP_excep_trapping_Msk (0xFUL << FPU_MVFR0_FP_excep_trapping_Pos) /*!< MVFR0: FP exception trapping bits Mask */
W
whsj2 已提交
1248

Y
yanmowudi 已提交
1249 1250
#define FPU_MVFR0_Double_precision_Pos 8                                         /*!< MVFR0: Double-precision bits Position */
#define FPU_MVFR0_Double_precision_Msk (0xFUL << FPU_MVFR0_Double_precision_Pos) /*!< MVFR0: Double-precision bits Mask */
W
whsj2 已提交
1251

Y
yanmowudi 已提交
1252 1253
#define FPU_MVFR0_Single_precision_Pos 4                                         /*!< MVFR0: Single-precision bits Position */
#define FPU_MVFR0_Single_precision_Msk (0xFUL << FPU_MVFR0_Single_precision_Pos) /*!< MVFR0: Single-precision bits Mask */
W
whsj2 已提交
1254

Y
yanmowudi 已提交
1255 1256
#define FPU_MVFR0_A_SIMD_registers_Pos 0                                         /*!< MVFR0: A_SIMD registers bits Position */
#define FPU_MVFR0_A_SIMD_registers_Msk (0xFUL << FPU_MVFR0_A_SIMD_registers_Pos) /*!< MVFR0: A_SIMD registers bits Mask */
W
whsj2 已提交
1257 1258

/* Media and FP Feature Register 1 */
Y
yanmowudi 已提交
1259 1260
#define FPU_MVFR1_FP_fused_MAC_Pos 28                                    /*!< MVFR1: FP fused MAC bits Position */
#define FPU_MVFR1_FP_fused_MAC_Msk (0xFUL << FPU_MVFR1_FP_fused_MAC_Pos) /*!< MVFR1: FP fused MAC bits Mask */
W
whsj2 已提交
1261

Y
yanmowudi 已提交
1262 1263
#define FPU_MVFR1_FP_HPFP_Pos 24                               /*!< MVFR1: FP HPFP bits Position */
#define FPU_MVFR1_FP_HPFP_Msk (0xFUL << FPU_MVFR1_FP_HPFP_Pos) /*!< MVFR1: FP HPFP bits Mask */
W
whsj2 已提交
1264

Y
yanmowudi 已提交
1265 1266
#define FPU_MVFR1_D_NaN_mode_Pos 4                                   /*!< MVFR1: D_NaN mode bits Position */
#define FPU_MVFR1_D_NaN_mode_Msk (0xFUL << FPU_MVFR1_D_NaN_mode_Pos) /*!< MVFR1: D_NaN mode bits Mask */
W
whsj2 已提交
1267

Y
yanmowudi 已提交
1268 1269
#define FPU_MVFR1_FtZ_mode_Pos 0                                 /*!< MVFR1: FtZ mode bits Position */
#define FPU_MVFR1_FtZ_mode_Msk (0xFUL << FPU_MVFR1_FtZ_mode_Pos) /*!< MVFR1: FtZ mode bits Mask */
W
whsj2 已提交
1270 1271 1272 1273

/*@} end of group CMSIS_FPU */
#endif

Y
yanmowudi 已提交
1274
    /** \ingroup  CMSIS_core_register
W
whsj2 已提交
1275 1276 1277 1278 1279
    \defgroup CMSIS_CoreDebug       Core Debug Registers (CoreDebug)
    \brief      Type definitions for the Core Debug Registers
  @{
 */

Y
yanmowudi 已提交
1280
    /** \brief  Structure type to access the Core Debug Register (CoreDebug).
W
whsj2 已提交
1281
 */
Y
yanmowudi 已提交
1282 1283 1284 1285 1286 1287 1288
    typedef struct
    {
        __IO uint32_t DHCSR; /*!< Offset: 0x000 (R/W)  Debug Halting Control and Status Register    */
        __O uint32_t DCRSR;  /*!< Offset: 0x004 ( /W)  Debug Core Register Selector Register        */
        __IO uint32_t DCRDR; /*!< Offset: 0x008 (R/W)  Debug Core Register Data Register            */
        __IO uint32_t DEMCR; /*!< Offset: 0x00C (R/W)  Debug Exception and Monitor Control Register */
    } CoreDebug_Type;
W
whsj2 已提交
1289 1290

/* Debug Halting Control and Status Register */
Y
yanmowudi 已提交
1291 1292
#define CoreDebug_DHCSR_DBGKEY_Pos 16                                       /*!< CoreDebug DHCSR: DBGKEY Position */
#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */
W
whsj2 已提交
1293

Y
yanmowudi 已提交
1294 1295
#define CoreDebug_DHCSR_S_RESET_ST_Pos 25                                      /*!< CoreDebug DHCSR: S_RESET_ST Position */
#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */
W
whsj2 已提交
1296

Y
yanmowudi 已提交
1297 1298
#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24                                       /*!< CoreDebug DHCSR: S_RETIRE_ST Position */
#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */
W
whsj2 已提交
1299

Y
yanmowudi 已提交
1300 1301
#define CoreDebug_DHCSR_S_LOCKUP_Pos 19                                    /*!< CoreDebug DHCSR: S_LOCKUP Position */
#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */
W
whsj2 已提交
1302

Y
yanmowudi 已提交
1303 1304
#define CoreDebug_DHCSR_S_SLEEP_Pos 18                                   /*!< CoreDebug DHCSR: S_SLEEP Position */
#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */
W
whsj2 已提交
1305

Y
yanmowudi 已提交
1306 1307
#define CoreDebug_DHCSR_S_HALT_Pos 17                                  /*!< CoreDebug DHCSR: S_HALT Position */
#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */
W
whsj2 已提交
1308

Y
yanmowudi 已提交
1309 1310
#define CoreDebug_DHCSR_S_REGRDY_Pos 16                                    /*!< CoreDebug DHCSR: S_REGRDY Position */
#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */
W
whsj2 已提交
1311

Y
yanmowudi 已提交
1312 1313
#define CoreDebug_DHCSR_C_SNAPSTALL_Pos 5                                        /*!< CoreDebug DHCSR: C_SNAPSTALL Position */
#define CoreDebug_DHCSR_C_SNAPSTALL_Msk (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos) /*!< CoreDebug DHCSR: C_SNAPSTALL Mask */
W
whsj2 已提交
1314

Y
yanmowudi 已提交
1315 1316
#define CoreDebug_DHCSR_C_MASKINTS_Pos 3                                       /*!< CoreDebug DHCSR: C_MASKINTS Position */
#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */
W
whsj2 已提交
1317

Y
yanmowudi 已提交
1318 1319
#define CoreDebug_DHCSR_C_STEP_Pos 2                                   /*!< CoreDebug DHCSR: C_STEP Position */
#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */
W
whsj2 已提交
1320

Y
yanmowudi 已提交
1321 1322
#define CoreDebug_DHCSR_C_HALT_Pos 1                                   /*!< CoreDebug DHCSR: C_HALT Position */
#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */
W
whsj2 已提交
1323

Y
yanmowudi 已提交
1324 1325
#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0                                      /*!< CoreDebug DHCSR: C_DEBUGEN Position */
#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL << CoreDebug_DHCSR_C_DEBUGEN_Pos) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */
W
whsj2 已提交
1326 1327

/* Debug Core Register Selector Register */
Y
yanmowudi 已提交
1328 1329
#define CoreDebug_DCRSR_REGWnR_Pos 16                                  /*!< CoreDebug DCRSR: REGWnR Position */
#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */
W
whsj2 已提交
1330

Y
yanmowudi 已提交
1331 1332
#define CoreDebug_DCRSR_REGSEL_Pos 0                                      /*!< CoreDebug DCRSR: REGSEL Position */
#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL << CoreDebug_DCRSR_REGSEL_Pos) /*!< CoreDebug DCRSR: REGSEL Mask */
W
whsj2 已提交
1333 1334

/* Debug Exception and Monitor Control Register */
Y
yanmowudi 已提交
1335 1336
#define CoreDebug_DEMCR_TRCENA_Pos 24                                  /*!< CoreDebug DEMCR: TRCENA Position */
#define CoreDebug_DEMCR_TRCENA_Msk (1UL << CoreDebug_DEMCR_TRCENA_Pos) /*!< CoreDebug DEMCR: TRCENA Mask */
W
whsj2 已提交
1337

Y
yanmowudi 已提交
1338 1339
#define CoreDebug_DEMCR_MON_REQ_Pos 19                                   /*!< CoreDebug DEMCR: MON_REQ Position */
#define CoreDebug_DEMCR_MON_REQ_Msk (1UL << CoreDebug_DEMCR_MON_REQ_Pos) /*!< CoreDebug DEMCR: MON_REQ Mask */
W
whsj2 已提交
1340

Y
yanmowudi 已提交
1341 1342
#define CoreDebug_DEMCR_MON_STEP_Pos 18                                    /*!< CoreDebug DEMCR: MON_STEP Position */
#define CoreDebug_DEMCR_MON_STEP_Msk (1UL << CoreDebug_DEMCR_MON_STEP_Pos) /*!< CoreDebug DEMCR: MON_STEP Mask */
W
whsj2 已提交
1343

Y
yanmowudi 已提交
1344 1345
#define CoreDebug_DEMCR_MON_PEND_Pos 17                                    /*!< CoreDebug DEMCR: MON_PEND Position */
#define CoreDebug_DEMCR_MON_PEND_Msk (1UL << CoreDebug_DEMCR_MON_PEND_Pos) /*!< CoreDebug DEMCR: MON_PEND Mask */
W
whsj2 已提交
1346

Y
yanmowudi 已提交
1347 1348
#define CoreDebug_DEMCR_MON_EN_Pos 16                                  /*!< CoreDebug DEMCR: MON_EN Position */
#define CoreDebug_DEMCR_MON_EN_Msk (1UL << CoreDebug_DEMCR_MON_EN_Pos) /*!< CoreDebug DEMCR: MON_EN Mask */
W
whsj2 已提交
1349

Y
yanmowudi 已提交
1350 1351
#define CoreDebug_DEMCR_VC_HARDERR_Pos 10                                      /*!< CoreDebug DEMCR: VC_HARDERR Position */
#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */
W
whsj2 已提交
1352

Y
yanmowudi 已提交
1353 1354
#define CoreDebug_DEMCR_VC_INTERR_Pos 9                                      /*!< CoreDebug DEMCR: VC_INTERR Position */
#define CoreDebug_DEMCR_VC_INTERR_Msk (1UL << CoreDebug_DEMCR_VC_INTERR_Pos) /*!< CoreDebug DEMCR: VC_INTERR Mask */
W
whsj2 已提交
1355

Y
yanmowudi 已提交
1356 1357
#define CoreDebug_DEMCR_VC_BUSERR_Pos 8                                      /*!< CoreDebug DEMCR: VC_BUSERR Position */
#define CoreDebug_DEMCR_VC_BUSERR_Msk (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos) /*!< CoreDebug DEMCR: VC_BUSERR Mask */
W
whsj2 已提交
1358

Y
yanmowudi 已提交
1359 1360
#define CoreDebug_DEMCR_VC_STATERR_Pos 7                                       /*!< CoreDebug DEMCR: VC_STATERR Position */
#define CoreDebug_DEMCR_VC_STATERR_Msk (1UL << CoreDebug_DEMCR_VC_STATERR_Pos) /*!< CoreDebug DEMCR: VC_STATERR Mask */
W
whsj2 已提交
1361

Y
yanmowudi 已提交
1362 1363
#define CoreDebug_DEMCR_VC_CHKERR_Pos 6                                      /*!< CoreDebug DEMCR: VC_CHKERR Position */
#define CoreDebug_DEMCR_VC_CHKERR_Msk (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos) /*!< CoreDebug DEMCR: VC_CHKERR Mask */
W
whsj2 已提交
1364

Y
yanmowudi 已提交
1365 1366
#define CoreDebug_DEMCR_VC_NOCPERR_Pos 5                                       /*!< CoreDebug DEMCR: VC_NOCPERR Position */
#define CoreDebug_DEMCR_VC_NOCPERR_Msk (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos) /*!< CoreDebug DEMCR: VC_NOCPERR Mask */
W
whsj2 已提交
1367

Y
yanmowudi 已提交
1368 1369
#define CoreDebug_DEMCR_VC_MMERR_Pos 4                                     /*!< CoreDebug DEMCR: VC_MMERR Position */
#define CoreDebug_DEMCR_VC_MMERR_Msk (1UL << CoreDebug_DEMCR_VC_MMERR_Pos) /*!< CoreDebug DEMCR: VC_MMERR Mask */
W
whsj2 已提交
1370

Y
yanmowudi 已提交
1371 1372
#define CoreDebug_DEMCR_VC_CORERESET_Pos 0                                         /*!< CoreDebug DEMCR: VC_CORERESET Position */
#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL << CoreDebug_DEMCR_VC_CORERESET_Pos) /*!< CoreDebug DEMCR: VC_CORERESET Mask */
W
whsj2 已提交
1373 1374 1375 1376 1377 1378 1379 1380 1381 1382

/*@} end of group CMSIS_CoreDebug */

/** \ingroup    CMSIS_core_register
    \defgroup   CMSIS_core_base     Core Definitions
    \brief      Definitions for base addresses, unions, and structures.
  @{
 */

/* Memory mapping of Cortex-M4 Hardware */
Y
yanmowudi 已提交
1383 1384 1385 1386 1387 1388 1389 1390 1391 1392 1393 1394 1395 1396 1397 1398 1399
#define SCS_BASE (0xE000E000UL)            /*!< System Control Space Base Address  */
#define ITM_BASE (0xE0000000UL)            /*!< ITM Base Address                   */
#define DWT_BASE (0xE0001000UL)            /*!< DWT Base Address                   */
#define TPI_BASE (0xE0040000UL)            /*!< TPI Base Address                   */
#define CoreDebug_BASE (0xE000EDF0UL)      /*!< Core Debug Base Address            */
#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address               */
#define NVIC_BASE (SCS_BASE + 0x0100UL)    /*!< NVIC Base Address                  */
#define SCB_BASE (SCS_BASE + 0x0D00UL)     /*!< System Control Block Base Address  */

#define SCnSCB ((SCnSCB_Type *)SCS_BASE)             /*!< System control Register not in SCB */
#define SCB ((SCB_Type *)SCB_BASE)                   /*!< SCB configuration struct           */
#define SysTick ((SysTick_Type *)SysTick_BASE)       /*!< SysTick configuration struct       */
#define NVIC ((NVIC_Type *)NVIC_BASE)                /*!< NVIC configuration struct          */
#define ITM ((ITM_Type *)ITM_BASE)                   /*!< ITM configuration struct           */
#define DWT ((DWT_Type *)DWT_BASE)                   /*!< DWT configuration struct           */
#define TPI ((TPI_Type *)TPI_BASE)                   /*!< TPI configuration struct           */
#define CoreDebug ((CoreDebug_Type *)CoreDebug_BASE) /*!< Core Debug configuration struct    */
W
whsj2 已提交
1400 1401

#if (__MPU_PRESENT == 1)
Y
yanmowudi 已提交
1402 1403
#define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit             */
#define MPU ((MPU_Type *)MPU_BASE)     /*!< Memory Protection Unit             */
W
whsj2 已提交
1404 1405 1406
#endif

#if (__FPU_PRESENT == 1)
Y
yanmowudi 已提交
1407 1408
#define FPU_BASE (SCS_BASE + 0x0F30UL) /*!< Floating Point Unit                */
#define FPU ((FPU_Type *)FPU_BASE)     /*!< Floating Point Unit                */
W
whsj2 已提交
1409 1410
#endif

Y
yanmowudi 已提交
1411
    /*@} */
W
whsj2 已提交
1412

Y
yanmowudi 已提交
1413
    /*******************************************************************************
W
whsj2 已提交
1414 1415 1416 1417 1418 1419 1420
 *                Hardware Abstraction Layer
  Core Function Interface contains:
  - Core NVIC Functions
  - Core SysTick Functions
  - Core Debug Functions
  - Core Register Access Functions
 ******************************************************************************/
Y
yanmowudi 已提交
1421
    /** \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference
W
whsj2 已提交
1422 1423
*/

Y
yanmowudi 已提交
1424 1425
    /* ##########################   NVIC functions  #################################### */
    /** \ingroup  CMSIS_Core_FunctionInterface
W
whsj2 已提交
1426 1427 1428 1429 1430
    \defgroup CMSIS_Core_NVICFunctions NVIC Functions
    \brief      Functions that manage interrupts and exceptions via the NVIC.
    @{
 */

Y
yanmowudi 已提交
1431
    /** \brief  Set Priority Grouping
W
whsj2 已提交
1432 1433 1434 1435 1436 1437 1438 1439 1440

  The function sets the priority grouping field using the required unlock sequence.
  The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field.
  Only values from 0..7 are used.
  In case of a conflict between priority grouping and available
  priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set.

    \param [in]      PriorityGroup  Priority grouping field.
 */
Y
yanmowudi 已提交
1441 1442 1443 1444
    __STATIC_INLINE void NVIC_SetPriorityGrouping(uint32_t PriorityGroup)
    {
        uint32_t reg_value;
        uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07); /* only values 0..7 are used          */
W
whsj2 已提交
1445

Y
yanmowudi 已提交
1446 1447 1448 1449 1450 1451 1452
        reg_value = SCB->AIRCR;                                         /* read old register configuration    */
        reg_value &= ~(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk); /* clear bits to change               */
        reg_value = (reg_value |
                     ((uint32_t)0x5FA << SCB_AIRCR_VECTKEY_Pos) |
                     (PriorityGroupTmp << 8)); /* Insert write key and priorty group */
        SCB->AIRCR = reg_value;
    }
W
whsj2 已提交
1453

Y
yanmowudi 已提交
1454
    /** \brief  Get Priority Grouping
W
whsj2 已提交
1455 1456 1457 1458 1459

  The function reads the priority grouping field from the NVIC Interrupt Controller.

    \return                Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field).
 */
Y
yanmowudi 已提交
1460 1461 1462 1463
    __STATIC_INLINE uint32_t NVIC_GetPriorityGrouping(void)
    {
        return ((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos); /* read priority grouping field */
    }
W
whsj2 已提交
1464

Y
yanmowudi 已提交
1465
    /** \brief  Enable External Interrupt
W
whsj2 已提交
1466 1467 1468 1469 1470

    The function enables a device-specific interrupt in the NVIC interrupt controller.

    \param [in]      IRQn  External interrupt number. Value cannot be negative.
 */
Y
yanmowudi 已提交
1471 1472 1473 1474 1475
    __STATIC_INLINE void NVIC_EnableIRQ(IRQn_Type IRQn)
    {
        /*  NVIC->ISER[((uint32_t)(IRQn) >> 5)] = (1 << ((uint32_t)(IRQn) & 0x1F));  enable interrupt */
        NVIC->ISER[(uint32_t)((int32_t)IRQn) >> 5] = (uint32_t)(1 << ((uint32_t)((int32_t)IRQn) & (uint32_t)0x1F)); /* enable interrupt */
    }
W
whsj2 已提交
1476

Y
yanmowudi 已提交
1477
    /** \brief  Disable External Interrupt
W
whsj2 已提交
1478 1479 1480 1481 1482

    The function disables a device-specific interrupt in the NVIC interrupt controller.

    \param [in]      IRQn  External interrupt number. Value cannot be negative.
 */
Y
yanmowudi 已提交
1483 1484 1485 1486
    __STATIC_INLINE void NVIC_DisableIRQ(IRQn_Type IRQn)
    {
        NVIC->ICER[((uint32_t)(IRQn) >> 5)] = (1 << ((uint32_t)(IRQn)&0x1F)); /* disable interrupt */
    }
W
whsj2 已提交
1487

Y
yanmowudi 已提交
1488
    /** \brief  Get Pending Interrupt
W
whsj2 已提交
1489 1490 1491 1492 1493 1494 1495 1496 1497

    The function reads the pending register in the NVIC and returns the pending bit
    for the specified interrupt.

    \param [in]      IRQn  Interrupt number.

    \return             0  Interrupt status is not pending.
    \return             1  Interrupt status is pending.
 */
Y
yanmowudi 已提交
1498 1499 1500 1501
    __STATIC_INLINE uint32_t NVIC_GetPendingIRQ(IRQn_Type IRQn)
    {
        return ((uint32_t)((NVIC->ISPR[(uint32_t)(IRQn) >> 5] & (1 << ((uint32_t)(IRQn)&0x1F))) ? 1 : 0)); /* Return 1 if pending else 0 */
    }
W
whsj2 已提交
1502

Y
yanmowudi 已提交
1503
    /** \brief  Set Pending Interrupt
W
whsj2 已提交
1504 1505 1506 1507 1508

    The function sets the pending bit of an external interrupt.

    \param [in]      IRQn  Interrupt number. Value cannot be negative.
 */
Y
yanmowudi 已提交
1509 1510 1511 1512
    __STATIC_INLINE void NVIC_SetPendingIRQ(IRQn_Type IRQn)
    {
        NVIC->ISPR[((uint32_t)(IRQn) >> 5)] = (1 << ((uint32_t)(IRQn)&0x1F)); /* set interrupt pending */
    }
W
whsj2 已提交
1513

Y
yanmowudi 已提交
1514
    /** \brief  Clear Pending Interrupt
W
whsj2 已提交
1515 1516 1517 1518 1519

    The function clears the pending bit of an external interrupt.

    \param [in]      IRQn  External interrupt number. Value cannot be negative.
 */
Y
yanmowudi 已提交
1520 1521 1522 1523
    __STATIC_INLINE void NVIC_ClearPendingIRQ(IRQn_Type IRQn)
    {
        NVIC->ICPR[((uint32_t)(IRQn) >> 5)] = (1 << ((uint32_t)(IRQn)&0x1F)); /* Clear pending interrupt */
    }
W
whsj2 已提交
1524

Y
yanmowudi 已提交
1525
    /** \brief  Get Active Interrupt
W
whsj2 已提交
1526 1527 1528 1529 1530 1531 1532 1533

    The function reads the active register in NVIC and returns the active bit.

    \param [in]      IRQn  Interrupt number.

    \return             0  Interrupt status is not active.
    \return             1  Interrupt status is active.
 */
Y
yanmowudi 已提交
1534 1535 1536 1537
    __STATIC_INLINE uint32_t NVIC_GetActive(IRQn_Type IRQn)
    {
        return ((uint32_t)((NVIC->IABR[(uint32_t)(IRQn) >> 5] & (1 << ((uint32_t)(IRQn)&0x1F))) ? 1 : 0)); /* Return 1 if active else 0 */
    }
W
whsj2 已提交
1538

Y
yanmowudi 已提交
1539
    /** \brief  Set Interrupt Priority
W
whsj2 已提交
1540 1541 1542 1543 1544 1545 1546 1547

    The function sets the priority of an interrupt.

    \note The priority cannot be set for every core interrupt.

    \param [in]      IRQn  Interrupt number.
    \param [in]  priority  Priority to set.
 */
Y
yanmowudi 已提交
1548 1549 1550 1551 1552 1553 1554 1555 1556 1557 1558 1559 1560
    __STATIC_INLINE void NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority)
    {
        if (IRQn < 0)
        {
            SCB->SHP[((uint32_t)(IRQn)&0xF) - 4] = ((priority << (8 - __NVIC_PRIO_BITS)) & 0xff);
        } /* set Priority for Cortex-M  System Interrupts */
        else
        {
            NVIC->IP[(uint32_t)(IRQn)] = ((priority << (8 - __NVIC_PRIO_BITS)) & 0xff);
        } /* set Priority for device specific Interrupts  */
    }

    /** \brief  Get Interrupt Priority
W
whsj2 已提交
1561 1562 1563 1564 1565 1566 1567 1568 1569 1570

    The function reads the priority of an interrupt. The interrupt
    number can be positive to specify an external (device specific)
    interrupt, or negative to specify an internal (core) interrupt.


    \param [in]   IRQn  Interrupt number.
    \return             Interrupt Priority. Value is aligned automatically to the implemented
                        priority bits of the microcontroller.
 */
Y
yanmowudi 已提交
1571 1572
    __STATIC_INLINE uint32_t NVIC_GetPriority(IRQn_Type IRQn)
    {
W
whsj2 已提交
1573

Y
yanmowudi 已提交
1574 1575 1576 1577 1578 1579 1580 1581 1582
        if (IRQn < 0)
        {
            return ((uint32_t)(SCB->SHP[((uint32_t)(IRQn)&0xF) - 4] >> (8 - __NVIC_PRIO_BITS)));
        } /* get priority for Cortex-M  system interrupts */
        else
        {
            return ((uint32_t)(NVIC->IP[(uint32_t)(IRQn)] >> (8 - __NVIC_PRIO_BITS)));
        } /* get priority for device specific interrupts  */
    }
W
whsj2 已提交
1583

Y
yanmowudi 已提交
1584
    /** \brief  Encode Priority
W
whsj2 已提交
1585 1586 1587 1588 1589 1590 1591 1592 1593 1594 1595

    The function encodes the priority for an interrupt with the given priority group,
    preemptive priority value, and subpriority value.
    In case of a conflict between priority grouping and available
    priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set.

    \param [in]     PriorityGroup  Used priority group.
    \param [in]   PreemptPriority  Preemptive priority value (starting from 0).
    \param [in]       SubPriority  Subpriority value (starting from 0).
    \return                        Encoded priority. Value can be used in the function \ref NVIC_SetPriority().
 */
Y
yanmowudi 已提交
1596 1597 1598 1599 1600
    __STATIC_INLINE uint32_t NVIC_EncodePriority(uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority)
    {
        uint32_t PriorityGroupTmp = (PriorityGroup & 0x07); /* only values 0..7 are used          */
        uint32_t PreemptPriorityBits;
        uint32_t SubPriorityBits;
W
whsj2 已提交
1601

Y
yanmowudi 已提交
1602 1603
        PreemptPriorityBits = ((7 - PriorityGroupTmp) > __NVIC_PRIO_BITS) ? __NVIC_PRIO_BITS : 7 - PriorityGroupTmp;
        SubPriorityBits = ((PriorityGroupTmp + __NVIC_PRIO_BITS) < 7) ? 0 : PriorityGroupTmp - 7 + __NVIC_PRIO_BITS;
W
whsj2 已提交
1604

Y
yanmowudi 已提交
1605 1606 1607 1608
        return (
            ((PreemptPriority & ((1 << (PreemptPriorityBits)) - 1)) << SubPriorityBits) |
            ((SubPriority & ((1 << (SubPriorityBits)) - 1))));
    }
W
whsj2 已提交
1609

Y
yanmowudi 已提交
1610
    /** \brief  Decode Priority
W
whsj2 已提交
1611 1612 1613 1614 1615 1616 1617 1618 1619 1620 1621

    The function decodes an interrupt priority value with a given priority group to
    preemptive priority value and subpriority value.
    In case of a conflict between priority grouping and available
    priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set.

    \param [in]         Priority   Priority value, which can be retrieved with the function \ref NVIC_GetPriority().
    \param [in]     PriorityGroup  Used priority group.
    \param [out] pPreemptPriority  Preemptive priority value (starting from 0).
    \param [out]     pSubPriority  Subpriority value (starting from 0).
 */
Y
yanmowudi 已提交
1622 1623 1624 1625 1626
    __STATIC_INLINE void NVIC_DecodePriority(uint32_t Priority, uint32_t PriorityGroup, uint32_t *pPreemptPriority, uint32_t *pSubPriority)
    {
        uint32_t PriorityGroupTmp = (PriorityGroup & 0x07); /* only values 0..7 are used          */
        uint32_t PreemptPriorityBits;
        uint32_t SubPriorityBits;
W
whsj2 已提交
1627

Y
yanmowudi 已提交
1628 1629
        PreemptPriorityBits = ((7 - PriorityGroupTmp) > __NVIC_PRIO_BITS) ? __NVIC_PRIO_BITS : 7 - PriorityGroupTmp;
        SubPriorityBits = ((PriorityGroupTmp + __NVIC_PRIO_BITS) < 7) ? 0 : PriorityGroupTmp - 7 + __NVIC_PRIO_BITS;
W
whsj2 已提交
1630

Y
yanmowudi 已提交
1631 1632 1633
        *pPreemptPriority = (Priority >> SubPriorityBits) & ((1 << (PreemptPriorityBits)) - 1);
        *pSubPriority = (Priority) & ((1 << (SubPriorityBits)) - 1);
    }
W
whsj2 已提交
1634

Y
yanmowudi 已提交
1635
    /** \brief  System Reset
W
whsj2 已提交
1636 1637 1638

    The function initiates a system reset request to reset the MCU.
 */
Y
yanmowudi 已提交
1639 1640 1641
    __STATIC_INLINE void NVIC_SystemReset(void)
    {
        __DSB(); /* Ensure all outstanding memory accesses included
W
whsj2 已提交
1642
                                                                  buffered write are completed before reset */
Y
yanmowudi 已提交
1643 1644 1645 1646 1647 1648 1649 1650 1651 1652 1653 1654
        SCB->AIRCR = ((0x5FA << SCB_AIRCR_VECTKEY_Pos) |
                      (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) |
                      SCB_AIRCR_SYSRESETREQ_Msk); /* Keep priority group unchanged */
        __DSB();                                  /* Ensure completion of memory access */
        while (1)
            ; /* wait until reset */
    }

    /*@} end of CMSIS_Core_NVICFunctions */

    /* ##################################    SysTick function  ############################################ */
    /** \ingroup  CMSIS_Core_FunctionInterface
W
whsj2 已提交
1655 1656 1657 1658 1659 1660 1661
    \defgroup CMSIS_Core_SysTickFunctions SysTick Functions
    \brief      Functions that configure the System.
  @{
 */

#if (__Vendor_SysTickConfig == 0)

Y
yanmowudi 已提交
1662
    /** \brief  System Tick Configuration
W
whsj2 已提交
1663 1664 1665 1666 1667 1668 1669 1670 1671 1672 1673 1674 1675 1676

    The function initializes the System Timer and its interrupt, and starts the System Tick Timer.
    Counter is in free running mode to generate periodic interrupts.

    \param [in]  ticks  Number of ticks between two interrupts.

    \return          0  Function succeeded.
    \return          1  Function failed.

    \note     When the variable <b>__Vendor_SysTickConfig</b> is set to 1, then the
    function <b>SysTick_Config</b> is not included. In this case, the file <b><i>device</i>.h</b>
    must contain a vendor-specific implementation of this function.

 */
Y
yanmowudi 已提交
1677 1678 1679 1680 1681 1682 1683 1684 1685 1686 1687 1688 1689
    __STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks)
    {
        if ((ticks - 1) > SysTick_LOAD_RELOAD_Msk)
            return (1); /* Reload value impossible */

        SysTick->LOAD = ticks - 1;                                   /* set reload register */
        NVIC_SetPriority(SysTick_IRQn, (1 << __NVIC_PRIO_BITS) - 1); /* set Priority for Systick Interrupt */
        SysTick->VAL = 0;                                            /* Load the SysTick Counter Value */
        SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk |
                        SysTick_CTRL_TICKINT_Msk |
                        SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */
        return (0);                              /* Function successful */
    }
W
whsj2 已提交
1690 1691 1692

#endif

Y
yanmowudi 已提交
1693
    /*@} end of CMSIS_Core_SysTickFunctions */
W
whsj2 已提交
1694

Y
yanmowudi 已提交
1695 1696
    /* ##################################### Debug In/Output function ########################################### */
    /** \ingroup  CMSIS_Core_FunctionInterface
W
whsj2 已提交
1697 1698 1699 1700 1701
    \defgroup CMSIS_core_DebugFunctions ITM Functions
    \brief   Functions that access the ITM debug interface.
  @{
 */

Y
yanmowudi 已提交
1702 1703
    extern volatile int32_t ITM_RxBuffer; /*!< External variable to receive characters.                         */
#define ITM_RXBUFFER_EMPTY 0x5AA55AA5     /*!< Value identifying \ref ITM_RxBuffer is ready for next character. */
W
whsj2 已提交
1704

Y
yanmowudi 已提交
1705
    /** \brief  ITM Send Character
W
whsj2 已提交
1706 1707 1708 1709 1710 1711 1712 1713 1714

    The function transmits a character via the ITM channel 0, and
    \li Just returns when no debugger is connected that has booked the output.
    \li Is blocking when a debugger is connected, but the previous character sent has not been transmitted.

    \param [in]     ch  Character to transmit.

    \returns            Character to transmit.
 */
Y
yanmowudi 已提交
1715 1716 1717 1718 1719 1720 1721 1722 1723 1724 1725 1726 1727
    __STATIC_INLINE uint32_t ITM_SendChar(uint32_t ch)
    {
        if ((ITM->TCR & ITM_TCR_ITMENA_Msk) && /* ITM enabled */
            (ITM->TER & (1UL << 0)))           /* ITM Port #0 enabled */
        {
            while (ITM->PORT[0].u32 == 0)
                ;
            ITM->PORT[0].u8 = (uint8_t)ch;
        }
        return (ch);
    }

    /** \brief  ITM Receive Character
W
whsj2 已提交
1728 1729 1730 1731 1732 1733

    The function inputs a character via the external variable \ref ITM_RxBuffer.

    \return             Received character.
    \return         -1  No character pending.
 */
Y
yanmowudi 已提交
1734 1735 1736
    __STATIC_INLINE int32_t ITM_ReceiveChar(void)
    {
        int32_t ch = -1; /* no character available */
W
whsj2 已提交
1737

Y
yanmowudi 已提交
1738 1739 1740 1741 1742
        if (ITM_RxBuffer != ITM_RXBUFFER_EMPTY)
        {
            ch = ITM_RxBuffer;
            ITM_RxBuffer = ITM_RXBUFFER_EMPTY; /* ready for next character */
        }
W
whsj2 已提交
1743

Y
yanmowudi 已提交
1744 1745
        return (ch);
    }
W
whsj2 已提交
1746

Y
yanmowudi 已提交
1747
    /** \brief  ITM Check Character
W
whsj2 已提交
1748 1749 1750 1751 1752 1753

    The function checks whether a character is pending for reading in the variable \ref ITM_RxBuffer.

    \return          0  No character available.
    \return          1  Character available.
 */
Y
yanmowudi 已提交
1754 1755 1756 1757 1758 1759 1760 1761 1762 1763 1764 1765 1766 1767
    __STATIC_INLINE int32_t ITM_CheckChar(void)
    {

        if (ITM_RxBuffer == ITM_RXBUFFER_EMPTY)
        {
            return (0); /* no character available */
        }
        else
        {
            return (1); /*    character available */
        }
    }

    /*@} end of CMSIS_core_DebugFunctions */
W
whsj2 已提交
1768 1769 1770 1771 1772 1773 1774 1775

#ifdef __cplusplus
}
#endif

#endif /* __CORE_CM4_H_DEPENDANT */

#endif /* __CMSIS_GENERIC */