1 /* -----------------------------------------------------------------------
3 * Copyright 2008-2009 H. Peter Anvin - All Rights Reserved
4 * Copyright 2009 Intel Corporation; author: H. Peter Anvin
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.
12 * ----------------------------------------------------------------------- */
15 * Linker script for the SYSLINUX core
18 OUTPUT_FORMAT("elf32-i386", "elf32-i386", "elf32-i386")
27 /* Prefix structure for the compression program */
34 /* "Early" sections (before the load) */
37 .earlybss (NOLOAD) : {
42 __earlybss_len = ABSOLUTE(__earlybss_end) - ABSOLUTE(__earlybss_start);
43 __earlybss_dwords = (__earlybss_len + 3) >> 2;
51 __bss16_len = ABSOLUTE(__bss16_end) - ABSOLUTE(__bss16_start);
52 __bss16_dwords = (__bss16_len + 3) >> 2;
55 .config : AT (__config_lma) {
60 __config_len = ABSOLUTE(__config_end) - ABSOLUTE(__config_start);
61 __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 __replacestub_start = .;
69 __replacestub_end = .;
71 __replacestub_len = ABSOLUTE(__replacestub_end) - ABSOLUTE(__replacestub_start);
72 __replacestub_dwords = (__replacestub_len + 3) >> 2;
76 .gentextnr : AT(__gentextnr_lma) {
77 __gentextnr_start = .;
81 __gentextnr_len = ABSOLUTE(__gentextnr_end) - ABSOLUTE(__gentextnr_start);
82 __gentextnr_dwords = (__gentextnr_len + 3) >> 2;
85 .stack16 : AT(STACK_BASE) {
90 __stack16_len = ABSOLUTE(__stack16_end) - ABSOLUTE(__stack16_start);
91 __stack16_dwords = (__stack16_len + 3) >> 2;
93 /* Initialized sections */
102 __init_len = ABSOLUTE(__init_end) - ABSOLUTE(__init_start);
103 __init_dwords = (__init_len + 3) >> 2;
111 __text16_len = ABSOLUTE(__text16_end) - ABSOLUTE(__text16_start);
112 __text16_dwords = (__text16_len + 3) >> 2;
115 * .textnr is used for 32-bit code that is used on the code
116 * path to initialize the .text segment
125 __textnr_len = ABSOLUTE(__textnr_end) - ABSOLUTE(__textnr_start);
126 __textnr_dwords = (__textnr_len + 3) >> 2;
133 __bcopyxx_text_start = .;
135 __bcopyxx_text_end = .;
137 __bcopyxx_text_len = ABSOLUTE(__bcopyxx_text_end) - ABSOLUTE(__bcopyxx_text_start);
138 __bcopyxx_text_dwords = (__bcopyxx_text_len + 3) >> 2;
141 __bcopyxx_data_start = .;
143 __bcopyxx_data_end = .;
145 __bcopyxx_data_len = ABSOLUTE(__bcopyxx_data_end) - ABSOLUTE(__bcopyxx_data_start);
146 __bcopyxx_data_dwords = (__bcopyxx_data_len + 3) >> 2;
149 __bcopyxx_len = ABSOLUTE(__bcopyxx_end) - ABSOLUTE(__bcopyxx_start);
150 __bcopyxx_dwords = (__bcopyxx_len + 3) >> 2;
158 __data16_len = ABSOLUTE(__data16_end) - ABSOLUTE(__data16_start);
159 __data16_dwords = (__data16_len + 3) >> 2;
163 . += SIZEOF(.config);
166 __replacestub_lma = .;
167 . += SIZEOF(.replacestub);
169 /* The 32-bit code loads above the non-progbits sections */
174 __high_clear_start = .;
182 __adv_len = ABSOLUTE(__adv_end) - ABSOLUTE(__adv_start);
183 __adv_dwords = (__adv_len + 3) >> 2;
185 /* Late uninitialized sections */
193 __uibss_len = ABSOLUTE(__uibss_end) - ABSOLUTE(__uibss_start);
194 __uibss_dwords = (__uibss_len + 3) >> 2;
197 __assert_end16 = ASSERT(_end16 <= 0x10000, "64K overflow");
200 * Special 16-bit segments
204 .real_mode (NOLOAD) : {
207 real_mode_seg = core_real_mode >> 4;
210 .xfer_buf (NOLOAD) : {
213 xfer_buf_seg = core_xfer_buf >> 4;
216 * Used to allocate lowmem buffers from 32-bit code
223 __lowmem_len = ABSOLUTE(__lowmem_end) - ABSOLUTE(__lowmem_start);
224 __lowmem_dwords = (__lowmem_len + 3) >> 2;
226 __high_clear_end = .;
228 __high_clear_len = ABSOLUTE(__high_clear_end) - ABSOLUTE(__high_clear_start);
229 __high_clear_dwords = (__high_clear_len + 3) >> 2;
231 /* Start of the lowmem heap */
236 * 32-bit code. This is a hack for the moment due to the
237 * real-mode segments also allocated.
245 __text_lma = __pm_code_lma;
246 .text : AT(__text_lma) {
257 __rodata_lma = __rodata_vma + __text_lma - __text_vma;
258 .rodata : AT(__rodata_lma) {
268 __ctors_lma = __ctors_vma + __text_lma - __text_vma;
269 .ctors : AT(__ctors_lma) {
271 KEEP (*(SORT(.preinit_array*)))
272 KEEP (*(SORT(.init_array*)))
273 KEEP (*(SORT(.ctors*)))
278 __dtors_lma = __dtors_vma + __text_lma - __text_vma;
279 .dtors : AT(__dtors_lma) {
281 KEEP (*(SORT(.fini_array*)))
282 KEEP (*(SORT(.dtors*)))
289 __dynsym_lma = __dynsym_vma + __text_lma - __text_vma;
290 .dynsym : AT(__dynsym_lma) {
295 __dynsym_len = __dynsym_end - __dynsym_start;
300 __dynstr_lma = __dynstr_vma + __text_lma - __text_vma;
301 .dynstr : AT(__dynstr_lma) {
306 __dynstr_len = __dynstr_end - __dynstr_start;
311 __gnu_hash_lma = __gnu_hash_vma + __text_lma - __text_vma;
312 .gnu.hash : AT(__gnu_hash_lma) {
313 __gnu_hash_start = .;
322 __dynlink_lma = __dynlink_vma + __text_lma - __text_vma;
323 .dynlink : AT(__dynlink_lma) {
332 __got_lma = __got_vma + __text_lma - __text_vma;
333 .got : AT(__got_lma) {
343 __dynamic_lma = __dynamic_vma + __text_lma - __text_vma;
344 .dynamic : AT(__dynamic_lma) {
353 __data_lma = __data_vma + __text_lma - __text_vma;
354 .data : AT(__data_lma) {
362 __pm_code_len = ABSOLUTE(__pm_code_end) - ABSOLUTE(__pm_code_start);
363 __pm_code_dwords = (__pm_code_len + 3) >> 2;
368 __bss_lma = .; /* Dummy */
369 .bss (NOLOAD) : AT (__bss_lma) {
376 __bss_len = ABSOLUTE(__bss_end) - ABSOLUTE(__bss_start);
377 __bss_dwords = (__bss_len + 3) >> 2;
379 /* Data saved away before bss initialization */
383 __savedata_lma = .; /* Dummy */
384 .savedata (NOLOAD) : AT (__savedata_lma) {
385 __savedata_start = .;
390 __savedata_len = ABSOLUTE(__savedata_end) - ABSOLUTE(__savedata_start);
391 __savedata_dwords = (__savedata_len + 3) >> 2;
393 /* XXX: This stack should be unified with the COM32 stack */
395 __stack_lma = .; /* Dummy */
396 .stack (NOLOAD) : AT(__stack_lma) {
401 __stack_len = ABSOLUTE(__stack_end) - ABSOLUTE(__stack_start);
402 __stack_dwords = (__stack_len + 3) >> 2;
406 /* COM32R and kernels are loaded after our own PM code */
408 free_high_memory = .;
410 /* Stuff we don't need... */