644 lines
50 KiB
C
Raw Normal View History

2021-08-06 16:59:04 +08:00
////////////////////////////////////////////////////////////////////////////////
/// @file reg_common.h
/// @author AE TEAM
/// @brief THIS FILE CONTAINS ALL THE FUNCTIONS PROTOTYPES FOR THE SERIES OF
/// MM32 FIRMWARE LIBRARY.
////////////////////////////////////////////////////////////////////////////////
/// @attention
///
/// THE EXISTING FIRMWARE IS ONLY FOR REFERENCE, WHICH IS DESIGNED TO PROVIDE
/// CUSTOMERS WITH CODING INFORMATION ABOUT THEIR PRODUCTS SO THEY CAN SAVE
/// TIME. THEREFORE, MINDMOTION SHALL NOT BE LIABLE FOR ANY DIRECT, INDIRECT OR
/// CONSEQUENTIAL DAMAGES ABOUT ANY CLAIMS ARISING OUT OF THE CONTENT OF SUCH
/// HARDWARE AND/OR THE USE OF THE CODING INFORMATION CONTAINED HEREIN IN
/// CONNECTION WITH PRODUCTS MADE BY CUSTOMERS.
///
/// <H2><CENTER>&COPY; COPYRIGHT MINDMOTION </CENTER></H2>
////////////////////////////////////////////////////////////////////////////////
// Define to prevent recursive inclusion
#ifndef __REG_COMMON_H
#define __REG_COMMON_H
// Files includes
#include <stdint.h>
#include <stdbool.h>
#include "types.h"
#if defined ( __CC_ARM )
#pragma anon_unions
#endif
#ifndef HSE_STARTUP_TIMEOUT
#define HSE_STARTUP_TIMEOUT (0x0500U) ///< Time out for HSE start up.
#endif
#ifdef CUSTOM_HSE_VAL
#ifndef HSE_VALUE
#define HSE_VALUE (12000000U) ///< Value of the External oscillator in Hz.
#endif
#else
#ifndef HSE_VALUE
#define HSE_VALUE (8000000U) ///< Value of the External oscillator in Hz.
#endif
#endif
#define HSI_VALUE_PLL_ON (8000000U) ///< Value of the Internal oscillator in Hz.
#define HSI_DIV6 (8000000U) ///< Value of the Internal oscillator in Hz.
// Value of the Internal oscillator in Hz.
#define LSI_VALUE (40000U) ///< Value of the Internal oscillator in Hz.
#ifndef HSI_VALUE
#define HSI_VALUE (8000000U) ///< Value of the Internal oscillator in Hz.
#endif
#define __MPU_PRESENT (0) ///< Cortex-M3 does not provide a MPU present or not
#ifndef __NVIC_PRIO_BITS
#define __NVIC_PRIO_BITS (4) ///< Cortex-M3 uses 4 Bits for the Priority Levels
//#warning "__NVIC_PRIO_BITS not defined in device header file; using default!"
#endif
#define __Vendor_SysTickConfig (0) ///< Set to 1 if different SysTick Config is used
////////////////////////////////////////////////////////////////////////////////
/// @brief MM32 MCU Interrupt Handle
////////////////////////////////////////////////////////////////////////////////
typedef enum IRQn {
NonMaskableInt_IRQn = -14, ///< 2 Non Maskable Interrupt
MemoryManagement_IRQn = -12, ///< 4 Cortex-M3 Memory Management Interrupt
BusFault_IRQn = -11, ///< 5 Cortex-M3 Bus Fault Interrupt
UsageFault_IRQn = -10, ///< 6 Cortex-M3 Usage Fault Interrupt
SVCall_IRQn = -5, ///< 11 Cortex-M3 SV Call Interrupt
DebugMonitor_IRQn = -4, ///< 12 Cortex-M3 Debug Monitor Interrupt
PendSV_IRQn = -2, ///< 14 Cortex-M3 Pend SV Interrupt
SysTick_IRQn = -1, ///< 15 Cortex-M3 System Tick Interrupt
WWDG_IWDG_IRQn = 0, ///< Watchdog interrupt
WWDG_IRQn = 0, ///< Watchdog interrupt
PVD_IRQn = 1, ///< (PVD) Interrupt
TAMPER_IRQn = 2, ///< Intrusion detection interrupted
RTC_IRQn = 3, ///< Real-time clock (RTC) global interrupt
FLASH_IRQn = 4, ///< Flash global interrupt
RCC_CRS_IRQn = 5, ///< RCC and CRS global interrupt
EXTI0_IRQn = 6, ///< EXTI line 0 interrupt
EXTI1_IRQn = 7, ///< EXTI line 1 interrupt
EXTI2_IRQn = 8, ///< EXTI line 2 interrupt
EXTI3_IRQn = 9, ///< EXTI line 3 interrupted
EXTI4_IRQn = 10, ///< EXTI line 4 interrupt
DMA1_Channel1_IRQn = 11, ///< DMA1 channel 1 global interrupt
DMA1_Channel2_IRQn = 12, ///< DMA1 channel 2 global interrupt
DMA1_Channel3_IRQn = 13, ///< DMA1 channel 3 global interrupt
DMA1_Channel4_IRQn = 14, ///< DMA1 channel 4 global interrupt
DMA1_Channel5_IRQn = 15, ///< DMA1 channel 5 global interrupt
DMA1_Channel6_IRQn = 16, ///< DMA1 channel 6 global interrupt
DMA1_Channel7_IRQn = 17, ///< DMA1 channel 7 global interrupt
ADC1_IRQn = 18, ///< ADC1 global interrupt
ADC1_2_IRQn = 18, ///< ADC1&ADC2 global interrupt
ADC2_IRQn = 18, ///< ADC2 global interrupt
FlashCache_IRQn = 19, ///< FlashCache outage
CAN1_RX_IRQn = 21, ///< CAN1 receive interrupt
CAN_IRQn = 21, ///< CAN interrupt
EXTI9_5_IRQn = 23, ///< EXTI line [9: 5] interrupted
TIM1_BRK_IRQn = 24, ///< TIM1 disconnect interrupt
TIM1_UP_IRQn = 25, ///< TIM1 update interrupt
IM1_TRG_COM_IRQn = 26, ///< TIM1 trigger and communication interrupt
TIM1_CC_IRQn = 27, ///< TIM1 capture compare interrupt
TIM2_IRQn = 28, ///< TIM2 global interrupt
TIM3_IRQn = 29, ///< TIM3 global interrupt
TIM4_IRQn = 30, ///< TIM4 global interrupt
I2C1_IRQn = 31, ///< I2C1 global interrupt
I2C2_IRQn = 33, ///< I2C2 global interrupt
SPI1_IRQn = 35, ///< SPI1 global interrupt
SPI2_IRQn = 36, ///< SPI2 global interrupt
UART1_IRQn = 37, ///< UART1 global interrupt
UART2_IRQn = 38, ///< UART2 global interrupt
UART3_IRQn = 39, ///< UART3 global interrupt
EXTI15_10_IRQn = 40, ///< EXTI line [15: 10] interrupted
RTCAlarm_IRQn = 41, ///< RTC alarm connected to EXTI interrupted
USB_WKUP_IRQn = 42, ///< Wake-up interrupt from USB connected to EXTI
TIM8_BRK_IRQn = 43, ///< TIM8 brake interruption
TIM8_UP_IRQn = 44, ///< TIM8 update interrupt
TIM8_TRG_COM_IRQn = 45, ///< TIM8 trigger, communication interrupt
TIM8_CC_IRQn = 46, ///< TIM8 capture compare interrupt
ADC3_IRQn = 47, ///< ADC3 global interrupt
SDIO_IRQn = 49, ///< SDIO global interrupt
TIM5_IRQn = 50, ///< TIM5 global interrupt
SPI3_IRQn = 51, ///< SPI3 global interrupt
UART4_IRQn = 52, ///< UART4 global interrupt
UART5_IRQn = 53, ///< UART5 global interrupt
TIM6_IRQn = 54, ///< TIM6 global interrupt
TIM7_IRQn = 55, ///< TIM7 global interrupt
DMA2_Channel1_IRQn = 56, ///< DMA2 channel 1 global interrupt
DMA2_Channel2_IRQn = 57, ///< DMA2 channel 2 global interrupt
DMA2_Channel3_IRQn = 58, ///< DMA2 channel 3 global interrupt
DMA2_Channel4_IRQn = 59, ///< DMA2 channel 4 global interrupt
DMA2_Channel5_IRQn = 60, ///< DMA2 channel 5 global interrupt
ETHERNET_MAC_IRQn = 61, ///< ETHERNET global interrupt
COMP1_2_IRQn = 64, ///< Comparator 1/2 interrupt connected to EXTI
USB_FS_IRQn = 67, ///< USB FS global interrupt
UART6_IRQn = 71, ///< UART6 global interrupt
UART7_IRQn = 82, ///< UART7 global interrupt
UART8_IRQn = 83, ///< UART8 global interrupt
} IRQn_Type;
#include <core_cm3.h>
#define PERIPH_BASE (0x40000000U) ///< Peripheral base address in the alias region
#define EEPROM_BASE (0x08100000U) ///< EEPROM base address in the alias region
#define SRAM_BITBAND_BASE (0x22000000U) ///< Peripheral base address in the bit-band region
#define PERIPH_BITBAND_BASE (0x42000000U) ///< SRAM base address in the bit-band region
#define APB1PERIPH_BASE (PERIPH_BASE + 0x00000000)
#define APB2PERIPH_BASE (PERIPH_BASE + 0x00010000)
#define AHBPERIPH_BASE (PERIPH_BASE + 0x00020000)
#define AHB2PERIPH_BASE (PERIPH_BASE + 0x10000000)
#define AHB3PERIPH_BASE (PERIPH_BASE + 0x20000000)
////////////////////////////////////////////////////////////////////////////////
/// @brief UID type pointer Definition
////////////////////////////////////////////////////////////////////////////////
#define UID_BASE (0x1FFFF7E0U) ///< Unique device ID register base address
///////////////////////////////////////////////////////////////////////////////
/// @brief Nested Vectored Interrupt Controller
///////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_ISER Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_ISER_SETENA (0xFFFFFFFFU) ///< Interrupt set enable bits
#define NVIC_ISER_SETENA_0 (0x00000001U) ///< bit 0
#define NVIC_ISER_SETENA_1 (0x00000002U) ///< bit 1
#define NVIC_ISER_SETENA_2 (0x00000004U) ///< bit 2
#define NVIC_ISER_SETENA_3 (0x00000008U) ///< bit 3
#define NVIC_ISER_SETENA_4 (0x00000010U) ///< bit 4
#define NVIC_ISER_SETENA_5 (0x00000020U) ///< bit 5
#define NVIC_ISER_SETENA_6 (0x00000040U) ///< bit 6
#define NVIC_ISER_SETENA_7 (0x00000080U) ///< bit 7
#define NVIC_ISER_SETENA_8 (0x00000100U) ///< bit 8
#define NVIC_ISER_SETENA_9 (0x00000200U) ///< bit 9
#define NVIC_ISER_SETENA_10 (0x00000400U) ///< bit 10
#define NVIC_ISER_SETENA_11 (0x00000800U) ///< bit 11
#define NVIC_ISER_SETENA_12 (0x00001000U) ///< bit 12
#define NVIC_ISER_SETENA_13 (0x00002000U) ///< bit 13
#define NVIC_ISER_SETENA_14 (0x00004000U) ///< bit 14
#define NVIC_ISER_SETENA_15 (0x00008000U) ///< bit 15
#define NVIC_ISER_SETENA_16 (0x00010000U) ///< bit 16
#define NVIC_ISER_SETENA_17 (0x00020000U) ///< bit 17
#define NVIC_ISER_SETENA_18 (0x00040000U) ///< bit 18
#define NVIC_ISER_SETENA_19 (0x00080000U) ///< bit 19
#define NVIC_ISER_SETENA_20 (0x00100000U) ///< bit 20
#define NVIC_ISER_SETENA_21 (0x00200000U) ///< bit 21
#define NVIC_ISER_SETENA_22 (0x00400000U) ///< bit 22
#define NVIC_ISER_SETENA_23 (0x00800000U) ///< bit 23
#define NVIC_ISER_SETENA_24 (0x01000000U) ///< bit 24
#define NVIC_ISER_SETENA_25 (0x02000000U) ///< bit 25
#define NVIC_ISER_SETENA_26 (0x04000000U) ///< bit 26
#define NVIC_ISER_SETENA_27 (0x08000000U) ///< bit 27
#define NVIC_ISER_SETENA_28 (0x10000000U) ///< bit 28
#define NVIC_ISER_SETENA_29 (0x20000000U) ///< bit 29
#define NVIC_ISER_SETENA_30 (0x40000000U) ///< bit 30
#define NVIC_ISER_SETENA_31 (0x80000000U) ///< bit 31
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_ICER Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_ICER_CLRENA (0xFFFFFFFFU) ///< Interrupt clear-enable bits
#define NVIC_ICER_CLRENA_0 (0x00000001U) ///< bit 0
#define NVIC_ICER_CLRENA_1 (0x00000002U) ///< bit 1
#define NVIC_ICER_CLRENA_2 (0x00000004U) ///< bit 2
#define NVIC_ICER_CLRENA_3 (0x00000008U) ///< bit 3
#define NVIC_ICER_CLRENA_4 (0x00000010U) ///< bit 4
#define NVIC_ICER_CLRENA_5 (0x00000020U) ///< bit 5
#define NVIC_ICER_CLRENA_6 (0x00000040U) ///< bit 6
#define NVIC_ICER_CLRENA_7 (0x00000080U) ///< bit 7
#define NVIC_ICER_CLRENA_8 (0x00000100U) ///< bit 8
#define NVIC_ICER_CLRENA_9 (0x00000200U) ///< bit 9
#define NVIC_ICER_CLRENA_10 (0x00000400U) ///< bit 10
#define NVIC_ICER_CLRENA_11 (0x00000800U) ///< bit 11
#define NVIC_ICER_CLRENA_12 (0x00001000U) ///< bit 12
#define NVIC_ICER_CLRENA_13 (0x00002000U) ///< bit 13
#define NVIC_ICER_CLRENA_14 (0x00004000U) ///< bit 14
#define NVIC_ICER_CLRENA_15 (0x00008000U) ///< bit 15
#define NVIC_ICER_CLRENA_16 (0x00010000U) ///< bit 16
#define NVIC_ICER_CLRENA_17 (0x00020000U) ///< bit 17
#define NVIC_ICER_CLRENA_18 (0x00040000U) ///< bit 18
#define NVIC_ICER_CLRENA_19 (0x00080000U) ///< bit 19
#define NVIC_ICER_CLRENA_20 (0x00100000U) ///< bit 20
#define NVIC_ICER_CLRENA_21 (0x00200000U) ///< bit 21
#define NVIC_ICER_CLRENA_22 (0x00400000U) ///< bit 22
#define NVIC_ICER_CLRENA_23 (0x00800000U) ///< bit 23
#define NVIC_ICER_CLRENA_24 (0x01000000U) ///< bit 24
#define NVIC_ICER_CLRENA_25 (0x02000000U) ///< bit 25
#define NVIC_ICER_CLRENA_26 (0x04000000U) ///< bit 26
#define NVIC_ICER_CLRENA_27 (0x08000000U) ///< bit 27
#define NVIC_ICER_CLRENA_28 (0x10000000U) ///< bit 28
#define NVIC_ICER_CLRENA_29 (0x20000000U) ///< bit 29
#define NVIC_ICER_CLRENA_30 (0x40000000U) ///< bit 30
#define NVIC_ICER_CLRENA_31 (0x80000000U) ///< bit 31
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_ISPR Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_ISPR_SETPEND (0xFFFFFFFFU) ///< Interrupt set-pending bits
#define NVIC_ISPR_SETPEND_0 (0x00000001U) ///< bit 0
#define NVIC_ISPR_SETPEND_1 (0x00000002U) ///< bit 1
#define NVIC_ISPR_SETPEND_2 (0x00000004U) ///< bit 2
#define NVIC_ISPR_SETPEND_3 (0x00000008U) ///< bit 3
#define NVIC_ISPR_SETPEND_4 (0x00000010U) ///< bit 4
#define NVIC_ISPR_SETPEND_5 (0x00000020U) ///< bit 5
#define NVIC_ISPR_SETPEND_6 (0x00000040U) ///< bit 6
#define NVIC_ISPR_SETPEND_7 (0x00000080U) ///< bit 7
#define NVIC_ISPR_SETPEND_8 (0x00000100U) ///< bit 8
#define NVIC_ISPR_SETPEND_9 (0x00000200U) ///< bit 9
#define NVIC_ISPR_SETPEND_10 (0x00000400U) ///< bit 10
#define NVIC_ISPR_SETPEND_11 (0x00000800U) ///< bit 11
#define NVIC_ISPR_SETPEND_12 (0x00001000U) ///< bit 12
#define NVIC_ISPR_SETPEND_13 (0x00002000U) ///< bit 13
#define NVIC_ISPR_SETPEND_14 (0x00004000U) ///< bit 14
#define NVIC_ISPR_SETPEND_15 (0x00008000U) ///< bit 15
#define NVIC_ISPR_SETPEND_16 (0x00010000U) ///< bit 16
#define NVIC_ISPR_SETPEND_17 (0x00020000U) ///< bit 17
#define NVIC_ISPR_SETPEND_18 (0x00040000U) ///< bit 18
#define NVIC_ISPR_SETPEND_19 (0x00080000U) ///< bit 19
#define NVIC_ISPR_SETPEND_20 (0x00100000U) ///< bit 20
#define NVIC_ISPR_SETPEND_21 (0x00200000U) ///< bit 21
#define NVIC_ISPR_SETPEND_22 (0x00400000U) ///< bit 22
#define NVIC_ISPR_SETPEND_23 (0x00800000U) ///< bit 23
#define NVIC_ISPR_SETPEND_24 (0x01000000U) ///< bit 24
#define NVIC_ISPR_SETPEND_25 (0x02000000U) ///< bit 25
#define NVIC_ISPR_SETPEND_26 (0x04000000U) ///< bit 26
#define NVIC_ISPR_SETPEND_27 (0x08000000U) ///< bit 27
#define NVIC_ISPR_SETPEND_28 (0x10000000U) ///< bit 28
#define NVIC_ISPR_SETPEND_29 (0x20000000U) ///< bit 29
#define NVIC_ISPR_SETPEND_30 (0x40000000U) ///< bit 30
#define NVIC_ISPR_SETPEND_31 (0x80000000U) ///< bit 31
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_ICPR Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_ICPR_CLRPEND (0xFFFFFFFFU) ///< Interrupt clear-pending bits
#define NVIC_ICPR_CLRPEND_0 (0x00000001U) ///< bit 0
#define NVIC_ICPR_CLRPEND_1 (0x00000002U) ///< bit 1
#define NVIC_ICPR_CLRPEND_2 (0x00000004U) ///< bit 2
#define NVIC_ICPR_CLRPEND_3 (0x00000008U) ///< bit 3
#define NVIC_ICPR_CLRPEND_4 (0x00000010U) ///< bit 4
#define NVIC_ICPR_CLRPEND_5 (0x00000020U) ///< bit 5
#define NVIC_ICPR_CLRPEND_6 (0x00000040U) ///< bit 6
#define NVIC_ICPR_CLRPEND_7 (0x00000080U) ///< bit 7
#define NVIC_ICPR_CLRPEND_8 (0x00000100U) ///< bit 8
#define NVIC_ICPR_CLRPEND_9 (0x00000200U) ///< bit 9
#define NVIC_ICPR_CLRPEND_10 (0x00000400U) ///< bit 10
#define NVIC_ICPR_CLRPEND_11 (0x00000800U) ///< bit 11
#define NVIC_ICPR_CLRPEND_12 (0x00001000U) ///< bit 12
#define NVIC_ICPR_CLRPEND_13 (0x00002000U) ///< bit 13
#define NVIC_ICPR_CLRPEND_14 (0x00004000U) ///< bit 14
#define NVIC_ICPR_CLRPEND_15 (0x00008000U) ///< bit 15
#define NVIC_ICPR_CLRPEND_16 (0x00010000U) ///< bit 16
#define NVIC_ICPR_CLRPEND_17 (0x00020000U) ///< bit 17
#define NVIC_ICPR_CLRPEND_18 (0x00040000U) ///< bit 18
#define NVIC_ICPR_CLRPEND_19 (0x00080000U) ///< bit 19
#define NVIC_ICPR_CLRPEND_20 (0x00100000U) ///< bit 20
#define NVIC_ICPR_CLRPEND_21 (0x00200000U) ///< bit 21
#define NVIC_ICPR_CLRPEND_22 (0x00400000U) ///< bit 22
#define NVIC_ICPR_CLRPEND_23 (0x00800000U) ///< bit 23
#define NVIC_ICPR_CLRPEND_24 (0x01000000U) ///< bit 24
#define NVIC_ICPR_CLRPEND_25 (0x02000000U) ///< bit 25
#define NVIC_ICPR_CLRPEND_26 (0x04000000U) ///< bit 26
#define NVIC_ICPR_CLRPEND_27 (0x08000000U) ///< bit 27
#define NVIC_ICPR_CLRPEND_28 (0x10000000U) ///< bit 28
#define NVIC_ICPR_CLRPEND_29 (0x20000000U) ///< bit 29
#define NVIC_ICPR_CLRPEND_30 (0x40000000U) ///< bit 30
#define NVIC_ICPR_CLRPEND_31 (0x80000000U) ///< bit 31
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_IABR Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_IABR_ACTIVE (0xFFFFFFFFU) ///< Interrupt active flags
#define NVIC_IABR_ACTIVE_0 (0x00000001U) ///< bit 0
#define NVIC_IABR_ACTIVE_1 (0x00000002U) ///< bit 1
#define NVIC_IABR_ACTIVE_2 (0x00000004U) ///< bit 2
#define NVIC_IABR_ACTIVE_3 (0x00000008U) ///< bit 3
#define NVIC_IABR_ACTIVE_4 (0x00000010U) ///< bit 4
#define NVIC_IABR_ACTIVE_5 (0x00000020U) ///< bit 5
#define NVIC_IABR_ACTIVE_6 (0x00000040U) ///< bit 6
#define NVIC_IABR_ACTIVE_7 (0x00000080U) ///< bit 7
#define NVIC_IABR_ACTIVE_8 (0x00000100U) ///< bit 8
#define NVIC_IABR_ACTIVE_9 (0x00000200U) ///< bit 9
#define NVIC_IABR_ACTIVE_10 (0x00000400U) ///< bit 10
#define NVIC_IABR_ACTIVE_11 (0x00000800U) ///< bit 11
#define NVIC_IABR_ACTIVE_12 (0x00001000U) ///< bit 12
#define NVIC_IABR_ACTIVE_13 (0x00002000U) ///< bit 13
#define NVIC_IABR_ACTIVE_14 (0x00004000U) ///< bit 14
#define NVIC_IABR_ACTIVE_15 (0x00008000U) ///< bit 15
#define NVIC_IABR_ACTIVE_16 (0x00010000U) ///< bit 16
#define NVIC_IABR_ACTIVE_17 (0x00020000U) ///< bit 17
#define NVIC_IABR_ACTIVE_18 (0x00040000U) ///< bit 18
#define NVIC_IABR_ACTIVE_19 (0x00080000U) ///< bit 19
#define NVIC_IABR_ACTIVE_20 (0x00100000U) ///< bit 20
#define NVIC_IABR_ACTIVE_21 (0x00200000U) ///< bit 21
#define NVIC_IABR_ACTIVE_22 (0x00400000U) ///< bit 22
#define NVIC_IABR_ACTIVE_23 (0x00800000U) ///< bit 23
#define NVIC_IABR_ACTIVE_24 (0x01000000U) ///< bit 24
#define NVIC_IABR_ACTIVE_25 (0x02000000U) ///< bit 25
#define NVIC_IABR_ACTIVE_26 (0x04000000U) ///< bit 26
#define NVIC_IABR_ACTIVE_27 (0x08000000U) ///< bit 27
#define NVIC_IABR_ACTIVE_28 (0x10000000U) ///< bit 28
#define NVIC_IABR_ACTIVE_29 (0x20000000U) ///< bit 29
#define NVIC_IABR_ACTIVE_30 (0x40000000U) ///< bit 30
#define NVIC_IABR_ACTIVE_31 (0x80000000U) ///< bit 31
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_PRI0 Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_IPR0_PRI_0 (0x000000FFU) ///< Priority of interrupt 0
#define NVIC_IPR0_PRI_1 (0x0000FF00U) ///< Priority of interrupt 1
#define NVIC_IPR0_PRI_2 (0x00FF0000U) ///< Priority of interrupt 2
#define NVIC_IPR0_PRI_3 (0xFF000000U) ///< Priority of interrupt 3
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_PRI1 Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_IPR1_PRI_4 (0x000000FFU) ///< Priority of interrupt 4
#define NVIC_IPR1_PRI_5 (0x0000FF00U) ///< Priority of interrupt 5
#define NVIC_IPR1_PRI_6 (0x00FF0000U) ///< Priority of interrupt 6
#define NVIC_IPR1_PRI_7 (0xFF000000U) ///< Priority of interrupt 7
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_PRI2 Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_IPR2_PRI_8 (0x000000FFU) ///< Priority of interrupt 8
#define NVIC_IPR2_PRI_9 (0x0000FF00U) ///< Priority of interrupt 9
#define NVIC_IPR2_PRI_10 (0x00FF0000U) ///< Priority of interrupt 10
#define NVIC_IPR2_PRI_11 (0xFF000000U) ///< Priority of interrupt 11
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_PRI3 Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_IPR3_PRI_12 (0x000000FFU) ///< Priority of interrupt 12
#define NVIC_IPR3_PRI_13 (0x0000FF00U) ///< Priority of interrupt 13
#define NVIC_IPR3_PRI_14 (0x00FF0000U) ///< Priority of interrupt 14
#define NVIC_IPR3_PRI_15 (0xFF000000U) ///< Priority of interrupt 15
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_PRI4 Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_IPR4_PRI_16 (0x000000FFU) ///< Priority of interrupt 16
#define NVIC_IPR4_PRI_17 (0x0000FF00U) ///< Priority of interrupt 17
#define NVIC_IPR4_PRI_18 (0x00FF0000U) ///< Priority of interrupt 18
#define NVIC_IPR4_PRI_19 (0xFF000000U) ///< Priority of interrupt 19
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_PRI5 Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_IPR5_PRI_20 (0x000000FFU) ///< Priority of interrupt 20
#define NVIC_IPR5_PRI_21 (0x0000FF00U) ///< Priority of interrupt 21
#define NVIC_IPR5_PRI_22 (0x00FF0000U) ///< Priority of interrupt 22
#define NVIC_IPR5_PRI_23 (0xFF000000U) ///< Priority of interrupt 23
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_PRI6 Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_IPR6_PRI_24 (0x000000FFU) ///< Priority of interrupt 24
#define NVIC_IPR6_PRI_25 (0x0000FF00U) ///< Priority of interrupt 25
#define NVIC_IPR6_PRI_26 (0x00FF0000U) ///< Priority of interrupt 26
#define NVIC_IPR6_PRI_27 (0xFF000000U) ///< Priority of interrupt 27
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_PRI7 Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_IPR7_PRI_28 (0x000000FFU) ///< Priority of interrupt 28
#define NVIC_IPR7_PRI_29 (0x0000FF00U) ///< Priority of interrupt 29
#define NVIC_IPR7_PRI_30 (0x00FF0000U) ///< Priority of interrupt 30
#define NVIC_IPR7_PRI_31 (0xFF000000U) ///< Priority of interrupt 31
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_PRI8 Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_IPR7_PRI_32 (0x000000FFU) ///< Priority of interrupt 32
#define NVIC_IPR7_PRI_33 (0x0000FF00U) ///< Priority of interrupt 33
#define NVIC_IPR7_PRI_34 (0x00FF0000U) ///< Priority of interrupt 34
#define NVIC_IPR7_PRI_35 (0xFF000000U) ///< Priority of interrupt 35
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_PRI9 Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_IPR7_PRI_36 (0x000000FFU) ///< Priority of interrupt 36
#define NVIC_IPR7_PRI_37 (0x0000FF00U) ///< Priority of interrupt 37
#define NVIC_IPR7_PRI_38 (0x00FF0000U) ///< Priority of interrupt 38
#define NVIC_IPR7_PRI_39 (0xFF000000U) ///< Priority of interrupt 39
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_PRI10 Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_IPR7_PRI_40 (0x000000FFU) ///< Priority of interrupt 40
#define NVIC_IPR7_PRI_41 (0x0000FF00U) ///< Priority of interrupt 41
#define NVIC_IPR7_PRI_42 (0x00FF0000U) ///< Priority of interrupt 42
#define NVIC_IPR7_PRI_43 (0xFF000000U) ///< Priority of interrupt 43
////////////////////////////////////////////////////////////////////////////////
/// @brief NVIC_PRI11 Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define NVIC_IPR7_PRI_44 (0x000000FFU) ///< Priority of interrupt 44
#define NVIC_IPR7_PRI_45 (0x0000FF00U) ///< Priority of interrupt 45
#define NVIC_IPR7_PRI_46 (0x00FF0000U) ///< Priority of interrupt 46
#define NVIC_IPR7_PRI_47 (0xFF000000U) ///< Priority of interrupt 47
////////////////////////////////////////////////////////////////////////////////
/// @brief SCB_CPUID Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define SCB_CPUID_REVISION (0x0000000FU) ///< Implementation defined revision number
#define SCB_CPUID_PARTNO (0x0000FFF0U) ///< Number of processor within family
#define SCB_CPUID_Constant (0x000F0000U) ///< Reads as 0x0F
#define SCB_CPUID_VARIANT (0x00F00000U) ///< Implementation defined variant number
#define SCB_CPUID_IMPLEMENTER (0xFF000000U) ///< Implementer code. ARM is 0x41
////////////////////////////////////////////////////////////////////////////////
/// @brief SCB_ICSR Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define SCB_ICSR_VECTACTIVE (0x000001FFU) ///< Active ISR number field
#define SCB_ICSR_RETTOBASE (0x00000800U) ///< All active exceptions minus the IPSR_current_exception yields the empty set
#define SCB_ICSR_VECTPENDING (0x003FF000U) ///< Pending ISR number field
#define SCB_ICSR_ISRPENDING (0x00400000U) ///< Interrupt pending flag
#define SCB_ICSR_ISRPREEMPT (0x00800000U) ///< It indicates that a pending interrupt becomes active in the next running cycle
#define SCB_ICSR_PENDSTCLR (0x02000000U) ///< Clear pending SysTick bit
#define SCB_ICSR_PENDSTSET (0x04000000U) ///< Set pending SysTick bit
#define SCB_ICSR_PENDSVCLR (0x08000000U) ///< Clear pending pendSV bit
#define SCB_ICSR_PENDSVSET (0x10000000U) ///< Set pending pendSV bit
#define SCB_ICSR_NMIPENDSET (0x80000000U) ///< Set pending NMI bit
////////////////////////////////////////////////////////////////////////////////
/// @brief SCB_VTOR Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define SCB_VTOR_TBLOFF (0x1FFFFF80U) ///< Vector table base offset field
#define SCB_VTOR_TBLBASE (0x20000000U) ///< Table base in code(0) or RAM(1)
////////////////////////////////////////////////////////////////////////////////
/// @brief SCB_AIRCR Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define SCB_AIRCR_VECTRESET (0x00000001U) ///< System Reset bit
#define SCB_AIRCR_VECTCLRACTIVE (0x00000002U) ///< Clear active vector bit
#define SCB_AIRCR_SYSRESETREQ (0x00000004U) ///< Requests chip control logic to generate a reset
#define SCB_AIRCR_PRIGROUP (0x00000700U) ///< PRIGROUP[2:0] bits (Priority group)
#define SCB_AIRCR_PRIGROUP_0 (0x00000100U) ///< Bit 0
#define SCB_AIRCR_PRIGROUP_1 (0x00000200U) ///< Bit 1
#define SCB_AIRCR_PRIGROUP_2 (0x00000400U) ///< Bit 2
#define SCB_AIRCR_PRIGROUP0 (0x00000000U) ///< Priority group=0 (7 bits of pre-emption priority, 1 bit of subpriority)
#define SCB_AIRCR_PRIGROUP1 (0x00000100U) ///< Priority group=1 (6 bits of pre-emption priority, 2 bits of subpriority)
#define SCB_AIRCR_PRIGROUP2 (0x00000200U) ///< Priority group=2 (5 bits of pre-emption priority, 3 bits of subpriority)
#define SCB_AIRCR_PRIGROUP3 (0x00000300U) ///< Priority group=3 (4 bits of pre-emption priority, 4 bits of subpriority)
#define SCB_AIRCR_PRIGROUP4 (0x00000400U) ///< Priority group=4 (3 bits of pre-emption priority, 5 bits of subpriority)
#define SCB_AIRCR_PRIGROUP5 (0x00000500U) ///< Priority group=5 (2 bits of pre-emption priority, 6 bits of subpriority)
#define SCB_AIRCR_PRIGROUP6 (0x00000600U) ///< Priority group=6 (1 bit of pre-emption priority, 7 bits of subpriority)
#define SCB_AIRCR_PRIGROUP7 (0x00000700U) ///< Priority group=7 (no pre-emption priority, 8 bits of subpriority)
#define SCB_AIRCR_ENDIANESS (0x00008000U) ///< Data endianness bit
#define SCB_AIRCR_VECTKEY (0xFFFF0000U) ///< Register key (VECTKEY) - Reads as 0xFA05 (VECTKEYSTAT)
////////////////////////////////////////////////////////////////////////////////
/// @brief SCB_SCR Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define SCB_SCR_SLEEPONEXIT (0x02U) ///< Sleep on exit bit
#define SCB_SCR_SLEEPDEEP (0x04U) ///< Sleep deep bit
#define SCB_SCR_SEVONPEND (0x10U) ///< Wake up from WFE
////////////////////////////////////////////////////////////////////////////////
/// @brief SCB_CCR Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define SCB_CCR_NONBASETHRDENA (0x0001U) ///< Thread mode can be entered from any level in Handler mode by controlled return value
#define SCB_CCR_USERSETMPEND (0x0002U) ///< Enables user code to write the Software Trigger Interrupt register to trigger (pend) a Main exception
#define SCB_CCR_UNALIGN_TRP (0x0008U) ///< Trap for unaligned access
#define SCB_CCR_DIV_0_TRP (0x0010U) ///< Trap on Divide by 0
#define SCB_CCR_BFHFNMIGN (0x0100U) ///< Handlers running at priority -1 and -2
#define SCB_CCR_STKALIGN (0x0200U) ///< On exception entry, the SP used prior to the exception is adjusted to be 8-byte aligned
////////////////////////////////////////////////////////////////////////////////
/// @brief SCB_SHPR Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define SCB_SHPR_PRI_N (0x000000FFU) ///< Priority of system handler 4,8, and 12. Mem Manage, reserved and Debug Monitor
#define SCB_SHPR_PRI_N1 (0x0000FF00U) ///< Priority of system handler 5,9, and 13. Bus Fault, reserved and reserved
#define SCB_SHPR_PRI_N2 (0x00FF0000U) ///< Priority of system handler 6,10, and 14. Usage Fault, reserved and PendSV
#define SCB_SHPR_PRI_N3 (0xFF000000U) ///< Priority of system handler 7,11, and 15. Reserved, SVCall and SysTick
////////////////////////////////////////////////////////////////////////////////
/// @brief SCB_SHCSR Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define SCB_SHCSR_MEMFAULTACT (0x00000001U) ///< MemManage is active
#define SCB_SHCSR_BUSFAULTACT (0x00000002U) ///< BusFault is active
#define SCB_SHCSR_USGFAULTACT (0x00000008U) ///< UsageFault is active
#define SCB_SHCSR_SVCALLACT (0x00000080U) ///< SVCall is active
#define SCB_SHCSR_MONITORACT (0x00000100U) ///< Monitor is active
#define SCB_SHCSR_PENDSVACT (0x00000400U) ///< PendSV is active
#define SCB_SHCSR_SYSTICKACT (0x00000800U) ///< SysTick is active
#define SCB_SHCSR_USGFAULTPENDED (0x00001000U) ///< Usage Fault is pended
#define SCB_SHCSR_MEMFAULTPENDED (0x00002000U) ///< MemManage is pended
#define SCB_SHCSR_BUSFAULTPENDED (0x00004000U) ///< Bus Fault is pended
#define SCB_SHCSR_SVCALLPENDED (0x00008000U) ///< SVCall is pended
#define SCB_SHCSR_MEMFAULTENA (0x00010000U) ///< MemManage enable
#define SCB_SHCSR_BUSFAULTENA (0x00020000U) ///< Bus Fault enable
#define SCB_SHCSR_USGFAULTENA (0x00040000U) ///< UsageFault enable
////////////////////////////////////////////////////////////////////////////////
/// @brief SCB_CFSR Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
///< MFSR
#define SCB_CFSR_IACCVIOL (0x00000001U) ///< Instruction access violation
#define SCB_CFSR_DACCVIOL (0x00000002U) ///< Data access violation
#define SCB_CFSR_MUNSTKERR (0x00000008U) ///< Unstacking error
#define SCB_CFSR_MSTKERR (0x00000010U) ///< Stacking error
#define SCB_CFSR_MMARVALID (0x00000080U) ///< Memory Manage Address Register address valid flag
///< BFSR
#define SCB_CFSR_IBUSERR (0x00000100U) ///< Instruction bus error flag
#define SCB_CFSR_PRECISERR (0x00000200U) ///< Precise data bus error
#define SCB_CFSR_IMPRECISERR (0x00000400U) ///< Imprecise data bus error
#define SCB_CFSR_UNSTKERR (0x00000800U) ///< Unstacking error
#define SCB_CFSR_STKERR (0x00001000U) ///< Stacking error
#define SCB_CFSR_BFARVALID (0x00008000U) ///< Bus Fault Address Register address valid flag
///< UFSR
#define SCB_CFSR_UNDEFINSTR (0x00010000U) ///< The processor attempt to excecute an undefined instruction
#define SCB_CFSR_INVSTATE (0x00020000U) ///< Invalid combination of EPSR and instruction
#define SCB_CFSR_INVPC (0x00040000U) ///< Attempt to load EXC_RETURN into pc illegally
#define SCB_CFSR_NOCP (0x00080000U) ///< Attempt to use a coprocessor instruction
#define SCB_CFSR_UNALIGNED (0x01000000U) ///< Fault occurs when there is an attempt to make an unaligned memory access
#define SCB_CFSR_DIVBYZERO (0x02000000U) ///< Fault occurs when SDIV or DIV instruction is used with a divisor of 0
////////////////////////////////////////////////////////////////////////////////
/// @brief SCB_HFSR Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define SCB_HFSR_VECTTBL (0x00000002U) ///< Fault occures because of vector table read on exception processing
#define SCB_HFSR_FORCED (0x40000000U) ///< Hard Fault activated when a configurable Fault was received and cannot activate
#define SCB_HFSR_DEBUGEVT (0x80000000U) ///< Fault related to debug
////////////////////////////////////////////////////////////////////////////////
/// @brief SCB_DFSR Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define SCB_DFSR_HALTED (0x01U) ///< Halt request flag
#define SCB_DFSR_BKPT (0x02U) ///< BKPT flag
#define SCB_DFSR_DWTTRAP (0x04U) ///< Data Watchpoint and Trace (DWT) flag
#define SCB_DFSR_VCATCH (0x08U) ///< Vector catch flag
#define SCB_DFSR_EXTERNAL (0x10U) ///< External debug request flag
////////////////////////////////////////////////////////////////////////////////
/// @brief SCB_MMFAR Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define SCB_MMFAR_ADDRESS (0xFFFFFFFFU) ///< Mem Manage fault address field
////////////////////////////////////////////////////////////////////////////////
/// @brief SCB_BFAR Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define SCB_BFAR_ADDRESS (0xFFFFFFFFU) ///< Bus fault address field
////////////////////////////////////////////////////////////////////////////////
/// @brief SCB_AFSR Register Bit Definition
////////////////////////////////////////////////////////////////////////////////
#define SCB_AFSR_IMPDEF (0xFFFFFFFFU) ///< Implementation defined
#endif
/// @}
/// @}
/// @}
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////