Update GCC porting of LPC178x

This commit is contained in:
Bernard Xiong 2013-03-29 16:28:11 +08:00
parent 8e6a534fa3
commit aaf0186852
4 changed files with 75 additions and 229 deletions

View File

@ -9,6 +9,16 @@
//*** <<< Use Configuration Wizard in Context Menu >>> *** //*** <<< Use Configuration Wizard in Context Menu >>> ***
*/ */
.syntax unified
.cpu cortex-m3
.fpu softvfp
.thumb
.word _sidata
.word _sdata
.word _edata
.word _sbss
.word _ebss
/* /*
// <h> Stack Configuration // <h> Stack Configuration
@ -16,7 +26,7 @@
// </h> // </h>
*/ */
.equ Stack_Size, 0x00000100 .equ Stack_Size, 0x00000200
.section ".stack", "w" .section ".stack", "w"
.align 3 .align 3
.globl __cs3_stack_mem .globl __cs3_stack_mem
@ -28,26 +38,6 @@ __cs3_stack_mem:
.size __cs3_stack_mem, . - __cs3_stack_mem .size __cs3_stack_mem, . - __cs3_stack_mem
.set __cs3_stack_size, . - __cs3_stack_mem .set __cs3_stack_size, . - __cs3_stack_mem
/*
// <h> Heap Configuration
// <o> Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
// </h>
*/
.equ Heap_Size, 0x00001000
.section ".heap", "w"
.align 3
.globl __cs3_heap_start
.globl __cs3_heap_end
__cs3_heap_start:
.if Heap_Size
.space Heap_Size
.endif
__cs3_heap_end:
/* Vector Table */ /* Vector Table */
.section ".cs3.interrupt_vector" .section ".cs3.interrupt_vector"
@ -56,7 +46,7 @@ __cs3_heap_end:
__cs3_interrupt_vector_cortex_m: __cs3_interrupt_vector_cortex_m:
.long __cs3_stack /* Top of Stack */ .long __cs3_stack /* Top of Stack */
.long __cs3_reset /* Reset Handler */ .long Reset_Handler /* Reset Handler */
.long NMI_Handler /* NMI Handler */ .long NMI_Handler /* NMI Handler */
.long HardFault_Handler /* Hard Fault Handler */ .long HardFault_Handler /* Hard Fault Handler */
.long MemManage_Handler /* MPU Fault Handler */ .long MemManage_Handler /* MPU Fault Handler */
@ -86,7 +76,7 @@ __cs3_interrupt_vector_cortex_m:
.long I2C0_IRQHandler /* 26: I2C0 */ .long I2C0_IRQHandler /* 26: I2C0 */
.long I2C1_IRQHandler /* 27: I2C1 */ .long I2C1_IRQHandler /* 27: I2C1 */
.long I2C2_IRQHandler /* 28: I2C2 */ .long I2C2_IRQHandler /* 28: I2C2 */
.long SPIFI_IRQHandler /* 29: SPIFI */ .long SPIFI_IRQHandler /* 29: SPIFI */
.long SSP0_IRQHandler /* 30: SSP0 */ .long SSP0_IRQHandler /* 30: SSP0 */
.long SSP1_IRQHandler /* 31: SSP1 */ .long SSP1_IRQHandler /* 31: SSP1 */
.long PLL0_IRQHandler /* 32: PLL0 Lock (Main PLL) */ .long PLL0_IRQHandler /* 32: PLL0 Lock (Main PLL) */
@ -102,61 +92,65 @@ __cs3_interrupt_vector_cortex_m:
.long DMA_IRQHandler /* 42: General Purpose DMA */ .long DMA_IRQHandler /* 42: General Purpose DMA */
.long I2S_IRQHandler /* 43: I2S */ .long I2S_IRQHandler /* 43: I2S */
.long ENET_IRQHandler /* 44: Ethernet */ .long ENET_IRQHandler /* 44: Ethernet */
.long MCI_IRQHandler /* 45: SD/MMC Card */ .long MCI_IRQHandler /* 45: SD/MMC Card */
.long MCPWM_IRQHandler /* 46: Motor Control PWM */ .long MCPWM_IRQHandler /* 46: Motor Control PWM */
.long QEI_IRQHandler /* 47: Quadrature Encoder Interface */ .long QEI_IRQHandler /* 47: Quadrature Encoder Interface */
.long PLL1_IRQHandler /* 48: PLL1 Lock (USB PLL) */ .long PLL1_IRQHandler /* 48: PLL1 Lock (USB PLL) */
.long USBActivity_IRQHandler /* 49: USB Activity */ .long USBActivity_IRQHandler /* 49: USB Activity */
.long CANActivity_IRQHandler /* 50: CAN Activity */ .long CANActivity_IRQHandler /* 50: CAN Activity */
.long UART4_IRQHandler /* 51: UART4 */ .long UART4_IRQHandler /* 51: UART4 */
.long SSP2_IRQHandler /* 52: SSP2 */ .long SSP2_IRQHandler /* 52: SSP2 */
.long LCD_IRQHandler /* 53: LCD */ .long LCD_IRQHandler /* 53: LCD */
.long GPIO_IRQHandler /* 54: GPIO */ .long GPIO_IRQHandler /* 54: GPIO */
.long PWM0_IRQHandler /* 55: PWM0 */ .long PWM0_IRQHandler /* 55: PWM0 */
.long EEPROM_IRQHandler /* 56: EEPROM */ .long EEPROM_IRQHandler /* 56: EEPROM */
.size __cs3_interrupt_vector_cortex_m, . - __cs3_interrupt_vector_cortex_m .size __cs3_interrupt_vector_cortex_m, . - __cs3_interrupt_vector_cortex_m
.thumb
/* Reset Handler */ /* Reset Handler */
.section .text.Reset_Handler
.section .cs3.reset,"x",%progbits .weak Reset_Handler
.thumb_func .type Reset_Handler, %function
.globl __cs3_reset_cortex_m Reset_Handler:
.type __cs3_reset_cortex_m, %function
__cs3_reset_cortex_m:
.fnstart .fnstart
#if (RAM_MODE) /* Copy the data segment initializers from flash to SRAM */
/* Clear .bss section (Zero init) */ movs r1, #0
MOV R0, #0 b LoopCopyDataInit
LDR R1, =__bss_start__
LDR R2, =__bss_end__ CopyDataInit:
CMP R1,R2 ldr r3, =_sidata
BEQ BSSIsEmpty ldr r3, [r3, r1]
LoopZI: str r3, [r0, r1]
CMP R1, R2 add r1, r1, #4
BHS BSSIsEmpty
STR R0, [R1] LoopCopyDataInit:
ADD R1, #4 ldr r0, =_sdata
BLO LoopZI ldr r3, =_edata
BSSIsEmpty: add r2, r0, r1
LDR R0, =SystemInit cmp r2, r3
BLX R0 bcc CopyDataInit
LDR R0,=main ldr r2, =_sbss
BX R0 b LoopFillZerobss
#else /* Zero fill the bss segment. */
LDR R0, =SystemInit FillZerobss:
BLX R0 movs r3, #0
LDR R0,=_start str r3, [r2], #4
BX R0
#endif LoopFillZerobss:
ldr r3, = _ebss
cmp r2, r3
bcc FillZerobss
/* Call the clock system intitialization function.*/
bl SystemInit
/* Call the application's entry point.*/
bl main
bx lr
.pool .pool
.cantunwind .cantunwind
.fnend .fnend
.size __cs3_reset_cortex_m,.-__cs3_reset_cortex_m .size Reset_Handler,.-Reset_Handler
.section ".text" .section ".text"
@ -243,7 +237,7 @@ Default_Handler:
IRQ I2C0_IRQHandler IRQ I2C0_IRQHandler
IRQ I2C1_IRQHandler IRQ I2C1_IRQHandler
IRQ I2C2_IRQHandler IRQ I2C2_IRQHandler
IRQ SPIFI_IRQHandler IRQ SPIFI_IRQHandler
IRQ SSP0_IRQHandler IRQ SSP0_IRQHandler
IRQ SSP1_IRQHandler IRQ SSP1_IRQHandler
IRQ PLL0_IRQHandler IRQ PLL0_IRQHandler
@ -263,13 +257,13 @@ Default_Handler:
IRQ MCPWM_IRQHandler IRQ MCPWM_IRQHandler
IRQ QEI_IRQHandler IRQ QEI_IRQHandler
IRQ PLL1_IRQHandler IRQ PLL1_IRQHandler
IRQ USBActivity_IRQHandler IRQ USBActivity_IRQHandler
IRQ CANActivity_IRQHandler IRQ CANActivity_IRQHandler
IRQ UART4_IRQHandler IRQ UART4_IRQHandler
IRQ SSP2_IRQHandler IRQ SSP2_IRQHandler
IRQ LCD_IRQHandler IRQ LCD_IRQHandler
IRQ GPIO_IRQHandler IRQ GPIO_IRQHandler
IRQ PWM0_IRQHandler IRQ PWM0_IRQHandler
IRQ EEPROM_IRQHandler IRQ EEPROM_IRQHandler
.end .end

