core: add support for .init/fini_table
[syslinux/sherbszt.git] / core / syslinux.ld
blob11adbcb837af083e04f17c9e92141c545a7caf70
1 /* -----------------------------------------------------------------------
2  *   
3  *   Copyright 2008-2009 H. Peter Anvin - All Rights Reserved
4  *   Copyright 2009 Intel Corporation; author: H. Peter Anvin
5  *
6  *   This program is free software; you can redistribute it and/or modify
7  *   it under the terms of the GNU General Public License as published by
8  *   the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
9  *   Boston MA 02110-1301, USA; either version 2 of the License, or
10  *   (at your option) any later version; incorporated herein by reference.
11  *
12  * ----------------------------------------------------------------------- */
15  * Linker script for the SYSLINUX core
16  */
18 OUTPUT_FORMAT("elf32-i386", "elf32-i386", "elf32-i386")
19 OUTPUT_ARCH(i386)
20 EXTERN(_start)
21 ENTRY(_start)
23 SECTIONS
25         /* Prefix structure for the compression program */
26         . = 0;
27         .prefix : {
28                 *(.prefix)
29         }
31         /* "Early" sections (before the load) */
32         . = 0x1000;
34         .earlybss (NOLOAD) : {
35                 __earlybss_start = .;
36                 *(.earlybss)
37                 __earlybss_end = .;
38         }
39         __earlybss_len = ABSOLUTE(__earlybss_end) - ABSOLUTE(__earlybss_start);
40         __earlybss_dwords = (__earlybss_len + 3) >> 2;
42         . = ALIGN(4);
43         .bss16 (NOLOAD) : {
44                 __bss16_start = .;
45                 *(.bss16)
46                 __bss16_end = .;
47         }
48         __bss16_len = ABSOLUTE(__bss16_end) - ABSOLUTE(__bss16_start);
49         __bss16_dwords = (__bss16_len + 3) >> 2;
51         . = ALIGN(4);
52         .config : AT (__config_lma) {
53                 __config_start = .;
54                 *(.config)
55                 __config_end = .;
56         }
57         __config_len = ABSOLUTE(__config_end) - ABSOLUTE(__config_start);
58         __config_dwords = (__config_len + 3) >> 2;
60         /* Generated and/or copied code */
62         . = ALIGN(128);         /* Minimum separation from mutable data */
63         .replacestub : AT (__replacestub_lma) {
64                 __replacestub_start = .;
65                 *(.replacestub)
66                 __replacestub_end = .;
67         }
68         __replacestub_len = ABSOLUTE(__replacestub_end) - ABSOLUTE(__replacestub_start);
69         __replacestub_dwords = (__replacestub_len + 3) >> 2;
71         . = ALIGN(16);
72         __gentextnr_lma = .;
73         .gentextnr : AT(__gentextnr_lma) {
74                 __gentextnr_start = .;
75                 *(.gentextnr)
76                 __gentextnr_end = .;
77         }
78         __gentextnr_len = ABSOLUTE(__gentextnr_end) - ABSOLUTE(__gentextnr_start);
79         __gentextnr_dwords = (__gentextnr_len + 3) >> 2;
81         . = STACK_BASE;
82         .stack16 : AT(STACK_BASE) {
83                 __stack16_start = .;
84                 . += STACK_LEN;
85                 __stack16_end = .;
86         }
87         __stack16_len = ABSOLUTE(__stack16_end) - ABSOLUTE(__stack16_start);
88         __stack16_dwords = (__stack16_len + 3) >> 2;
90         /* Initialized sections */
92         . = 0x7c00;
93         .init : {
94                 FILL(0x90909090)
95                 __init_start = .;
96                 *(.init)
97                 __init_end = .;
98         }
99         __init_len = ABSOLUTE(__init_end) - ABSOLUTE(__init_start);
100         __init_dwords = (__init_len + 3) >> 2;
102         .text16 : {
103                 FILL(0x90909090)
104                 __text16_start = .;
105                 *(.text16)
106                 __text16_end = .;
107         }
108         __text16_len = ABSOLUTE(__text16_end) - ABSOLUTE(__text16_start);
109         __text16_dwords = (__text16_len + 3) >> 2;
111         /*
112          * .textnr is used for 32-bit code that is used on the code
113          * path to initialize the .text segment
114          */
115         . = ALIGN(16);
116         .textnr : {
117                 FILL(0x90909090)
118                 __textnr_start = .;
119                 *(.textnr)
120                 __textnr_end = .;
121         }
122         __textnr_len = ABSOLUTE(__textnr_end) - ABSOLUTE(__textnr_start);
123         __textnr_dwords = (__textnr_len + 3) >> 2;
125         . = ALIGN(16);
126         __bcopyxx_start = .;
128         .bcopyxx.text : {
129                 FILL(0x90909090)
130                 __bcopyxx_text_start = .;
131                 *(.bcopyxx.text)
132                 __bcopyxx_text_end = .;
133         }
134         __bcopyxx_text_len = ABSOLUTE(__bcopyxx_text_end) - ABSOLUTE(__bcopyxx_text_start);
135         __bcopyxx_text_dwords = (__bcopyxx_text_len + 3) >> 2;
137         .bcopyxx.data : {
138                 __bcopyxx_data_start = .;
139                 *(.bcopyxx.text)
140                 __bcopyxx_data_end = .;
141         }
142         __bcopyxx_data_len = ABSOLUTE(__bcopyxx_data_end) - ABSOLUTE(__bcopyxx_data_start);
143         __bcopyxx_data_dwords = (__bcopyxx_data_len + 3) >> 2;
145         __bcopyxx_end = .;
146         __bcopyxx_len = ABSOLUTE(__bcopyxx_end) - ABSOLUTE(__bcopyxx_start);
147         __bcopyxx_dwords = (__bcopyxx_len + 3) >> 2;
149         . = ALIGN(4);
150         .data16 : {
151               __data16_start = .;
152               *(.data16)
153               __data16_end = .;
154         }
155         __data16_len = ABSOLUTE(__data16_end) - ABSOLUTE(__data16_start);
156         __data16_dwords = (__data16_len + 3) >> 2;
158         . = ALIGN(4);
159         __config_lma = .;
160         . += SIZEOF(.config);
162         . = ALIGN(4);
163         __replacestub_lma = .;
164         . += SIZEOF(.replacestub);
166         /* The 32-bit code loads above the non-progbits sections */
168         . = ALIGN(16);
169         __pm_code_lma = .;
171         __high_clear_start = .;
173         . = ALIGN(512);
174         .adv (NOLOAD) : {
175                 __adv_start = .;
176                 *(.adv)
177                 __adv_end = .;
178         }
179         __adv_len = ABSOLUTE(__adv_end) - ABSOLUTE(__adv_start);
180         __adv_dwords = (__adv_len + 3) >> 2;
182         /* Late uninitialized sections */
184         . = ALIGN(4);
185         .uibss (NOLOAD) : {
186                 __uibss_start = .;
187                 *(.uibss)
188                 __uibss_end = .;
189         }
190         __uibss_len = ABSOLUTE(__uibss_end) - ABSOLUTE(__uibss_start);
191         __uibss_dwords = (__uibss_len + 3) >> 2;
193         _end16 = .;
194         __assert_end16 = ASSERT(_end16 <= 0x10000, "64K overflow");
196         /*
197          * Special 16-bit segments
198          */
200         . = ALIGN(65536);
201         .real_mode (NOLOAD) : {
202                 *(.real_mode)
203         }
204         real_mode_seg = core_real_mode >> 4;
206         . = ALIGN(65536);
207         .xfer_buf (NOLOAD) : {
208                 *(.xfer_buf)
209         }
210         xfer_buf_seg = core_xfer_buf >> 4;
212         /*
213          * The auxilliary data segment is used by the 16-bit code
214          * for items that don't need to live in the bottom 64K.
215          */
217         . = ALIGN(16);
218         .auxseg (NOLOAD) : {
219                 __auxseg_start = .;
220                 *(.auxseg)
221                 __auxseg_end = .;
222         }
223         __auxseg_len = ABSOLUTE(__auxseg_end) - ABSOLUTE(__auxseg_start);
224         __auxseg_dwords = (__auxseg_len + 3) >> 2;
225         aux_seg = __auxseg_start >> 4;
227         /*
228          * Used to allocate lowmem buffers from 32-bit code
229          */
230         .lowmem (NOLOAD) : {
231                 __lowmem_start = .;
232                 *(.lowmem)
233                 __lowmem_end = .;
234         }
235         __lowmem_len = ABSOLUTE(__lowmem_end) - ABSOLUTE(__lowmem_start);
236         __lowmem_dwords = (__lowmem_len + 3) >> 2;
238         __high_clear_end = .;
240         __high_clear_len = ABSOLUTE(__high_clear_end) - ABSOLUTE(__high_clear_start);
241         __high_clear_dwords = (__high_clear_len + 3) >> 2;
243         /* Start of the lowmem heap */
244         . = ALIGN(16);
245         __lowmem_heap = .;
247         /*
248          * 32-bit code.  This is a hack for the moment due to the
249          * real-mode segments also allocated.
250          */
252         . = 0x100000;
254         __pm_code_start = .;
256         __text_vma = .;
257         __text_lma = __pm_code_lma;
258         .text : AT(__text_lma) {
259                 FILL(0x90909090)
260                 __text_start = .;
261                 *(.text)
262                 *(.text.*)
263                 __text_end = .;
264         }
266         . = ALIGN(16);
268         __rodata_vma = .;
269         __rodata_lma = __rodata_vma + __text_lma - __text_vma;
270         .rodata : AT(__rodata_lma) {
271                 __rodata_start = .;
272                 *(.rodata)
273                 *(.rodata.*)
274                 __rodata_end = .;
275         }
277         . = ALIGN(4);
279         __ctors_vma = .;
280         __ctors_lma = __ctors_vma + __text_lma - __text_vma;
281         .ctors : AT(__ctors_lma) {
282                 __ctors_start = .;
283                 KEEP (*(SORT(.preinit_array*)))
284                 KEEP (*(SORT(.init_array*)))
285                 KEEP (*(SORT(.ctors*)))
286                 __ctors_end = .;
287         }
289         __dtors_vma = .;
290         __dtors_lma = __dtors_vma + __text_lma - __text_vma;
291         .dtors : AT(__dtors_lma) {
292                 __dtors_start = .;
293                 KEEP (*(SORT(.fini_array*)))
294                 KEEP (*(SORT(.dtors*)))
295                 __dtors_end = .;
296         }
298         . = ALIGN(4);
300         __dynlink_vma = .;
301         __dynlink_lma = __dynlink_vma + __text_lma - __text_vma;
302         .dynlink : AT(__dynlink_lma) {
303                 __dynlink_start = .;
304                 *(.dynlink)
305                 __dynlink_end = .;
306         }
308         . = ALIGN(4);
310         __got_vma = .;
311         __got_lma = __got_vma + __text_lma - __text_vma;
312         .got : AT(__got_lma) {
313                 __got_start = .;
314                 KEEP (*(.got.plt))
315                 KEEP (*(.got))
316                 __got_end = .;
317         }
319         __data_vma = .;
320         __data_lma = __data_vma + __text_lma - __text_vma;
321         .data : AT(__data_lma) {
322                 __data_start = .;
323                 *(.data)
324                 *(.data.*)
325                 __data_end = .;
326         }
328         __pm_code_end = .;
329         __pm_code_len = ABSOLUTE(__pm_code_end) - ABSOLUTE(__pm_code_start);
330         __pm_code_dwords = (__pm_code_len + 3) >> 2;
332         . = ALIGN(128);
333         
334         __bss_vma = .;
335         __bss_lma = .;          /* Dummy */
336         .bss (NOLOAD) : AT (__bss_lma) {
337                 __bss_start = .;
338                 *(.bss)
339                 *(.bss.*)
340                 *(COMMON)
341                 __bss_end = .;
342         }
343         __bss_len = ABSOLUTE(__bss_end) - ABSOLUTE(__bss_start);
344         __bss_dwords = (__bss_len + 3) >> 2;
346         /* Very large objects which don't need to be zeroed */
348         __hugebss_vma = .;
349         __hugebss_lma = .;              /* Dummy */
350         .hugebss (NOLOAD) : AT (__hugebss_lma) {
351                 __hugebss_start = .;
352                 *(.hugebss)
353                 *(.hugebss.*)
354                 __hugebss_end = .;
355         }
356         __hugebss_len = ABSOLUTE(__hugebss_end) - ABSOLUTE(__hugebss_start);
357         __hugebss_dwords = (__hugebss_len + 3) >> 2;
360         /* XXX: This stack should be unified with the COM32 stack */
361         __stack_vma = .;
362         __stack_lma = .;        /* Dummy */
363         .stack (NOLOAD) : AT(__stack_lma) {
364                 __stack_start = .;
365                 *(.stack)
366                 __stack_end = .;
367         }
368         __stack_len = ABSOLUTE(__stack_end) - ABSOLUTE(__stack_start);
369         __stack_dwords = (__stack_len + 3) >> 2;
371         _end = .;
373         /* COM32R and kernels are loaded after our own PM code */
374         . = ALIGN(65536);
375         free_high_memory = .;
377         /* Stuff we don't need... */
378         /DISCARD/ : {
379                 *(.eh_frame)
380         }