2012-08-14 18:07:04 -04:00
|
|
|
/*****************************************************************************
|
2013-12-30 17:37:40 -05:00
|
|
|
* Purpose: CMSIS-compliant startup code for LM3S Cortex-M3 devices, GNU-ARM
|
2014-04-06 11:43:13 -04:00
|
|
|
* Last updated for version 5.3.0
|
|
|
|
* Last updated on 2014-02-24
|
2012-08-14 18:07:04 -04:00
|
|
|
*
|
|
|
|
* Q u a n t u m L e a P s
|
|
|
|
* ---------------------------
|
|
|
|
* innovating embedded systems
|
|
|
|
*
|
2014-04-06 11:43:13 -04:00
|
|
|
* Copyright (C) Quantum Leaps, www.state-machine.com.
|
2012-08-14 18:07:04 -04:00
|
|
|
*
|
2013-12-30 17:37:40 -05:00
|
|
|
* This program is open source software: you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License as published
|
|
|
|
* by the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
2012-08-14 18:07:04 -04:00
|
|
|
*
|
2013-12-30 17:37:40 -05:00
|
|
|
* Alternatively, this program may be distributed and modified under the
|
2012-08-14 18:07:04 -04:00
|
|
|
* terms of Quantum Leaps commercial licenses, which expressly supersede
|
2013-12-30 17:37:40 -05:00
|
|
|
* the GNU General Public License and are specifically designed for
|
|
|
|
* licensees interested in retaining the proprietary status of their code.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2012-08-14 18:07:04 -04:00
|
|
|
*
|
|
|
|
* Contact information:
|
2014-04-06 11:43:13 -04:00
|
|
|
* Web: www.state-machine.com
|
|
|
|
* Email: info@state-machine.com
|
2012-08-14 18:07:04 -04:00
|
|
|
*****************************************************************************/
|
|
|
|
|
2013-12-30 17:37:40 -05:00
|
|
|
/* Function prototypes -----------------------------------------------------*/
|
|
|
|
void Reset_Handler(void);
|
|
|
|
void NMI_Handler(void);
|
|
|
|
void HardFault_Handler(void);
|
|
|
|
void MemManage_Handler(void);
|
|
|
|
void BusFault_Handler(void);
|
|
|
|
void UsageFault_Handler(void);
|
|
|
|
void HardFault_Handler(void);
|
|
|
|
void Spurious_Handler(void);
|
|
|
|
|
|
|
|
void assert_failed(char const *file, int line); /* defined in the BSP */
|
|
|
|
|
|
|
|
/*----------------------------------------------------------------------------
|
|
|
|
* weak aliases for each Exception handler to the Spurious_Handler.
|
|
|
|
* Any function with the same name will override these definitions.
|
|
|
|
*/
|
|
|
|
__attribute__ ((weak)) void SVC_Handler(void);
|
|
|
|
__attribute__ ((weak)) void DebugMon_Handler(void);
|
|
|
|
__attribute__ ((weak)) void PendSV_Handler(void);
|
|
|
|
__attribute__ ((weak)) void SysTick_Handler(void);
|
|
|
|
__attribute__ ((weak)) void Spurious_Handler(void);
|
|
|
|
|
|
|
|
/* external interrupts... */
|
|
|
|
__attribute__ ((weak)) void GPIOPortA_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void GPIOPortB_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void GPIOPortC_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void GPIOPortD_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void GPIOPortE_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void UART0_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void UART1_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void SSI0_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void I2C0_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void PWMFault_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void PWMGen0_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void PWMGen1_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void PWMGen2_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void QEI0_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void ADCSeq0_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void ADCSeq1_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void ADCSeq2_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void ADCSeq3_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void Watchdog_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void Timer0A_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void Timer0B_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void Timer1A_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void Timer1B_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void Timer2A_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void Timer2B_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void Comp0_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void Comp1_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void Comp2_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void SysCtrl_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void FlashCtrl_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void GPIOPortF_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void GPIOPortG_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void GPIOPortH_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void UART2_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void SSI1_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void Timer3A_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void Timer3B_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void I2C1_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void QEI1_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void CAN0_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void CAN1_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void CAN2_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void Ethernet_IRQHandler(void);
|
|
|
|
__attribute__ ((weak)) void Hibernate_IRQHandler(void);
|
2012-08-14 18:07:04 -04:00
|
|
|
|
|
|
|
|
|
|
|
/*----------------------------------------------------------------------------
|
|
|
|
* weak aliases for each Exception handler to the Spurious_Handler.
|
|
|
|
* Any function with the same name will override these definitions.
|
|
|
|
*/
|
|
|
|
#pragma weak SVC_Handler = Spurious_Handler
|
|
|
|
#pragma weak DebugMon_Handler = Spurious_Handler
|
|
|
|
#pragma weak PendSV_Handler = Spurious_Handler
|
|
|
|
#pragma weak SysTick_Handler = Spurious_Handler
|
|
|
|
#pragma weak GPIOPortA_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak GPIOPortB_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak GPIOPortC_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak GPIOPortD_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak GPIOPortE_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak UART0_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak UART1_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak SSI0_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak I2C0_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak PWMFault_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak PWMGen0_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak PWMGen1_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak PWMGen2_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak QEI0_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak ADCSeq0_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak ADCSeq1_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak ADCSeq2_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak ADCSeq3_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak Watchdog_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak Timer0A_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak Timer0B_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak Timer1A_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak Timer1B_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak Timer2A_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak Timer2B_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak Comp0_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak Comp1_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak Comp2_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak SysCtrl_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak FlashCtrl_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak GPIOPortF_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak GPIOPortG_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak GPIOPortH_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak UART2_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak SSI1_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak Timer3A_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak Timer3B_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak I2C1_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak QEI1_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak CAN0_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak CAN1_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak CAN2_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak Ethernet_IRQHandler = Spurious_Handler
|
|
|
|
#pragma weak Hibernate_IRQHandler = Spurious_Handler
|
|
|
|
|
2013-12-30 17:37:40 -05:00
|
|
|
|
|
|
|
/* start and end of stack defined in the linker script ---------------------*/
|
|
|
|
extern unsigned __stack_start__;
|
|
|
|
extern unsigned __stack_end__;
|
|
|
|
|
2012-08-14 18:07:04 -04:00
|
|
|
/* exception and interrupt vector table ------------------------------------*/
|
2013-12-30 17:37:40 -05:00
|
|
|
typedef union VectorTableEntryTag {
|
|
|
|
void *pointer; /* used only to initialize the stack top */
|
|
|
|
void (*handler)(void); /* used for all exception and interrupt handlers */
|
2012-08-14 18:07:04 -04:00
|
|
|
} VectorTableEntry;
|
|
|
|
|
|
|
|
/*..........................................................................*/
|
|
|
|
__attribute__ ((section(".isr_vector")))
|
|
|
|
VectorTableEntry const g_pfnVectors[] = {
|
2013-12-30 17:37:40 -05:00
|
|
|
{ .pointer = &__stack_end__ }, /* initial stack pointer */
|
2012-08-14 18:07:04 -04:00
|
|
|
{ .handler = &Reset_Handler }, /* Reset Handler */
|
|
|
|
{ .handler = &NMI_Handler }, /* NMI Handler */
|
|
|
|
{ .handler = &HardFault_Handler }, /* Hard Fault Handler */
|
|
|
|
{ .handler = &MemManage_Handler }, /* MPU Fault Handler */
|
|
|
|
{ .handler = &BusFault_Handler }, /* Bus Fault Handler */
|
|
|
|
{ .handler = &UsageFault_Handler }, /* Usage Fault Handler */
|
|
|
|
{ .handler = &Spurious_Handler }, /* Reserved */
|
|
|
|
{ .handler = &Spurious_Handler }, /* Reserved */
|
|
|
|
{ .handler = &Spurious_Handler }, /* Reserved */
|
|
|
|
{ .handler = &Spurious_Handler }, /* Reserved */
|
|
|
|
{ .handler = &SVC_Handler }, /* SVCall Handler */
|
|
|
|
{ .handler = &DebugMon_Handler }, /* Debug Monitor Handler */
|
|
|
|
{ .handler = &Spurious_Handler }, /* Reserved */
|
|
|
|
{ .handler = &PendSV_Handler }, /* PendSV Handler */
|
|
|
|
{ .handler = &SysTick_Handler }, /* SysTick Handler */
|
|
|
|
/* external interrupts (IRQs) ... */
|
2013-12-30 17:37:40 -05:00
|
|
|
{ .handler = &GPIOPortA_IRQHandler }, /* GPIO Port A */
|
|
|
|
{ .handler = &GPIOPortB_IRQHandler }, /* GPIO Port B */
|
|
|
|
{ .handler = &GPIOPortC_IRQHandler }, /* GPIO Port C */
|
|
|
|
{ .handler = &GPIOPortD_IRQHandler }, /* GPIO Port D */
|
|
|
|
{ .handler = &GPIOPortE_IRQHandler }, /* GPIO Port E */
|
|
|
|
{ .handler = &UART0_IRQHandler }, /* UART0 Rx and Tx */
|
|
|
|
{ .handler = &UART1_IRQHandler }, /* UART1 Rx and Tx */
|
|
|
|
{ .handler = &SSI0_IRQHandler }, /* SSI0 Rx and Tx */
|
|
|
|
{ .handler = &I2C0_IRQHandler }, /* I2C0 Master and Slave */
|
|
|
|
{ .handler = &PWMFault_IRQHandler }, /* PWM Fault */
|
|
|
|
{ .handler = &PWMGen0_IRQHandler }, /* PWM Generator 0 */
|
|
|
|
{ .handler = &PWMGen1_IRQHandler }, /* PWM Generator 1 */
|
|
|
|
{ .handler = &PWMGen2_IRQHandler }, /* PWM Generator 2 */
|
|
|
|
{ .handler = &QEI0_IRQHandler }, /* Quadrature Encoder 0 */
|
|
|
|
{ .handler = &ADCSeq0_IRQHandler }, /* ADC Sequence 0 */
|
|
|
|
{ .handler = &ADCSeq1_IRQHandler }, /* ADC Sequence 1 */
|
|
|
|
{ .handler = &ADCSeq2_IRQHandler }, /* ADC Sequence 2 */
|
|
|
|
{ .handler = &ADCSeq3_IRQHandler }, /* ADC Sequence 3 */
|
|
|
|
{ .handler = &Watchdog_IRQHandler }, /* Watchdog timer */
|
|
|
|
{ .handler = &Timer0A_IRQHandler }, /* Timer 0 subtimer A */
|
|
|
|
{ .handler = &Timer0B_IRQHandler }, /* Timer 0 subtimer B */
|
|
|
|
{ .handler = &Timer1A_IRQHandler }, /* Timer 1 subtimer A */
|
|
|
|
{ .handler = &Timer1B_IRQHandler }, /* Timer 1 subtimer B */
|
|
|
|
{ .handler = &Timer2A_IRQHandler }, /* Timer 2 subtimer A */
|
|
|
|
{ .handler = &Timer2B_IRQHandler }, /* Timer 2 subtimer B */
|
|
|
|
{ .handler = &Comp0_IRQHandler }, /* Analog Comparator 0 */
|
|
|
|
{ .handler = &Comp1_IRQHandler }, /* Analog Comparator 1 */
|
|
|
|
{ .handler = &Comp2_IRQHandler }, /* Analog Comparator 2 */
|
|
|
|
{ .handler = &SysCtrl_IRQHandler }, /* System Control (PLL,OSC,BO) */
|
|
|
|
{ .handler = &FlashCtrl_IRQHandler }, /* FLASH Control */
|
|
|
|
{ .handler = &GPIOPortF_IRQHandler }, /* GPIO Port F */
|
|
|
|
{ .handler = &GPIOPortG_IRQHandler }, /* GPIO Port G */
|
|
|
|
{ .handler = &GPIOPortH_IRQHandler }, /* GPIO Port H */
|
|
|
|
{ .handler = &UART2_IRQHandler }, /* UART2 Rx and Tx */
|
|
|
|
{ .handler = &SSI1_IRQHandler }, /* SSI1 Rx and Tx */
|
|
|
|
{ .handler = &Timer3A_IRQHandler }, /* Timer 3 subtimer A */
|
|
|
|
{ .handler = &Timer3B_IRQHandler }, /* Timer 3 subtimer B */
|
|
|
|
{ .handler = &I2C1_IRQHandler }, /* I2C1 Master and Slave */
|
|
|
|
{ .handler = &QEI1_IRQHandler }, /* Quadrature Encoder 1 */
|
|
|
|
{ .handler = &CAN0_IRQHandler }, /* CAN0 */
|
|
|
|
{ .handler = &CAN1_IRQHandler }, /* CAN1 */
|
|
|
|
{ .handler = &CAN2_IRQHandler }, /* CAN2 */
|
|
|
|
{ .handler = &Ethernet_IRQHandler }, /* Ethernet */
|
|
|
|
{ .handler = &Hibernate_IRQHandler }, /* Hibernate */
|
2012-08-14 18:07:04 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2013-12-30 17:37:40 -05:00
|
|
|
/* exception handlers ------------------------------------------------------*/
|
|
|
|
__attribute__((naked)) void Reset_Handler(void);
|
2012-08-14 18:07:04 -04:00
|
|
|
void Reset_Handler(void) {
|
|
|
|
extern int main(void);
|
|
|
|
extern int __libc_init_array(void);
|
|
|
|
extern unsigned __data_start; /* start of .data in the linker script */
|
|
|
|
extern unsigned __data_end__; /* end of .data in the linker script */
|
|
|
|
extern unsigned const __data_load; /* initialization values for .data */
|
|
|
|
extern unsigned __bss_start__; /* start of .bss in the linker script */
|
|
|
|
extern unsigned __bss_end__; /* end of .bss in the linker script */
|
|
|
|
unsigned const *src;
|
|
|
|
unsigned *dst;
|
|
|
|
|
2014-04-06 11:43:13 -04:00
|
|
|
/* copy the data segment initializers from flash to RAM... */
|
2012-08-14 18:07:04 -04:00
|
|
|
src = &__data_load;
|
|
|
|
for (dst = &__data_start; dst < &__data_end__; ++dst, ++src) {
|
|
|
|
*dst = *src;
|
|
|
|
}
|
|
|
|
/* zero fill the .bss segment... */
|
|
|
|
for (dst = &__bss_start__; dst < &__bss_end__; ++dst) {
|
|
|
|
*dst = 0;
|
|
|
|
}
|
2014-04-06 11:43:13 -04:00
|
|
|
|
|
|
|
/* call all static constructors in C++ (harmless in C programs) */
|
2012-08-14 18:07:04 -04:00
|
|
|
__libc_init_array();
|
|
|
|
|
2013-12-30 17:37:40 -05:00
|
|
|
(void)main(); /* application's entry point, which should never return! */
|
2012-08-14 18:07:04 -04:00
|
|
|
}
|
|
|
|
/*..........................................................................*/
|
2013-12-30 17:37:40 -05:00
|
|
|
__attribute__((naked)) void NMI_Handler(void);
|
|
|
|
void NMI_Handler(void) {
|
2014-04-06 11:43:13 -04:00
|
|
|
__asm volatile (
|
|
|
|
" ldr r0,=str_nmi\n\t"
|
|
|
|
" mov r1,#1\n\t"
|
|
|
|
" b assert_failed\n\t"
|
|
|
|
"str_nmi: .asciz \"NMI\"\n\t"
|
|
|
|
);
|
2013-12-30 17:37:40 -05:00
|
|
|
}
|
|
|
|
/*..........................................................................*/
|
|
|
|
__attribute__((naked)) void MemManage_Handler(void);
|
|
|
|
void MemManage_Handler(void) {
|
2014-04-06 11:43:13 -04:00
|
|
|
__asm volatile (
|
|
|
|
" ldr r0,=str_mem\n\t"
|
|
|
|
" mov r1,#1\n\t"
|
|
|
|
" b assert_failed\n\t"
|
|
|
|
"str_mem: .asciz \"MemManage\"\n\t"
|
|
|
|
);
|
2013-12-30 17:37:40 -05:00
|
|
|
}
|
|
|
|
/*..........................................................................*/
|
|
|
|
__attribute__((naked)) void HardFault_Handler(void);
|
|
|
|
void HardFault_Handler(void) {
|
2014-04-06 11:43:13 -04:00
|
|
|
__asm volatile (
|
|
|
|
" mov r0,sp\n\t"
|
|
|
|
" ldr r1,=__stack_start__\n\t"
|
|
|
|
" cmp r0,r1\n\t"
|
|
|
|
" bcs stack_ok\n\t"
|
|
|
|
" ldr r0,=__stack_end__\n\t"
|
|
|
|
" mov sp,r0\n\t"
|
|
|
|
" ldr r0,=str_overflow\n\t"
|
|
|
|
" mov r1,#1\n\t"
|
|
|
|
" b assert_failed\n\t"
|
|
|
|
"stack_ok:\n\t"
|
|
|
|
" ldr r0,=str_hardfault\n\t"
|
|
|
|
" mov r1,#2\n\t"
|
|
|
|
" b assert_failed\n\t"
|
|
|
|
"str_overflow: .asciz \"StackOverflow\"\n\t"
|
|
|
|
"str_hardfault: .asciz \"HardFault\"\n\t"
|
|
|
|
);
|
2012-08-14 18:07:04 -04:00
|
|
|
}
|
|
|
|
/*..........................................................................*/
|
2013-12-30 17:37:40 -05:00
|
|
|
__attribute__((naked)) void BusFault_Handler(void);
|
|
|
|
void BusFault_Handler(void) {
|
2014-04-06 11:43:13 -04:00
|
|
|
__asm volatile (
|
|
|
|
" ldr r0,=str_bus\n\t"
|
|
|
|
" mov r1,#1\n\t"
|
|
|
|
" b assert_failed\n\t"
|
|
|
|
"str_bus: .asciz \"BusFault\"\n\t"
|
|
|
|
);
|
2013-12-30 17:37:40 -05:00
|
|
|
}
|
|
|
|
/*..........................................................................*/
|
|
|
|
__attribute__((naked)) void UsageFault_Handler(void);
|
|
|
|
void UsageFault_Handler(void) {
|
2014-04-06 11:43:13 -04:00
|
|
|
__asm volatile (
|
|
|
|
" ldr r0,=str_usage\n\t"
|
|
|
|
" mov r1,#1\n\t"
|
|
|
|
" b assert_failed\n\t"
|
|
|
|
"str_usage: .asciz \"UsageFault\"\n\t"
|
|
|
|
);
|
2013-12-30 17:37:40 -05:00
|
|
|
}
|
|
|
|
/*..........................................................................*/
|
|
|
|
__attribute__((naked)) void Spurious_Handler(void);
|
|
|
|
void Spurious_Handler(void) {
|
2014-04-06 11:43:13 -04:00
|
|
|
__asm volatile (
|
|
|
|
" ldr r0,=str_spur\n\t"
|
|
|
|
" mov r1,#1\n\t"
|
|
|
|
" b assert_failed\n\t"
|
|
|
|
"str_spur: .asciz \"Spurious\"\n\t"
|
|
|
|
);
|
2013-12-30 17:37:40 -05:00
|
|
|
}
|
|
|
|
/*..........................................................................*/
|
2012-08-14 18:07:04 -04:00
|
|
|
void _init() {
|
|
|
|
}
|
|
|
|
|
2013-12-30 17:37:40 -05:00
|
|
|
|
2014-04-06 11:43:13 -04:00
|
|
|
|