/* ** ################################################################### ** Processors: MK20DX64VLH7 ** MK20DX128VLH7 ** MK20DX256VLH7 ** MK20DX64VLK7 ** MK20DX128VLK7 ** MK20DX256VLK7 ** MK20DX128VLL7 ** MK20DX256VLL7 ** MK20DX64VMB7 ** MK20DX128VMB7 ** MK20DX256VMB7 ** MK20DX128VML7 ** MK20DX256VML7 ** ** Compilers: ARM Compiler ** Freescale C/C++ for Embedded ARM ** GNU C Compiler ** IAR ANSI C/C++ Compiler for ARM ** ** Reference manual: Kxx (P1 silicon) Sub-Family Reference Manual Rev. 0, draft A Oct 2011 ** Version: rev. 1.0, 2012-01-15 ** ** Abstract: ** Provides a system configuration function and a global variable that ** contains the system frequency. It configures the device and initializes ** the oscillator (PLL) that is part of the microcontroller device. ** ** Copyright: 2015 Freescale Semiconductor, Inc. All Rights Reserved. ** ** http: www.freescale.com ** mail: support@freescale.com ** ** Revisions: ** - rev. 1.0 (2012-01-15) ** Initial public version. ** ** ################################################################### */ /** * @file MK20DX256.h * @version 2.0 * @date 2012-03-19 * @brief CMSIS Peripheral Access Layer for MK20DX256 * * CMSIS Peripheral Access Layer for MK20DX256 */ #if !defined(MK20DX256_H_) #define MK20DX256_H_ /**< Symbol preventing repeated inclusion */ #define MCU_MK20DX256 /** Memory map major version (memory maps with equal major version number are * compatible) */ #define MCU_MEM_MAP_VERSION 0x0200u /** Memory map minor version */ #define MCU_MEM_MAP_VERSION_MINOR 0x0000u /** * @brief Macro to access a single bit of a peripheral register (bit band region * 0x40000000 to 0x400FFFFF) using the bit-band alias region access. * @param Reg Register to access. * @param Bit Bit number to access. * @return Value of the targeted bit in the bit band region. */ #define BITBAND_REG(Reg,Bit) (*((uint32_t volatile*)(0x42000000u + (32u*((uint32_t)&(Reg) - (uint32_t)0x40000000u)) + (4u*((uint32_t)(Bit)))))) /* ---------------------------------------------------------------------------- -- Interrupt vector numbers ---------------------------------------------------------------------------- */ /** * @addtogroup Interrupt_vector_numbers Interrupt vector numbers * @{ */ /** Interrupt Number Definitions */ typedef enum IRQn { /* Core interrupts */ NonMaskableInt_IRQn = -14, /**< Non Maskable Interrupt */ MemoryManagement_IRQn = -12, /**< Cortex-M4 Memory Management Interrupt */ BusFault_IRQn = -11, /**< Cortex-M4 Bus Fault Interrupt */ UsageFault_IRQn = -10, /**< Cortex-M4 Usage Fault Interrupt */ SVCall_IRQn = -5, /**< Cortex-M4 SV Call Interrupt */ DebugMonitor_IRQn = -4, /**< Cortex-M4 Debug Monitor Interrupt */ PendSV_IRQn = -2, /**< Cortex-M4 Pend SV Interrupt */ SysTick_IRQn = -1, /**< Cortex-M4 System Tick Interrupt */ /* Device specific interrupts */ DMA0_IRQn = 0, /**< DMA channel 0 transfer complete interrupt */ DMA1_IRQn = 1, /**< DMA channel 1 transfer complete interrupt */ DMA2_IRQn = 2, /**< DMA channel 2 transfer complete interrupt */ DMA3_IRQn = 3, /**< DMA channel 3 transfer complete interrupt */ DMA4_IRQn = 4, DMA5_IRQn = 5, DMA6_IRQn = 6, DMA7_IRQn = 7, DMA8_IRQn = 8, DMA9_IRQn = 9, DMA10_IRQn = 10, DMA11_IRQn = 11, DMA12_IRQn = 12, DMA13_IRQn = 13, DMA14_IRQn = 14, DMA15_IRQn = 15, DMA_Error_IRQn = 16, /**< DMA error interrupt */ Reserved33_IRQn = 17, FTFL_IRQn = 18, /**< FTFL interrupt */ Read_Collision_IRQn = 19, /**< Read collision interrupt */ LVD_LVW_IRQn = 20, /**< Low Voltage Detect, Low Voltage Warning */ LLW_IRQn = 21, /**< Low Leakage Wakeup */ Watchdog_IRQn = 22, /**< WDOG interrupt */ Reserved39_IRQn = 23, I2C0_IRQn = 24, /**< I2C0 interrupt */ I2C1_IRQn = 25, SPI0_IRQn = 26, /**< SPI0 interrupt */ SPI1_IRQn = 27, Reserved44_IRQn = 28, CAN0_ORed_Message_buffer_IRQn = 29, /**< CAN0 OR'd message buffers interrupt */ CAN0_Bus_Off_IRQn = 30, /**< CAN0 bus off interrupt */ CAN0_Error_IRQn = 31, /**< CAN0 error interrupt */ CAN0_Tx_Warning_IRQn = 32, /**< CAN0 Tx warning interrupt */ CAN0_Rx_Warning_IRQn = 33, /**< CAN0 Rx warning interrupt */ CAN0_Wake_Up_IRQn = 34, /**< CAN0 wake up interrupt */ I2S0_Tx_IRQn = 35, /**< I2S0 transmit interrupt */ I2S0_Rx_IRQn = 36, /**< I2S0 receive interrupt */ Reserved53_IRQn = 37, Reserved54_IRQn = 38, Reserved55_IRQn = 39, Reserved56_IRQn = 40, Reserved57_IRQn = 41, Reserved58_IRQn = 42, Reserved59_IRQn = 43, UART0_LON_IRQn = 44, /**< UART0 LON interrupt */ UART0_RX_TX_IRQn = 45, /**< UART0 receive/transmit interrupt */ UART0_ERR_IRQn = 46, /**< UART0 error interrupt */ UART1_RX_TX_IRQn = 47, /**< UART1 receive/transmit interrupt */ UART1_ERR_IRQn = 48, /**< UART1 error interrupt */ UART2_RX_TX_IRQn = 49, /**< UART2 receive/transmit interrupt */ UART2_ERR_IRQn = 50, /**< UART2 error interrupt */ Reserved67_IRQn = 51, Reserved68_IRQn = 52, Reserved69_IRQn = 53, Reserved70_IRQn = 54, Reserved71_IRQn = 55, Reserved72_IRQn = 56, ADC0_IRQn = 57, /**< ADC0 interrupt */ ADC1_IRQn = 58, CMP0_IRQn = 59, /**< CMP0 interrupt */ CMP1_IRQn = 60, /**< CMP1 interrupt */ CMP2_IRQn = 61, FTM0_IRQn = 62, /**< FTM0 fault, overflow and channels interrupt */ FTM1_IRQn = 63, /**< FTM1 fault, overflow and channels interrupt */ FTM2_IRQn = 64, CMT_IRQn = 65, /**< CMT interrupt */ RTC_IRQn = 66, /**< RTC interrupt */ RTC_Seconds_IRQn = 67, /**< RTC seconds interrupt */ PIT0_IRQn = 68, /**< PIT timer channel 0 interrupt */ PIT1_IRQn = 69, /**< PIT timer channel 1 interrupt */ PIT2_IRQn = 70, /**< PIT timer channel 2 interrupt */ PIT3_IRQn = 71, /**< PIT timer channel 3 interrupt */ PDB0_IRQn = 72, /**< PDB0 interrupt */ USB0_IRQn = 73, /**< USB0 interrupt */ USBDCD_IRQn = 74, /**< USBDCD interrupt */ Reserved91_IRQn = 75, Reserved92_IRQn = 76, Reserved93_IRQn = 77, Reserved94_IRQn = 78, Reserved95_IRQn = 79, Reserved96_IRQn = 80, DAC0_IRQn = 81, Reserved98_IRQn = 82, TSI0_IRQn = 83, /**< TSI0 interrupt */ MCG_IRQn = 84, /**< MCG interrupt */ LPTimer_IRQn = 85, /**< LPTimer interrupt */ Reserved102_IRQn = 86, PORTA_IRQn = 87, /**< Port A interrupt */ PORTB_IRQn = 88, /**< Port B interrupt */ PORTC_IRQn = 89, /**< Port C interrupt */ PORTD_IRQn = 90, /**< Port D interrupt */ PORTE_IRQn = 91, /**< Port E interrupt */ Reserved108_IRQn = 92, Reserved109_IRQn = 93, SWI_IRQn = 94 /**< Software interrupt */ } IRQn_Type; /** * @} */ /* end of group Interrupt_vector_numbers */ /* ---------------------------------------------------------------------------- -- Cortex M4 Core Configuration ---------------------------------------------------------------------------- */ /** * @addtogroup Cortex_Core_Configuration Cortex M4 Core Configuration * @{ */ #define __MPU_PRESENT 0 /**< Defines if an MPU is present or not */ #define __NVIC_PRIO_BITS 4 /**< Number of priority bits implemented in the NVIC */ #define __Vendor_SysTickConfig 0 /**< Vendor specific implementation of SysTickConfig is defined */ #include "core_cm4.h" /* Core Peripheral Access Layer */ #include "system_MK20DX256.h" /* Device specific configuration file */ /** * @} */ /* end of group Cortex_Core_Configuration */ /* ---------------------------------------------------------------------------- -- Device Peripheral Access Layer ---------------------------------------------------------------------------- */ /** * @addtogroup Peripheral_access_layer Device Peripheral Access Layer * @{ */ /* ** Start of section using anonymous unions */ #if defined(__ARMCC_VERSION) #pragma push #pragma anon_unions #elif defined(__CWCC__) #pragma push #pragma cpp_extensions on #elif defined(__GNUC__) /* anonymous unions are enabled by default */ #elif defined(__IAR_SYSTEMS_ICC__) #pragma language=extended #else #error Not supported compiler type #endif /* ---------------------------------------------------------------------------- -- ADC Peripheral Access Layer ---------------------------------------------------------------------------- */ /** * @addtogroup ADC_Peripheral_Access_Layer ADC Peripheral Access Layer * @{ */ /** ADC - Register Layout Typedef */ typedef struct { __IO uint32_t SC1[2]; /**< ADC status and control registers 1, array offset: 0x0, array step: 0x4 */ __IO uint32_t CFG1; /**< ADC configuration register 1, offset: 0x8 */ __IO uint32_t CFG2; /**< Configuration register 2, offset: 0xC */ __I uint32_t R[2]; /**< ADC data result register, array offset: 0x10, array step: 0x4 */ __IO uint32_t CV1; /**< Compare value registers, offset: 0x18 */ __IO uint32_t CV2; /**< Compare value registers, offset: 0x1C */ __IO uint32_t SC2; /**< Status and control register 2, offset: 0x20 */ __IO uint32_t SC3; /**< Status and control register 3, offset: 0x24 */ __IO uint32_t OFS; /**< ADC offset correction register, offset: 0x28 */ __IO uint32_t PG; /**< ADC plus-side gain register, offset: 0x2C */ __IO uint32_t MG; /**< ADC minus-side gain register, offset: 0x30 */ __IO uint32_t CLPD; /**< ADC plus-side general calibration value register, offset: 0x34 */ __IO uint32_t CLPS; /**< ADC plus-side general calibration value register, offset: 0x38 */ __IO uint32_t CLP4; /**< ADC plus-side general calibration value register, offset: 0x3C */ __IO uint32_t CLP3; /**< ADC plus-side general calibration value register, offset: 0x40 */ __IO uint32_t CLP2; /**< ADC plus-side general calibration value register, offset: 0x44 */ __IO uint32_t CLP1; /**< ADC plus-side general calibration value register, offset: 0x48 */ __IO uint32_t CLP0; /**< ADC plus-side general calibration value register, offset: 0x4C */ uint8_t RESERVED_0[4]; __IO uint32_t CLMD; /**< ADC minus-side general calibration value register, offset: 0x54 */ __IO uint32_t CLMS; /**< ADC minus-side general calibration value register, offset: 0x58 */ __IO uint32_t CLM4; /**< ADC minus-side general calibration value register, offset: 0x5C */ __IO uint32_t CLM3; /**< ADC minus-side general calibration value register, offset: 0x60 */ __IO uint32_t CLM2; /**< ADC minus-side general calibration value register, offset: 0x64 */ __IO uint32_t CLM1; /**< ADC minus-side general calibration value register, offset: 0x68 */ __IO uint32_t CLM0; /**< ADC minus-side general calibration value register, offset: 0x6C */ } ADC_Type; /* ---------------------------------------------------------------------------- -- ADC Register Masks ---------------------------------------------------------------------------- */ /** * @addtogroup ADC_Register_Masks ADC Register Masks * @{ */ /* SC1 Bit Fields */ #define ADC_SC1_ADCH_MASK 0x1Fu #define ADC_SC1_ADCH_SHIFT 0 #define ADC_SC1_ADCH(x) (((uint32_t)(((uint32_t)(x))<