fixes for host gcc 4.6.1
[zpugcc/jano.git] / toolchain / gcc / libgloss / m68k / mvme135.ld
blobdba0dbe233dd893ca1312e0e92af101e2bf4cbac
1 STARTUP(crt0.o)
2 OUTPUT_ARCH(m68k)
3 /* Uncomment this if you want srecords. This is needed for a.out
4  * if you plan to use GDB.
5 OUTPUT_FORMAT(srec)
6  */
7 SEARCH_DIR(.)
8 GROUP(-lmvme135 -lc -lgcc)
9 __DYNAMIC  =  0;
12  * Setup the memory map of the Motorola MVME135 Board
13  * stack grows down from high memory.
14  *
15  * The memory map look like this:
16  * +--------------------+ <- low memory
17  * | .text              |
18  * |        _etext      |
19  * |        ctor list   | the ctor and dtor lists are for
20  * |        dtor list   | C++ support
21  * +--------------------+
22  * | .data              | initialized data goes here
23  * |        _edata      |
24  * +--------------------+
25  * | .bss               |
26  * |        __bss_start | start of bss, cleared by crt0
27  * |        _end        | start of heap, used by sbrk()
28  * +--------------------+
29  * .                    .
30  * .                    .
31  * .                    .
32  * |        __stack     | top of stack
33  * +--------------------+
34  */
36 MEMORY
38   ram (rwx) : ORIGIN = 0x5000, LENGTH = 1M
42  * Allocate the stack to be at the top of memory, since the stack
43  * grows down
44  */
46 PROVIDE (__stack = 1M - 8);
49  * Initalize some symbols to be zero so we can reference them in the
50  * crt0 without core dumping. These functions are all optional, but
51  * we do this so we can have our crt0 always use them if they exist. 
52  * This is so BSPs work better when using the crt0 installed gcc.
53  * We have to initalize them twice, so we cover a.out (which prepends
54  * an underscore) and coff object file formats.
55  */
56 PROVIDE (hardware_init_hook = 0);
57 PROVIDE (_hardware_init_hook = 0);
58 PROVIDE (software_init_hook = 0);
59 PROVIDE (_software_init_hook = 0);
61  * stick everything in ram (of course)
62  */
63 SECTIONS
65   .text :
66   {
67     *(.text)
68     . = ALIGN(0x4);
69      __CTOR_LIST__ = .;
70     ___CTOR_LIST__ = .;
71     LONG((__CTOR_END__ - __CTOR_LIST__) / 4 - 2)
72     *(.ctors)
73     LONG(0)
74     __CTOR_END__ = .;
75     __DTOR_LIST__ = .;
76     ___DTOR_LIST__ = .;
77     LONG((__DTOR_END__ - __DTOR_LIST__) / 4 - 2)
78     *(.dtors)
79      LONG(0)
80     __DTOR_END__ = .;
81     *(.rodata)
82     *(.gcc_except_table) 
84     . = ALIGN(0x2);
85     __INIT_SECTION__ = . ;
86     LONG (0x4e560000)   /* linkw %fp,#0 */
87     *(.init)
88     SHORT (0x4e5e)      /* unlk %fp */
89     SHORT (0x4e75)      /* rts */
91     __FINI_SECTION__ = . ;
92     LONG (0x4e560000)   /* linkw %fp,#0 */
93     *(.fini)
94     SHORT (0x4e5e)      /* unlk %fp */
95     SHORT (0x4e75)      /* rts */
97     _etext = .;
98     *(.lit)
99   } > ram
101   .data :
102   {
103     *(.shdata)
104     *(.data)
105     _edata = .;
106   } > ram
108   .bss :
109   {
110     . = ALIGN(0x4);
111     __bss_start = . ;
112     *(.shbss)
113     *(.bss)
114     *(COMMON)
115     _end =  ALIGN (0x8);
116     __end = _end;
117   } > ram
119   .stab 0 (NOLOAD) :
120   {
121     *(.stab)
122   }
124   .stabstr 0 (NOLOAD) :
125   {
126     *(.stabstr)
127   }