diff options
| author | Marti Bolivar <mbolivar@leaflabs.com> | 2011-05-09 16:35:13 -0400 | 
|---|---|---|
| committer | Marti Bolivar <mbolivar@leaflabs.com> | 2011-05-09 16:40:58 -0400 | 
| commit | 868fb1c273e562a1140abfa948022c9d4f55bccf (patch) | |
| tree | 73067aa8cf6f8bd0d7663a634c1f878a78b567ed /support | |
| parent | 47c53377292a4db28057fc6394c928cde3727e97 (diff) | |
| download | librambutan-868fb1c273e562a1140abfa948022c9d4f55bccf.tar.gz librambutan-868fb1c273e562a1140abfa948022c9d4f55bccf.zip | |
Reverting commits between `git merge-head master refactor` and master.
This is a combination of 11 revert commits, and allows for a clean
merge of the work done in the refactor branch.
The combined commit messages follow.
Revert "Committing basic ring_buffer test."
This reverts commit 987fa5f433e0cd41b1621dad8b4e331cf82d49f3.
Revert "qa-slave-shield.cpp and test-session.cpp fixes for Mini and RET6 Edition."
This reverts commit cdd367bdd264c9e19180032c119850fbba2115ba.
Revert "Brought examples/ up to date; PIN_MAP bugfix for D24."
This reverts commit b4c2d4514c6d52cac8a649c5d5c24b68a3c0a416.
Revert "Separated GPIO config to a separate FSMC routine."
This reverts commit 744848ad0fc33eed66acc44e41c3c9d646c5b100.
Revert "Slightly faster RAM writes (6.5MHz)."
This reverts commit 8ba0b6bb065acb4aff26bc9c838de5f37515caf1.
Revert "FSMC working but slow (~6 MHz)."
This reverts commit 0dc9490cf4f4f10a23b08fef1728773f10c1b76a.
Revert "Maple Mini ERROR_LED_PIN fix."
This reverts commit 07d437706840901db1e09ff0ab88229c67c1fa8a.
Revert "Fixing USBSerial::read(void*, uint32) return value (thanks, Crenn!)"
This reverts commit 3ba7196712a5bfe4fe1166b6c34d49c3d7254568.
Revert "Trivial gpio_init() bugfix"
This reverts commit f6ce003bb935f26eeefa54acf7c2ae6afaabd871.
Revert "Trivial changes to test-session.cpp"
This reverts commit a32a37b121ac7e62660d2a83fe67c857fe705122.
Revert ".gitignore: Ignore cscope* files"
This reverts commit d8c72c17bd6d7416a0846e69f4f5ae5cb229d58e.
Diffstat (limited to 'support')
| -rw-r--r-- | support/ld/maple_RET6/flash.ld | 211 | ||||
| -rw-r--r-- | support/ld/maple_RET6/jtag.ld | 186 | ||||
| -rw-r--r-- | support/ld/maple_RET6/ram.ld | 220 | 
3 files changed, 0 insertions, 617 deletions
| diff --git a/support/ld/maple_RET6/flash.ld b/support/ld/maple_RET6/flash.ld deleted file mode 100644 index 4e820d2..0000000 --- a/support/ld/maple_RET6/flash.ld +++ /dev/null @@ -1,211 +0,0 @@ -/* Linker script for STM32 (by Lanchon with Mods by LeafLabs)
 - *
 - * Version:Sourcery G++ 4.2-84
 - * BugURL:https://support.codesourcery.com/GNUToolchain/
 - *
 - *  Copyright 2007 CodeSourcery.
 - *
 - * The authors hereby grant permission to use, copy, modify, distribute,
 - * and license this software and its documentation for any purpose, provided
 - * that existing copyright notices are retained in all copies and that this
 - * notice is included verbatim in any distributions. No written agreement,
 - * license, or royalty fee is required for any of the authorized uses.
 - * Modifications to this software may be copyrighted by their authors
 - * and need not follow the licensing terms described here, provided that
 - * the new terms are clearly indicated on the first page of each file where
 - * they apply. */
 -
 -/* Linker script for STM32 (by Lanchon),
 - * ROM and RAM relocated to their positions 
 - * as placed by Maple bootloader
 - *
 - * Configure target memory and included script
 - * according to your application requirements. */
 -
 -/* Define memory spaces. */
 -MEMORY
 -{
 -  ram (rwx) : ORIGIN = 0x20000C00, LENGTH = 61K
 -  rom (rx)  : ORIGIN = 0x08005000, LENGTH = 492K
 -}
 -
 -OUTPUT_FORMAT ("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
 -ENTRY(_start)
 -SEARCH_DIR(.)
 -/* GROUP(-lgcc -lc -lcs3 -lcs3unhosted -lcs3-lanchon-stm32) */
 -GROUP(libgcc.a libc.a libm.a libcs3-lanchon-stm32.a)
 -
 -/* These force the linker to search for particular symbols from
 - * the start of the link process and thus ensure the user's
 - * overrides are picked up
 - */
 -EXTERN(__cs3_reset_lanchon_stm32)
 -INCLUDE names.inc
 -EXTERN(__cs3_interrupt_vector_lanchon_stm32)
 -EXTERN(__cs3_start_c main __cs3_stack __cs3_heap_end)
 -EXTERN(_start)
 -
 -PROVIDE(__cs3_stack = __cs3_region_start_ram + __cs3_region_size_ram);
 -PROVIDE(__cs3_heap_start = _end);
 -PROVIDE(__cs3_heap_end = __cs3_region_start_ram + __cs3_region_size_ram);
 -
 -SECTIONS
 -{
 -  .text :
 -  {
 -    CREATE_OBJECT_SYMBOLS
 -    __cs3_region_start_rom = .;
 -    *(.cs3.region-head.rom)
 -    __cs3_interrupt_vector = __cs3_interrupt_vector_lanchon_stm32;
 -    *(.cs3.interrupt_vector)
 -    /* Make sure we pulled in an interrupt vector.  */
 -    ASSERT (. != __cs3_interrupt_vector_lanchon_stm32, "No interrupt vector");
 -    *(.rom)
 -    *(.rom.b)
 -
 -    PROVIDE(__cs3_reset_lanchon_stm32 = _start);
 -    __cs3_reset = __cs3_reset_lanchon_stm32;
 -    *(.cs3.reset)
 -
 -    *(.text .text.* .gnu.linkonce.t.*)
 -    *(.plt)
 -    *(.gnu.warning)
 -    *(.glue_7t) *(.glue_7) *(.vfp11_veneer)
 -
 -    *(.rodata .rodata.* .gnu.linkonce.r.*)
 -
 -    *(.ARM.extab* .gnu.linkonce.armextab.*)
 -    *(.gcc_except_table)
 -    *(.eh_frame_hdr)
 -    *(.eh_frame)
 -
 -    . = ALIGN(4);
 -    KEEP(*(.init))
 -
 -    . = ALIGN(4);
 -    __preinit_array_start = .;
 -    KEEP (*(.preinit_array))
 -    __preinit_array_end = .;
 -
 -    . = ALIGN(4);
 -    __init_array_start = .;
 -    KEEP (*(SORT(.init_array.*)))
 -    KEEP (*(.init_array))
 -    __init_array_end = .;
 -
 -    . = ALIGN(0x4);
 -    KEEP (*crtbegin.o(.ctors))
 -    KEEP (*(EXCLUDE_FILE (*crtend.o) .ctors))
 -    KEEP (*(SORT(.ctors.*)))
 -    KEEP (*crtend.o(.ctors))
 -
 -    . = ALIGN(4);
 -    KEEP(*(.fini))
 -
 -    . = ALIGN(4);
 -    __fini_array_start = .;
 -    KEEP (*(.fini_array))
 -    KEEP (*(SORT(.fini_array.*)))
 -    __fini_array_end = .;
 -
 -    KEEP (*crtbegin.o(.dtors))
 -    KEEP (*(EXCLUDE_FILE (*crtend.o) .dtors))
 -    KEEP (*(SORT(.dtors.*)))
 -    KEEP (*crtend.o(.dtors))
 -
 -    . = ALIGN(4);
 -    __cs3_regions = .;
 -    LONG (0)
 -    LONG (__cs3_region_init_ram)
 -    LONG (__cs3_region_start_ram)
 -    LONG (__cs3_region_init_size_ram)
 -    LONG (__cs3_region_zero_size_ram)
 -  } >rom
 -
 -  /* .ARM.exidx is sorted, so has to go in its own output section.  */
 -  __exidx_start = .;
 -  .ARM.exidx :
 -  {
 -    *(.ARM.exidx* .gnu.linkonce.armexidx.*)
 -  } >rom
 -  __exidx_end = .;
 -  .text.align :
 -  {
 -    . = ALIGN(8);
 -    _etext = .;
 -  } >rom
 -
 -/* expose a custom rom only section */
 -  .USER_FLASH :
 -  {
 -    *(.USER_FLASH)
 -  } >rom
 -
 -
 -  /* __cs3_region_end_rom is deprecated */
 -  __cs3_region_end_rom = __cs3_region_start_rom + LENGTH(rom);
 -  __cs3_region_size_rom = LENGTH(rom);
 -  __cs3_region_num = 1;
 -
 -  .data :
 -  {
 -    __cs3_region_start_ram = .;
 -    *(.cs3.region-head.ram)
 -    KEEP(*(.jcr))
 -    *(.got.plt) *(.got)
 -    *(.shdata)
 -    *(.data .data.* .gnu.linkonce.d.*)
 -    *(.ram)
 -    . = ALIGN (8);
 -    _edata = .;
 -  } >ram AT>rom
 -  .bss :
 -  {
 -    *(.shbss)
 -    *(.bss .bss.* .gnu.linkonce.b.*)
 -    *(COMMON)
 -    *(.ram.b)
 -    . = ALIGN (8);
 -    _end = .;
 -    __end = .;
 -  } >ram AT>rom
 -  /* __cs3_region_end_ram is deprecated */
 -  __cs3_region_end_ram = __cs3_region_start_ram + LENGTH(ram);
 -  __cs3_region_size_ram = LENGTH(ram);
 -  __cs3_region_init_ram = LOADADDR (.data);
 -  __cs3_region_init_size_ram = _edata - ADDR (.data);
 -  __cs3_region_zero_size_ram = _end - _edata;
 -  __cs3_region_num = 1;
 -
 -  .stab 0 (NOLOAD) : { *(.stab) }
 -  .stabstr 0 (NOLOAD) : { *(.stabstr) }
 -  /* 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) }
 -
 -  .note.gnu.arm.ident 0 : { KEEP (*(.note.gnu.arm.ident)) }
 -  .ARM.attributes 0 : { KEEP (*(.ARM.attributes)) }
 -  /DISCARD/ : { *(.note.GNU-stack) }
 -}
 diff --git a/support/ld/maple_RET6/jtag.ld b/support/ld/maple_RET6/jtag.ld deleted file mode 100644 index 90a0a3f..0000000 --- a/support/ld/maple_RET6/jtag.ld +++ /dev/null @@ -1,186 +0,0 @@ -/* Linker script for STM32 (by Lanchon),
 - * ROM and RAM relocated to their positions 
 - * as placed by Maple bootloader
 - *
 - * Configure target memory and included script
 - * according to your application requirements. */
 -
 -/* Define memory spaces. */
 -MEMORY
 -{
 -  ram (rwx) : ORIGIN = 0x20000000, LENGTH = 64K
 -  rom (rx)  : ORIGIN = 0x08000000, LENGTH = 512K
 -}
 -
 -OUTPUT_FORMAT ("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
 -ENTRY(_start)
 -SEARCH_DIR(.)
 -/* GROUP(-lgcc -lc -lcs3 -lcs3unhosted -lcs3-lanchon-stm32) */
 -GROUP(libgcc.a libc.a libm.a libcs3-lanchon-stm32.a)
 -
 -/* These force the linker to search for particular symbols from
 - * the start of the link process and thus ensure the user's
 - * overrides are picked up
 - */
 -EXTERN(__cs3_reset_lanchon_stm32)
 -INCLUDE names.inc
 -EXTERN(__cs3_interrupt_vector_lanchon_stm32)
 -EXTERN(__cs3_start_c main __cs3_stack __cs3_heap_end)
 -EXTERN(_start)
 -
 -PROVIDE(__cs3_stack = __cs3_region_start_ram + __cs3_region_size_ram);
 -PROVIDE(__cs3_heap_start = _end);
 -PROVIDE(__cs3_heap_end = __cs3_region_start_ram + __cs3_region_size_ram);
 -
 -SECTIONS
 -{
 -  .text :
 -  {
 -    CREATE_OBJECT_SYMBOLS
 -    __cs3_region_start_rom = .;
 -    *(.cs3.region-head.rom)
 -    __cs3_interrupt_vector = __cs3_interrupt_vector_lanchon_stm32;
 -    *(.cs3.interrupt_vector)
 -    /* Make sure we pulled in an interrupt vector.  */
 -    ASSERT (. != __cs3_interrupt_vector_lanchon_stm32, "No interrupt vector");
 -    *(.rom)
 -    *(.rom.b)
 -
 -    PROVIDE(__cs3_reset_lanchon_stm32 = _start);
 -    __cs3_reset = __cs3_reset_lanchon_stm32;
 -    *(.cs3.reset)
 -
 -    *(.text .text.* .gnu.linkonce.t.*)
 -    *(.plt)
 -    *(.gnu.warning)
 -    *(.glue_7t) *(.glue_7) *(.vfp11_veneer)
 -
 -    *(.rodata .rodata.* .gnu.linkonce.r.*)
 -
 -    *(.ARM.extab* .gnu.linkonce.armextab.*)
 -    *(.gcc_except_table)
 -    *(.eh_frame_hdr)
 -    *(.eh_frame)
 -
 -    . = ALIGN(4);
 -    KEEP(*(.init))
 -
 -    . = ALIGN(4);
 -    __preinit_array_start = .;
 -    KEEP (*(.preinit_array))
 -    __preinit_array_end = .;
 -
 -    . = ALIGN(4);
 -    __init_array_start = .;
 -    KEEP (*(SORT(.init_array.*)))
 -    KEEP (*(.init_array))
 -    __init_array_end = .;
 -
 -    . = ALIGN(0x4);
 -    KEEP (*crtbegin.o(.ctors))
 -    KEEP (*(EXCLUDE_FILE (*crtend.o) .ctors))
 -    KEEP (*(SORT(.ctors.*)))
 -    KEEP (*crtend.o(.ctors))
 -
 -    . = ALIGN(4);
 -    KEEP(*(.fini))
 -
 -    . = ALIGN(4);
 -    __fini_array_start = .;
 -    KEEP (*(.fini_array))
 -    KEEP (*(SORT(.fini_array.*)))
 -    __fini_array_end = .;
 -
 -    KEEP (*crtbegin.o(.dtors))
 -    KEEP (*(EXCLUDE_FILE (*crtend.o) .dtors))
 -    KEEP (*(SORT(.dtors.*)))
 -    KEEP (*crtend.o(.dtors))
 -
 -    . = ALIGN(4);
 -    __cs3_regions = .;
 -    LONG (0)
 -    LONG (__cs3_region_init_ram)
 -    LONG (__cs3_region_start_ram)
 -    LONG (__cs3_region_init_size_ram)
 -    LONG (__cs3_region_zero_size_ram)
 -  } >rom
 -
 -  /* .ARM.exidx is sorted, so has to go in its own output section.  */
 -  __exidx_start = .;
 -  .ARM.exidx :
 -  {
 -    *(.ARM.exidx* .gnu.linkonce.armexidx.*)
 -  } >rom
 -  __exidx_end = .;
 -  .text.align :
 -  {
 -    . = ALIGN(8);
 -    _etext = .;
 -  } >rom
 -  /* __cs3_region_end_rom is deprecated */
 -  __cs3_region_end_rom = __cs3_region_start_rom + LENGTH(rom);
 -  __cs3_region_size_rom = LENGTH(rom);
 -  __cs3_region_num = 1;
 -
 -  .data :
 -  {
 -    __cs3_region_start_ram = .;
 -    *(.cs3.region-head.ram)
 -    KEEP(*(.jcr))
 -    *(.got.plt) *(.got)
 -    *(.shdata)
 -    *(.data .data.* .gnu.linkonce.d.*)
 -    *(.ram)
 -    . = ALIGN (8);
 -    _edata = .;
 -  } >ram AT>rom
 -  .bss :
 -  {
 -    *(.shbss)
 -    *(.bss .bss.* .gnu.linkonce.b.*)
 -    *(COMMON)
 -    *(.ram.b)
 -    . = ALIGN (8);
 -    _end = .;
 -    __end = .;
 -  } >ram AT>rom
 -  /* __cs3_region_end_ram is deprecated */
 -  __cs3_region_end_ram = __cs3_region_start_ram + LENGTH(ram);
 -  __cs3_region_size_ram = LENGTH(ram);
 -  __cs3_region_init_ram = LOADADDR (.data);
 -  __cs3_region_init_size_ram = _edata - ADDR (.data);
 -  __cs3_region_zero_size_ram = _end - _edata;
 -  __cs3_region_num = 1;
 -
 -  .stab 0 (NOLOAD) : { *(.stab) }
 -  .stabstr 0 (NOLOAD) : { *(.stabstr) }
 -  /* 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) }
 -
 -  .note.gnu.arm.ident 0 : { KEEP (*(.note.gnu.arm.ident)) }
 -  .ARM.attributes 0 : { KEEP (*(.ARM.attributes)) }
 -  /DISCARD/ : { *(.note.GNU-stack) }
 -}
 diff --git a/support/ld/maple_RET6/ram.ld b/support/ld/maple_RET6/ram.ld deleted file mode 100644 index a5e1482..0000000 --- a/support/ld/maple_RET6/ram.ld +++ /dev/null @@ -1,220 +0,0 @@ -/* Linker script for STM32 (by Lanchon with Mods by LeafLabs)
 - *
 - * Version:Sourcery G++ 4.2-84
 - * BugURL:https://support.codesourcery.com/GNUToolchain/
 - *
 - *  Copyright 2007 CodeSourcery.
 - *
 - * The authors hereby grant permission to use, copy, modify, distribute,
 - * and license this software and its documentation for any purpose, provided
 - * that existing copyright notices are retained in all copies and that this
 - * notice is included verbatim in any distributions. No written agreement,
 - * license, or royalty fee is required for any of the authorized uses.
 - * Modifications to this software may be copyrighted by their authors
 - * and need not follow the licensing terms described here, provided that
 - * the new terms are clearly indicated on the first page of each file where
 - * they apply. */
 -
 -/* Linker script for STM32 (by Lanchon),
 - * ROM and RAM relocated to their positions 
 - * as placed by Maple bootloader
 - *
 - * Configure target memory and included script
 - * according to your application requirements. */
 -
 -/* Define memory spaces. */
 -MEMORY
 -{
 -  ram (rwx) : ORIGIN = 0x20000C00, LENGTH = 61K
 -  rom (rx)  : ORIGIN = 0x08005000, LENGTH = 0K
 -}
 -
 -
 -OUTPUT_FORMAT ("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
 -ENTRY(_start)
 -SEARCH_DIR(.)
 -/* GROUP(-lgcc -lc -lcs3 -lcs3unhosted -lcs3-lanchon-stm32) */
 -GROUP(libgcc.a libc.a libm.a libcs3-lanchon-stm32.a)
 -
 -/* These force the linker to search for particular symbols from
 - * the start of the link process and thus ensure the user's
 - * overrides are picked up
 - */
 -EXTERN(__cs3_reset_lanchon_stm32)
 -INCLUDE names.inc
 -EXTERN(__cs3_interrupt_vector_lanchon_stm32)
 -EXTERN(__cs3_start_c main __cs3_stack __cs3_heap_end)
 -EXTERN(_start)
 -
 -PROVIDE(__cs3_stack = __cs3_region_start_ram + __cs3_region_size_ram);
 -PROVIDE(__cs3_heap_start = _end);
 -PROVIDE(__cs3_heap_end = __cs3_region_start_ram + __cs3_region_size_ram);
 -
 -SECTIONS
 -{
 -  .text :
 -  {
 -    CREATE_OBJECT_SYMBOLS
 -    __cs3_region_start_ram = .;
 -    *(.cs3.region-head.ram)
 -    __cs3_interrupt_vector = __cs3_interrupt_vector_lanchon_stm32;
 -    *(.cs3.interrupt_vector)
 -    /* Make sure we pulled in an interrupt vector.  */
 -    ASSERT (. != __cs3_interrupt_vector_lanchon_stm32, "No interrupt vector");
 -
 -    PROVIDE(__cs3_reset_lanchon_stm32 = _start);
 -    __cs3_reset = __cs3_reset_lanchon_stm32;
 -    *(.cs3.reset)
 -
 -    *(.text .text.* .gnu.linkonce.t.*)
 -    *(.plt)
 -    *(.gnu.warning)
 -    *(.glue_7t) *(.glue_7) *(.vfp11_veneer)
 -
 -    *(.rodata .rodata.* .gnu.linkonce.r.*)
 -
 -    *(.ARM.extab* .gnu.linkonce.armextab.*)
 -    *(.gcc_except_table)
 -    *(.eh_frame_hdr)
 -    *(.eh_frame)
 -
 -    . = ALIGN(4);
 -    KEEP(*(.init))
 -
 -    . = ALIGN(4);
 -    __preinit_array_start = .;
 -    KEEP (*(.preinit_array))
 -    __preinit_array_end = .;
 -
 -    . = ALIGN(4);
 -    __init_array_start = .;
 -    KEEP (*(SORT(.init_array.*)))
 -    KEEP (*(.init_array))
 -    __init_array_end = .;
 -
 -    . = ALIGN(0x4);
 -    KEEP (*crtbegin.o(.ctors))
 -    KEEP (*(EXCLUDE_FILE (*crtend.o) .ctors))
 -    KEEP (*(SORT(.ctors.*)))
 -    KEEP (*crtend.o(.ctors))
 -
 -    . = ALIGN(4);
 -    KEEP(*(.fini))
 -
 -    . = ALIGN(4);
 -    __fini_array_start = .;
 -    KEEP (*(.fini_array))
 -    KEEP (*(SORT(.fini_array.*)))
 -    __fini_array_end = .;
 -
 -    KEEP (*crtbegin.o(.dtors))
 -    KEEP (*(EXCLUDE_FILE (*crtend.o) .dtors))
 -    KEEP (*(SORT(.dtors.*)))
 -    KEEP (*crtend.o(.dtors))
 -
 -    . = ALIGN(4);
 -    __cs3_regions = .;
 -    LONG (0)
 -    LONG (__cs3_region_init_ram)
 -    LONG (__cs3_region_start_ram)
 -    LONG (__cs3_region_init_size_ram)
 -    LONG (__cs3_region_zero_size_ram)
 -  } >ram
 -
 -  /* .ARM.exidx is sorted, so has to go in its own output section.  */
 -  /* even cs3.rom is in ram since its running as user code under the Maple
 -     bootloader */
 -  __exidx_start = .;
 -  .ARM.exidx :
 -  {
 -    *(.ARM.exidx* .gnu.linkonce.armexidx.*)
 -  } >ram
 -  __exidx_end = .;
 -  .text.align :
 -  {
 -    . = ALIGN(8);
 -    _etext = .;
 -  } >ram
 -
 -  .cs3.rom :
 -  {
 -    __cs3_region_start_rom = .;
 -    *(.cs3.region-head.rom)
 -    *(.rom)
 -    . = ALIGN (8);
 -  } >ram
 -
 -  .cs3.rom.bss :
 -  {
 -    *(.rom.b)
 -    . = ALIGN (8);
 -  } >ram
 -  /* __cs3_region_end_rom is deprecated */
 -  __cs3_region_end_rom = __cs3_region_start_rom + LENGTH(ram);
 -  __cs3_region_size_rom = LENGTH(ram);
 -  __cs3_region_init_rom = LOADADDR (.cs3.rom);
 -  __cs3_region_init_size_rom = SIZEOF(.cs3.rom);
 -  __cs3_region_zero_size_rom = SIZEOF(.cs3.rom.bss);
 -
 -  .data :
 -  {
 -
 -    KEEP(*(.jcr))
 -    *(.got.plt) *(.got)
 -    *(.shdata)
 -    *(.data .data.* .gnu.linkonce.d.*)
 -    *(.ram)
 -    . = ALIGN (8);
 -    _edata = .;
 -  } >ram
 -  .bss :
 -  {
 -    *(.shbss)
 -    *(.bss .bss.* .gnu.linkonce.b.*)
 -    *(COMMON)
 -    *(.ram.b)
 -    . = ALIGN (8);
 -    _end = .;
 -    __end = .;
 -  } >ram
 -  /* __cs3_region_end_ram is deprecated */
 -  __cs3_region_end_ram = __cs3_region_start_ram + LENGTH(ram);
 -  __cs3_region_size_ram = LENGTH(ram);
 -  __cs3_region_init_ram = LOADADDR (.text);
 -  __cs3_region_init_size_ram = _edata - ADDR (.text);
 -  __cs3_region_zero_size_ram = _end - _edata;
 -  __cs3_region_num = 1;
 -
 -  .stab 0 (NOLOAD) : { *(.stab) }
 -  .stabstr 0 (NOLOAD) : { *(.stabstr) }
 -  /* 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) }
 -
 -  .note.gnu.arm.ident 0 : { KEEP (*(.note.gnu.arm.ident)) }
 -  .ARM.attributes 0 : { KEEP (*(.ARM.attributes)) }
 -  /DISCARD/ : { *(.note.GNU-stack) }
 -}
 -
 | 
