mbed library sources

Fork of mbed-src by mbed official

Revision:
232:1e593fe58241
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/targets/cmsis/TARGET_NXP/TARGET_LPC15XX/TOOLCHAIN_GCC_CR/startup_LPC15xx.cpp	Tue Jun 17 11:00:07 2014 +0100
@@ -0,0 +1,219 @@
+extern "C" {
+
+#include "LPC15xx.h"
+
+#define WEAK          __attribute__ ((weak))
+#define ALIAS(f)      __attribute__ ((weak, alias (#f)))
+#define AFTER_VECTORS __attribute__ ((section(".after_vectors")))void ResetISR(void);
+
+extern unsigned int __data_section_table;
+extern unsigned int __data_section_table_end;
+extern unsigned int __bss_section_table;
+extern unsigned int __bss_section_table_end;
+
+
+extern void __libc_init_array(void);
+extern int main(void);
+extern void _vStackTop(void);
+extern void (* const g_pfnVectors[])(void);
+
+	 void ResetISR          (void);
+WEAK void NMI_Handler(void);
+WEAK void HardFault_Handler(void);
+WEAK void MemManage_Handler(void);
+WEAK void BusFault_Handler(void);
+WEAK void UsageFault_Handler(void);
+WEAK void SVC_Handler(void);
+WEAK void DebugMon_Handler(void);
+WEAK void PendSV_Handler(void);
+WEAK void SysTick_Handler(void);
+WEAK void IntDefaultHandler(void);
+
+
+void WDT_IRQHandler(void) ALIAS(IntDefaultHandler);
+void BOD_IRQHandler(void) ALIAS(IntDefaultHandler);
+void FMC_IRQHandler(void) ALIAS(IntDefaultHandler);
+void EEPROM_IRQHandler(void) ALIAS(IntDefaultHandler);
+void DMA_IRQHandler(void) ALIAS(IntDefaultHandler);
+void GINT0_IRQHandler(void) ALIAS(IntDefaultHandler);
+void GINT1_IRQHandler(void) ALIAS(IntDefaultHandler);
+void PIN_INT0_IRQHandler(void) ALIAS(IntDefaultHandler);
+void PIN_INT1_IRQHandler(void) ALIAS(IntDefaultHandler);
+void PIN_INT2_IRQHandler(void) ALIAS(IntDefaultHandler);
+void PIN_INT3_IRQHandler(void) ALIAS(IntDefaultHandler);
+void PIN_INT4_IRQHandler(void) ALIAS(IntDefaultHandler);
+void PIN_INT5_IRQHandler(void) ALIAS(IntDefaultHandler);
+void PIN_INT6_IRQHandler(void) ALIAS(IntDefaultHandler);
+void PIN_INT7_IRQHandler(void) ALIAS(IntDefaultHandler);
+void RIT_IRQHandler(void) ALIAS(IntDefaultHandler);
+void SCT0_IRQHandler(void) ALIAS(IntDefaultHandler);
+void SCT1_IRQHandler(void) ALIAS(IntDefaultHandler);
+void SCT2_IRQHandler(void) ALIAS(IntDefaultHandler);
+void SCT3_IRQHandler(void) ALIAS(IntDefaultHandler);
+void MRT_IRQHandler(void) ALIAS(IntDefaultHandler);
+void UART0_IRQHandler(void) ALIAS(IntDefaultHandler);
+void UART1_IRQHandler(void) ALIAS(IntDefaultHandler);
+void UART2_IRQHandler(void) ALIAS(IntDefaultHandler);
+void I2C0_IRQHandler(void) ALIAS(IntDefaultHandler);
+void SPI0_IRQHandler(void) ALIAS(IntDefaultHandler);
+void SPI1_IRQHandler(void) ALIAS(IntDefaultHandler);
+void CAN_IRQHandler(void) ALIAS(IntDefaultHandler);
+void USB_IRQHandler(void) ALIAS(IntDefaultHandler);
+void USB_FIQHandler(void) ALIAS(IntDefaultHandler);
+void USBWakeup_IRQHandler(void) ALIAS(IntDefaultHandler);
+void ADC0A_IRQHandler(void) ALIAS(IntDefaultHandler);
+void ADC0B_IRQHandler(void) ALIAS(IntDefaultHandler);
+void ADC0_THCMP_IRQHandler(void) ALIAS(IntDefaultHandler);
+void ADC0_OVR_IRQHandler(void) ALIAS(IntDefaultHandler);
+void ADC1A_IRQHandler(void) ALIAS(IntDefaultHandler);
+void ADC1B_IRQHandler(void) ALIAS(IntDefaultHandler);
+void ADC1_THCMP_IRQHandler(void) ALIAS(IntDefaultHandler);
+void ADC1_OVR_IRQHandler(void) ALIAS(IntDefaultHandler);
+void DAC_IRQHandler(void) ALIAS(IntDefaultHandler);
+void ACMP0_IRQHandler(void) ALIAS(IntDefaultHandler);
+void ACMP1_IRQHandler(void) ALIAS(IntDefaultHandler);
+void ACMP2_IRQHandler(void) ALIAS(IntDefaultHandler);
+void ACMP3_IRQHandler(void) ALIAS(IntDefaultHandler);
+void QEI_IRQHandler(void) ALIAS(IntDefaultHandler);
+void RTC_ALARM_IRQHandler(void) ALIAS(IntDefaultHandler);
+void RTC_WAKE_IRQHandler(void) ALIAS(IntDefaultHandler);
+
+
+__attribute__ ((section(".isr_vector")))
+void (* const g_pfnVectors[])(void) = {
+	// Core Level - CM3
+	&_vStackTop,                       // The initial stack pointer
+	ResetISR,                          // The reset handler
+	NMI_Handler,                       // The NMI handler
+	HardFault_Handler,                 // The hard fault handler
+	MemManage_Handler,                 // The MPU fault handler
+	BusFault_Handler,                  // The bus fault handler
+	UsageFault_Handler,                // The usage fault handler
+	0,                                 // Reserved
+	0,                                 // Reserved
+	0,                                 // Reserved
+	0,                                 // Reserved
+	SVC_Handler,                       // SVCall handler
+	DebugMon_Handler,                  // Debug monitor handler
+	0,                                 // Reserved
+	PendSV_Handler,                    // The PendSV handler
+	SysTick_Handler,                   // The SysTick handler
+
+    // Chip Level - LPC15xx
+    WDT_IRQHandler,                    //  0 - Windowed watchdog timer
+    BOD_IRQHandler,                    //  1 - BOD
+    FMC_IRQHandler,                    //  2 - Flash controller
+    EEPROM_IRQHandler,                 //  3 - EEPROM controller
+    DMA_IRQHandler,                    //  4 - DMA
+    GINT0_IRQHandler,                  //  5 - GINT0
+    GINT1_IRQHandler,                  //  6 - GINT1
+    PIN_INT0_IRQHandler,               //  7 - PIO INT0
+    PIN_INT1_IRQHandler,               //  8 - PIO INT1
+    PIN_INT2_IRQHandler,               //  9 - PIO INT2
+    PIN_INT3_IRQHandler,               // 10 - PIO INT3
+    PIN_INT4_IRQHandler,               // 11 - PIO INT4
+    PIN_INT5_IRQHandler,               // 12 - PIO INT5
+    PIN_INT6_IRQHandler,               // 13 - PIO INT6
+    PIN_INT7_IRQHandler,               // 14 - PIO INT7
+    RIT_IRQHandler,                    // 15 - RIT
+    SCT0_IRQHandler,                   // 16 - State configurable timer
+    SCT1_IRQHandler,                   // 17 - State configurable timer
+    SCT2_IRQHandler,                   // 18 - State configurable timer
+    SCT3_IRQHandler,                   // 19 - State configurable timer
+    MRT_IRQHandler,                    // 20 - Multi-Rate Timer
+    UART0_IRQHandler,                  // 21 - UART0
+    UART1_IRQHandler,                  // 22 - UART1
+    UART2_IRQHandler,                  // 23 - UART2
+    I2C0_IRQHandler,                   // 24 - I2C0 controller
+    SPI0_IRQHandler,                   // 25 - SPI0 controller
+    SPI1_IRQHandler,                   // 26 - SPI1 controller
+    CAN_IRQHandler,                    // 27 - C_CAN0
+    USB_IRQHandler,                    // 28 - USB IRQ
+    USB_FIQHandler,                    // 29 - USB FIQ
+    USBWakeup_IRQHandler,              // 30 - USB wake-up
+    ADC0A_IRQHandler,            	   // 31 - ADC0 sequence A completion
+    ADC0B_IRQHandler,              	   // 32 - ADC0 sequence B completion
+    ADC0_THCMP_IRQHandler,             // 33 - ADC0 threshold compare
+    ADC0_OVR_IRQHandler,               // 34 - ADC0 overrun
+    ADC1A_IRQHandler,                  // 35 - ADC1 sequence A completion
+    ADC1B_IRQHandler,                  // 36 - ADC1 sequence B completion
+    ADC1_THCMP_IRQHandler,             // 37 - ADC1 threshold compare
+    ADC1_OVR_IRQHandler,               // 38 - ADC1 overrun
+    DAC_IRQHandler,                    // 39 - DAC
+    ACMP0_IRQHandler,                  // 40 - Analog Comparator 0
+    ACMP1_IRQHandler,                  // 41 - Analog Comparator 1
+    ACMP2_IRQHandler,                  // 42 - Analog Comparator 2
+    ACMP3_IRQHandler,                  // 43 - Analog Comparator 3
+    QEI_IRQHandler,                    // 44 - QEI
+    RTC_ALARM_IRQHandler,              // 45 - RTC alarm
+    RTC_WAKE_IRQHandler,               // 46 - RTC wake-up
+
+}; 
+/* End Vector */
+
+AFTER_VECTORS void data_init(unsigned int romstart, unsigned int start, unsigned int len) {
+    unsigned int *pulDest = (unsigned int*) start;
+    unsigned int *pulSrc = (unsigned int*) romstart;
+    unsigned int loop;
+    for (loop = 0; loop < len; loop = loop + 4) *pulDest++ = *pulSrc++;
+}
+
+AFTER_VECTORS void bss_init(unsigned int start, unsigned int len) {
+    unsigned int *pulDest = (unsigned int*) start;
+    unsigned int loop;
+    for (loop = 0; loop < len; loop = loop + 4) *pulDest++ = 0;
+}
+
+
+/* Reset entry point*/
+extern "C" void software_init_hook(void) __attribute__((weak));
+
+AFTER_VECTORS void ResetISR(void) {
+    unsigned int LoadAddr, ExeAddr, SectionLen;
+    unsigned int *SectionTableAddr;
+    
+    SectionTableAddr = &__data_section_table;
+    
+    while (SectionTableAddr < &__data_section_table_end) {
+        LoadAddr = *SectionTableAddr++;
+        ExeAddr = *SectionTableAddr++;
+        SectionLen = *SectionTableAddr++;
+        data_init(LoadAddr, ExeAddr, SectionLen);
+    }
+    while (SectionTableAddr < &__bss_section_table_end) {
+        ExeAddr = *SectionTableAddr++;
+        SectionLen = *SectionTableAddr++;
+        bss_init(ExeAddr, SectionLen);
+    }
+    
+    SystemInit();
+    if (software_init_hook) 
+        software_init_hook(); 
+    else {
+        __libc_init_array();
+        main();
+    }
+    while (1) {;}
+}
+
+AFTER_VECTORS void NMI_Handler       (void) {}
+AFTER_VECTORS void HardFault_Handler (void) {}
+AFTER_VECTORS void MemManage_Handler (void) {}
+AFTER_VECTORS void BusFault_Handler  (void) {}
+AFTER_VECTORS void UsageFault_Handler(void) {}
+AFTER_VECTORS void SVC_Handler       (void) {}
+AFTER_VECTORS void DebugMon_Handler  (void) {}
+AFTER_VECTORS void PendSV_Handler    (void) {}
+AFTER_VECTORS void SysTick_Handler   (void) {}
+AFTER_VECTORS void IntDefaultHandler (void) {}
+
+int __aeabi_atexit(void *object, void (*destructor)(void *), void *dso_handle) {return 0;}
+}
+
+#include <stdlib.h>
+
+void *operator new(size_t size)  {return malloc(size);}
+void *operator new[](size_t size){return malloc(size);}
+
+void operator delete(void *p)   {free(p);}
+void operator delete[](void *p) {free(p);}