core, pxe: Don't push on one stack and pop from the other in pxenv
[syslinux.git] / core / syslinux.ld
blobfa8c8c9ba842e86f07cfe64264b9405a47ce4468
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 STACK32_LEN = 65536;
25 SECTIONS
27         /* Prefix structure for the compression program */
28         . = 0;
29         HIDDEN(__module_start = .);
30         .prefix : {
31                 *(.prefix)
32         }
34         /* "Early" sections (before the load) */
35         . = 0x1000;
37         .earlybss (NOLOAD) : {
38                 HIDDEN(__earlybss_start = .);
39                 *(.earlybss)
40                 HIDDEN(__earlybss_end = .);
41         }
42         HIDDEN(__earlybss_len = ABSOLUTE(__earlybss_end) - ABSOLUTE(__earlybss_start));
43         HIDDEN(__earlybss_dwords = (__earlybss_len + 3) >> 2);
45         . = ALIGN(4);
46         .bss16 (NOLOAD) : {
47                 HIDDEN(__bss16_start = .);
48                 *(.bss16)
49                 HIDDEN(__bss16_end = .);
50         }
51         HIDDEN(__bss16_len = ABSOLUTE(__bss16_end) - ABSOLUTE(__bss16_start));
52         HIDDEN(__bss16_dwords = (__bss16_len + 3) >> 2);
54         . = ALIGN(4);
55         .config : AT (__config_lma) {
56                 HIDDEN(__config_start = .);
57                 *(.config)
58                 HIDDEN(__config_end = .);
59         }
60         HIDDEN(__config_len = ABSOLUTE(__config_end) - ABSOLUTE(__config_start));
61         HIDDEN(__config_dwords = (__config_len + 3) >> 2);
63         /* Generated and/or copied code */
65         . = ALIGN(128);         /* Minimum separation from mutable data */
66         .replacestub : AT (__replacestub_lma) {
67                 HIDDEN(__replacestub_start = .);
68                 *(.replacestub)
69                 HIDDEN(__replacestub_end = .);
70         }
71         HIDDEN(__replacestub_len = ABSOLUTE(__replacestub_end) - ABSOLUTE(__replacestub_start));
72         HIDDEN(__replacestub_dwords = (__replacestub_len + 3) >> 2);
74         . = ALIGN(16);
75         HIDDEN(__gentextnr_lma = .);
76         .gentextnr : AT(__gentextnr_lma) {
77                 HIDDEN(__gentextnr_start = .);
78                 *(.gentextnr)
79                 HIDDEN(__gentextnr_end = .);
80         }
81         HIDDEN(__gentextnr_len = ABSOLUTE(__gentextnr_end) - ABSOLUTE(__gentextnr_start));
82         HIDDEN(__gentextnr_dwords = (__gentextnr_len + 3) >> 2);
84         . = STACK_BASE;
85         .stack16 : AT(STACK_BASE) {
86                 HIDDEN(__stack16_start = .);
87                 . += STACK_LEN;
88                 HIDDEN(__stack16_end = .);
89         }
90         HIDDEN(__stack16_len = ABSOLUTE(__stack16_end) - ABSOLUTE(__stack16_start));
91         HIDDEN(__stack16_dwords = (__stack16_len + 3) >> 2);
93         /* Initialized sections */
95         . = 0x7c00;
96         .init : {
97                 FILL(0x90909090)
98                 HIDDEN(__init_start = .);
99                 *(.init)
100                 HIDDEN(__init_end = .);
101         }
102         HIDDEN(__init_len = ABSOLUTE(__init_end) - ABSOLUTE(__init_start));
103         HIDDEN(__init_dwords = (__init_len + 3) >> 2);
105         .text16 : {
106                 FILL(0x90909090)
107                 HIDDEN(__text16_start = .);
108                 *(.text16)
109                 HIDDEN(__text16_end = .);
110         }
111         HIDDEN(__text16_len = ABSOLUTE(__text16_end) - ABSOLUTE(__text16_start));
112         HIDDEN(__text16_dwords = (__text16_len + 3) >> 2);
114         /*
115          * .textnr is used for 32-bit code that is used on the code
116          * path to initialize the .text segment
117          */
118         . = ALIGN(16);
119         .textnr : {
120                 FILL(0x90909090)
121                 HIDDEN(__textnr_start = .);
122                 *(.textnr)
123                 HIDDEN(__textnr_end = .);
124         }
125         HIDDEN(__textnr_len = ABSOLUTE(__textnr_end) - ABSOLUTE(__textnr_start));
126         HIDDEN(__textnr_dwords = (__textnr_len + 3) >> 2);
128         . = ALIGN(16);
129         HIDDEN(__bcopyxx_start = .);
131         .bcopyxx.text : {
132                 FILL(0x90909090)
133                 HIDDEN(__bcopyxx_text_start = .);
134                 *(.bcopyxx.text)
135                 HIDDEN(__bcopyxx_text_end = .);
136         }
137         HIDDEN(__bcopyxx_text_len = ABSOLUTE(__bcopyxx_text_end) - ABSOLUTE(__bcopyxx_text_start));
138         HIDDEN(__bcopyxx_text_dwords = (__bcopyxx_text_len + 3) >> 2);
140         .bcopyxx.data : {
141                 HIDDEN(__bcopyxx_data_start = .);
142                 *(.bcopyxx.text)
143                 HIDDEN(__bcopyxx_data_end = .);
144         }
145         HIDDEN(__bcopyxx_data_len = ABSOLUTE(__bcopyxx_data_end) - ABSOLUTE(__bcopyxx_data_start));
146         HIDDEN(__bcopyxx_data_dwords = (__bcopyxx_data_len + 3) >> 2);
148         HIDDEN(__bcopyxx_end = .);
149         HIDDEN(__bcopyxx_len = ABSOLUTE(__bcopyxx_end) - ABSOLUTE(__bcopyxx_start));
150         HIDDEN(__bcopyxx_dwords = (__bcopyxx_len + 3) >> 2);
152         . = ALIGN(4);
153         .data16 : {
154                 HIDDEN(__data16_start = .);
155                 *(.data16)
156                 HIDDEN(__data16_end = .);
157         }
158         HIDDEN(__data16_len = ABSOLUTE(__data16_end) - ABSOLUTE(__data16_start));
159         HIDDEN(__data16_dwords = (__data16_len + 3) >> 2);
161         . = ALIGN(4);
162         HIDDEN(__config_lma = .);
163         . += SIZEOF(.config);
165         . = ALIGN(4);
166         HIDDEN(__replacestub_lma = .);
167         . += SIZEOF(.replacestub);
169         /* The 32-bit code loads above the non-progbits sections */
171         . = ALIGN(16);
172         HIDDEN(__pm_code_lma = .);
174         HIDDEN(__high_clear_start = .);
176         . = ALIGN(512);
177         .adv (NOLOAD) : {
178                 HIDDEN(__adv_start = .);
179                 *(.adv)
180                 HIDDEN(__adv_end = .);
181         }
182         HIDDEN(__adv_len = ABSOLUTE(__adv_end) - ABSOLUTE(__adv_start));
183         HIDDEN(__adv_dwords = (__adv_len + 3) >> 2);
185         /* Late uninitialized sections */
187         . = ALIGN(4);
188         .uibss (NOLOAD) : {
189                 HIDDEN(__uibss_start = .);
190                 *(.uibss)
191                 HIDDEN(__uibss_end = .);
192         }
193         HIDDEN(__uibss_len = ABSOLUTE(__uibss_end) - ABSOLUTE(__uibss_start));
194         HIDDEN(__uibss_dwords = (__uibss_len + 3) >> 2);
196         HIDDEN(_end16 = .);
197         HIDDEN(__assert_end16 = ASSERT(_end16 <= 0x10000, "64K overflow"));
199         /*
200          * Special 16-bit segments
201          */
203         . = ALIGN(65536);
204         .real_mode (NOLOAD) : {
205                 *(.real_mode)
206         }
207         HIDDEN(real_mode_seg = core_real_mode >> 4);
209         . = ALIGN(65536);
210         .xfer_buf (NOLOAD) : {
211                 *(.xfer_buf)
212         }
213         HIDDEN(xfer_buf_seg = core_xfer_buf >> 4);
215         /*
216          * Used to allocate lowmem buffers from 32-bit code
217          */
218         .lowmem (NOLOAD) : {
219                 HIDDEN(__lowmem_start = .);
220                 *(.lowmem)
221                 HIDDEN(__lowmem_end = .);
222         }
223         HIDDEN(__lowmem_len = ABSOLUTE(__lowmem_end) - ABSOLUTE(__lowmem_start));
224         HIDDEN(__lowmem_dwords = (__lowmem_len + 3) >> 2);
226         HIDDEN(__high_clear_end = .);
228         HIDDEN(__high_clear_len = ABSOLUTE(__high_clear_end) - ABSOLUTE(__high_clear_start));
229         HIDDEN(__high_clear_dwords = (__high_clear_len + 3) >> 2);
231         /* Start of the lowmem heap */
232         . = ALIGN(16);
233         HIDDEN(__lowmem_heap = .);
235         /*
236          * 32-bit code.  This is a hack for the moment due to the
237          * real-mode segments also allocated.
238          */
240         . = 0x100000;
242         HIDDEN(__pm_code_start = .);
244         HIDDEN(__text_vma = .);
245         HIDDEN(__text_lma = __pm_code_lma);
246         .text : AT(__text_lma) {
247                 FILL(0x90909090)
248                 HIDDEN(__text_start = .);
249                 *(.text)
250                 *(.text.*)
251                 HIDDEN(__text_end = .);
252         }
254         . = ALIGN(16);
256         HIDDEN(__rodata_vma = .);
257         HIDDEN(__rodata_lma = __rodata_vma + __text_lma - __text_vma);
258         .rodata : AT(__rodata_lma) {
259                 HIDDEN(__rodata_start = .);
260                 *(.rodata)
261                 *(.rodata.*)
262                 HIDDEN(__rodata_end = .);
263         }
265         . = ALIGN(4);
267         HIDDEN(__ctors_vma = .);
268         HIDDEN(__ctors_lma = __ctors_vma + __text_lma - __text_vma);
269         .ctors : AT(__ctors_lma) {
270                 HIDDEN(__ctors_start = .);
271                 KEEP (*(SORT(.preinit_array*)))
272                 KEEP (*(SORT(.init_array*)))
273                 KEEP (*(SORT(.ctors*)))
274                 HIDDEN(__ctors_end = .);
275         }
277         HIDDEN(__dtors_vma = .);
278         HIDDEN(__dtors_lma = __dtors_vma + __text_lma - __text_vma);
279         .dtors : AT(__dtors_lma) {
280                 HIDDEN(__dtors_start = .);
281                 KEEP (*(SORT(.fini_array*)))
282                 KEEP (*(SORT(.dtors*)))
283                 HIDDEN(__dtors_end = .);
284         }
286         . = ALIGN(4);
288         HIDDEN(__dynsym_vma = .);
289         HIDDEN(__dynsym_lma = __dynsym_vma + __text_lma - __text_vma);
290         .dynsym : AT(__dynsym_lma) {
291                 HIDDEN(__dynsym_start = .);
292                 *(.dynsym)
293                 HIDDEN(__dynsym_end = .);
294         }
295         HIDDEN(__dynsym_len = __dynsym_end - __dynsym_start);
297         . = ALIGN(4);
299         HIDDEN(__dynstr_vma = .);
300         HIDDEN(__dynstr_lma = __dynstr_vma + __text_lma - __text_vma);
301         .dynstr : AT(__dynstr_lma) {
302                 HIDDEN(__dynstr_start = .);
303                 *(.dynstr)
304                 HIDDEN(__dynstr_end = .);
305         }
306         HIDDEN(__dynstr_len = __dynstr_end - __dynstr_start);
308         . = ALIGN(4);
310         HIDDEN(__gnu_hash_vma = .);
311         HIDDEN(__gnu_hash_lma = __gnu_hash_vma + __text_lma - __text_vma);
312         .gnu.hash : AT(__gnu_hash_lma) {
313                 HIDDEN(__gnu_hash_start = .);
314                 *(.gnu.hash)
315                 HIDDEN(__gnu_hash_end = .);
316         }
319         . = ALIGN(4);
321         HIDDEN(__dynlink_vma = .);
322         HIDDEN(__dynlink_lma = __dynlink_vma + __text_lma - __text_vma);
323         .dynlink : AT(__dynlink_lma) {
324                 HIDDEN(__dynlink_start = .);
325                 *(.dynlink)
326                 HIDDEN(__dynlink_end = .);
327         }
329         . = ALIGN(4);
331         HIDDEN(__got_vma = .);
332         HIDDEN(__got_lma = __got_vma + __text_lma - __text_vma);
333         .got : AT(__got_lma) {
334                 HIDDEN(__got_start = .);
335                 KEEP (*(.got.plt))
336                 KEEP (*(.got))
337                 HIDDEN(__got_end = .);
338         }
340         . = ALIGN(4);
342         HIDDEN(__dynamic_vma = .);
343         HIDDEN(__dynamic_lma = __dynamic_vma + __text_lma - __text_vma);
344         .dynamic : AT(__dynamic_lma) {
345                 HIDDEN(__dynamic_start = .);
346                 *(.dynamic)
347                 HIDDEN(__dynamic_end = .);
348         }
350         . = ALIGN(16);
352         HIDDEN(__data_vma = .);
353         HIDDEN(__data_lma = __data_vma + __text_lma - __text_vma);
354         .data : AT(__data_lma) {
355                 HIDDEN(__data_start = .);
356                 *(.data)
357                 *(.data.*)
358                 HIDDEN(__data_end = .);
359         }
361         HIDDEN(__pm_code_end = .);
362         HIDDEN(__pm_code_len = ABSOLUTE(__pm_code_end) - ABSOLUTE(__pm_code_start));
363         HIDDEN(__pm_code_dwords = (__pm_code_len + 3) >> 2);
365         . = ALIGN(128);
366         
367         HIDDEN(__bss_vma = .);
368         HIDDEN(__bss_lma = .);          /* Dummy */
369         .bss (NOLOAD) : AT (__bss_lma) {
370                 HIDDEN(__bss_start = .);
371                 *(.bss)
372                 *(.bss.*)
373                 *(COMMON)
374                 HIDDEN(__bss_end = .);
375         }
376         HIDDEN(__bss_len = ABSOLUTE(__bss_end) - ABSOLUTE(__bss_start));
377         HIDDEN(__bss_dwords = (__bss_len + 3) >> 2);
379         /* Data saved away before bss initialization */
380         . = ALIGN(128);
382         HIDDEN(__savedata_vma = .);
383         HIDDEN(__savedata_lma = .);             /* Dummy */
384         .savedata (NOLOAD) : AT (__savedata_lma) {
385                 HIDDEN(__savedata_start = .);
386                 *(.savedata)
387                 *(.savedata.*)
388                 HIDDEN(__savedata_end = .);
389         }
390         HIDDEN(__savedata_len = ABSOLUTE(__savedata_end) - ABSOLUTE(__savedata_start));
391         HIDDEN(__savedata_dwords = (__savedata_len + 3) >> 2);
393         /* XXX: This stack should be unified with the COM32 stack */
394         HIDDEN(__stack_vma = .);
395         __stack_lma = .;        /* Dummy */
396         .stack (NOLOAD) : AT(__stack_lma) {
397                 HIDDEN(__stack_start = .);
398                 *(.stack)
399                 HIDDEN(__stack_end = .);
400         }
401         HIDDEN(__stack_len = ABSOLUTE(__stack_end) - ABSOLUTE(__stack_start));
402         HIDDEN(__stack_dwords = (__stack_len + 3) >> 2);
404         HIDDEN(_end = .);
406         /* Heap follows after our own PM code */
407         . = ALIGN(65536);
408         HIDDEN(free_high_memory = .);
410         /* Stuff we don't need... */
411         /DISCARD/ : {
412                 *(.eh_frame)
413         }