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 * ----------------------------------------------------------------------- */ 13 14/* 15 * Linker script for the SYSLINUX core 16 */ 17 18OUTPUT_FORMAT("elf32-i386", "elf32-i386", "elf32-i386") 19OUTPUT_ARCH(i386) 20EXTERN(_start) 21ENTRY(_start) 22 23STACK32_LEN = 65536; 24 25SECTIONS 26{ 27 /* Prefix structure for the compression program */ 28 . = 0; 29 HIDDEN(__module_start = .); 30 .prefix : { 31 *(.prefix) 32 } 33 34 /* "Early" sections (before the load) */ 35 . = 0x1000; 36 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); 44 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); 53 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); 62 63 /* Generated and/or copied code */ 64 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); 73 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); 83 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); 92 93 /* Initialized sections */ 94 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); 104 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); 113 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); 127 128 . = ALIGN(16); 129 HIDDEN(__bcopyxx_start = .); 130 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); 139 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); 147 148 HIDDEN(__bcopyxx_end = .); 149 HIDDEN(__bcopyxx_len = ABSOLUTE(__bcopyxx_end) - ABSOLUTE(__bcopyxx_start)); 150 HIDDEN(__bcopyxx_dwords = (__bcopyxx_len + 3) >> 2); 151 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); 160 161 . = ALIGN(4); 162 HIDDEN(__config_lma = .); 163 . += SIZEOF(.config); 164 165 . = ALIGN(4); 166 HIDDEN(__replacestub_lma = .); 167 . += SIZEOF(.replacestub); 168 169 /* The 32-bit code loads above the non-progbits sections */ 170 171 . = ALIGN(16); 172 HIDDEN(__pm_code_lma = .); 173 174 HIDDEN(__high_clear_start = .); 175 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); 184 185 /* Late uninitialized sections */ 186 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); 195 196 HIDDEN(_end16 = .); 197 HIDDEN(__assert_end16 = ASSERT(_end16 <= 0x10000, "64K overflow")); 198 199 /* 200 * Special 16-bit segments 201 */ 202 203 . = ALIGN(65536); 204 .real_mode (NOLOAD) : { 205 *(.real_mode) 206 } 207 HIDDEN(real_mode_seg = core_real_mode >> 4); 208 209 . = ALIGN(65536); 210 .xfer_buf (NOLOAD) : { 211 *(.xfer_buf) 212 } 213 HIDDEN(xfer_buf_seg = core_xfer_buf >> 4); 214 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); 225 226 HIDDEN(__high_clear_end = .); 227 228 HIDDEN(__high_clear_len = ABSOLUTE(__high_clear_end) - ABSOLUTE(__high_clear_start)); 229 HIDDEN(__high_clear_dwords = (__high_clear_len + 3) >> 2); 230 231 /* Start of the lowmem heap */ 232 . = ALIGN(16); 233 HIDDEN(__lowmem_heap = .); 234 235 /* 236 * 32-bit code. This is a hack for the moment due to the 237 * real-mode segments also allocated. 238 */ 239 240 . = 0x100000; 241 242 HIDDEN(__pm_code_start = .); 243 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 } 253 254 . = ALIGN(16); 255 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 } 264 265 . = ALIGN(4); 266 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 } 276 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 } 285 286 . = ALIGN(4); 287 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); 296 297 . = ALIGN(4); 298 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); 307 308 . = ALIGN(4); 309 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 } 317 318 319 . = ALIGN(4); 320 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 } 328 329 . = ALIGN(4); 330 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 } 339 340 . = ALIGN(4); 341 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 } 349 350 . = ALIGN(16); 351 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 } 360 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); 364 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); 378 379 /* Data saved away before bss initialization */ 380 . = ALIGN(128); 381 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); 392 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); 403 404 HIDDEN(_end = .); 405 406 /* Heap follows after our own PM code */ 407 . = ALIGN(65536); 408 HIDDEN(free_high_memory = .); 409 410 /* Stuff we don't need... */ 411 /DISCARD/ : { 412 *(.eh_frame) 413 } 414} 415