aboutsummaryrefslogtreecommitdiff
path: root/ld/scripttempl/tic4xcoff.sc
diff options
context:
space:
mode:
Diffstat (limited to 'ld/scripttempl/tic4xcoff.sc')
-rw-r--r--ld/scripttempl/tic4xcoff.sc92
1 files changed, 92 insertions, 0 deletions
diff --git a/ld/scripttempl/tic4xcoff.sc b/ld/scripttempl/tic4xcoff.sc
new file mode 100644
index 0000000..29dc400
--- /dev/null
+++ b/ld/scripttempl/tic4xcoff.sc
@@ -0,0 +1,92 @@
+# 32 interrupt vectors + 32 trap vectors each of 4 bytes
+# The .bss and .data sections need to be contiguous for direct addressing
+# The data page pointer gets loaded with the start of .bss
+# TI C compiler uses .cinit to initialise variables in .bss
+
+test -z "$ENTRY" && ENTRY=_start
+# These are substituted in as variables in order to get '}' in a shell
+# conditional expansion.
+INIT='.init : { *(.init) }'
+FINI='.fini : { *(.fini) }'
+cat <<EOF
+OUTPUT_FORMAT("${OUTPUT_FORMAT}")
+OUTPUT_ARCH("${OUTPUT_ARCH}")
+${LIB_SEARCH_DIRS}
+
+ENTRY(${ENTRY})
+${RELOCATING+ __SYSMEM_SIZE = DEFINED(__SYSMEM_SIZE) ? __SYSMEM_SIZE : 0x4000;}
+${RELOCATING+ __STACK_SIZE = DEFINED(__STACK_SIZE) ? __STACK_SIZE : 0x1000;}
+
+SECTIONS
+{
+ .comms ${RELOCATING+ 64} : {
+ *(.comms)
+ }
+ .bss ${RELOCATING+ SIZEOF(.comms) + ADDR(.comms)} : {
+ ${RELOCATING+ .bss = .;}
+ *(.bss)
+ *(COMMON)
+ ${RELOCATING+ end = .;}
+ ${RELOCATING+ _end = end;}
+ }
+ .data ${RELOCATING+ SIZEOF(.bss) + ADDR(.bss)} :
+ {
+ ${RELOCATING+ .data = .;}
+ *(.data)
+ ${RELOCATING+ edata = .;}
+ }
+ .const ${RELOCATING+ SIZEOF(.data) + ADDR(.data)} :
+ {
+ *(.const)
+ }
+ .cinit ${RELOCATING+ SIZEOF(.const) + ADDR(.const)} :
+ {
+ ${RELOCATING+ cinit = .;}
+ *(.cinit)
+ LONG(0);
+ }
+ .text ${RELOCATING+ SIZEOF(.cinit) + ADDR(.cinit)} : {
+ ${RELOCATING+ .text = .;}
+ ${RELOCATING+ *(.init)}
+ *(.text)
+ ${CONSTRUCTING+ ___CTOR_LIST__ = .;}
+ ${CONSTRUCTING+ LONG(___CTOR_END__ - ___CTOR_LIST__ - 2)}
+ ${CONSTRUCTING+ *(.ctors)}
+ ${CONSTRUCTING+ LONG(0);}
+ ${CONSTRUCTING+ ___CTOR_END__ = .;}
+ ${CONSTRUCTING+ ___DTOR_LIST__ = .;}
+ ${CONSTRUCTING+ LONG(___DTOR_END__ - ___DTOR_LIST__ - 2)}
+ ${CONSTRUCTING+ *(.dtors)}
+ ${CONSTRUCTING+ LONG(0)}
+ ${CONSTRUCTING+ ___DTOR_END__ = .;}
+ ${RELOCATING+ *(.fini)}
+ ${RELOCATING+ etext = .;}
+ ${RELOCATING+ _etext = etext;}
+ }
+ .stack ${RELOCATING+ SIZEOF(.text) + ADDR(.text)} :
+ {
+ *(.stack)
+ ${RELOCATING+ . = . + __STACK_SIZE};
+ }
+ .sysmem ${RELOCATING+ SIZEOF(.stack) + ADDR(.stack)} :
+ {
+ *(.sysmem)
+ }
+ .heap ${RELOCATING+ SIZEOF(.sysmem) + ADDR(.sysmem)} :
+ {
+ ${RELOCATING+ . += __SYSMEM_SIZE - SIZEOF(.sysmem)};
+ }
+ ${RELOCATING- ${INIT}}
+ ${RELOCATING- ${FINI}}
+ .stab 0 ${RELOCATING+(NOLOAD)} :
+ {
+ [ .stab ]
+ }
+ .stabstr 0 ${RELOCATING+(NOLOAD)} :
+ {
+ [ .stabstr ]
+ }
+/* The TI tools sets cinit to -1 if the ram model is used. */
+ ${RELOCATING+ cinit = SIZEOF(.cinit) == 1 ? cinit : -1;}
+}
+EOF