212 lines
11 KiB
C
212 lines
11 KiB
C
|
/**************************************************************************//**
|
||
|
* @file best2300a.h
|
||
|
* @brief CMSIS Core Peripheral Access Layer Header File for
|
||
|
* ARMCM4 Device Series
|
||
|
* @version V2.02
|
||
|
* @date 10. September 2014
|
||
|
*
|
||
|
* @note configured for CM4 with FPU
|
||
|
*
|
||
|
******************************************************************************/
|
||
|
/* Copyright (c) 2011 - 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.
|
||
|
---------------------------------------------------------------------------*/
|
||
|
|
||
|
|
||
|
#ifndef __BEST2300A_H__
|
||
|
#define __BEST2300A_H__
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
#ifndef __ASSEMBLER__
|
||
|
/* ------------------------- Interrupt Number Definition ------------------------ */
|
||
|
|
||
|
typedef enum IRQn
|
||
|
{
|
||
|
/* ------------------- Cortex-M33 Processor Exceptions Numbers ------------------ */
|
||
|
NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */
|
||
|
HardFault_IRQn = -13, /*!< 3 HardFault Interrupt */
|
||
|
MemoryManagement_IRQn = -12, /*!< 4 Memory Management Interrupt */
|
||
|
BusFault_IRQn = -11, /*!< 5 Bus Fault Interrupt */
|
||
|
UsageFault_IRQn = -10, /*!< 6 Usage Fault Interrupt */
|
||
|
SVCall_IRQn = -5, /*!< 11 SV Call Interrupt */
|
||
|
DebugMonitor_IRQn = -4, /*!< 12 Debug Monitor Interrupt */
|
||
|
PendSV_IRQn = -2, /*!< 14 Pend SV Interrupt */
|
||
|
SysTick_IRQn = -1, /*!< 15 System Tick Interrupt */
|
||
|
|
||
|
/* -------------------- BEST2300A Specific Interrupt Numbers -------------------- */
|
||
|
FPU_IRQn = 0, /*!< FPU Interrupt */
|
||
|
SENSOR_WKUP_IRQn = 1, /*!< SENSOR Wakeup Interrupt */
|
||
|
SDMMC_IRQn = 2, /*!< SDMMC Interrupt */
|
||
|
AUDMA_IRQn = 3, /*!< Audio DMA Interrupt */
|
||
|
GPDMA_IRQn = 4, /*!< General Purpose DMA Interrupt */
|
||
|
AON_WDT_IRQn = 5, /*!< AON Watchdog Timer Interrupt */
|
||
|
USB_PHY_IRQn = 6, /*!< USB PHY Interrupt */
|
||
|
USB_IRQn = 7, /*!< USB Interrupt */
|
||
|
WAKEUP_IRQn = 8, /*!< Wakeup Interrupt */
|
||
|
AON_GPIO_IRQn = 9, /*!< AON GPIO Interrupt */
|
||
|
MCU_WDT_IRQn = 10, /*!< Watchdog Timer Interrupt */
|
||
|
SENSOR_ENG_IRQn = 11, /*!< Sensor Engine Interrupt */
|
||
|
MCU_TIMER00_IRQn = 12, /*!< Timer00 Interrupt */
|
||
|
MCU_TIMER01_IRQn = 13, /*!< Timer01 Interrupt */
|
||
|
I2C0_IRQn = 14, /*!< I2C0 Interrupt */
|
||
|
SPI0_IRQn = 15, /*!< SPI0 Interrupt */
|
||
|
SPILCD_IRQn = 16, /*!< SPILCD Interrupt */
|
||
|
UART0_IRQn = 17, /*!< UART0 Interrupt */
|
||
|
UART1_IRQn = 18, /*!< UART1 Interrupt */
|
||
|
CODEC_IRQn = 19, /*!< CODEC Interrupt */
|
||
|
BTPCM_IRQn = 20, /*!< BTPCM Interrupt */
|
||
|
I2S0_IRQn = 21, /*!< I2S0 Interrupt */
|
||
|
SPDIF0_IRQn = 22, /*!< SPDIF0 Interrupt */
|
||
|
I2S1_IRQn = 23, /*!< I2S1 Interrupt */
|
||
|
BT_IRQn = 24, /*!< BT to MCU Interrupt */
|
||
|
CODEC_TX_PEAK_IRQn = 25, /*!< CODEC TX PEAK Interrupt */
|
||
|
UART2_IRQn = 26, /*!< UART2 Interrupt */
|
||
|
MCU_TIMER10_IRQn = 27, /*!< Timer10 Interrupt */
|
||
|
MCU_TIMER11_IRQn = 28, /*!< Timer11 Interrupt */
|
||
|
I2C1_IRQn = 29, /*!< I2C1 Interrupt */
|
||
|
DUMP_IRQn = 30, /*!< DUMP Interrupt */
|
||
|
SPIPHY_IRQn = 31, /*!< SPIPHY Interrupt */
|
||
|
ISDONE_IRQn = 32, /*!< Intersys MCU2BT Data Done Interrupt */
|
||
|
ISDONE1_IRQn = 33, /*!< Intersys MCU2BT Data1 Done Interrupt */
|
||
|
ISDATA_IRQn = 34, /*!< Intersys BT2MCU Data Indication Interrupt */
|
||
|
ISDATA1_IRQn = 35, /*!< Intersys BT2MCU Data1 Indication Interrupt */
|
||
|
CP2MCU_DATA_IRQn = 36, /*!< Intersys CP2MCU Data Indication Interrupt */
|
||
|
CP2MCU_DATA1_IRQn = 37, /*!< Intersys CP2MCU Data1 Indication Interrupt */
|
||
|
CP2MCU_DATA2_IRQn = 38, /*!< Intersys CP2MCU Data Indication Interrupt */
|
||
|
CP2MCU_DATA3_IRQn = 39, /*!< Intersys CP2MCU Data1 Indication Interrupt */
|
||
|
USB_CAL_IRQn = 40, /*!< USB Calibration Interrupt */
|
||
|
USB_PIN_IRQn = 41, /*!< USB Pin Interrupt */
|
||
|
PMU_IRQn = 42, /*!< PMU Interrupt */
|
||
|
SEC_ENG_IRQn = 43, /*!< Security Engine Interrupt */
|
||
|
AON_IRQn = 44, /*!< AON Interrupt */
|
||
|
AON_TIMER00_IRQn = 45, /*!< AON Timer00 Interrupt */
|
||
|
AON_TIMER01_IRQn = 46, /*!< AON Timer01 Interrupt */
|
||
|
SEDMA_IRQn = 47, /*!< Security Engine DMA Interrupt */
|
||
|
MCU2CP_DONE_IRQn = 48, /*!< Intersys MCU2CP Data Done Interrupt */
|
||
|
MCU2CP_DONE1_IRQn = 49, /*!< Intersys MCU2CP Data Done Interrupt */
|
||
|
MCU2CP_DONE2_IRQn = 50, /*!< Intersys MCU2CP Data Done Interrupt */
|
||
|
MCU2CP_DONE3_IRQn = 51, /*!< Intersys MCU2CP Data Done Interrupt */
|
||
|
TRNG_IRQn = 52, /*!< TRNG Interrupt */
|
||
|
BT_STAMP_IRQn = 53, /*!< BT Playtime Stamp Interrupt */
|
||
|
I2S_HS_SLAVE_IRQn = 54, /*!< I2S HS Slave Interrupt */
|
||
|
PWRKEY_IRQn = 55, /*!< Power Key Interrupt */
|
||
|
ITNPMU_IRQn = 56, /*!< Internal PMU Interrupt */
|
||
|
I2C2_IRQn = 57, /*!< I2C2 Interrupt */
|
||
|
|
||
|
USER_IRQn_QTY,
|
||
|
INVALID_IRQn = USER_IRQn_QTY,
|
||
|
} IRQn_Type;
|
||
|
|
||
|
#define GPIO_IRQn AON_GPIO_IRQn
|
||
|
#define GPADC_IRQn INVALID_IRQn
|
||
|
#define PWRKEY_IRQn INVALID_IRQn
|
||
|
#ifdef CORE_SLEEP_POWER_DOWN
|
||
|
#define TIMER00_IRQn AON_TIMER00_IRQn
|
||
|
#define TIMER01_IRQn AON_TIMER01_IRQn
|
||
|
#else
|
||
|
#define TIMER00_IRQn MCU_TIMER00_IRQn
|
||
|
#define TIMER01_IRQn MCU_TIMER01_IRQn
|
||
|
#endif
|
||
|
#define WDT_IRQn AON_WDT_IRQn
|
||
|
|
||
|
#endif
|
||
|
|
||
|
/* ================================================================================ */
|
||
|
/* ================ Processor and Core Peripheral Section ================ */
|
||
|
/* ================================================================================ */
|
||
|
|
||
|
/* -------- Configuration of Core Peripherals ----------------------------------- */
|
||
|
#define __CM33_REV 0x0000U /* Core revision r0p1 */
|
||
|
#define __SAUREGION_PRESENT 0U /* SAU regions present */
|
||
|
#define __MPU_PRESENT 1U /* MPU present */
|
||
|
#define __VTOR_PRESENT 1U /* VTOR present */
|
||
|
#define __NVIC_PRIO_BITS 3U /* Number of Bits used for Priority Levels */
|
||
|
#define __Vendor_SysTickConfig 0U /* Set to 1 if different SysTick Config is used */
|
||
|
#define __FPU_PRESENT 1U /* FPU present */
|
||
|
#define __DSP_PRESENT 1U /* DSP extension present */
|
||
|
|
||
|
#include "core_cm33.h" /* Processor and core peripherals */
|
||
|
|
||
|
#ifndef __ASSEMBLER__
|
||
|
|
||
|
#include "system_ARMCM.h" /* System Header */
|
||
|
|
||
|
#endif
|
||
|
|
||
|
/* ================================================================================ */
|
||
|
/* ================ Device Specific Peripheral Section ================ */
|
||
|
/* ================================================================================ */
|
||
|
|
||
|
/* ------------------- Start of section using anonymous unions ------------------ */
|
||
|
#if defined (__CC_ARM)
|
||
|
#pragma push
|
||
|
#pragma anon_unions
|
||
|
#elif defined (__ICCARM__)
|
||
|
#pragma language=extended
|
||
|
#elif defined(__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050)
|
||
|
#pragma clang diagnostic push
|
||
|
#pragma clang diagnostic ignored "-Wc11-extensions"
|
||
|
#pragma clang diagnostic ignored "-Wreserved-id-macro"
|
||
|
#elif defined (__GNUC__)
|
||
|
/* anonymous unions are enabled by default */
|
||
|
#elif defined (__TMS470__)
|
||
|
/* anonymous unions are enabled by default */
|
||
|
#elif defined (__TASKING__)
|
||
|
#pragma warning 586
|
||
|
#elif defined (__CSMC__)
|
||
|
/* anonymous unions are enabled by default */
|
||
|
#else
|
||
|
#warning Not supported compiler type
|
||
|
#endif
|
||
|
|
||
|
/* -------------------- End of section using anonymous unions ------------------- */
|
||
|
#if defined (__CC_ARM)
|
||
|
#pragma pop
|
||
|
#elif defined (__ICCARM__)
|
||
|
/* leave anonymous unions enabled */
|
||
|
#elif (defined(__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050))
|
||
|
#pragma clang diagnostic pop
|
||
|
#elif defined (__GNUC__)
|
||
|
/* anonymous unions are enabled by default */
|
||
|
#elif defined (__TMS470__)
|
||
|
/* anonymous unions are enabled by default */
|
||
|
#elif defined (__TASKING__)
|
||
|
#pragma warning restore
|
||
|
#elif defined (__CSMC__)
|
||
|
/* anonymous unions are enabled by default */
|
||
|
#else
|
||
|
#warning Not supported compiler type
|
||
|
#endif
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif
|