fix LPC812 PWM
Fork of mbed-dev by
targets/cmsis/TARGET_NXP/TARGET_LPC23XX/TOOLCHAIN_GCC_CR/LPC2368.ld@129:2e517c56bcfb, 2016-05-16 (annotated)
- Committer:
- nameless129
- Date:
- Mon May 16 16:50:30 2016 +0000
- Revision:
- 129:2e517c56bcfb
- Parent:
- 0:9b334a45a8ff
PWM Fix:Duty 0%??H???????????????
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
bogdanm | 0:9b334a45a8ff | 1 | OUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm", "elf32-littlearm") |
bogdanm | 0:9b334a45a8ff | 2 | OUTPUT_ARCH(arm) |
bogdanm | 0:9b334a45a8ff | 3 | ENTRY(vectors) |
bogdanm | 0:9b334a45a8ff | 4 | |
bogdanm | 0:9b334a45a8ff | 5 | GROUP( libgcc.a libc.a libm.a libcr_newlib_nohost.a crti.o crtn.o crtbegin.o crtend.o ) |
bogdanm | 0:9b334a45a8ff | 6 | |
bogdanm | 0:9b334a45a8ff | 7 | /* Memory Definitions: */ |
bogdanm | 0:9b334a45a8ff | 8 | MEMORY |
bogdanm | 0:9b334a45a8ff | 9 | { |
bogdanm | 0:9b334a45a8ff | 10 | Flash (rx) : ORIGIN = 0x00000000, LENGTH = 512k |
bogdanm | 0:9b334a45a8ff | 11 | Ram (rwx) : ORIGIN = 0x40000000, LENGTH = 32k |
bogdanm | 0:9b334a45a8ff | 12 | UsbRam (rw) : ORIGIN = 0x7FD00000, LENGTH = 8k |
bogdanm | 0:9b334a45a8ff | 13 | EthRam (rw) : ORIGIN = 0x7FE00000, LENGTH = 16k |
bogdanm | 0:9b334a45a8ff | 14 | CanRam (rw) : ORIGIN = 0xE0038000, LENGTH = 2k |
bogdanm | 0:9b334a45a8ff | 15 | BatRam (rw) : ORIGIN = 0xE0084000, LENGTH = 2k |
bogdanm | 0:9b334a45a8ff | 16 | } |
bogdanm | 0:9b334a45a8ff | 17 | |
bogdanm | 0:9b334a45a8ff | 18 | /* Stack sizes: */ |
bogdanm | 0:9b334a45a8ff | 19 | UND_Stack_Size = 16; |
bogdanm | 0:9b334a45a8ff | 20 | SVC_Stack_Size = 512; |
bogdanm | 0:9b334a45a8ff | 21 | ABT_Stack_Size = 16; |
bogdanm | 0:9b334a45a8ff | 22 | FIQ_Stack_Size = 16; |
bogdanm | 0:9b334a45a8ff | 23 | IRQ_Stack_Size = 256; |
bogdanm | 0:9b334a45a8ff | 24 | Stack_Size_Total = UND_Stack_Size + SVC_Stack_Size + ABT_Stack_Size + FIQ_Stack_Size + IRQ_Stack_Size; |
bogdanm | 0:9b334a45a8ff | 25 | |
bogdanm | 0:9b334a45a8ff | 26 | /* Stack tops for each mode: */ |
bogdanm | 0:9b334a45a8ff | 27 | __und_stack_top__ = __stacks_top__; |
bogdanm | 0:9b334a45a8ff | 28 | __abt_stack_top__ = __und_stack_top__ - UND_Stack_Size ; |
bogdanm | 0:9b334a45a8ff | 29 | __fiq_stack_top__ = __abt_stack_top__ - ABT_Stack_Size ; |
bogdanm | 0:9b334a45a8ff | 30 | __irq_stack_top__ = __fiq_stack_top__ - FIQ_Stack_Size ; |
bogdanm | 0:9b334a45a8ff | 31 | __svc_stack_top__ = __irq_stack_top__ - IRQ_Stack_Size ; |
bogdanm | 0:9b334a45a8ff | 32 | |
bogdanm | 0:9b334a45a8ff | 33 | /* C-accessible symbols for memory address ranges: */ |
bogdanm | 0:9b334a45a8ff | 34 | __FLASH_segment_start__ = ORIGIN( Flash ); |
bogdanm | 0:9b334a45a8ff | 35 | __FLASH_segment_end__ = ORIGIN( Flash ) + LENGTH( Flash ); |
bogdanm | 0:9b334a45a8ff | 36 | __SRAM_segment_start__ = ORIGIN( Ram ); |
bogdanm | 0:9b334a45a8ff | 37 | __SRAM_segment_end__ = ORIGIN( Ram ) + LENGTH( Ram ); |
bogdanm | 0:9b334a45a8ff | 38 | |
bogdanm | 0:9b334a45a8ff | 39 | /* Stacks (full descending) at top of RAM, grows downward: |
bogdanm | 0:9b334a45a8ff | 40 | * |
bogdanm | 0:9b334a45a8ff | 41 | * __stack_min__ is used by the malloc implementation to ensure heap never collides |
bogdanm | 0:9b334a45a8ff | 42 | * with stack (assuming stack never grows beyond Stack_Size_Total in length) */ |
bogdanm | 0:9b334a45a8ff | 43 | __stacks_top__ = __SRAM_segment_end__; |
bogdanm | 0:9b334a45a8ff | 44 | __stacks_min__ = __SRAM_segment_end__ - Stack_Size_Total; |
bogdanm | 0:9b334a45a8ff | 45 | |
bogdanm | 0:9b334a45a8ff | 46 | SECTIONS |
bogdanm | 0:9b334a45a8ff | 47 | { |
bogdanm | 0:9b334a45a8ff | 48 | /* first section is .text which is used for code */ |
bogdanm | 0:9b334a45a8ff | 49 | __text_start__ = . ; |
bogdanm | 0:9b334a45a8ff | 50 | .text : { |
bogdanm | 0:9b334a45a8ff | 51 | __privileged_code_start__ = . ; |
bogdanm | 0:9b334a45a8ff | 52 | KEEP( *( .vectors ) ) |
bogdanm | 0:9b334a45a8ff | 53 | *( .privileged_code ) |
bogdanm | 0:9b334a45a8ff | 54 | |
bogdanm | 0:9b334a45a8ff | 55 | __privileged_code_end__ = .; |
bogdanm | 0:9b334a45a8ff | 56 | |
bogdanm | 0:9b334a45a8ff | 57 | *( .text .text.* .gnu.linkonce.t.* ) |
bogdanm | 0:9b334a45a8ff | 58 | *( .plt ) |
bogdanm | 0:9b334a45a8ff | 59 | *( .gnu.warning ) |
bogdanm | 0:9b334a45a8ff | 60 | *( .glue_7t ) *( .glue_7 ) *( .vfp11_veneer ) |
bogdanm | 0:9b334a45a8ff | 61 | |
bogdanm | 0:9b334a45a8ff | 62 | *( .rodata .rodata.* .gnu.linkonce.r.* ) |
bogdanm | 0:9b334a45a8ff | 63 | |
bogdanm | 0:9b334a45a8ff | 64 | *(.ARM.extab* .gnu.linkonce.armextab.*) |
bogdanm | 0:9b334a45a8ff | 65 | *(.gcc_except_table) |
bogdanm | 0:9b334a45a8ff | 66 | *(.eh_frame_hdr) |
bogdanm | 0:9b334a45a8ff | 67 | *(.eh_frame) |
bogdanm | 0:9b334a45a8ff | 68 | |
bogdanm | 0:9b334a45a8ff | 69 | . = ALIGN( 4 ) ; |
bogdanm | 0:9b334a45a8ff | 70 | KEEP( *( .init ) ) |
bogdanm | 0:9b334a45a8ff | 71 | . = ALIGN( 4 ) ; |
bogdanm | 0:9b334a45a8ff | 72 | __preinit_array_start = . ; |
bogdanm | 0:9b334a45a8ff | 73 | KEEP( *( .preinit_array ) ) |
bogdanm | 0:9b334a45a8ff | 74 | __preinit_array_end = . ; |
bogdanm | 0:9b334a45a8ff | 75 | . = ALIGN( 4 ) ; |
bogdanm | 0:9b334a45a8ff | 76 | __init_array_start = . ; |
bogdanm | 0:9b334a45a8ff | 77 | KEEP( *( SORT( .init_array.* ) ) ) |
bogdanm | 0:9b334a45a8ff | 78 | KEEP( *( .init_array ) ) |
bogdanm | 0:9b334a45a8ff | 79 | __init_array_end = . ; |
bogdanm | 0:9b334a45a8ff | 80 | |
bogdanm | 0:9b334a45a8ff | 81 | . = ALIGN( 4 ) ; |
bogdanm | 0:9b334a45a8ff | 82 | KEEP( *crtbegin.o( .ctors ) ) |
bogdanm | 0:9b334a45a8ff | 83 | KEEP( *( EXCLUDE_FILE( *crtend.o ) .ctors ) ) |
bogdanm | 0:9b334a45a8ff | 84 | KEEP( *( SORT( .ctors.* ) ) ) |
bogdanm | 0:9b334a45a8ff | 85 | KEEP( *crtend.o( .ctors ) ) |
bogdanm | 0:9b334a45a8ff | 86 | |
bogdanm | 0:9b334a45a8ff | 87 | . = ALIGN( 4 ) ; |
bogdanm | 0:9b334a45a8ff | 88 | KEEP( *( .fini ) ) |
bogdanm | 0:9b334a45a8ff | 89 | . = ALIGN( 4 ) ; |
bogdanm | 0:9b334a45a8ff | 90 | __fini_array_start = . ; |
bogdanm | 0:9b334a45a8ff | 91 | KEEP( *( .fini_array ) ) |
bogdanm | 0:9b334a45a8ff | 92 | KEEP( *( SORT( .fini_array.* ) ) ) |
bogdanm | 0:9b334a45a8ff | 93 | __fini_array_end = . ; |
bogdanm | 0:9b334a45a8ff | 94 | |
bogdanm | 0:9b334a45a8ff | 95 | KEEP( *crtbegin.o( .dtors ) ) |
bogdanm | 0:9b334a45a8ff | 96 | KEEP( *( EXCLUDE_FILE( *crtend.o ) .dtors ) ) |
bogdanm | 0:9b334a45a8ff | 97 | KEEP( *( SORT( .dtors.* ) ) ) |
bogdanm | 0:9b334a45a8ff | 98 | KEEP( *crtend.o( .dtors ) ) |
bogdanm | 0:9b334a45a8ff | 99 | |
bogdanm | 0:9b334a45a8ff | 100 | } >Flash |
bogdanm | 0:9b334a45a8ff | 101 | |
bogdanm | 0:9b334a45a8ff | 102 | __exidx_start = . ; |
bogdanm | 0:9b334a45a8ff | 103 | .ARM.exidx : { |
bogdanm | 0:9b334a45a8ff | 104 | *( .ARM.exidx* .gnu.linkonce.armexidx.* ) |
bogdanm | 0:9b334a45a8ff | 105 | } >Flash |
bogdanm | 0:9b334a45a8ff | 106 | __exidx_end = . ; |
bogdanm | 0:9b334a45a8ff | 107 | |
bogdanm | 0:9b334a45a8ff | 108 | .text.align : { . = ALIGN( 8 ) ; } >Flash /* Alignment schenanigans */ |
bogdanm | 0:9b334a45a8ff | 109 | __text_end__ = . ; |
bogdanm | 0:9b334a45a8ff | 110 | |
bogdanm | 0:9b334a45a8ff | 111 | /* .bss section -- used for uninitialized data */ |
bogdanm | 0:9b334a45a8ff | 112 | /* Located at the start of RAM */ |
bogdanm | 0:9b334a45a8ff | 113 | .bss (NOLOAD) : { |
bogdanm | 0:9b334a45a8ff | 114 | __bss_start__ = . ; |
bogdanm | 0:9b334a45a8ff | 115 | *crt0.o( .ram_vectors ) |
bogdanm | 0:9b334a45a8ff | 116 | |
bogdanm | 0:9b334a45a8ff | 117 | __user_bss_start__ = . ; |
bogdanm | 0:9b334a45a8ff | 118 | *( .user_bss ) |
bogdanm | 0:9b334a45a8ff | 119 | __user_bss_end__ = . ; |
bogdanm | 0:9b334a45a8ff | 120 | |
bogdanm | 0:9b334a45a8ff | 121 | *( .shbss ) |
bogdanm | 0:9b334a45a8ff | 122 | *( .bss .bss.* .gnu.linkonce.b.* ) |
bogdanm | 0:9b334a45a8ff | 123 | *( COMMON ) |
bogdanm | 0:9b334a45a8ff | 124 | *( .ram.b ) |
bogdanm | 0:9b334a45a8ff | 125 | . = ALIGN( 8 ) ; |
bogdanm | 0:9b334a45a8ff | 126 | |
bogdanm | 0:9b334a45a8ff | 127 | __bss_end__ = . ; |
bogdanm | 0:9b334a45a8ff | 128 | } >Ram AT>Flash |
bogdanm | 0:9b334a45a8ff | 129 | |
bogdanm | 0:9b334a45a8ff | 130 | /* .data section -- used for initialized data */ |
bogdanm | 0:9b334a45a8ff | 131 | .data : { |
bogdanm | 0:9b334a45a8ff | 132 | __data_start__ = . ; |
bogdanm | 0:9b334a45a8ff | 133 | KEEP( *( .jcr ) ) |
bogdanm | 0:9b334a45a8ff | 134 | *( .got.plt ) *( .got ) |
bogdanm | 0:9b334a45a8ff | 135 | *( .shdata ) |
bogdanm | 0:9b334a45a8ff | 136 | *( .data .data.* .gnu.linkonce.d.* ) |
bogdanm | 0:9b334a45a8ff | 137 | *( .ram ) |
bogdanm | 0:9b334a45a8ff | 138 | . = ALIGN( 8 ) ; |
bogdanm | 0:9b334a45a8ff | 139 | __data_end__ = . ; |
bogdanm | 0:9b334a45a8ff | 140 | } >Ram AT>Flash |
bogdanm | 0:9b334a45a8ff | 141 | |
bogdanm | 0:9b334a45a8ff | 142 | __data_init_start__ = LOADADDR( .data ) ; |
bogdanm | 0:9b334a45a8ff | 143 | |
bogdanm | 0:9b334a45a8ff | 144 | /* Heap starts here and grows up in memory */ |
bogdanm | 0:9b334a45a8ff | 145 | . = ALIGN( 8 ) ; |
bogdanm | 0:9b334a45a8ff | 146 | __heap_start__ = . ; |
bogdanm | 0:9b334a45a8ff | 147 | _pvHeapStart = . ; |
bogdanm | 0:9b334a45a8ff | 148 | end = . ; |
bogdanm | 0:9b334a45a8ff | 149 | |
bogdanm | 0:9b334a45a8ff | 150 | .stab 0 (NOLOAD) : { *(.stab) } |
bogdanm | 0:9b334a45a8ff | 151 | .stabstr 0 (NOLOAD) : { *(.stabstr) } |
bogdanm | 0:9b334a45a8ff | 152 | /* DWARF debug sections. */ |
bogdanm | 0:9b334a45a8ff | 153 | /* Symbols in the DWARF debugging sections are relative to the */ |
bogdanm | 0:9b334a45a8ff | 154 | /* beginning of the section so we begin them at 0. */ |
bogdanm | 0:9b334a45a8ff | 155 | /* DWARF 1 */ |
bogdanm | 0:9b334a45a8ff | 156 | .debug 0 : { *(.debug) } |
bogdanm | 0:9b334a45a8ff | 157 | .line 0 : { *(.line) } |
bogdanm | 0:9b334a45a8ff | 158 | /* GNU DWARF 1 extensions */ |
bogdanm | 0:9b334a45a8ff | 159 | .debug_srcinfo 0 : { *(.debug_srcinfo) } |
bogdanm | 0:9b334a45a8ff | 160 | .debug_sfnames 0 : { *(.debug_sfnames) } |
bogdanm | 0:9b334a45a8ff | 161 | /* DWARF 1.1 and DWARF 2 */ |
bogdanm | 0:9b334a45a8ff | 162 | .debug_aranges 0 : { *(.debug_aranges) } |
bogdanm | 0:9b334a45a8ff | 163 | .debug_pubnames 0 : { *(.debug_pubnames) } |
bogdanm | 0:9b334a45a8ff | 164 | /* DWARF 2 */ |
bogdanm | 0:9b334a45a8ff | 165 | .debug_info 0 : { *(.debug_info .gnu.linkonce.wi.*) } |
bogdanm | 0:9b334a45a8ff | 166 | .debug_abbrev 0 : { *(.debug_abbrev) } |
bogdanm | 0:9b334a45a8ff | 167 | .debug_line 0 : { *(.debug_line) } |
bogdanm | 0:9b334a45a8ff | 168 | .debug_frame 0 : { *(.debug_frame) } |
bogdanm | 0:9b334a45a8ff | 169 | .debug_str 0 : { *(.debug_str) } |
bogdanm | 0:9b334a45a8ff | 170 | .debug_loc 0 : { *(.debug_loc) } |
bogdanm | 0:9b334a45a8ff | 171 | .debug_macinfo 0 : { *(.debug_macinfo) } |
bogdanm | 0:9b334a45a8ff | 172 | /* SGI/MIPS DWARF 2 extensions */ |
bogdanm | 0:9b334a45a8ff | 173 | .debug_weaknames 0 : { *(.debug_weaknames) } |
bogdanm | 0:9b334a45a8ff | 174 | .debug_funcnames 0 : { *(.debug_funcnames) } |
bogdanm | 0:9b334a45a8ff | 175 | .debug_typenames 0 : { *(.debug_typenames) } |
bogdanm | 0:9b334a45a8ff | 176 | .debug_varnames 0 : { *(.debug_varnames) } |
bogdanm | 0:9b334a45a8ff | 177 | /* DWARF 3 */ |
bogdanm | 0:9b334a45a8ff | 178 | .debug_pubtypes 0 : { *(.debug_pubtypes) } |
bogdanm | 0:9b334a45a8ff | 179 | .debug_ranges 0 : { *(.debug_ranges) } |
bogdanm | 0:9b334a45a8ff | 180 | |
bogdanm | 0:9b334a45a8ff | 181 | .note.gnu.arm.ident 0 : { KEEP( *( .note.gnu.arm.ident ) ) } |
bogdanm | 0:9b334a45a8ff | 182 | .ARM.attributes 0 : { |
bogdanm | 0:9b334a45a8ff | 183 | KEEP( *( .ARM.attributes ) ) |
bogdanm | 0:9b334a45a8ff | 184 | KEEP( *( .gnu.attributes ) ) |
bogdanm | 0:9b334a45a8ff | 185 | } |
bogdanm | 0:9b334a45a8ff | 186 | /DISCARD/ : { *( .note.GNU-stack ) } |
bogdanm | 0:9b334a45a8ff | 187 | |
bogdanm | 0:9b334a45a8ff | 188 | /* C data can be defined as being in special purpose RAMs using |
bogdanm | 0:9b334a45a8ff | 189 | * __attribute__ ((section ("ethram"))) for example. */ |
bogdanm | 0:9b334a45a8ff | 190 | .usbram (NOLOAD): |
bogdanm | 0:9b334a45a8ff | 191 | { |
bogdanm | 0:9b334a45a8ff | 192 | *( .usbram ) |
bogdanm | 0:9b334a45a8ff | 193 | *( .usbram.* ) |
bogdanm | 0:9b334a45a8ff | 194 | } > UsbRam |
bogdanm | 0:9b334a45a8ff | 195 | .ethram (NOLOAD): |
bogdanm | 0:9b334a45a8ff | 196 | { |
bogdanm | 0:9b334a45a8ff | 197 | *( .ethram ) |
bogdanm | 0:9b334a45a8ff | 198 | *( .ethram.* ) |
bogdanm | 0:9b334a45a8ff | 199 | } > EthRam |
bogdanm | 0:9b334a45a8ff | 200 | .canram (NOLOAD): |
bogdanm | 0:9b334a45a8ff | 201 | { |
bogdanm | 0:9b334a45a8ff | 202 | *( .canram ) |
bogdanm | 0:9b334a45a8ff | 203 | *( .canram.* ) |
bogdanm | 0:9b334a45a8ff | 204 | } > CanRam |
bogdanm | 0:9b334a45a8ff | 205 | .batram (NOLOAD): |
bogdanm | 0:9b334a45a8ff | 206 | { |
bogdanm | 0:9b334a45a8ff | 207 | *( .batram ) |
bogdanm | 0:9b334a45a8ff | 208 | *( .batram.* ) |
bogdanm | 0:9b334a45a8ff | 209 | } > BatRam |
bogdanm | 0:9b334a45a8ff | 210 | } |