2020-10-11 19:35:30 +02:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause */
|
|
|
|
/* See the end of this file for copyright, licensing, and warranty information. */
|
2020-06-12 00:03:16 +02:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
/** Reset interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_reset(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Non-maskable interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_nmi(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Hard fault inerrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_hard_fault(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Memory management fault interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_mem_fault(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Bus fault interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_bus_fault(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Usage fault (illegal instruction) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_usage_fault(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** SVC interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_svc(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Debug handler (reserved) */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_debug_mon(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Pending SV interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
extern void irq_pend_sv(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** SysTick interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_sys_tick(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
|
|
|
|
/** Supply Controller (0) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_supc(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Reset Controller (1) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_rstc(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Real-time Clock (2) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_rtc(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Real-time Timer (3) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_rtt(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Watchdog Timer (4) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_wdt(void);
|
|
|
|
/** Power Management Controller (5) interrupt handler */
|
|
|
|
void irq_pmc(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Embedded Flash Controller 0 (6) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_efc0(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Embedded Flash Controller 1 (7) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_efc1(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Universal Asynchronous Receiver Transmitter (8) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_uart(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Static Memory Controller (9) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_smc(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Parallel I/O Controller A (11) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_pioa(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Parallel I/O Controller B (12) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_piob(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Parallel I/O Controller C (13) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_pioc(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Parallel I/O Controller D (14) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_piod(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Universal Synchronous/Asynchronous Receiver Transmitter 0 (17) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_usart0(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Universal Synchronous/Asynchronous Receiver Transmitter 1 (18) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_usart1(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Universal Synchronous/Asynchronous Receiver Transmitter 2 (19) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_usart2(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Universal Synchronous/Asynchronous Receiver Transmitter 3 (20) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_usart3(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Multimedia Card Interface (21) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_hsmci(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Two-Wire Interface 0 (22) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_twi0(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Two-Wire Interface 1 (23) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_twi1(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Serial Peripheral Interface 0 (24) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_spi0(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Synchronous Serial Controller (26) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_ssc(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Timer/Counter 0 (27) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_tc0(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Timer/Counter 1 (28) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_tc1(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Timer/Counter 2 (29) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_tc2(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Timer/Counter 3 (30) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_tc3(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Timer/Counter 4 (31) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_tc4(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Timer/Counter 5 (32) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_tc5(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Timer/Counter 6 (33) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_tc6(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Timer/Counter 7 (34) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_tc7(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Timer/Counter 8 (35) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_tc8(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Pulse Width Modulation Controller (36) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_pwm(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Analog to Digital Converter Controller (37) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_adc(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Digital to Analog Converter Controller (38) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_dacc(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Direct Memory Access Controller (39) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_dmac(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** USB OTG High Speed (40) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_uotghs(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** True Random Number Generator (41) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_trng(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Ethernet MAC (42) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_emac(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Controller Area Network 0 (43) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_can0(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
/** Controller Area Network 1 (44) interrupt handler */
|
2020-10-10 23:15:47 +02:00
|
|
|
void irq_can1(void);
|
2020-06-12 00:03:16 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Interrupt numbers for sam3x8e
|
|
|
|
*/
|
|
|
|
enum irqno {
|
|
|
|
IRQNO_NMI = -14,
|
|
|
|
IRQNO_MEM_FAULT = -12,
|
|
|
|
IRQNO_BUS_FAULT = -11,
|
|
|
|
IRQNO_USAGE_FAULT = -10,
|
|
|
|
IRQNO_SVC_CALL = -5,
|
|
|
|
IRQNO_DEBUG = -4,
|
|
|
|
IRQNO_PEND_SV = -2,
|
|
|
|
IRQNO_SYS_TICK = -1,
|
|
|
|
|
|
|
|
IRQNO_SUPC = 0,
|
|
|
|
IRQNO_RSTC = 1,
|
|
|
|
IRQNO_RTC = 2,
|
|
|
|
IRQNO_RTT = 3,
|
|
|
|
IRQNO_WDT = 4,
|
|
|
|
IRQNO_PMC = 5,
|
|
|
|
IRQNO_EFC0 = 6,
|
|
|
|
IRQNO_EFC1 = 7,
|
|
|
|
IRQNO_UART = 8,
|
|
|
|
IRQNO_SMC = 9,
|
2020-10-10 23:11:21 +02:00
|
|
|
IRQNO_PIOA = 11,
|
2020-06-12 00:03:16 +02:00
|
|
|
IRQNO_PIOB = 12,
|
|
|
|
IRQNO_PIOC = 13,
|
|
|
|
IRQNO_PIOD = 14,
|
|
|
|
IRQNO_USART0 = 17,
|
|
|
|
IRQNO_USART1 = 18,
|
|
|
|
IRQNO_USART2 = 19,
|
|
|
|
IRQNO_USART3 = 20,
|
|
|
|
IRQNO_HSMCI = 21,
|
|
|
|
IRQNO_TWI0 = 22,
|
|
|
|
IRQNO_TWI1 = 23,
|
|
|
|
IRQNO_SPI0 = 24,
|
|
|
|
IRQNO_SSC = 26,
|
|
|
|
IRQNO_TC0 = 27,
|
|
|
|
IRQNO_TC1 = 28,
|
|
|
|
IRQNO_TC2 = 29,
|
|
|
|
IRQNO_TC3 = 30,
|
|
|
|
IRQNO_TC4 = 31,
|
|
|
|
IRQNO_TC5 = 32,
|
|
|
|
IRQNO_TC6 = 33,
|
|
|
|
IRQNO_TC7 = 34,
|
|
|
|
IRQNO_TC8 = 35,
|
|
|
|
IRQNO_PWM = 36,
|
|
|
|
IRQNO_ADC = 37,
|
|
|
|
IRQNO_DACC = 38,
|
|
|
|
IRQNO_DMAC = 39,
|
|
|
|
IRQNO_UOTGHS = 40,
|
|
|
|
IRQNO_TRNG = 41,
|
|
|
|
IRQNO_EMAC = 42,
|
|
|
|
IRQNO_CAN0 = 43,
|
|
|
|
IRQNO_CAN1 = 44,
|
|
|
|
};
|
2020-10-11 19:35:30 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (c) 2020 Felix Kopp <sandtler@sandtler.club>
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without modification, are permitted
|
|
|
|
* provided that the following conditions are met:
|
|
|
|
*
|
|
|
|
* 1. Redistributions of source code must retain the above copyright notice, this list of
|
|
|
|
* conditions and the following disclaimer.
|
|
|
|
* 2. 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.
|
|
|
|
* 3. Neither the name of the copyright holder 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 HOLDER 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.
|
|
|
|
*/
|