cc26x0.h
5.21 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/*
* Copyright (C) 2016 Leon George
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @ingroup cpu_cc26x0_definitions
* @{
*
* @file
* @brief CC26x0 MCU interrupt definitions
*
* @author Leon M. George <leon@georgemail.eu>
*/
#ifndef CC26X0_H
#define CC26X0_H
#include <stdint.h>
#ifdef __cplusplus
extern "C" {
#endif
typedef volatile uint8_t reg8_t;
typedef volatile uint32_t reg32_t;
/** @addtogroup CC26x0_cmsis CMSIS Definitions */
/*@{*/
/** interrupt number definition */
typedef enum IRQn
{
/****** Cortex-M3 Processor Exceptions Numbers ****************************/
ResetHandler_IRQn = -15, /**< 1 Reset Handler */
NonMaskableInt_IRQn = -14, /**< 2 Non Maskable Interrupt */
HardFault_IRQn = -13, /**< 3 Cortex-M3 Hard Fault 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 */
/****** CC26x0 specific Interrupt Numbers *********************************/
EDGE_DETECT_IRQN = 0, /**< 16 AON edge detect */
I2C_IRQN = 1, /**< 17 I2C */
RF_CPE1_IRQN = 2, /**< 18 RF Command and Packet Engine 1 */
SPIS_IRQN = 3, /**< 19 AON SpiSplave Rx, Tx and CS */
AON_RTC_IRQN = 4, /**< 20 AON RTC */
UART0_IRQN = 5, /**< 21 UART0 Rx and Tx */
AON_AUX_SWEV0_IRQN = 6, /**< 22 Sensor Controller software event 0, through AON domain*/
SSI0_IRQN = 7, /**< 23 SSI0 Rx and Tx */
SSI1_IRQN = 8, /**< 24 SSI1 Rx and Tx */
RF_CPE0_IRQN = 9, /**< 25 RF Command and Packet Engine 0 */
RF_HW_IRQN = 10, /**< 26 RF Core Hardware */
RF_CMD_ACK_IRQN = 11, /**< 27 RF Core Command Acknowledge */
I2S_IRQN = 12, /**< 28 I2S */
AON_AUX_SWEV1_IRQN = 13, /**< 29 Sensor Controller software event 1, through AON domain*/
WATCHDOG_IRQN = 14, /**< 30 Watchdog timer */
GPTIMER_0A_IRQN = 15, /**< 31 Timer 0 subtimer A */
GPTIMER_0B_IRQN = 16, /**< 32 Timer 0 subtimer B */
GPTIMER_1A_IRQN = 17, /**< 33 Timer 1 subtimer A */
GPTIMER_1B_IRQN = 18, /**< 34 Timer 1 subtimer B */
GPTIMER_2A_IRQN = 19, /**< 35 Timer 2 subtimer A */
GPTIMER_2B_IRQN = 20, /**< 36 Timer 2 subtimer B */
GPTIMER_3A_IRQN = 21, /**< 37 Timer 3 subtimer A */
GPTIMER_3B_IRQN = 22, /**< 38 Timer 3 subtimer B */
CRYPTO_IRQN = 23, /**< 39 Crypto Core Result available */
UDMA_IRQN = 24, /**< 40 uDMA Software */
UDMA_ERR_IRQN = 25, /**< 41 uDMA Error */
FLASH_CTRL_IRQN = 26, /**< 42 Flash controller */
SW0_IRQN = 27, /**< 43 Software Event 0 */
AUX_COMBO_IRQN = 28, /**< 44 AUX combined event, directly to MCU domain*/
AON_PRG0_IRQN = 29, /**< 45 AON programmable 0 */
PROG_IRQN = 30, /**< 46 Dynamic Programmable interrupt (default source: PRCM)*/
AUX_COMPA_IRQN = 31, /**< 47 AUX Comparator A */
AUX_ADC_IRQN = 32, /**< 48 AUX ADC IRQ */
TRNG_IRQN = 33, /**< 49 TRNG event */
IRQN_COUNT = (TRNG_IRQN + 1) /**< Number of peripheral IDs */
} IRQn_Type;
/**
* @brief Configuration of the Cortex-M3 processor and core peripherals
*/
#define __MPU_PRESENT 1 /**< CC26x0 does provide a MPU */
#define __NVIC_PRIO_BITS 3 /**< CC26x0 offers priority levels from 0..7 */
#define __Vendor_SysTickConfig 0 /**< Set to 1 if different SysTick config is used */
#define RCOSC48M_FREQ 48000000 /**< 48 MHz */
#define RCOSC24M_FREQ 24000000 /**< 24 MHz */
/**
* @brief CMSIS includes
*/
#include <core_cm3.h>
/*@}*/
/** @ingroup cpu_specific_peripheral_memory_map
* @{
*/
#define FLASH_BASE 0x00000000 /**< FLASH base address */
/*@}*/
#ifdef __cplusplus
}
#endif
#endif /* CC26X0_H */
/*@}*/