source: rtems/c/src/lib/libbsp/arm/lpc24xx/include/irq.h @ 4a6cc2a

4.115
Last change on this file since 4a6cc2a was 4a6cc2a, checked in by Sebastian Huber <sebastian.huber@…>, on 11/08/11 at 10:39:46

2011-11-08 Sebastian Huber <sebastian.huber@…>

  • include/lpc17xx.h: New file.
  • Makefile.am, preinstall.am: Reflect change above. Update due to API changes.
  • configure.ac, console/console-config.c, include/bsp.h, include/io.h, include/irq.h, include/lcd.h, include/lpc-clock-config.h, include/lpc24xx.h, include/start-config.h, irq/irq-dispatch.c, irq/irq.c, misc/bspidle.c, misc/io.c, misc/lcd.c, misc/restart.c, misc/system-clocks.c, ssp/ssp.c, startup/bspreset.c, startup/bspstart.c, startup/bspstarthooks.c, startup/start-config-emc-dynamic.c, startup/start-config-emc-static.c, startup/start-config-pinsel.c: Basic support for LPC17XX. New memory configurations for W9825G2JB75I, IS42S32800B, and SST39VF3201.
  • Property mode set to 100644
File size: 2.3 KB
Line 
1/**
2 * @file
3 *
4 * @ingroup bsp_interrupt
5 *
6 * @brief LPC24XX interrupt definitions.
7 */
8
9/*
10 * Copyright (c) 2008-2011 embedded brains GmbH.  All rights reserved.
11 *
12 *  embedded brains GmbH
13 *  Obere Lagerstr. 30
14 *  82178 Puchheim
15 *  Germany
16 *  <rtems@embedded-brains.de>
17 *
18 * The license and distribution terms for this file may be
19 * found in the file LICENSE in this distribution or at
20 * http://www.rtems.com/license/LICENSE.
21 */
22
23#ifndef LIBBSP_ARM_LPC24XX_IRQ_H
24#define LIBBSP_ARM_LPC24XX_IRQ_H
25
26#ifndef ASM
27  #include <rtems.h>
28  #include <rtems/irq.h>
29  #include <rtems/irq-extension.h>
30#endif
31
32/**
33 * @addtogroup bsp_interrupt
34 *
35 * @{
36 */
37
38#define BSP_INTERRUPT_VECTOR_MIN 0
39
40#ifdef ARM_MULTILIB_ARCH_V4
41  #define LPC24XX_IRQ_WDT 0
42  #define LPC24XX_IRQ_SOFTWARE 1
43  #define LPC24XX_IRQ_ARM_CORE_0 2
44  #define LPC24XX_IRQ_ARM_CORE_1 3
45  #define LPC24XX_IRQ_TIMER_0 4
46  #define LPC24XX_IRQ_TIMER_1 5
47  #define LPC24XX_IRQ_UART_0 6
48  #define LPC24XX_IRQ_UART_1 7
49  #define LPC24XX_IRQ_PWM 8
50  #define LPC24XX_IRQ_I2C_0 9
51  #define LPC24XX_IRQ_SPI_SSP_0 10
52  #define LPC24XX_IRQ_SSP_1 11
53  #define LPC24XX_IRQ_PLL 12
54  #define LPC24XX_IRQ_RTC 13
55  #define LPC24XX_IRQ_EINT_0 14
56  #define LPC24XX_IRQ_EINT_1 15
57  #define LPC24XX_IRQ_EINT_2 16
58  #define LPC24XX_IRQ_EINT_3 17
59  #define LPC24XX_IRQ_ADC_0 18
60  #define LPC24XX_IRQ_I2C_1 19
61  #define LPC24XX_IRQ_BOD 20
62  #define LPC24XX_IRQ_ETHERNET 21
63  #define LPC24XX_IRQ_USB 22
64  #define LPC24XX_IRQ_CAN 23
65  #define LPC24XX_IRQ_SD_MMC 24
66  #define LPC24XX_IRQ_DMA 25
67  #define LPC24XX_IRQ_TIMER_2 26
68  #define LPC24XX_IRQ_TIMER_3 27
69  #define LPC24XX_IRQ_UART_2 28
70  #define LPC24XX_IRQ_UART_3 29
71  #define LPC24XX_IRQ_I2C_2 30
72  #define LPC24XX_IRQ_I2S 31
73
74  #define BSP_INTERRUPT_VECTOR_MAX 31
75#endif
76
77#define LPC24XX_IRQ_PRIORITY_VALUE_MIN 0
78#ifdef ARM_MULTILIB_ARCH_V4
79  #define LPC24XX_IRQ_PRIORITY_VALUE_MAX 15
80#endif
81#define LPC24XX_IRQ_PRIORITY_COUNT (LPC24XX_IRQ_PRIORITY_VALUE_MAX + 1)
82#define LPC24XX_IRQ_PRIORITY_HIGHEST LPC24XX_IRQ_PRIORITY_VALUE_MIN
83#define LPC24XX_IRQ_PRIORITY_LOWEST LPC24XX_IRQ_PRIORITY_VALUE_MAX
84
85#ifndef ASM
86
87void lpc24xx_irq_set_priority(rtems_vector_number vector, unsigned priority);
88
89unsigned lpc24xx_irq_get_priority(rtems_vector_number vector);
90
91void bsp_interrupt_dispatch(void);
92
93#endif /* ASM */
94
95/** @} */
96
97#endif /* LIBBSP_ARM_LPC24XX_IRQ_H */
Note: See TracBrowser for help on using the repository browser.