aboutsummaryrefslogtreecommitdiff
path: root/lib/lpc43xx
diff options
context:
space:
mode:
authorMichael Ossmann2012-05-22 13:55:50 -0600
committerMichael Ossmann2012-05-22 13:55:50 -0600
commit5e1bcaa5820ea3972e12319b4b5bd1ac09994f45 (patch)
tree3c0e14e3f9d561c40de7a188c517e6f2799b6ec7 /lib/lpc43xx
parent9439ce9d69afeb5e961cbc28ab581c3d4fc3fc60 (diff)
gpio.c, vector.c updated for LPC43xx
Diffstat (limited to 'lib/lpc43xx')
-rw-r--r--lib/lpc43xx/gpio.c2
-rw-r--r--lib/lpc43xx/vector.c181
2 files changed, 165 insertions, 18 deletions
diff --git a/lib/lpc43xx/gpio.c b/lib/lpc43xx/gpio.c
index 6c44081..9134f70 100644
--- a/lib/lpc43xx/gpio.c
+++ b/lib/lpc43xx/gpio.c
@@ -17,7 +17,7 @@
* along with this library. If not, see <http://www.gnu.org/licenses/>.
*/
-#include <libopencm3/lpc17xx/gpio.h>
+#include <libopencm3/lpc43xx/gpio.h>
void gpio_set(u32 gpioport, u32 gpios)
{
diff --git a/lib/lpc43xx/vector.c b/lib/lpc43xx/vector.c
index 016db7a..2d803a1 100644
--- a/lib/lpc43xx/vector.c
+++ b/lib/lpc43xx/vector.c
@@ -2,6 +2,7 @@
* This file is part of the libopencm3 project.
*
* Copyright (C) 2010 Piotr Esden-Tempski <piotr@esden.net>
+ * Copyright (C) 2012 Michael Ossmann <mike@ossmann.com>
*
* This library is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
@@ -36,26 +37,126 @@ void WEAK sv_call_handler(void);
void WEAK debug_monitor_handler(void);
void WEAK pend_sv_handler(void);
void WEAK sys_tick_handler(void);
-
-/* TODO: Interrupt handler prototypes */
+void WEAK dac_irqhandler(void)
+void WEAK m0core_irqhandler(void)
+void WEAK dma_irqhandler(void)
+void WEAK ethernet_irqhandler(void)
+void WEAK sdio_irqhandler(void)
+void WEAK lcd_irqhandler(void)
+void WEAK usb0_irqhandler(void)
+void WEAK usb1_irqhandler(void)
+void WEAK sct_irqhandler(void)
+void WEAK ritimer_irqhandler(void)
+void WEAK timer0_irqhandler(void)
+void WEAK timer1_irqhandler(void)
+void WEAK timer2_irqhandler(void)
+void WEAK timer3_irqhandler(void)
+void WEAK mcpwm_irqhandler(void)
+void WEAK adc0_irqhandler(void)
+void WEAK i2c0_irqhandler(void)
+void WEAK i2c1_irqhandler(void)
+void WEAK spi_irqhandler(void)
+void WEAK adc1_irqhandler(void)
+void WEAK ssp0_irqhandler(void)
+void WEAK ssp1_irqhandler(void)
+void WEAK usart0_irqhandler(void)
+void WEAK uart1_irqhandler(void)
+void WEAK usart2_irqhandler(void)
+void WEAK usart3_irqhandler(void)
+void WEAK i2s0_irqhandler(void)
+void WEAK i2s1_irqhandler(void)
+void WEAK spifi_irqhandler(void)
+void WEAK sgpio_irqhandler(void)
+void WEAK pin_int0_irqhandler(void)
+void WEAK pin_int1_irqhandler(void)
+void WEAK pin_int2_irqhandler(void)
+void WEAK pin_int3_irqhandler(void)
+void WEAK pin_int4_irqhandler(void)
+void WEAK pin_int5_irqhandler(void)
+void WEAK pin_int6_irqhandler(void)
+void WEAK pin_int7_irqhandler(void)
+void WEAK gint0_irqhandler(void)
+void WEAK gint1_irqhandler(void)
+void WEAK eventrouter_irqhandler(void)
+void WEAK c_can1_irqhandler(void)
+void WEAK atimer_irqhandler(void)
+void WEAK rtc_irqhandler(void)
+void WEAK wwdt_irqhandler(void)
+void WEAK c_can0_irqhandler(void)
+void WEAK qei_irqhandler(void)
__attribute__ ((section(".vectors")))
void (*const vector_table[]) (void) = {
- (void*)&_stack, /* Addr: 0x0000_0000 */
- reset_handler, /* Addr: 0x0000_0004 */
- nmi_handler, /* Addr: 0x0000_0008 */
- hard_fault_handler, /* Addr: 0x0000_000C */
- mem_manage_handler, /* Addr: 0x0000_0010 */
- bus_fault_handler, /* Addr: 0x0000_0014 */
- usage_fault_handler, /* Addr: 0x0000_0018 */
- 0, 0, 0, 0, /* Reserved Addr: 0x0000_001C - 0x0000_002B */
- sv_call_handler, /* Addr: 0x0000_002C */
- debug_monitor_handler, /* Addr: 0x0000_0030 */
- 0, /* Reserved Addr: 0x0000_00034 */
- pend_sv_handler, /* Addr: 0x0000_0038 */
- sys_tick_handler, /* Addr: 0x0000_003C */
-};
+ /* Cortex-M4 interrupts */
+ (void*)&_stack,
+ reset_handler,
+ nmi_handler,
+ hard_fault_handler,
+ mem_manage_handler,
+ bus_fault_handler,
+ usage_fault_handler,
+ 0, 0, 0, 0, /* reserved */
+ sv_call_handler,
+ debug_monitor_handler,
+ 0, /* reserved */
+ pend_sv_handler,
+ sys_tick_handler,
+ /* LPC43xx interrupts */
+ dac_irqhandler,
+ m0core_irqhandler,
+ dma_irqhandler,
+ 0, /* reserved */
+ 0, /* reserved */
+ ethernet_irqhandler,
+ sdio_irqhandler,
+ lcd_irqhandler,
+ usb0_irqhandler,
+ usb1_irqhandler,
+ sct_irqhandler,
+ ritimer_irqhandler,
+ timer0_irqhandler,
+ timer1_irqhandler,
+ timer2_irqhandler,
+ timer3_irqhandler,
+ mcpwm_irqhandler,
+ adc0_irqhandler,
+ i2c0_irqhandler,
+ i2c1_irqhandler,
+ spi_irqhandler,
+ adc1_irqhandler,
+ ssp0_irqhandler,
+ ssp1_irqhandler,
+ usart0_irqhandler,
+ uart1_irqhandler,
+ usart2_irqhandler,
+ usart3_irqhandler,
+ i2s0_irqhandler,
+ i2s1_irqhandler,
+ spifi_irqhandler,
+ sgpio_irqhandler,
+ pin_int0_irqhandler,
+ pin_int1_irqhandler,
+ pin_int2_irqhandler,
+ pin_int3_irqhandler,
+ pin_int4_irqhandler,
+ pin_int5_irqhandler,
+ pin_int6_irqhandler,
+ pin_int7_irqhandler,
+ gint0_irqhandler,
+ gint1_irqhandler,
+ eventrouter_irqhandler,
+ c_can1_irqhandler,
+ 0, /* reserved */
+ 0, /* reserved */
+ atimer_irqhandler,
+ rtc_irqhandler,
+ 0, /* reserved */
+ wwdt_irqhandler,
+ 0, /* reserved */
+ c_can0_irqhandler,
+ qei_irqhandler,
+};
void reset_handler(void)
{
@@ -91,4 +192,50 @@ void null_handler(void)
#pragma weak debug_monitor_handler = null_handler
#pragma weak pend_sv_handler = null_handler
#pragma weak sys_tick_handler = null_handler
-/* TODO: Interrupt handler weak aliases */
+#pragma weak dac_irqhandler = null_handler
+#pragma weak m0core_irqhandler = null_handler
+#pragma weak dma_irqhandler = null_handler
+#pragma weak ethernet_irqhandler = null_handler
+#pragma weak sdio_irqhandler = null_handler
+#pragma weak lcd_irqhandler = null_handler
+#pragma weak usb0_irqhandler = null_handler
+#pragma weak usb1_irqhandler = null_handler
+#pragma weak sct_irqhandler = null_handler
+#pragma weak ritimer_irqhandler = null_handler
+#pragma weak timer0_irqhandler = null_handler
+#pragma weak timer1_irqhandler = null_handler
+#pragma weak timer2_irqhandler = null_handler
+#pragma weak timer3_irqhandler = null_handler
+#pragma weak mcpwm_irqhandler = null_handler
+#pragma weak adc0_irqhandler = null_handler
+#pragma weak i2c0_irqhandler = null_handler
+#pragma weak i2c1_irqhandler = null_handler
+#pragma weak spi_irqhandler = null_handler
+#pragma weak adc1_irqhandler = null_handler
+#pragma weak ssp0_irqhandler = null_handler
+#pragma weak ssp1_irqhandler = null_handler
+#pragma weak usart0_irqhandler = null_handler
+#pragma weak uart1_irqhandler = null_handler
+#pragma weak usart2_irqhandler = null_handler
+#pragma weak usart3_irqhandler = null_handler
+#pragma weak i2s0_irqhandler = null_handler
+#pragma weak i2s1_irqhandler = null_handler
+#pragma weak spifi_irqhandler = null_handler
+#pragma weak sgpio_irqhandler = null_handler
+#pragma weak pin_int0_irqhandler = null_handler
+#pragma weak pin_int1_irqhandler = null_handler
+#pragma weak pin_int2_irqhandler = null_handler
+#pragma weak pin_int3_irqhandler = null_handler
+#pragma weak pin_int4_irqhandler = null_handler
+#pragma weak pin_int5_irqhandler = null_handler
+#pragma weak pin_int6_irqhandler = null_handler
+#pragma weak pin_int7_irqhandler = null_handler
+#pragma weak gint0_irqhandler = null_handler
+#pragma weak gint1_irqhandler = null_handler
+#pragma weak eventrouter_irqhandler = null_handler
+#pragma weak c_can1_irqhandler = null_handler
+#pragma weak atimer_irqhandler = null_handler
+#pragma weak rtc_irqhandler = null_handler
+#pragma weak wwdt_irqhandler = null_handler
+#pragma weak c_can0_irqhandler = null_handler
+#pragma weak qei_irqhandler = null_handler