161 lines
7.8 KiB
C
161 lines
7.8 KiB
C
/*
|
|
* @brief Basic CMSIS include file
|
|
*
|
|
* @note
|
|
* Copyright(C) NXP Semiconductors, 2013
|
|
* All rights reserved.
|
|
*
|
|
* @par
|
|
* Software that is described herein is for illustrative purposes only
|
|
* which provides customers with programming information regarding the
|
|
* LPC products. This software is supplied "AS IS" without any warranties of
|
|
* any kind, and NXP Semiconductors and its licensor disclaim any and
|
|
* all warranties, express or implied, including all implied warranties of
|
|
* merchantability, fitness for a particular purpose and non-infringement of
|
|
* intellectual property rights. NXP Semiconductors assumes no responsibility
|
|
* or liability for the use of the software, conveys no license or rights under any
|
|
* patent, copyright, mask work right, or any other intellectual property rights in
|
|
* or to any products. NXP Semiconductors reserves the right to make changes
|
|
* in the software without notification. NXP Semiconductors also makes no
|
|
* representation or warranty that such application will be suitable for the
|
|
* specified use without further testing or modification.
|
|
*
|
|
* @par
|
|
* Permission to use, copy, modify, and distribute this software and its
|
|
* documentation is hereby granted, under NXP Semiconductors' and its
|
|
* licensor's relevant copyrights in the software, without fee, provided that it
|
|
* is used in conjunction with NXP Semiconductors microcontrollers. This
|
|
* copyright, permission, and disclaimer notice must appear in all copies of
|
|
* this code.
|
|
*/
|
|
|
|
#ifndef __CMSIS_H_
|
|
#define __CMSIS_H_
|
|
|
|
#include "lpc_types.h"
|
|
|
|
// >>> system config
|
|
#define CHIP_LPC8XX
|
|
#define CHIP_LPC82X
|
|
// <<<
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/** @defgroup CMSIS_8XX_ALL CHIP: LPC8xx CMSIS include file
|
|
* @ingroup CHIP_8XX_Drivers
|
|
* @{
|
|
*/
|
|
|
|
#if defined(__ARMCC_VERSION)
|
|
// Kill warning "#pragma push with no matching #pragma pop"
|
|
#pragma diag_suppress 2525
|
|
#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 push // FIXME not usable for IAR
|
|
#pragma language=extended
|
|
#else
|
|
#error Not supported compiler type
|
|
#endif
|
|
|
|
#if !defined(CORE_M0PLUS)
|
|
#error Please #define CORE_M0PLUS
|
|
#endif
|
|
|
|
/** @defgroup CMSIS_8XX CHIP: LPC8xx Cortex CMSIS definitions
|
|
* @ingroup CMSIS_8XX_ALL
|
|
* @{
|
|
*/
|
|
|
|
/* Configuration of the Cortex-M0+ Processor and Core Peripherals */
|
|
#define __CM0PLUS_REV 0x0001 /*!< Cortex-M0+ Core Revision */
|
|
#define __MPU_PRESENT 0 /*!< MPU present or not */
|
|
#define __VTOR_PRESENT 1 /*!< VTOR is present in this implementation */
|
|
#define __NVIC_PRIO_BITS 2 /*!< Number of Bits used for Priority Levels */
|
|
#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/** @defgroup CMSIS_8XX_IRQ CHIP: LPC8xx peripheral interrupt numbers
|
|
* @ingroup CMSIS_8XX_ALL
|
|
* @{
|
|
*/
|
|
|
|
typedef enum {
|
|
/****** Cortex-M0 Processor Exceptions Numbers ***************************************************/
|
|
Reset_IRQn = -15, /*!< 1 Reset Vector, invoked on Power up and warm reset */
|
|
NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */
|
|
HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */
|
|
SVCall_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */
|
|
PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */
|
|
SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */
|
|
|
|
/****** LPC8xx Specific Interrupt Numbers ********************************************************/
|
|
SPI0_IRQn = 0, /*!< SPI0 */
|
|
SPI1_IRQn = 1, /*!< SPI1 */
|
|
Reserved0_IRQn = 2, /*!< Reserved Interrupt */
|
|
UART0_IRQn = 3, /*!< USART0 */
|
|
UART1_IRQn = 4, /*!< USART1 */
|
|
UART2_IRQn = 5, /*!< USART2 */
|
|
Reserved1_IRQn = 6, /*!< Reserved Interrupt */
|
|
I2C1_IRQn = 7, /*!< I2C1 */
|
|
I2C0_IRQn = 8, /*!< I2C0 */
|
|
I2C_IRQn = 8, /*!< Alias for I2C0 */
|
|
SCT_IRQn = 9, /*!< SCT */
|
|
MRT_IRQn = 10, /*!< MRT */
|
|
CMP_IRQn = 11, /*!< CMP */
|
|
WDT_IRQn = 12, /*!< WDT */
|
|
BOD_IRQn = 13, /*!< BOD */
|
|
FLASH_IRQn = 14, /*!< Flash interrupt */
|
|
WKT_IRQn = 15, /*!< WKT Interrupt */
|
|
ADC_SEQA_IRQn = 16, /*!< ADC sequence A completion */
|
|
ADC_SEQB_IRQn = 17, /*!< ADC sequence B completion */
|
|
ADC_THCMP_IRQn = 18, /*!< ADC threshold compare */
|
|
ADC_OVR_IRQn = 19, /*!< ADC overrun */
|
|
DMA_IRQn = 20, /*!< Reserved Interrupt */
|
|
I2C2_IRQn = 21, /*!< Reserved Interrupt */
|
|
I2C3_IRQn = 22, /*!< Reserved Interrupt */
|
|
Reserved2_IRQn = 23, /*!< Reserved Interrupt */
|
|
PININT0_IRQn = 24, /*!< External Interrupt 0 */
|
|
PIN_INT0_IRQn = 24, /*!< External Interrupt 0 (alias) */
|
|
PININT1_IRQn = 25, /*!< External Interrupt 1 */
|
|
PIN_INT1_IRQn = 25, /*!< External Interrupt 1 (alias) */
|
|
PININT2_IRQn = 26, /*!< External Interrupt 2 */
|
|
PIN_INT2_IRQn = 26, /*!< External Interrupt 2 (alias) */
|
|
PININT3_IRQn = 27, /*!< External Interrupt 3 */
|
|
PIN_INT3_IRQn = 27, /*!< External Interrupt 3 (alias) */
|
|
PININT4_IRQn = 28, /*!< External Interrupt 4 */
|
|
PIN_INT4_IRQn = 28, /*!< External Interrupt 4 (alias) */
|
|
PININT5_IRQn = 29, /*!< External Interrupt 5 */
|
|
PIN_INT5_IRQn = 29, /*!< External Interrupt 5 (alias) */
|
|
PININT6_IRQn = 30, /*!< External Interrupt 6 */
|
|
PIN_INT6_IRQn = 30, /*!< External Interrupt 6 (alias) */
|
|
PININT7_IRQn = 31, /*!< External Interrupt 7 */
|
|
PIN_INT7_IRQn = 31, /*!< External Interrupt 7 (alias) */
|
|
} IRQn_Type;
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
#include "core_cm0plus.h" /*!< Cortex-M0+ processor and core peripherals */
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* __CMSIS_H_ */
|