source: rtems/c/src/lib/libbsp/v850/gdbv850sim/startup/linkcmds @ 2d7ae960

4.115
Last change on this file since 2d7ae960 was 2d7ae960, checked in by Joel Sherrill <joel.sherrill@…>, on 06/11/12 at 18:37:29

v850 port: Initial addition with BSP for simulator in GDB

Port

+ v850 does not have appear to have any optimized bit scan instructions
+ v850 does have single instructions for wap u16 and u32
+ Code path optimization preferences set
+ Add BSP variants for each GCC CPU model flag and a README

  • v850e1 variant does not work (fails during BSP initialization)

BSP for GDB v850 Simulator

+ linkcmds matches defaults in GDB simulator with RTEMS mods
+ crt1.c added from v850 newlib port for main()
+ BSP exits cleanly
+ printk and console I/O work
+ uses clock tick from IDLE task
+ Tests not requiring real clock ISR work

Documentation

+ CPU Supplment chapter for v850 added

  • Property mode set to 100644
File size: 5.7 KB
Line 
1/*
2 * Declare some sizes.
3 */
4_RamBase = DEFINED(_RamBase) ? _RamBase : 0x100000; /* RAM starts at 1MB */
5_RamSize = DEFINED(_RamSize) ? _RamSize : 0x100000; /* default is 1MB */
6_HeapSize = DEFINED(_HeapSize) ? _HeapSize : 0x0;
7_StackSize = DEFINED(_StackSize) ? _StackSize : 0x1000;
8
9/* Default linker script, for normal executables */
10OUTPUT_FORMAT("elf32-v850", "elf32-v850",
11              "elf32-v850")
12OUTPUT_ARCH(v850)
13ENTRY(_start)
14/* GROUP(-lc -lsim -lgcc) */
15SEARCH_DIR(.);
16EXTERN(__ctbp __ep __gp);
17SECTIONS
18{
19  /* This saves a little space in the ELF file, since the zda starts
20     at a higher location that the ELF headers take up.  */
21  .zdata 0x160 :
22  {
23        *(.zdata)
24        *(.zbss)
25        *(reszdata)
26        *(.zcommon)
27  }
28  /* This is the read only part of the zero data area.
29     Having it as a seperate section prevents its
30     attributes from being inherited by the zdata
31     section.  Specifically it prevents the zdata
32     section from being marked READONLY.  */
33  .rozdata ALIGN (4) :
34  {
35        *(.rozdata)
36        *(romzdata)
37        *(romzbss)
38  }
39  /* Read-only sections, merged into text segment.  */
40  . = 0x100000;
41  .interp       : { *(.interp) }
42  .hash         : { *(.hash) }
43  .dynsym       : { *(.dynsym) }
44  .dynstr       : { *(.dynstr) }
45  .rel.text     : { *(.rel.text) }
46  .rela.text    : { *(.rela.text) }
47  .rel.data     : { *(.rel.data) }
48  .rela.data    : { *(.rela.data) }
49  .rel.rodata   : { *(.rel.rodata) }
50  .rela.rodata  : { *(.rela.rodata) }
51  .rel.gcc_except_table : { *(.rel.gcc_except_table) }
52  .rela.gcc_except_table : { *(.rela.gcc_except_table) }
53  .rel.got      : { *(.rel.got) }
54  .rela.got     : { *(.rela.got) }
55  .rel.ctors    : { *(.rel.ctors) }
56  .rela.ctors   : { *(.rela.ctors) }
57  .rel.dtors    : { *(.rel.dtors) }
58  .rela.dtors   : { *(.rela.dtors) }
59  .rel.init     : { *(.rel.init) }
60  .rela.init    : { *(.rela.init) }
61  .rel.fini     : { *(.rel.fini) }
62  .rela.fini    : { *(.rela.fini) }
63  .rel.bss      : { *(.rel.bss) }
64  .rela.bss     : { *(.rela.bss) }
65  .rel.plt      : { *(.rel.plt) }
66  .rela.plt     : { *(.rela.plt) }
67  .init         : { KEEP (*(.init)) } =0
68  .plt          : { *(.plt) }
69  .text         :
70  {
71    *(.text)
72    *(.text.*)
73    /* .gnu.warning sections are handled specially by elf32.em.  */
74    *(.gnu.warning)
75    *(.gnu.linkonce.t*)
76  } =0
77  _etext = .;
78  PROVIDE (etext = .);
79   /* This is special code area at the end of the normal text section.
80      It contains a small lookup table at the start followed by the
81      code pointed to by entries in the lookup table.  */
82  .call_table_data ALIGN (4) :
83  {
84    PROVIDE(__ctbp = .);
85    *(.call_table_data)
86  } = 0xff   /* Fill gaps with 0xff.  */
87  .call_table_text :
88  {
89    *(.call_table_text)
90  }
91  .fini         : { KEEP (*(.fini)) } =0
92  .rodata       : { *(.rodata) *(.rodata.*) *(.gnu.linkonce.r*) }
93  .rodata1      : { *(.rodata1) }
94  .data         :
95  {
96    *(.data)
97    *(.data.*)
98    *(.gnu.linkonce.d*)
99    CONSTRUCTORS
100  }
101  .data1        : { *(.data1) }
102  .ctors        :
103  {
104    ___ctors = .;
105    KEEP (*(EXCLUDE_FILE (*crtend.o) .ctors))
106    KEEP (*(SORT(.ctors.*)))
107    KEEP (*crtend(.ctors))
108    ___ctors_end = .;
109  }
110  .dtors        :
111  {
112    ___dtors = .;
113    KEEP (*(EXCLUDE_FILE (*crtend.o) .dtors))
114    KEEP (*(SORT(.dtors.*)))
115    KEEP (*crtend.o(.dtors))
116    ___dtors_end = .;
117  }
118  .jcr          :
119  {
120    KEEP (*(.jcr))
121  }
122  .gcc_except_table : { *(.gcc_except_table) }
123  .got          : { *(.got.plt) *(.got) }
124  .dynamic      : { *(.dynamic) }
125  .tdata ALIGN (4) :
126  {
127        PROVIDE (__ep = .);
128        *(.tbyte)
129        *(.tcommon_byte)
130        *(.tdata)
131        *(.tbss)
132        *(.tcommon)
133  }
134  /* We want the small data sections together, so single-instruction offsets
135     can access them all, and initialized data all before uninitialized, so
136     we can shorten the on-disk segment size.  */
137  .sdata ALIGN (4) :
138  {
139        PROVIDE (__gp = . + 0x8000);
140        *(.sdata)
141   }
142  /* See comment about .rozdata. */
143  .rosdata ALIGN (4) :
144  {
145        *(.rosdata)
146  }
147  /* We place the .sbss data section AFTER the .rosdata section, so that
148     it can directly preceed the .bss section.  This allows runtime startup
149     code to initialise all the zero-data sections by simply taking the
150     value of '_edata' and zeroing until it reaches '_end'.  */
151  .sbss :
152  {
153        __sbss_start = .;
154        *(.sbss)
155        *(.scommon)
156  }
157  _edata  = DEFINED (__sbss_start) ? __sbss_start : . ;
158  PROVIDE (edata = _edata);
159  .bss       :
160  {
161        __bss_start = DEFINED (__sbss_start) ? __sbss_start : . ;
162        __real_bss_start = . ;
163        *(.dynbss)
164        *(.bss)
165        *(COMMON)
166  }
167  . += _StackSize;
168  _stack = .;
169  _WorkAreaBase = .;
170  _end = . ;
171  PROVIDE (end = .);
172  /* Stabs debugging sections.  */
173  .stab 0               : { *(.stab) }
174  .stabstr 0            : { *(.stabstr) }
175  .stab.excl 0          : { *(.stab.excl) }
176  .stab.exclstr 0       : { *(.stab.exclstr) }
177  .stab.index 0         : { *(.stab.index) }
178  .stab.indexstr 0      : { *(.stab.indexstr) }
179  .comment 0            : { *(.comment) }
180  /* DWARF debug sections.
181     Symbols in the DWARF debugging sections are relative to the beginning
182     of the section so we begin them at 0.  */
183  /* DWARF 1 */
184  .debug          0     : { *(.debug) }
185  .line           0     : { *(.line) }
186  /* GNU DWARF 1 extensions */
187  .debug_srcinfo  0     : { *(.debug_srcinfo) }
188  .debug_sfnames  0     : { *(.debug_sfnames) }
189  /* DWARF 1.1 and DWARF 2 */
190  .debug_aranges  0     : { *(.debug_aranges) }
191  .debug_pubnames 0     : { *(.debug_pubnames) }
192  /* DWARF 2 */
193  .debug_info     0     : { *(.debug_info) *(.gnu.linkonce.wi.*) }
194  .debug_abbrev   0     : { *(.debug_abbrev) }
195  .debug_line     0     : { *(.debug_line) }
196  .debug_frame    0     : { *(.debug_frame) }
197  .debug_str      0     : { *(.debug_str) }
198  .debug_loc      0     : { *(.debug_loc) }
199  .debug_macinfo  0     : { *(.debug_macinfo) }
200  /* SGI/MIPS DWARF 2 extensions.  */
201  .debug_weaknames 0    : { *(.debug_weaknames) }
202  .debug_funcnames 0    : { *(.debug_funcnames) }
203  .debug_typenames 0    : { *(.debug_typenames) }
204  .debug_varnames  0    : { *(.debug_varnames) }
205  /* libgloss - User stack.  */
206/*
207  .stack 0x200000       :
208  {
209        __stack = .;
210        *(.stack)
211  }
212*/
213}
214
Note: See TracBrowser for help on using the repository browser.