mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 01:52:45 +01:00
226 lines
11 KiB
C
226 lines
11 KiB
C
//*****************************************************************************
|
|
//
|
|
// hw_ints.h - Macros that define the interrupt assignment on Stellaris.
|
|
//
|
|
// Copyright (c) 2005-2012 Texas Instruments Incorporated. All rights reserved.
|
|
// Software License Agreement
|
|
//
|
|
// 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 Texas Instruments Incorporated 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 THE COPYRIGHT
|
|
// OWNER OR 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.
|
|
//
|
|
// This is part of revision 9453 of the Stellaris Firmware Development Package.
|
|
//
|
|
//*****************************************************************************
|
|
|
|
#ifndef STELLARIS_HW_INTS_H
|
|
#define STELLARIS_HW_INTS_H
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// The following are defines for the fault assignments.
|
|
//
|
|
//*****************************************************************************
|
|
#define FAULT_NMI 2 // NMI fault
|
|
#define FAULT_HARD 3 // Hard fault
|
|
#define FAULT_MPU 4 // MPU fault
|
|
#define FAULT_BUS 5 // Bus fault
|
|
#define FAULT_USAGE 6 // Usage fault
|
|
#define FAULT_SVCALL 11 // SVCall
|
|
#define FAULT_DEBUG 12 // Debug monitor
|
|
#define FAULT_PENDSV 14 // PendSV
|
|
#define FAULT_SYSTICK 15 // System Tick
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// The following are defines for the interrupt assignments.
|
|
//
|
|
//*****************************************************************************
|
|
#define INT_GPIOA 16 // GPIO Port A
|
|
#define INT_GPIOB 17 // GPIO Port B
|
|
#define INT_GPIOC 18 // GPIO Port C
|
|
#define INT_GPIOD 19 // GPIO Port D
|
|
#define INT_GPIOE 20 // GPIO Port E
|
|
#define INT_UART0 21 // UART0 Rx and Tx
|
|
#define INT_UART1 22 // UART1 Rx and Tx
|
|
#define INT_SSI0 23 // SSI0 Rx and Tx
|
|
#define INT_I2C0 24 // I2C0 Master and Slave
|
|
#define INT_PWM0_FAULT 25 // PWM0 Fault
|
|
#define INT_PWM0_0 26 // PWM0 Generator 0
|
|
#define INT_PWM0_1 27 // PWM0 Generator 1
|
|
#define INT_PWM0_2 28 // PWM0 Generator 2
|
|
#define INT_QEI0 29 // Quadrature Encoder 0
|
|
#define INT_ADC0SS0 30 // ADC0 Sequence 0
|
|
#define INT_ADC0SS1 31 // ADC0 Sequence 1
|
|
#define INT_ADC0SS2 32 // ADC0 Sequence 2
|
|
#define INT_ADC0SS3 33 // ADC0 Sequence 3
|
|
#define INT_WATCHDOG 34 // Watchdog timer
|
|
#define INT_TIMER0A 35 // Timer 0 subtimer A
|
|
#define INT_TIMER0B 36 // Timer 0 subtimer B
|
|
#define INT_TIMER1A 37 // Timer 1 subtimer A
|
|
#define INT_TIMER1B 38 // Timer 1 subtimer B
|
|
#define INT_TIMER2A 39 // Timer 2 subtimer A
|
|
#define INT_TIMER2B 40 // Timer 2 subtimer B
|
|
#define INT_COMP0 41 // Analog Comparator 0
|
|
#define INT_COMP1 42 // Analog Comparator 1
|
|
#define INT_COMP2 43 // Analog Comparator 2
|
|
#define INT_SYSCTL 44 // System Control (PLL, OSC, BO)
|
|
#define INT_FLASH 45 // FLASH Control
|
|
#define INT_GPIOF 46 // GPIO Port F
|
|
#define INT_GPIOG 47 // GPIO Port G
|
|
#define INT_GPIOH 48 // GPIO Port H
|
|
#define INT_UART2 49 // UART2 Rx and Tx
|
|
#define INT_SSI1 50 // SSI1 Rx and Tx
|
|
#define INT_TIMER3A 51 // Timer 3 subtimer A
|
|
#define INT_TIMER3B 52 // Timer 3 subtimer B
|
|
#define INT_I2C1 53 // I2C1 Master and Slave
|
|
#define INT_QEI1 54 // Quadrature Encoder 1
|
|
#define INT_CAN0 55 // CAN0
|
|
#define INT_CAN1 56 // CAN1
|
|
#define INT_CAN2 57 // CAN2
|
|
#define INT_ETH 58 // Ethernet
|
|
#define INT_HIBERNATE 59 // Hibernation module
|
|
#define INT_USB0 60 // USB 0 Controller
|
|
#define INT_PWM0_3 61 // PWM0 Generator 3
|
|
#define INT_UDMA 62 // uDMA controller
|
|
#define INT_UDMAERR 63 // uDMA Error
|
|
#define INT_ADC1SS0 64 // ADC1 Sequence 0
|
|
#define INT_ADC1SS1 65 // ADC1 Sequence 1
|
|
#define INT_ADC1SS2 66 // ADC1 Sequence 2
|
|
#define INT_ADC1SS3 67 // ADC1 Sequence 3
|
|
#define INT_I2S0 68 // I2S0
|
|
#define INT_EPI0 69 // EPI0
|
|
#define INT_GPIOJ 70 // GPIO Port J
|
|
#define INT_GPIOK 71 // GPIO Port K
|
|
#define INT_GPIOL 72 // GPIO Port L
|
|
#define INT_SSI2 73 // SSI2
|
|
#define INT_SSI3 74 // SSI3
|
|
#define INT_UART3 75 // UART3
|
|
#define INT_UART4 76 // UART4
|
|
#define INT_UART5 77 // UART5
|
|
#define INT_UART6 78 // UART6
|
|
#define INT_UART7 79 // UART7
|
|
#define INT_I2C2 84 // I2C2
|
|
#define INT_I2C3 85 // I2C3
|
|
#define INT_TIMER4A 86 // Timer 4A
|
|
#define INT_TIMER4B 87 // Timer 4B
|
|
#define INT_TIMER5A 108 // Timer 5A
|
|
#define INT_TIMER5B 109 // Timer 5B
|
|
#define INT_WTIMER0A 110 // Wide Timer 0A
|
|
#define INT_WTIMER0B 111 // Wide Timer 0B
|
|
#define INT_WTIMER1A 112 // Wide Timer 1A
|
|
#define INT_WTIMER1B 113 // Wide Timer 1B
|
|
#define INT_WTIMER2A 114 // Wide Timer 2A
|
|
#define INT_WTIMER2B 115 // Wide Timer 2B
|
|
#define INT_WTIMER3A 116 // Wide Timer 3A
|
|
#define INT_WTIMER3B 117 // Wide Timer 3B
|
|
#define INT_WTIMER4A 118 // Wide Timer 4A
|
|
#define INT_WTIMER4B 119 // Wide Timer 4B
|
|
#define INT_WTIMER5A 120 // Wide Timer 5A
|
|
#define INT_WTIMER5B 121 // Wide Timer 5B
|
|
#define INT_SYSEXC 122 // System Exception (imprecise)
|
|
#define INT_PECI0 123 // PECI 0
|
|
#define INT_LPC0 124 // LPC 0
|
|
#define INT_I2C4 125 // I2C4
|
|
#define INT_I2C5 126 // I2C5
|
|
#define INT_GPIOM 127 // GPIO Port M
|
|
#define INT_GPION 128 // GPIO Port N
|
|
#define INT_FAN0 130 // FAN 0
|
|
#define INT_GPIOP0 132 // GPIO Port P (Summary or P0)
|
|
#define INT_GPIOP1 133 // GPIO Port P1
|
|
#define INT_GPIOP2 134 // GPIO Port P2
|
|
#define INT_GPIOP3 135 // GPIO Port P3
|
|
#define INT_GPIOP4 136 // GPIO Port P4
|
|
#define INT_GPIOP5 137 // GPIO Port P5
|
|
#define INT_GPIOP6 138 // GPIO Port P6
|
|
#define INT_GPIOP7 139 // GPIO Port P7
|
|
#define INT_GPIOQ0 140 // GPIO Port Q (Summary or Q0)
|
|
#define INT_GPIOQ1 141 // GPIO Port Q1
|
|
#define INT_GPIOQ2 142 // GPIO Port Q2
|
|
#define INT_GPIOQ3 143 // GPIO Port Q3
|
|
#define INT_GPIOQ4 144 // GPIO Port Q4
|
|
#define INT_GPIOQ5 145 // GPIO Port Q5
|
|
#define INT_GPIOQ6 146 // GPIO Port Q6
|
|
#define INT_GPIOQ7 147 // GPIO Port Q7
|
|
#define INT_PWM1_0 150 // PWM1 Generator 0
|
|
#define INT_PWM1_1 151 // PWM1 Generator 1
|
|
#define INT_PWM1_2 152 // PWM1 Generator 2
|
|
#define INT_PWM1_3 153 // PWM1 Generator 3
|
|
#define INT_PWM1_FAULT 154 // PWM1 Fault
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// The following are defines for the total number of interrupts.
|
|
//
|
|
//*****************************************************************************
|
|
#define NUM_INTERRUPTS 155
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// The following are defines for the total number of priority levels.
|
|
//
|
|
//*****************************************************************************
|
|
#define NUM_PRIORITY 8
|
|
#define NUM_PRIORITY_BITS 3
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// The following definitions are deprecated.
|
|
//
|
|
//*****************************************************************************
|
|
#ifndef DEPRECATED
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// The following are deprecated defines for the interrupt assignments.
|
|
//
|
|
//*****************************************************************************
|
|
#define INT_SSI 23 // SSI Rx and Tx
|
|
#define INT_I2C 24 // I2C Master and Slave
|
|
#define INT_PWM_FAULT 25 // PWM Fault
|
|
#define INT_PWM0 26 // PWM Generator 0
|
|
#define INT_PWM1 27 // PWM Generator 1
|
|
#define INT_PWM2 28 // PWM Generator 2
|
|
#define INT_QEI 29 // Quadrature Encoder
|
|
#define INT_ADC0 30 // ADC Sequence 0
|
|
#define INT_ADC1 31 // ADC Sequence 1
|
|
#define INT_ADC2 32 // ADC Sequence 2
|
|
#define INT_ADC3 33 // ADC Sequence 3
|
|
#define INT_PWM3 61 // PWM Generator 3
|
|
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* STELLARIS_HW_INTS_H */
|