View File

@ -1,133 +0,0 @@
/*
* linker script for LPC1788 (512kB Flash, 48kB + 48kB SRAM ) with GNU ld
* yiyue.fang 2012-04-14
*/
/* Program Entry, set to mark it as "used" and avoid gc */
MEMORY
{
CODE (rx) : ORIGIN = 0x00000000, LENGTH = 0x00080000
DATA (rw) : ORIGIN = 0x10000000, LENGTH = 0x00010000
}
ENTRY(Reset_Handler)
_system_stack_size = 0x200;
SECTIONS
{
.text :
{
. = ALIGN(4);
KEEP(*(.interrupt_vector)) /* Startup code */
. = ALIGN(4);
*(.text) /* remaining code */
*(.text.*) /* remaining code */
*(.rodata) /* read-only data (constants) */
*(.rodata*)
*(.glue_7)
*(.glue_7t)
*(.gnu.linkonce.t*)
/* section information for finsh shell */
. = ALIGN(4);
__fsymtab_start = .;
KEEP(*(FSymTab))
__fsymtab_end = .;
. = ALIGN(4);
__vsymtab_start = .;
KEEP(*(VSymTab))
__vsymtab_end = .;
. = ALIGN(4);
. = ALIGN(4);
_etext = .;
} > CODE = 0
/* .ARM.exidx is sorted, so has to go in its own output section. */
__exidx_start = .;
.ARM.exidx :
{
*(.ARM.exidx* .gnu.linkonce.armexidx.*)
/* This is used by the startup in order to initialize the .data secion */
_sidata = .;
} > CODE
__exidx_end = .;
/* .data section which is used for initialized data */
.data : AT (_sidata)
{
. = ALIGN(4);
/* This is used by the startup in order to initialize the .data secion */
_sdata = . ;
*(.data)
*(.data.*)
*(.gnu.linkonce.d*)
. = ALIGN(4);
/* This is used by the startup in order to initialize the .data secion */
_edata = . ;
} >DATA
.stack :
{
. = . + _system_stack_size;
. = ALIGN(4);
_estack = .;
} >DATA
__bss_start = .;
.bss :
{
. = ALIGN(4);
/* This is used by the startup in order to initialize the .bss secion */
_sbss = .;
*(.bss)
*(.bss.*)
*(COMMON)
. = ALIGN(4);
/* This is used by the startup in order to initialize the .bss secion */
_ebss = . ;
*(.bss.init)
} > DATA
__bss_end = .;
_end = .;
/* Stabs debugging sections. */
.stab 0 : { *(.stab) }
.stabstr 0 : { *(.stabstr) }
.stab.excl 0 : { *(.stab.excl) }
.stab.exclstr 0 : { *(.stab.exclstr) }
.stab.index 0 : { *(.stab.index) }
.stab.indexstr 0 : { *(.stab.indexstr) }
.comment 0 : { *(.comment) }
/* DWARF debug sections.
* Symbols in the DWARF debugging sections are relative to the beginning
* of the section so we begin them at 0. */
/* DWARF 1 */
.debug 0 : { *(.debug) }
.line 0 : { *(.line) }
/* GNU DWARF 1 extensions */
.debug_srcinfo 0 : { *(.debug_srcinfo) }
.debug_sfnames 0 : { *(.debug_sfnames) }
/* DWARF 1.1 and DWARF 2 */
.debug_aranges 0 : { *(.debug_aranges) }
.debug_pubnames 0 : { *(.debug_pubnames) }
/* DWARF 2 */
.debug_info 0 : { *(.debug_info .gnu.linkonce.wi.*) }
.debug_abbrev 0 : { *(.debug_abbrev) }
.debug_line 0 : { *(.debug_line) }
.debug_frame 0 : { *(.debug_frame) }
.debug_str 0 : { *(.debug_str) }
.debug_loc 0 : { *(.debug_loc) }
.debug_macinfo 0 : { *(.debug_macinfo) }
/* SGI/MIPS DWARF 2 extensions */
.debug_weaknames 0 : { *(.debug_weaknames) }
.debug_funcnames 0 : { *(.debug_funcnames) }
.debug_typenames 0 : { *(.debug_typenames) }
.debug_varnames 0 : { *(.debug_varnames) }
}

View File

@ -1,15 +0,0 @@
; *************************************************************
; *** Scatter-Loading Description File generated by uVision ***
; *************************************************************
LR_IROM1 0x00000000 0x00080000 { ; load region size_region
ER_IROM1 0x00000000 0x00080000 { ; load address = execution address
*.o (RESET, +First)
*(InRoot$$Sections)
.ANY (+RO)
}
RW_IRAM1 0x10000000 0x00010000 { ; RW data
.ANY (+RW +ZI)
}
}

View File

@ -70,12 +70,12 @@ SECTIONS
_edata = . ; _edata = . ;
} >DATA } >DATA
.stack : .stack :
{ {
. = . + _system_stack_size; . = . + _system_stack_size;
. = ALIGN(4); . = ALIGN(4);
_estack = .; _estack = .;
} >DATA } >DATA
__bss_start = .; __bss_start = .;
.bss : .bss :