|
|
|
@ -1,13 +1,13 @@
|
|
|
|
|
/**************************************************************************//**
|
|
|
|
|
* @file core_cm3.h
|
|
|
|
|
* @brief CMSIS Cortex-M3 Core Peripheral Access Layer Header File
|
|
|
|
|
* @version V4.00
|
|
|
|
|
* @date 22. August 2014
|
|
|
|
|
* @version V4.10
|
|
|
|
|
* @date 18. March 2015
|
|
|
|
|
*
|
|
|
|
|
* @note
|
|
|
|
|
*
|
|
|
|
|
******************************************************************************/
|
|
|
|
|
/* Copyright (c) 2009 - 2014 ARM LIMITED
|
|
|
|
|
/* Copyright (c) 2009 - 2015 ARM LIMITED
|
|
|
|
|
|
|
|
|
|
All rights reserved.
|
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
@ -232,13 +232,7 @@ typedef union
|
|
|
|
|
{
|
|
|
|
|
struct
|
|
|
|
|
{
|
|
|
|
|
#if (__CORTEX_M != 0x04)
|
|
|
|
|
uint32_t _reserved0:27; /*!< bit: 0..26 Reserved */
|
|
|
|
|
#else
|
|
|
|
|
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 */
|
|
|
|
|
#endif
|
|
|
|
|
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 */
|
|
|
|
@ -248,6 +242,22 @@ typedef union
|
|
|
|
|
uint32_t w; /*!< Type used for word access */
|
|
|
|
|
} APSR_Type;
|
|
|
|
|
|
|
|
|
|
/* APSR Register Definitions */
|
|
|
|
|
#define APSR_N_Pos 31 /*!< APSR: N Position */
|
|
|
|
|
#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */
|
|
|
|
|
|
|
|
|
|
#define APSR_Z_Pos 30 /*!< APSR: Z Position */
|
|
|
|
|
#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */
|
|
|
|
|
|
|
|
|
|
#define APSR_C_Pos 29 /*!< APSR: C Position */
|
|
|
|
|
#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */
|
|
|
|
|
|
|
|
|
|
#define APSR_V_Pos 28 /*!< APSR: V Position */
|
|
|
|
|
#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */
|
|
|
|
|
|
|
|
|
|
#define APSR_Q_Pos 27 /*!< APSR: Q Position */
|
|
|
|
|
#define APSR_Q_Msk (1UL << APSR_Q_Pos) /*!< APSR: Q Mask */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** \brief Union type to access the Interrupt Program Status Register (IPSR).
|
|
|
|
|
*/
|
|
|
|
@ -261,6 +271,10 @@ typedef union
|
|
|
|
|
uint32_t w; /*!< Type used for word access */
|
|
|
|
|
} IPSR_Type;
|
|
|
|
|
|
|
|
|
|
/* IPSR Register Definitions */
|
|
|
|
|
#define IPSR_ISR_Pos 0 /*!< IPSR: ISR Position */
|
|
|
|
|
#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** \brief Union type to access the Special-Purpose Program Status Registers (xPSR).
|
|
|
|
|
*/
|
|
|
|
@ -269,13 +283,7 @@ typedef union
|
|
|
|
|
struct
|
|
|
|
|
{
|
|
|
|
|
uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */
|
|
|
|
|
#if (__CORTEX_M != 0x04)
|
|
|
|
|
uint32_t _reserved0:15; /*!< bit: 9..23 Reserved */
|
|
|
|
|
#else
|
|
|
|
|
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 */
|
|
|
|
|
#endif
|
|
|
|
|
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 */
|
|
|
|
@ -287,6 +295,31 @@ typedef union
|
|
|
|
|
uint32_t w; /*!< Type used for word access */
|
|
|
|
|
} xPSR_Type;
|
|
|
|
|
|
|
|
|
|
/* xPSR Register Definitions */
|
|
|
|
|
#define xPSR_N_Pos 31 /*!< xPSR: N Position */
|
|
|
|
|
#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */
|
|
|
|
|
|
|
|
|
|
#define xPSR_Z_Pos 30 /*!< xPSR: Z Position */
|
|
|
|
|
#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */
|
|
|
|
|
|
|
|
|
|
#define xPSR_C_Pos 29 /*!< xPSR: C Position */
|
|
|
|
|
#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */
|
|
|
|
|
|
|
|
|
|
#define xPSR_V_Pos 28 /*!< xPSR: V Position */
|
|
|
|
|
#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */
|
|
|
|
|
|
|
|
|
|
#define xPSR_Q_Pos 27 /*!< xPSR: Q Position */
|
|
|
|
|
#define xPSR_Q_Msk (1UL << xPSR_Q_Pos) /*!< xPSR: Q Mask */
|
|
|
|
|
|
|
|
|
|
#define xPSR_IT_Pos 25 /*!< xPSR: IT Position */
|
|
|
|
|
#define xPSR_IT_Msk (3UL << xPSR_IT_Pos) /*!< xPSR: IT Mask */
|
|
|
|
|
|
|
|
|
|
#define xPSR_T_Pos 24 /*!< xPSR: T Position */
|
|
|
|
|
#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */
|
|
|
|
|
|
|
|
|
|
#define xPSR_ISR_Pos 0 /*!< xPSR: ISR Position */
|
|
|
|
|
#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** \brief Union type to access the Control Registers (CONTROL).
|
|
|
|
|
*/
|
|
|
|
@ -296,12 +329,18 @@ typedef union
|
|
|
|
|
{
|
|
|
|
|
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 */
|
|
|
|
|
uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */
|
|
|
|
|
} b; /*!< Structure used for bit access */
|
|
|
|
|
uint32_t w; /*!< Type used for word access */
|
|
|
|
|
} CONTROL_Type;
|
|
|
|
|
|
|
|
|
|
/* CONTROL Register Definitions */
|
|
|
|
|
#define CONTROL_SPSEL_Pos 1 /*!< CONTROL: SPSEL Position */
|
|
|
|
|
#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */
|
|
|
|
|
|
|
|
|
|
#define CONTROL_nPRIV_Pos 0 /*!< CONTROL: nPRIV Position */
|
|
|
|
|
#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */
|
|
|
|
|
|
|
|
|
|
/*@} end of group CMSIS_CORE */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -332,7 +371,7 @@ typedef struct
|
|
|
|
|
|
|
|
|
|
/* Software Triggered Interrupt Register Definitions */
|
|
|
|
|
#define NVIC_STIR_INTID_Pos 0 /*!< STIR: INTLINESNUM Position */
|
|
|
|
|
#define NVIC_STIR_INTID_Msk (0x1FFUL << NVIC_STIR_INTID_Pos) /*!< STIR: INTLINESNUM Mask */
|
|
|
|
|
#define NVIC_STIR_INTID_Msk (0x1FFUL /*<< NVIC_STIR_INTID_Pos*/) /*!< STIR: INTLINESNUM Mask */
|
|
|
|
|
|
|
|
|
|
/*@} end of group CMSIS_NVIC */
|
|
|
|
|
|
|
|
|
@ -384,7 +423,7 @@ typedef struct
|
|
|
|
|
#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */
|
|
|
|
|
|
|
|
|
|
#define SCB_CPUID_REVISION_Pos 0 /*!< SCB CPUID: REVISION Position */
|
|
|
|
|
#define SCB_CPUID_REVISION_Msk (0xFUL << SCB_CPUID_REVISION_Pos) /*!< SCB CPUID: REVISION Mask */
|
|
|
|
|
#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */
|
|
|
|
|
|
|
|
|
|
/* SCB Interrupt Control State Register Definitions */
|
|
|
|
|
#define SCB_ICSR_NMIPENDSET_Pos 31 /*!< SCB ICSR: NMIPENDSET Position */
|
|
|
|
@ -415,7 +454,7 @@ typedef struct
|
|
|
|
|
#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */
|
|
|
|
|
|
|
|
|
|
#define SCB_ICSR_VECTACTIVE_Pos 0 /*!< SCB ICSR: VECTACTIVE Position */
|
|
|
|
|
#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL << SCB_ICSR_VECTACTIVE_Pos) /*!< SCB ICSR: VECTACTIVE Mask */
|
|
|
|
|
#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */
|
|
|
|
|
|
|
|
|
|
/* SCB Vector Table Offset Register Definitions */
|
|
|
|
|
#if (__CM3_REV < 0x0201) /* core r2p1 */
|
|
|
|
@ -449,7 +488,7 @@ typedef struct
|
|
|
|
|
#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */
|
|
|
|
|
|
|
|
|
|
#define SCB_AIRCR_VECTRESET_Pos 0 /*!< SCB AIRCR: VECTRESET Position */
|
|
|
|
|
#define SCB_AIRCR_VECTRESET_Msk (1UL << SCB_AIRCR_VECTRESET_Pos) /*!< SCB AIRCR: VECTRESET Mask */
|
|
|
|
|
#define SCB_AIRCR_VECTRESET_Msk (1UL /*<< SCB_AIRCR_VECTRESET_Pos*/) /*!< SCB AIRCR: VECTRESET Mask */
|
|
|
|
|
|
|
|
|
|
/* SCB System Control Register Definitions */
|
|
|
|
|
#define SCB_SCR_SEVONPEND_Pos 4 /*!< SCB SCR: SEVONPEND Position */
|
|
|
|
@ -478,7 +517,7 @@ typedef struct
|
|
|
|
|
#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */
|
|
|
|
|
|
|
|
|
|
#define SCB_CCR_NONBASETHRDENA_Pos 0 /*!< SCB CCR: NONBASETHRDENA Position */
|
|
|
|
|
#define SCB_CCR_NONBASETHRDENA_Msk (1UL << SCB_CCR_NONBASETHRDENA_Pos) /*!< SCB CCR: NONBASETHRDENA Mask */
|
|
|
|
|
#define SCB_CCR_NONBASETHRDENA_Msk (1UL /*<< SCB_CCR_NONBASETHRDENA_Pos*/) /*!< SCB CCR: NONBASETHRDENA Mask */
|
|
|
|
|
|
|
|
|
|
/* SCB System Handler Control and State Register Definitions */
|
|
|
|
|
#define SCB_SHCSR_USGFAULTENA_Pos 18 /*!< SCB SHCSR: USGFAULTENA Position */
|
|
|
|
@ -521,7 +560,7 @@ typedef struct
|
|
|
|
|
#define SCB_SHCSR_BUSFAULTACT_Msk (1UL << SCB_SHCSR_BUSFAULTACT_Pos) /*!< SCB SHCSR: BUSFAULTACT Mask */
|
|
|
|
|
|
|
|
|
|
#define SCB_SHCSR_MEMFAULTACT_Pos 0 /*!< SCB SHCSR: MEMFAULTACT Position */
|
|
|
|
|
#define SCB_SHCSR_MEMFAULTACT_Msk (1UL << SCB_SHCSR_MEMFAULTACT_Pos) /*!< SCB SHCSR: MEMFAULTACT Mask */
|
|
|
|
|
#define SCB_SHCSR_MEMFAULTACT_Msk (1UL /*<< SCB_SHCSR_MEMFAULTACT_Pos*/) /*!< SCB SHCSR: MEMFAULTACT Mask */
|
|
|
|
|
|
|
|
|
|
/* SCB Configurable Fault Status Registers Definitions */
|
|
|
|
|
#define SCB_CFSR_USGFAULTSR_Pos 16 /*!< SCB CFSR: Usage Fault Status Register Position */
|
|
|
|
@ -531,7 +570,7 @@ typedef struct
|
|
|
|
|
#define SCB_CFSR_BUSFAULTSR_Msk (0xFFUL << SCB_CFSR_BUSFAULTSR_Pos) /*!< SCB CFSR: Bus Fault Status Register Mask */
|
|
|
|
|
|
|
|
|
|
#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 */
|
|
|
|
|
#define SCB_CFSR_MEMFAULTSR_Msk (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/) /*!< SCB CFSR: Memory Manage Fault Status Register Mask */
|
|
|
|
|
|
|
|
|
|
/* SCB Hard Fault Status Registers Definitions */
|
|
|
|
|
#define SCB_HFSR_DEBUGEVT_Pos 31 /*!< SCB HFSR: DEBUGEVT Position */
|
|
|
|
@ -557,7 +596,7 @@ typedef struct
|
|
|
|
|
#define SCB_DFSR_BKPT_Msk (1UL << SCB_DFSR_BKPT_Pos) /*!< SCB DFSR: BKPT Mask */
|
|
|
|
|
|
|
|
|
|
#define SCB_DFSR_HALTED_Pos 0 /*!< SCB DFSR: HALTED Position */
|
|
|
|
|
#define SCB_DFSR_HALTED_Msk (1UL << SCB_DFSR_HALTED_Pos) /*!< SCB DFSR: HALTED Mask */
|
|
|
|
|
#define SCB_DFSR_HALTED_Msk (1UL /*<< SCB_DFSR_HALTED_Pos*/) /*!< SCB DFSR: HALTED Mask */
|
|
|
|
|
|
|
|
|
|
/*@} end of group CMSIS_SCB */
|
|
|
|
|
|
|
|
|
@ -583,7 +622,7 @@ typedef struct
|
|
|
|
|
|
|
|
|
|
/* Interrupt Controller Type Register Definitions */
|
|
|
|
|
#define SCnSCB_ICTR_INTLINESNUM_Pos 0 /*!< ICTR: INTLINESNUM Position */
|
|
|
|
|
#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL << SCnSCB_ICTR_INTLINESNUM_Pos) /*!< ICTR: INTLINESNUM Mask */
|
|
|
|
|
#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL /*<< SCnSCB_ICTR_INTLINESNUM_Pos*/) /*!< ICTR: INTLINESNUM Mask */
|
|
|
|
|
|
|
|
|
|
/* Auxiliary Control Register Definitions */
|
|
|
|
|
|
|
|
|
@ -594,7 +633,7 @@ typedef struct
|
|
|
|
|
#define SCnSCB_ACTLR_DISDEFWBUF_Msk (1UL << SCnSCB_ACTLR_DISDEFWBUF_Pos) /*!< ACTLR: DISDEFWBUF Mask */
|
|
|
|
|
|
|
|
|
|
#define SCnSCB_ACTLR_DISMCYCINT_Pos 0 /*!< ACTLR: DISMCYCINT Position */
|
|
|
|
|
#define SCnSCB_ACTLR_DISMCYCINT_Msk (1UL << SCnSCB_ACTLR_DISMCYCINT_Pos) /*!< ACTLR: DISMCYCINT Mask */
|
|
|
|
|
#define SCnSCB_ACTLR_DISMCYCINT_Msk (1UL /*<< SCnSCB_ACTLR_DISMCYCINT_Pos*/) /*!< ACTLR: DISMCYCINT Mask */
|
|
|
|
|
|
|
|
|
|
/*@} end of group CMSIS_SCnotSCB */
|
|
|
|
|
|
|
|
|
@ -626,15 +665,15 @@ typedef struct
|
|
|
|
|
#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */
|
|
|
|
|
|
|
|
|
|
#define SysTick_CTRL_ENABLE_Pos 0 /*!< SysTick CTRL: ENABLE Position */
|
|
|
|
|
#define SysTick_CTRL_ENABLE_Msk (1UL << SysTick_CTRL_ENABLE_Pos) /*!< SysTick CTRL: ENABLE Mask */
|
|
|
|
|
#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */
|
|
|
|
|
|
|
|
|
|
/* SysTick Reload Register Definitions */
|
|
|
|
|
#define SysTick_LOAD_RELOAD_Pos 0 /*!< SysTick LOAD: RELOAD Position */
|
|
|
|
|
#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL << SysTick_LOAD_RELOAD_Pos) /*!< SysTick LOAD: RELOAD Mask */
|
|
|
|
|
#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */
|
|
|
|
|
|
|
|
|
|
/* SysTick Current Register Definitions */
|
|
|
|
|
#define SysTick_VAL_CURRENT_Pos 0 /*!< SysTick VAL: CURRENT Position */
|
|
|
|
|
#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL << SysTick_VAL_CURRENT_Pos) /*!< SysTick VAL: CURRENT Mask */
|
|
|
|
|
#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */
|
|
|
|
|
|
|
|
|
|
/* SysTick Calibration Register Definitions */
|
|
|
|
|
#define SysTick_CALIB_NOREF_Pos 31 /*!< SysTick CALIB: NOREF Position */
|
|
|
|
@ -644,7 +683,7 @@ typedef struct
|
|
|
|
|
#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */
|
|
|
|
|
|
|
|
|
|
#define SysTick_CALIB_TENMS_Pos 0 /*!< SysTick CALIB: TENMS Position */
|
|
|
|
|
#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL << SysTick_CALIB_TENMS_Pos) /*!< SysTick CALIB: TENMS Mask */
|
|
|
|
|
#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */
|
|
|
|
|
|
|
|
|
|
/*@} end of group CMSIS_SysTick */
|
|
|
|
|
|
|
|
|
@ -695,7 +734,7 @@ typedef struct
|
|
|
|
|
|
|
|
|
|
/* ITM Trace Privilege Register Definitions */
|
|
|
|
|
#define ITM_TPR_PRIVMASK_Pos 0 /*!< ITM TPR: PRIVMASK Position */
|
|
|
|
|
#define ITM_TPR_PRIVMASK_Msk (0xFUL << ITM_TPR_PRIVMASK_Pos) /*!< ITM TPR: PRIVMASK Mask */
|
|
|
|
|
#define ITM_TPR_PRIVMASK_Msk (0xFUL /*<< ITM_TPR_PRIVMASK_Pos*/) /*!< ITM TPR: PRIVMASK Mask */
|
|
|
|
|
|
|
|
|
|
/* ITM Trace Control Register Definitions */
|
|
|
|
|
#define ITM_TCR_BUSY_Pos 23 /*!< ITM TCR: BUSY Position */
|
|
|
|
@ -723,19 +762,19 @@ typedef struct
|
|
|
|
|
#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos) /*!< ITM TCR: TSENA Mask */
|
|
|
|
|
|
|
|
|
|
#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 */
|
|
|
|
|
#define ITM_TCR_ITMENA_Msk (1UL /*<< ITM_TCR_ITMENA_Pos*/) /*!< ITM TCR: ITM Enable bit Mask */
|
|
|
|
|
|
|
|
|
|
/* ITM Integration Write Register Definitions */
|
|
|
|
|
#define ITM_IWR_ATVALIDM_Pos 0 /*!< ITM IWR: ATVALIDM Position */
|
|
|
|
|
#define ITM_IWR_ATVALIDM_Msk (1UL << ITM_IWR_ATVALIDM_Pos) /*!< ITM IWR: ATVALIDM Mask */
|
|
|
|
|
#define ITM_IWR_ATVALIDM_Msk (1UL /*<< ITM_IWR_ATVALIDM_Pos*/) /*!< ITM IWR: ATVALIDM Mask */
|
|
|
|
|
|
|
|
|
|
/* ITM Integration Read Register Definitions */
|
|
|
|
|
#define ITM_IRR_ATREADYM_Pos 0 /*!< ITM IRR: ATREADYM Position */
|
|
|
|
|
#define ITM_IRR_ATREADYM_Msk (1UL << ITM_IRR_ATREADYM_Pos) /*!< ITM IRR: ATREADYM Mask */
|
|
|
|
|
#define ITM_IRR_ATREADYM_Msk (1UL /*<< ITM_IRR_ATREADYM_Pos*/) /*!< ITM IRR: ATREADYM Mask */
|
|
|
|
|
|
|
|
|
|
/* ITM Integration Mode Control Register Definitions */
|
|
|
|
|
#define ITM_IMCR_INTEGRATION_Pos 0 /*!< ITM IMCR: INTEGRATION Position */
|
|
|
|
|
#define ITM_IMCR_INTEGRATION_Msk (1UL << ITM_IMCR_INTEGRATION_Pos) /*!< ITM IMCR: INTEGRATION Mask */
|
|
|
|
|
#define ITM_IMCR_INTEGRATION_Msk (1UL /*<< ITM_IMCR_INTEGRATION_Pos*/) /*!< ITM IMCR: INTEGRATION Mask */
|
|
|
|
|
|
|
|
|
|
/* ITM Lock Status Register Definitions */
|
|
|
|
|
#define ITM_LSR_ByteAcc_Pos 2 /*!< ITM LSR: ByteAcc Position */
|
|
|
|
@ -745,7 +784,7 @@ typedef struct
|
|
|
|
|
#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos) /*!< ITM LSR: Access Mask */
|
|
|
|
|
|
|
|
|
|
#define ITM_LSR_Present_Pos 0 /*!< ITM LSR: Present Position */
|
|
|
|
|
#define ITM_LSR_Present_Msk (1UL << ITM_LSR_Present_Pos) /*!< ITM LSR: Present Mask */
|
|
|
|
|
#define ITM_LSR_Present_Msk (1UL /*<< ITM_LSR_Present_Pos*/) /*!< ITM LSR: Present Mask */
|
|
|
|
|
|
|
|
|
|
/*@}*/ /* end of group CMSIS_ITM */
|
|
|
|
|
|
|
|
|
@ -838,31 +877,31 @@ typedef struct
|
|
|
|
|
#define DWT_CTRL_POSTPRESET_Msk (0xFUL << DWT_CTRL_POSTPRESET_Pos) /*!< DWT CTRL: POSTPRESET Mask */
|
|
|
|
|
|
|
|
|
|
#define DWT_CTRL_CYCCNTENA_Pos 0 /*!< DWT CTRL: CYCCNTENA Position */
|
|
|
|
|
#define DWT_CTRL_CYCCNTENA_Msk (0x1UL << DWT_CTRL_CYCCNTENA_Pos) /*!< DWT CTRL: CYCCNTENA Mask */
|
|
|
|
|
#define DWT_CTRL_CYCCNTENA_Msk (0x1UL /*<< DWT_CTRL_CYCCNTENA_Pos*/) /*!< DWT CTRL: CYCCNTENA Mask */
|
|
|
|
|
|
|
|
|
|
/* DWT CPI Count Register Definitions */
|
|
|
|
|
#define DWT_CPICNT_CPICNT_Pos 0 /*!< DWT CPICNT: CPICNT Position */
|
|
|
|
|
#define DWT_CPICNT_CPICNT_Msk (0xFFUL << DWT_CPICNT_CPICNT_Pos) /*!< DWT CPICNT: CPICNT Mask */
|
|
|
|
|
#define DWT_CPICNT_CPICNT_Msk (0xFFUL /*<< DWT_CPICNT_CPICNT_Pos*/) /*!< DWT CPICNT: CPICNT Mask */
|
|
|
|
|
|
|
|
|
|
/* DWT Exception Overhead Count Register Definitions */
|
|
|
|
|
#define DWT_EXCCNT_EXCCNT_Pos 0 /*!< DWT EXCCNT: EXCCNT Position */
|
|
|
|
|
#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL << DWT_EXCCNT_EXCCNT_Pos) /*!< DWT EXCCNT: EXCCNT Mask */
|
|
|
|
|
#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL /*<< DWT_EXCCNT_EXCCNT_Pos*/) /*!< DWT EXCCNT: EXCCNT Mask */
|
|
|
|
|
|
|
|
|
|
/* DWT Sleep Count Register Definitions */
|
|
|
|
|
#define DWT_SLEEPCNT_SLEEPCNT_Pos 0 /*!< DWT SLEEPCNT: SLEEPCNT Position */
|
|
|
|
|
#define DWT_SLEEPCNT_SLEEPCNT_Msk (0xFFUL << DWT_SLEEPCNT_SLEEPCNT_Pos) /*!< DWT SLEEPCNT: SLEEPCNT Mask */
|
|
|
|
|
#define DWT_SLEEPCNT_SLEEPCNT_Msk (0xFFUL /*<< DWT_SLEEPCNT_SLEEPCNT_Pos*/) /*!< DWT SLEEPCNT: SLEEPCNT Mask */
|
|
|
|
|
|
|
|
|
|
/* DWT LSU Count Register Definitions */
|
|
|
|
|
#define DWT_LSUCNT_LSUCNT_Pos 0 /*!< DWT LSUCNT: LSUCNT Position */
|
|
|
|
|
#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL << DWT_LSUCNT_LSUCNT_Pos) /*!< DWT LSUCNT: LSUCNT Mask */
|
|
|
|
|
#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL /*<< DWT_LSUCNT_LSUCNT_Pos*/) /*!< DWT LSUCNT: LSUCNT Mask */
|
|
|
|
|
|
|
|
|
|
/* DWT Folded-instruction Count Register Definitions */
|
|
|
|
|
#define DWT_FOLDCNT_FOLDCNT_Pos 0 /*!< DWT FOLDCNT: FOLDCNT Position */
|
|
|
|
|
#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL << DWT_FOLDCNT_FOLDCNT_Pos) /*!< DWT FOLDCNT: FOLDCNT Mask */
|
|
|
|
|
#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL /*<< DWT_FOLDCNT_FOLDCNT_Pos*/) /*!< DWT FOLDCNT: FOLDCNT Mask */
|
|
|
|
|
|
|
|
|
|
/* DWT Comparator Mask Register Definitions */
|
|
|
|
|
#define DWT_MASK_MASK_Pos 0 /*!< DWT MASK: MASK Position */
|
|
|
|
|
#define DWT_MASK_MASK_Msk (0x1FUL << DWT_MASK_MASK_Pos) /*!< DWT MASK: MASK Mask */
|
|
|
|
|
#define DWT_MASK_MASK_Msk (0x1FUL /*<< DWT_MASK_MASK_Pos*/) /*!< DWT MASK: MASK Mask */
|
|
|
|
|
|
|
|
|
|
/* DWT Comparator Function Register Definitions */
|
|
|
|
|
#define DWT_FUNCTION_MATCHED_Pos 24 /*!< DWT FUNCTION: MATCHED Position */
|
|
|
|
@ -890,7 +929,7 @@ typedef struct
|
|
|
|
|
#define DWT_FUNCTION_EMITRANGE_Msk (0x1UL << DWT_FUNCTION_EMITRANGE_Pos) /*!< DWT FUNCTION: EMITRANGE Mask */
|
|
|
|
|
|
|
|
|
|
#define DWT_FUNCTION_FUNCTION_Pos 0 /*!< DWT FUNCTION: FUNCTION Position */
|
|
|
|
|
#define DWT_FUNCTION_FUNCTION_Msk (0xFUL << DWT_FUNCTION_FUNCTION_Pos) /*!< DWT FUNCTION: FUNCTION Mask */
|
|
|
|
|
#define DWT_FUNCTION_FUNCTION_Msk (0xFUL /*<< DWT_FUNCTION_FUNCTION_Pos*/) /*!< DWT FUNCTION: FUNCTION Mask */
|
|
|
|
|
|
|
|
|
|
/*@}*/ /* end of group CMSIS_DWT */
|
|
|
|
|
|
|
|
|
@ -933,11 +972,11 @@ typedef struct
|
|
|
|
|
|
|
|
|
|
/* TPI Asynchronous Clock Prescaler Register Definitions */
|
|
|
|
|
#define TPI_ACPR_PRESCALER_Pos 0 /*!< TPI ACPR: PRESCALER Position */
|
|
|
|
|
#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL << TPI_ACPR_PRESCALER_Pos) /*!< TPI ACPR: PRESCALER Mask */
|
|
|
|
|
#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL /*<< TPI_ACPR_PRESCALER_Pos*/) /*!< TPI ACPR: PRESCALER Mask */
|
|
|
|
|
|
|
|
|
|
/* TPI Selected Pin Protocol Register Definitions */
|
|
|
|
|
#define TPI_SPPR_TXMODE_Pos 0 /*!< TPI SPPR: TXMODE Position */
|
|
|
|
|
#define TPI_SPPR_TXMODE_Msk (0x3UL << TPI_SPPR_TXMODE_Pos) /*!< TPI SPPR: TXMODE Mask */
|
|
|
|
|
#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */
|
|
|
|
|
|
|
|
|
|
/* TPI Formatter and Flush Status Register Definitions */
|
|
|
|
|
#define TPI_FFSR_FtNonStop_Pos 3 /*!< TPI FFSR: FtNonStop Position */
|
|
|
|
@ -950,7 +989,7 @@ typedef struct
|
|
|
|
|
#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */
|
|
|
|
|
|
|
|
|
|
#define TPI_FFSR_FlInProg_Pos 0 /*!< TPI FFSR: FlInProg Position */
|
|
|
|
|
#define TPI_FFSR_FlInProg_Msk (0x1UL << TPI_FFSR_FlInProg_Pos) /*!< TPI FFSR: FlInProg Mask */
|
|
|
|
|
#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */
|
|
|
|
|
|
|
|
|
|
/* TPI Formatter and Flush Control Register Definitions */
|
|
|
|
|
#define TPI_FFCR_TrigIn_Pos 8 /*!< TPI FFCR: TrigIn Position */
|
|
|
|
@ -961,7 +1000,7 @@ typedef struct
|
|
|
|
|
|
|
|
|
|
/* TPI TRIGGER Register Definitions */
|
|
|
|
|
#define TPI_TRIGGER_TRIGGER_Pos 0 /*!< TPI TRIGGER: TRIGGER Position */
|
|
|
|
|
#define TPI_TRIGGER_TRIGGER_Msk (0x1UL << TPI_TRIGGER_TRIGGER_Pos) /*!< TPI TRIGGER: TRIGGER Mask */
|
|
|
|
|
#define TPI_TRIGGER_TRIGGER_Msk (0x1UL /*<< TPI_TRIGGER_TRIGGER_Pos*/) /*!< TPI TRIGGER: TRIGGER Mask */
|
|
|
|
|
|
|
|
|
|
/* TPI Integration ETM Data Register Definitions (FIFO0) */
|
|
|
|
|
#define TPI_FIFO0_ITM_ATVALID_Pos 29 /*!< TPI FIFO0: ITM_ATVALID Position */
|
|
|
|
@ -983,11 +1022,11 @@ typedef struct
|
|
|
|
|
#define TPI_FIFO0_ETM1_Msk (0xFFUL << TPI_FIFO0_ETM1_Pos) /*!< TPI FIFO0: ETM1 Mask */
|
|
|
|
|
|
|
|
|
|
#define TPI_FIFO0_ETM0_Pos 0 /*!< TPI FIFO0: ETM0 Position */
|
|
|
|
|
#define TPI_FIFO0_ETM0_Msk (0xFFUL << TPI_FIFO0_ETM0_Pos) /*!< TPI FIFO0: ETM0 Mask */
|
|
|
|
|
#define TPI_FIFO0_ETM0_Msk (0xFFUL /*<< TPI_FIFO0_ETM0_Pos*/) /*!< TPI FIFO0: ETM0 Mask */
|
|
|
|
|
|
|
|
|
|
/* TPI ITATBCTR2 Register Definitions */
|
|
|
|
|
#define TPI_ITATBCTR2_ATREADY_Pos 0 /*!< TPI ITATBCTR2: ATREADY Position */
|
|
|
|
|
#define TPI_ITATBCTR2_ATREADY_Msk (0x1UL << TPI_ITATBCTR2_ATREADY_Pos) /*!< TPI ITATBCTR2: ATREADY Mask */
|
|
|
|
|
#define TPI_ITATBCTR2_ATREADY_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY_Pos*/) /*!< TPI ITATBCTR2: ATREADY Mask */
|
|
|
|
|
|
|
|
|
|
/* TPI Integration ITM Data Register Definitions (FIFO1) */
|
|
|
|
|
#define TPI_FIFO1_ITM_ATVALID_Pos 29 /*!< TPI FIFO1: ITM_ATVALID Position */
|
|
|
|
@ -1009,15 +1048,15 @@ typedef struct
|
|
|
|
|
#define TPI_FIFO1_ITM1_Msk (0xFFUL << TPI_FIFO1_ITM1_Pos) /*!< TPI FIFO1: ITM1 Mask */
|
|
|
|
|
|
|
|
|
|
#define TPI_FIFO1_ITM0_Pos 0 /*!< TPI FIFO1: ITM0 Position */
|
|
|
|
|
#define TPI_FIFO1_ITM0_Msk (0xFFUL << TPI_FIFO1_ITM0_Pos) /*!< TPI FIFO1: ITM0 Mask */
|
|
|
|
|
#define TPI_FIFO1_ITM0_Msk (0xFFUL /*<< TPI_FIFO1_ITM0_Pos*/) /*!< TPI FIFO1: ITM0 Mask */
|
|
|
|
|
|
|
|
|
|
/* TPI ITATBCTR0 Register Definitions */
|
|
|
|
|
#define TPI_ITATBCTR0_ATREADY_Pos 0 /*!< TPI ITATBCTR0: ATREADY Position */
|
|
|
|
|
#define TPI_ITATBCTR0_ATREADY_Msk (0x1UL << TPI_ITATBCTR0_ATREADY_Pos) /*!< TPI ITATBCTR0: ATREADY Mask */
|
|
|
|
|
#define TPI_ITATBCTR0_ATREADY_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY_Pos*/) /*!< TPI ITATBCTR0: ATREADY Mask */
|
|
|
|
|
|
|
|
|
|
/* TPI Integration Mode Control Register Definitions */
|
|
|
|
|
#define TPI_ITCTRL_Mode_Pos 0 /*!< TPI ITCTRL: Mode Position */
|
|
|
|
|
#define TPI_ITCTRL_Mode_Msk (0x1UL << TPI_ITCTRL_Mode_Pos) /*!< TPI ITCTRL: Mode Mask */
|
|
|
|
|
#define TPI_ITCTRL_Mode_Msk (0x1UL /*<< TPI_ITCTRL_Mode_Pos*/) /*!< TPI ITCTRL: Mode Mask */
|
|
|
|
|
|
|
|
|
|
/* TPI DEVID Register Definitions */
|
|
|
|
|
#define TPI_DEVID_NRZVALID_Pos 11 /*!< TPI DEVID: NRZVALID Position */
|
|
|
|
@ -1036,15 +1075,15 @@ typedef struct
|
|
|
|
|
#define TPI_DEVID_AsynClkIn_Msk (0x1UL << TPI_DEVID_AsynClkIn_Pos) /*!< TPI DEVID: AsynClkIn Mask */
|
|
|
|
|
|
|
|
|
|
#define TPI_DEVID_NrTraceInput_Pos 0 /*!< TPI DEVID: NrTraceInput Position */
|
|
|
|
|
#define TPI_DEVID_NrTraceInput_Msk (0x1FUL << TPI_DEVID_NrTraceInput_Pos) /*!< TPI DEVID: NrTraceInput Mask */
|
|
|
|
|
#define TPI_DEVID_NrTraceInput_Msk (0x1FUL /*<< TPI_DEVID_NrTraceInput_Pos*/) /*!< TPI DEVID: NrTraceInput Mask */
|
|
|
|
|
|
|
|
|
|
/* TPI DEVTYPE Register Definitions */
|
|
|
|
|
#define TPI_DEVTYPE_SubType_Pos 0 /*!< TPI DEVTYPE: SubType Position */
|
|
|
|
|
#define TPI_DEVTYPE_SubType_Msk (0xFUL << TPI_DEVTYPE_SubType_Pos) /*!< TPI DEVTYPE: SubType Mask */
|
|
|
|
|
|
|
|
|
|
#define TPI_DEVTYPE_MajorType_Pos 4 /*!< TPI DEVTYPE: MajorType Position */
|
|
|
|
|
#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */
|
|
|
|
|
|
|
|
|
|
#define TPI_DEVTYPE_SubType_Pos 0 /*!< TPI DEVTYPE: SubType Position */
|
|
|
|
|
#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */
|
|
|
|
|
|
|
|
|
|
/*@}*/ /* end of group CMSIS_TPI */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -1080,7 +1119,7 @@ typedef struct
|
|
|
|
|
#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */
|
|
|
|
|
|
|
|
|
|
#define MPU_TYPE_SEPARATE_Pos 0 /*!< MPU TYPE: SEPARATE Position */
|
|
|
|
|
#define MPU_TYPE_SEPARATE_Msk (1UL << MPU_TYPE_SEPARATE_Pos) /*!< MPU TYPE: SEPARATE Mask */
|
|
|
|
|
#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */
|
|
|
|
|
|
|
|
|
|
/* MPU Control Register */
|
|
|
|
|
#define MPU_CTRL_PRIVDEFENA_Pos 2 /*!< MPU CTRL: PRIVDEFENA Position */
|
|
|
|
@ -1090,11 +1129,11 @@ typedef struct
|
|
|
|
|
#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */
|
|
|
|
|
|
|
|
|
|
#define MPU_CTRL_ENABLE_Pos 0 /*!< MPU CTRL: ENABLE Position */
|
|
|
|
|
#define MPU_CTRL_ENABLE_Msk (1UL << MPU_CTRL_ENABLE_Pos) /*!< MPU CTRL: ENABLE Mask */
|
|
|
|
|
#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */
|
|
|
|
|
|
|
|
|
|
/* MPU Region Number Register */
|
|
|
|
|
#define MPU_RNR_REGION_Pos 0 /*!< MPU RNR: REGION Position */
|
|
|
|
|
#define MPU_RNR_REGION_Msk (0xFFUL << MPU_RNR_REGION_Pos) /*!< MPU RNR: REGION Mask */
|
|
|
|
|
#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */
|
|
|
|
|
|
|
|
|
|
/* MPU Region Base Address Register */
|
|
|
|
|
#define MPU_RBAR_ADDR_Pos 5 /*!< MPU RBAR: ADDR Position */
|
|
|
|
@ -1104,7 +1143,7 @@ typedef struct
|
|
|
|
|
#define MPU_RBAR_VALID_Msk (1UL << MPU_RBAR_VALID_Pos) /*!< MPU RBAR: VALID Mask */
|
|
|
|
|
|
|
|
|
|
#define MPU_RBAR_REGION_Pos 0 /*!< MPU RBAR: REGION Position */
|
|
|
|
|
#define MPU_RBAR_REGION_Msk (0xFUL << MPU_RBAR_REGION_Pos) /*!< MPU RBAR: REGION Mask */
|
|
|
|
|
#define MPU_RBAR_REGION_Msk (0xFUL /*<< MPU_RBAR_REGION_Pos*/) /*!< MPU RBAR: REGION Mask */
|
|
|
|
|
|
|
|
|
|
/* MPU Region Attribute and Size Register */
|
|
|
|
|
#define MPU_RASR_ATTRS_Pos 16 /*!< MPU RASR: MPU Region Attribute field Position */
|
|
|
|
@ -1135,7 +1174,7 @@ typedef struct
|
|
|
|
|
#define MPU_RASR_SIZE_Msk (0x1FUL << MPU_RASR_SIZE_Pos) /*!< MPU RASR: Region Size Field Mask */
|
|
|
|
|
|
|
|
|
|
#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 */
|
|
|
|
|
#define MPU_RASR_ENABLE_Msk (1UL /*<< MPU_RASR_ENABLE_Pos*/) /*!< MPU RASR: Region enable bit Disable Mask */
|
|
|
|
|
|
|
|
|
|
/*@} end of group CMSIS_MPU */
|
|
|
|
|
#endif
|
|
|
|
@ -1192,14 +1231,14 @@ typedef struct
|
|
|
|
|
#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */
|
|
|
|
|
|
|
|
|
|
#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 */
|
|
|
|
|
#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */
|
|
|
|
|
|
|
|
|
|
/* Debug Core Register Selector Register */
|
|
|
|
|
#define CoreDebug_DCRSR_REGWnR_Pos 16 /*!< CoreDebug DCRSR: REGWnR Position */
|
|
|
|
|
#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */
|
|
|
|
|
|
|
|
|
|
#define CoreDebug_DCRSR_REGSEL_Pos 0 /*!< CoreDebug DCRSR: REGSEL Position */
|
|
|
|
|
#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL << CoreDebug_DCRSR_REGSEL_Pos) /*!< CoreDebug DCRSR: REGSEL Mask */
|
|
|
|
|
#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */
|
|
|
|
|
|
|
|
|
|
/* Debug Exception and Monitor Control Register */
|
|
|
|
|
#define CoreDebug_DEMCR_TRCENA_Pos 24 /*!< CoreDebug DEMCR: TRCENA Position */
|
|
|
|
@ -1239,7 +1278,7 @@ typedef struct
|
|
|
|
|
#define CoreDebug_DEMCR_VC_MMERR_Msk (1UL << CoreDebug_DEMCR_VC_MMERR_Pos) /*!< CoreDebug DEMCR: VC_MMERR Mask */
|
|
|
|
|
|
|
|
|
|
#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 */
|
|
|
|
|
#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */
|
|
|
|
|
|
|
|
|
|
/*@} end of group CMSIS_CoreDebug */
|
|
|
|
|
|
|
|
|
@ -1311,13 +1350,13 @@ typedef struct
|
|
|
|
|
__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 */
|
|
|
|
|
uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */
|
|
|
|
|
|
|
|
|
|
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 */
|
|
|
|
|
reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */
|
|
|
|
|
reg_value = (reg_value |
|
|
|
|
|
((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) |
|
|
|
|
|
(PriorityGroupTmp << 8) ); /* Insert write key and priorty group */
|
|
|
|
|
SCB->AIRCR = reg_value;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -1330,7 +1369,7 @@ __STATIC_INLINE void NVIC_SetPriorityGrouping(uint32_t PriorityGroup)
|
|
|
|
|
*/
|
|
|
|
|
__STATIC_INLINE uint32_t NVIC_GetPriorityGrouping(void)
|
|
|
|
|
{
|
|
|
|
|
return ((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos); /* read priority grouping field */
|
|
|
|
|
return ((uint32_t)((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -1342,7 +1381,7 @@ __STATIC_INLINE uint32_t NVIC_GetPriorityGrouping(void)
|
|
|
|
|
*/
|
|
|
|
|
__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) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)(int32_t)IRQn) & 0x1FUL));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -1354,7 +1393,7 @@ __STATIC_INLINE void NVIC_EnableIRQ(IRQn_Type IRQn)
|
|
|
|
|
*/
|
|
|
|
|
__STATIC_INLINE void NVIC_DisableIRQ(IRQn_Type IRQn)
|
|
|
|
|
{
|
|
|
|
|
NVIC->ICER[((uint32_t)(IRQn) >> 5)] = (1 << ((uint32_t)(IRQn) & 0x1F)); /* disable interrupt */
|
|
|
|
|
NVIC->ICER[(((uint32_t)(int32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)(int32_t)IRQn) & 0x1FUL));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -1370,7 +1409,7 @@ __STATIC_INLINE void NVIC_DisableIRQ(IRQn_Type IRQn)
|
|
|
|
|
*/
|
|
|
|
|
__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 */
|
|
|
|
|
return((uint32_t)(((NVIC->ISPR[(((uint32_t)(int32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)(int32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -1382,7 +1421,7 @@ __STATIC_INLINE uint32_t NVIC_GetPendingIRQ(IRQn_Type IRQn)
|
|
|
|
|
*/
|
|
|
|
|
__STATIC_INLINE void NVIC_SetPendingIRQ(IRQn_Type IRQn)
|
|
|
|
|
{
|
|
|
|
|
NVIC->ISPR[((uint32_t)(IRQn) >> 5)] = (1 << ((uint32_t)(IRQn) & 0x1F)); /* set interrupt pending */
|
|
|
|
|
NVIC->ISPR[(((uint32_t)(int32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)(int32_t)IRQn) & 0x1FUL));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -1394,7 +1433,7 @@ __STATIC_INLINE void NVIC_SetPendingIRQ(IRQn_Type IRQn)
|
|
|
|
|
*/
|
|
|
|
|
__STATIC_INLINE void NVIC_ClearPendingIRQ(IRQn_Type IRQn)
|
|
|
|
|
{
|
|
|
|
|
NVIC->ICPR[((uint32_t)(IRQn) >> 5)] = (1 << ((uint32_t)(IRQn) & 0x1F)); /* Clear pending interrupt */
|
|
|
|
|
NVIC->ICPR[(((uint32_t)(int32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)(int32_t)IRQn) & 0x1FUL));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -1409,7 +1448,7 @@ __STATIC_INLINE void NVIC_ClearPendingIRQ(IRQn_Type IRQn)
|
|
|
|
|
*/
|
|
|
|
|
__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 */
|
|
|
|
|
return((uint32_t)(((NVIC->IABR[(((uint32_t)(int32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)(int32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -1424,10 +1463,12 @@ __STATIC_INLINE uint32_t NVIC_GetActive(IRQn_Type IRQn)
|
|
|
|
|
*/
|
|
|
|
|
__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 */
|
|
|
|
|
if((int32_t)IRQn < 0) {
|
|
|
|
|
SCB->SHP[(((uint32_t)(int32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8 - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL);
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
NVIC->IP[(uint32_t)(IRQn)] = ((priority << (8 - __NVIC_PRIO_BITS)) & 0xff); } /* set Priority for device specific Interrupts */
|
|
|
|
|
NVIC->IP[((uint32_t)(int32_t)IRQn)] = (uint8_t)((priority << (8 - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -1445,10 +1486,12 @@ __STATIC_INLINE void NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority)
|
|
|
|
|
__STATIC_INLINE uint32_t NVIC_GetPriority(IRQn_Type IRQn)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
if(IRQn < 0) {
|
|
|
|
|
return((uint32_t)(SCB->SHP[((uint32_t)(IRQn) & 0xF)- |