623 lines
18 KiB
Diff
623 lines
18 KiB
Diff
|
From a14b1b3d3e375d2e8af8804171ef5e52574dbb2a Mon Sep 17 00:00:00 2001
|
||
|
From: "H. Peter Anvin" <hpa@zytor.com>
|
||
|
Date: Tue, 9 Feb 2016 18:15:50 -0800
|
||
|
Subject: [PATCH] core: Clean up the i386-bios build
|
||
|
|
||
|
Remove symbols and data structures not used in the i386-bios build,
|
||
|
and clean up the linker script so that most internal symbols are
|
||
|
HIDDEN.
|
||
|
|
||
|
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
|
||
|
|
||
|
Upstream: ff859050fa4e6535cae098dc35d88a265466448d
|
||
|
|
||
|
This patch fixes the following build failure with i386 binutils 2.28.1:
|
||
|
|
||
|
/builds/arnout/buildroot/output/host/bin/i586-buildroot-linux-uclibc-ld -Bsymbolic -pie -E --hash-style=gnu -T
|
||
|
/builds/arnout/buildroot/output/build/syslinux-6.03/core/i386/syslinux.ld -M -o ldlinux.elf ldlinux.o \
|
||
|
--start-group libcom32.a --whole-archive /builds/arnout/buildroot/output/build/syslinux-6.03/bios/com32/lib/libcom32core.a libldlinux.a --end-group -N
|
||
|
--no-omagic \
|
||
|
> ldlinux.map
|
||
|
/builds/arnout/buildroot/output/host/bin/i586-buildroot-linux-uclibc-ld: ldlinux.elf: Not enough room for program headers, try linking with -N
|
||
|
/builds/arnout/buildroot/output/host/bin/i586-buildroot-linux-uclibc-ld: final link failed: Bad value
|
||
|
/builds/arnout/buildroot/output/build/syslinux-6.03/core/Makefile:167: recipe for target 'ldlinux.elf' failed
|
||
|
|
||
|
Signed-off-by: Arnout Vandecappelle (Essensium/Mind) <arnout@mind.be>
|
||
|
---
|
||
|
core/extern.inc | 17 +--
|
||
|
core/i386/syslinux.ld | 287 +++++++++++++++++++++++++-------------------------
|
||
|
core/layout.inc | 11 --
|
||
|
3 files changed, 143 insertions(+), 172 deletions(-)
|
||
|
|
||
|
diff --git a/core/extern.inc b/core/extern.inc
|
||
|
index af8eb04c..ce4abfab 100644
|
||
|
--- a/core/extern.inc
|
||
|
+++ b/core/extern.inc
|
||
|
@@ -12,27 +12,17 @@
|
||
|
; hello.c
|
||
|
extern hello
|
||
|
|
||
|
- ;abort.c
|
||
|
- extern abort_load_new
|
||
|
-
|
||
|
; elflink/load_env32.c
|
||
|
extern load_env32, pm_env32_run
|
||
|
|
||
|
- ; memscan.c
|
||
|
- extern highmem_init
|
||
|
-
|
||
|
- extern linux_kernel
|
||
|
-
|
||
|
extern mp1, mp2, mp3, mp4, mp5
|
||
|
|
||
|
- extern hexdump, mydump
|
||
|
+ extern hexdump
|
||
|
|
||
|
extern mem_init
|
||
|
|
||
|
; fs.c
|
||
|
- extern pm_fs_init, pm_searchdir, getfssec, getfsbytes
|
||
|
- extern pm_mangle_name, pm_load_config
|
||
|
- extern pm_open_file, pm_close_file
|
||
|
+ extern pm_fs_init
|
||
|
extern SectorSize, SectorShift
|
||
|
|
||
|
; chdir.c
|
||
|
@@ -41,9 +31,6 @@
|
||
|
; readdir.c
|
||
|
extern opendir, readdir, closedir
|
||
|
|
||
|
- ; newconfig.c
|
||
|
- extern pm_is_config_file
|
||
|
-
|
||
|
; idle.c
|
||
|
extern __idle
|
||
|
|
||
|
diff --git a/core/i386/syslinux.ld b/core/i386/syslinux.ld
|
||
|
index 92b75b11..39198d75 100644
|
||
|
--- a/core/i386/syslinux.ld
|
||
|
+++ b/core/i386/syslinux.ld
|
||
|
@@ -1,7 +1,7 @@
|
||
|
/* -----------------------------------------------------------------------
|
||
|
*
|
||
|
* Copyright 2008-2009 H. Peter Anvin - All Rights Reserved
|
||
|
- * Copyright 2009 Intel Corporation; author: H. Peter Anvin
|
||
|
+ * Copyright 2009-2016 Intel Corporation; author: H. Peter Anvin
|
||
|
*
|
||
|
* This program is free software; you can redistribute it and/or modify
|
||
|
* it under the terms of the GNU General Public License as published by
|
||
|
@@ -12,7 +12,7 @@
|
||
|
* ----------------------------------------------------------------------- */
|
||
|
|
||
|
/*
|
||
|
- * Linker script for the SYSLINUX core
|
||
|
+ * Linker script for the SYSLINUX core when built for i386-bios
|
||
|
*/
|
||
|
|
||
|
OUTPUT_FORMAT("elf32-i386", "elf32-i386", "elf32-i386")
|
||
|
@@ -26,7 +26,7 @@ SECTIONS
|
||
|
{
|
||
|
/* Prefix structure for the compression program */
|
||
|
. = 0;
|
||
|
- __module_start = .;
|
||
|
+ HIDDEN(__module_start = ABSOLUTE(.));
|
||
|
.prefix : {
|
||
|
*(.prefix)
|
||
|
}
|
||
|
@@ -35,81 +35,82 @@ SECTIONS
|
||
|
. = 0x1000;
|
||
|
|
||
|
.earlybss (NOLOAD) : {
|
||
|
- __earlybss_start = .;
|
||
|
+ HIDDEN(__earlybss_start = .);
|
||
|
*(.earlybss)
|
||
|
- __earlybss_end = .;
|
||
|
+ HIDDEN(__earlybss_end = .);
|
||
|
}
|
||
|
- __earlybss_len = ABSOLUTE(__earlybss_end) - ABSOLUTE(__earlybss_start);
|
||
|
- __earlybss_dwords = (__earlybss_len + 3) >> 2;
|
||
|
+ HIDDEN(__earlybss_len = ABSOLUTE(__earlybss_end) - ABSOLUTE(__earlybss_start));
|
||
|
+ HIDDEN(__earlybss_dwords = (__earlybss_len + 3) >> 2);
|
||
|
|
||
|
. = ALIGN(4);
|
||
|
.bss16 (NOLOAD) : {
|
||
|
- __bss16_start = .;
|
||
|
+ HIDDEN(__bss16_start = .);
|
||
|
*(.bss16)
|
||
|
- __bss16_end = .;
|
||
|
+ HIDDEN(__bss16_end = .);
|
||
|
}
|
||
|
- __bss16_len = ABSOLUTE(__bss16_end) - ABSOLUTE(__bss16_start);
|
||
|
- __bss16_dwords = (__bss16_len + 3) >> 2;
|
||
|
+ HIDDEN(__bss16_len = ABSOLUTE(__bss16_end) - ABSOLUTE(__bss16_start));
|
||
|
+ HIDDEN(__bss16_dwords = (__bss16_len + 3) >> 2);
|
||
|
|
||
|
. = ALIGN(4);
|
||
|
.config : AT (__config_lma) {
|
||
|
- __config_start = .;
|
||
|
+ HIDDEN(__config_start = .);
|
||
|
*(.config)
|
||
|
- __config_end = .;
|
||
|
+ HIDDEN(__config_end = .);
|
||
|
}
|
||
|
- __config_len = ABSOLUTE(__config_end) - ABSOLUTE(__config_start);
|
||
|
- __config_dwords = (__config_len + 3) >> 2;
|
||
|
+ HIDDEN(__config_len = ABSOLUTE(__config_end) - ABSOLUTE(__config_start));
|
||
|
+ HIDDEN(__config_dwords = (__config_len + 3) >> 2);
|
||
|
|
||
|
/* Generated and/or copied code */
|
||
|
|
||
|
. = ALIGN(128); /* Minimum separation from mutable data */
|
||
|
.replacestub : AT (__replacestub_lma) {
|
||
|
- __replacestub_start = .;
|
||
|
+ HIDDEN(__replacestub_start = .);
|
||
|
*(.replacestub)
|
||
|
- __replacestub_end = .;
|
||
|
+ HIDDEN(__replacestub_end = .);
|
||
|
}
|
||
|
- __replacestub_len = ABSOLUTE(__replacestub_end) - ABSOLUTE(__replacestub_start);
|
||
|
- __replacestub_dwords = (__replacestub_len + 3) >> 2;
|
||
|
+ HIDDEN(__replacestub_len = ABSOLUTE(__replacestub_end) - ABSOLUTE(__replacestub_start));
|
||
|
+ HIDDEN(__replacestub_dwords = (__replacestub_len + 3) >> 2);
|
||
|
|
||
|
. = ALIGN(16);
|
||
|
- __gentextnr_lma = .;
|
||
|
+ HIDDEN(__gentextnr_lma = .);
|
||
|
.gentextnr : AT(__gentextnr_lma) {
|
||
|
- __gentextnr_start = .;
|
||
|
+ HIDDEN(__gentextnr_start = .);
|
||
|
*(.gentextnr)
|
||
|
- __gentextnr_end = .;
|
||
|
+ HIDDEN(__gentextnr_end = .);
|
||
|
}
|
||
|
- __gentextnr_len = ABSOLUTE(__gentextnr_end) - ABSOLUTE(__gentextnr_start);
|
||
|
- __gentextnr_dwords = (__gentextnr_len + 3) >> 2;
|
||
|
+ HIDDEN(__gentextnr_len = ABSOLUTE(__gentextnr_end) - ABSOLUTE(__gentextnr_start));
|
||
|
+ HIDDEN(__gentextnr_dwords = (__gentextnr_len + 3) >> 2);
|
||
|
|
||
|
. = STACK_BASE;
|
||
|
.stack16 : AT(STACK_BASE) {
|
||
|
- __stack16_start = .;
|
||
|
+ HIDDEN(__stack16_start = .);
|
||
|
. += STACK_LEN;
|
||
|
- __stack16_end = .;
|
||
|
+ HIDDEN(__stack16_end = .);
|
||
|
}
|
||
|
- __stack16_len = ABSOLUTE(__stack16_end) - ABSOLUTE(__stack16_start);
|
||
|
- __stack16_dwords = (__stack16_len + 3) >> 2;
|
||
|
+ HIDDEN(__stack16_len = ABSOLUTE(__stack16_end) - ABSOLUTE(__stack16_start));
|
||
|
+ HIDDEN(__stack16_dwords = (__stack16_len + 3) >> 2);
|
||
|
|
||
|
/* Initialized sections */
|
||
|
|
||
|
. = 0x7c00;
|
||
|
.init : {
|
||
|
FILL(0x90909090)
|
||
|
- __init_start = .;
|
||
|
+ HIDDEN(__init_start = .);
|
||
|
*(.init)
|
||
|
- __init_end = .;
|
||
|
+ HIDDEN(__init_end = .);
|
||
|
}
|
||
|
- __init_len = ABSOLUTE(__init_end) - ABSOLUTE(__init_start);
|
||
|
- __init_dwords = (__init_len + 3) >> 2;
|
||
|
+ HIDDEN(__init_len = ABSOLUTE(__init_end) - ABSOLUTE(__init_start));
|
||
|
+ HIDDEN(__init_dwords = (__init_len + 3) >> 2);
|
||
|
|
||
|
+ . = ALIGN(4);
|
||
|
.text16 : {
|
||
|
FILL(0x90909090)
|
||
|
- __text16_start = .;
|
||
|
+ HIDDEN(__text16_start = .);
|
||
|
*(.text16)
|
||
|
- __text16_end = .;
|
||
|
+ HIDDEN(__text16_end = .);
|
||
|
}
|
||
|
- __text16_len = ABSOLUTE(__text16_end) - ABSOLUTE(__text16_start);
|
||
|
- __text16_dwords = (__text16_len + 3) >> 2;
|
||
|
+ HIDDEN(__text16_len = ABSOLUTE(__text16_end) - ABSOLUTE(__text16_start));
|
||
|
+ HIDDEN(__text16_dwords = (__text16_len + 3) >> 2);
|
||
|
|
||
|
/*
|
||
|
* .textnr is used for 32-bit code that is used on the code
|
||
|
@@ -118,99 +119,92 @@ SECTIONS
|
||
|
. = ALIGN(16);
|
||
|
.textnr : {
|
||
|
FILL(0x90909090)
|
||
|
- __textnr_start = .;
|
||
|
+ HIDDEN(__textnr_start = .);
|
||
|
*(.textnr)
|
||
|
- __textnr_end = .;
|
||
|
+ HIDDEN(__textnr_end = .);
|
||
|
}
|
||
|
- __textnr_len = ABSOLUTE(__textnr_end) - ABSOLUTE(__textnr_start);
|
||
|
- __textnr_dwords = (__textnr_len + 3) >> 2;
|
||
|
+ HIDDEN(__textnr_len = ABSOLUTE(__textnr_end) - ABSOLUTE(__textnr_start));
|
||
|
+ HIDDEN(__textnr_dwords = (__textnr_len + 3) >> 2);
|
||
|
|
||
|
. = ALIGN(16);
|
||
|
- __bcopyxx_start = .;
|
||
|
+ HIDDEN(__bcopyxx_start = .);
|
||
|
|
||
|
.bcopyxx.text : {
|
||
|
FILL(0x90909090)
|
||
|
- __bcopyxx_text_start = .;
|
||
|
+ HIDDEN(__bcopyxx_text_start = .);
|
||
|
*(.bcopyxx.text)
|
||
|
- __bcopyxx_text_end = .;
|
||
|
+ HIDDEN(__bcopyxx_text_end = .);
|
||
|
}
|
||
|
- __bcopyxx_text_len = ABSOLUTE(__bcopyxx_text_end) - ABSOLUTE(__bcopyxx_text_start);
|
||
|
- __bcopyxx_text_dwords = (__bcopyxx_text_len + 3) >> 2;
|
||
|
+ HIDDEN(__bcopyxx_text_len = ABSOLUTE(__bcopyxx_text_end) - ABSOLUTE(__bcopyxx_text_start));
|
||
|
+ HIDDEN(__bcopyxx_text_dwords = (__bcopyxx_text_len + 3) >> 2);
|
||
|
|
||
|
.bcopyxx.data : {
|
||
|
- __bcopyxx_data_start = .;
|
||
|
+ HIDDEN(__bcopyxx_data_start = .);
|
||
|
*(.bcopyxx.text)
|
||
|
- __bcopyxx_data_end = .;
|
||
|
+ HIDDEN(__bcopyxx_data_end = .);
|
||
|
}
|
||
|
- __bcopyxx_data_len = ABSOLUTE(__bcopyxx_data_end) - ABSOLUTE(__bcopyxx_data_start);
|
||
|
- __bcopyxx_data_dwords = (__bcopyxx_data_len + 3) >> 2;
|
||
|
+ HIDDEN(__bcopyxx_data_len = ABSOLUTE(__bcopyxx_data_end) - ABSOLUTE(__bcopyxx_data_start));
|
||
|
+ HIDDEN(__bcopyxx_data_dwords = (__bcopyxx_data_len + 3) >> 2);
|
||
|
|
||
|
- __bcopyxx_end = .;
|
||
|
- __bcopyxx_len = ABSOLUTE(__bcopyxx_end) - ABSOLUTE(__bcopyxx_start);
|
||
|
- __bcopyxx_dwords = (__bcopyxx_len + 3) >> 2;
|
||
|
+ HIDDEN(__bcopyxx_end = .);
|
||
|
+ HIDDEN(__bcopyxx_len = ABSOLUTE(__bcopyxx_end) - ABSOLUTE(__bcopyxx_start));
|
||
|
+ HIDDEN(__bcopyxx_dwords = (__bcopyxx_len + 3) >> 2);
|
||
|
|
||
|
. = ALIGN(4);
|
||
|
.data16 : {
|
||
|
- __data16_start = .;
|
||
|
+ HIDDEN(__data16_start = .);
|
||
|
*(.data16)
|
||
|
- __data16_end = .;
|
||
|
+ HIDDEN(__data16_end = .);
|
||
|
}
|
||
|
- __data16_len = ABSOLUTE(__data16_end) - ABSOLUTE(__data16_start);
|
||
|
- __data16_dwords = (__data16_len + 3) >> 2;
|
||
|
+ HIDDEN(__data16_len = ABSOLUTE(__data16_end) - ABSOLUTE(__data16_start));
|
||
|
+ HIDDEN(__data16_dwords = (__data16_len + 3) >> 2);
|
||
|
|
||
|
. = ALIGN(4);
|
||
|
- __config_lma = .;
|
||
|
+ HIDDEN(__config_lma = ABSOLUTE(.));
|
||
|
. += SIZEOF(.config);
|
||
|
|
||
|
. = ALIGN(4);
|
||
|
- __replacestub_lma = .;
|
||
|
+ HIDDEN(__replacestub_lma = ABSOLUTE(.));
|
||
|
. += SIZEOF(.replacestub);
|
||
|
|
||
|
/* The 32-bit code loads above the non-progbits sections */
|
||
|
|
||
|
. = ALIGN(16);
|
||
|
- __pm_code_lma = .;
|
||
|
+ HIDDEN(__pm_code_lma = ABSOLUTE(.));
|
||
|
|
||
|
- __high_clear_start = .;
|
||
|
+ HIDDEN(__high_clear_start = .);
|
||
|
|
||
|
. = ALIGN(512);
|
||
|
.adv (NOLOAD) : {
|
||
|
- __adv_start = .;
|
||
|
+ HIDDEN(__adv_start = .);
|
||
|
*(.adv)
|
||
|
- __adv_end = .;
|
||
|
+ HIDDEN(__adv_end = .);
|
||
|
}
|
||
|
- __adv_len = ABSOLUTE(__adv_end) - ABSOLUTE(__adv_start);
|
||
|
- __adv_dwords = (__adv_len + 3) >> 2;
|
||
|
+ HIDDEN(__adv_len = ABSOLUTE(__adv_end) - ABSOLUTE(__adv_start));
|
||
|
+ HIDDEN(__adv_dwords = (__adv_len + 3) >> 2);
|
||
|
|
||
|
/* Late uninitialized sections */
|
||
|
|
||
|
. = ALIGN(4);
|
||
|
.uibss (NOLOAD) : {
|
||
|
- __uibss_start = .;
|
||
|
+ HIDDEN(__uibss_start = .);
|
||
|
*(.uibss)
|
||
|
- __uibss_end = .;
|
||
|
+ HIDDEN(__uibss_end = .);
|
||
|
}
|
||
|
- __uibss_len = ABSOLUTE(__uibss_end) - ABSOLUTE(__uibss_start);
|
||
|
- __uibss_dwords = (__uibss_len + 3) >> 2;
|
||
|
+ HIDDEN(__uibss_len = ABSOLUTE(__uibss_end) - ABSOLUTE(__uibss_start));
|
||
|
+ HIDDEN(__uibss_dwords = (__uibss_len + 3) >> 2);
|
||
|
|
||
|
- _end16 = .;
|
||
|
- __assert_end16 = ASSERT(_end16 <= 0x10000, "64K overflow");
|
||
|
+ HIDDEN(_end16 = .);
|
||
|
+ HIDDEN(__assert_end16 = ASSERT(_end16 <= 0x10000, "64K overflow"));
|
||
|
|
||
|
/*
|
||
|
* Special 16-bit segments
|
||
|
*/
|
||
|
-
|
||
|
- . = ALIGN(65536);
|
||
|
- .real_mode (NOLOAD) : {
|
||
|
- *(.real_mode)
|
||
|
- }
|
||
|
- real_mode_seg = core_real_mode >> 4;
|
||
|
-
|
||
|
. = ALIGN(65536);
|
||
|
.xfer_buf (NOLOAD) : {
|
||
|
*(.xfer_buf)
|
||
|
}
|
||
|
- xfer_buf_seg = core_xfer_buf >> 4;
|
||
|
+ HIDDEN(xfer_buf_seg = core_xfer_buf >> 4);
|
||
|
|
||
|
/*
|
||
|
* The auxilliary data segment is used by the 16-bit code
|
||
|
@@ -219,33 +213,33 @@ SECTIONS
|
||
|
|
||
|
. = ALIGN(16);
|
||
|
.auxseg (NOLOAD) : {
|
||
|
- __auxseg_start = .;
|
||
|
+ HIDDEN(__auxseg_start = .);
|
||
|
*(.auxseg)
|
||
|
- __auxseg_end = .;
|
||
|
+ HIDDEN(__auxseg_end = .);
|
||
|
}
|
||
|
- __auxseg_len = ABSOLUTE(__auxseg_end) - ABSOLUTE(__auxseg_start);
|
||
|
- __auxseg_dwords = (__auxseg_len + 3) >> 2;
|
||
|
- aux_seg = __auxseg_start >> 4;
|
||
|
+ HIDDEN(__auxseg_len = ABSOLUTE(__auxseg_end) - ABSOLUTE(__auxseg_start));
|
||
|
+ HIDDEN(__auxseg_dwords = (__auxseg_len + 3) >> 2);
|
||
|
+ HIDDEN(aux_seg = __auxseg_start >> 4);
|
||
|
|
||
|
/*
|
||
|
* Used to allocate lowmem buffers from 32-bit code
|
||
|
*/
|
||
|
.lowmem (NOLOAD) : {
|
||
|
- __lowmem_start = .;
|
||
|
+ HIDDEN(__lowmem_start = .);
|
||
|
*(.lowmem)
|
||
|
- __lowmem_end = .;
|
||
|
+ HIDDEN(__lowmem_end = .);
|
||
|
}
|
||
|
- __lowmem_len = ABSOLUTE(__lowmem_end) - ABSOLUTE(__lowmem_start);
|
||
|
- __lowmem_dwords = (__lowmem_len + 3) >> 2;
|
||
|
+ HIDDEN(__lowmem_len = ABSOLUTE(__lowmem_end) - ABSOLUTE(__lowmem_start));
|
||
|
+ HIDDEN(__lowmem_dwords = (__lowmem_len + 3) >> 2);
|
||
|
|
||
|
- __high_clear_end = .;
|
||
|
+ HIDDEN(__high_clear_end = .);
|
||
|
|
||
|
- __high_clear_len = ABSOLUTE(__high_clear_end) - ABSOLUTE(__high_clear_start);
|
||
|
- __high_clear_dwords = (__high_clear_len + 3) >> 2;
|
||
|
+ HIDDEN(__high_clear_len = ABSOLUTE(__high_clear_end) - ABSOLUTE(__high_clear_start));
|
||
|
+ HIDDEN(__high_clear_dwords = (__high_clear_len + 3) >> 2);
|
||
|
|
||
|
/* Start of the lowmem heap */
|
||
|
. = ALIGN(16);
|
||
|
- __lowmem_heap = .;
|
||
|
+ HIDDEN(__lowmem_heap = .);
|
||
|
|
||
|
/*
|
||
|
* 32-bit code. This is a hack for the moment due to the
|
||
|
@@ -254,136 +248,137 @@ SECTIONS
|
||
|
|
||
|
. = 0x100000;
|
||
|
|
||
|
- __pm_code_start = .;
|
||
|
- __vma_to_lma = __pm_code_lma - __pm_code_start;
|
||
|
+ HIDDEN(__pm_code_start = .);
|
||
|
+ HIDDEN(__vma_to_lma = ABSOLUTE(__pm_code_lma - __pm_code_start));
|
||
|
|
||
|
.text : AT(ADDR(.text) + __vma_to_lma) {
|
||
|
FILL(0x90909090)
|
||
|
- __text_start = .;
|
||
|
+ HIDDEN(__text_start = .);
|
||
|
*(.text)
|
||
|
*(.text.*)
|
||
|
- __text_end = .;
|
||
|
+ HIDDEN(__text_end = .);
|
||
|
}
|
||
|
|
||
|
.rodata : AT(ADDR(.rodata) + __vma_to_lma) {
|
||
|
- __rodata_start = .;
|
||
|
+ HIDDEN(__rodata_start = .);
|
||
|
*(.rodata)
|
||
|
*(.rodata.*)
|
||
|
- __rodata_end = .;
|
||
|
+ HIDDEN(__rodata_end = .);
|
||
|
}
|
||
|
|
||
|
.ctors : AT(ADDR(.ctors) + __vma_to_lma) {
|
||
|
- __ctors_start = .;
|
||
|
+ HIDDEN(__ctors_start = .);
|
||
|
KEEP (*(SORT(.ctors.*)))
|
||
|
KEEP (*(.ctors))
|
||
|
- __ctors_end = .;
|
||
|
+ HIDDEN(__ctors_end = .);
|
||
|
}
|
||
|
|
||
|
.dtors : AT(ADDR(.dtors) + __vma_to_lma) {
|
||
|
- __dtors_start = .;
|
||
|
+ HIDDEN(__dtors_start = .);
|
||
|
KEEP (*(SORT(.dtors.*)))
|
||
|
KEEP (*(.dtors))
|
||
|
- __dtors_end = .;
|
||
|
+ HIDDEN(__dtors_end = .);
|
||
|
}
|
||
|
|
||
|
.dynsym : AT(ADDR(.dynsym) + __vma_to_lma) {
|
||
|
- __dynsym_start = .;
|
||
|
- *(.dynsym)
|
||
|
- __dynsym_end = .;
|
||
|
+ HIDDEN(__dynsym_start = .);
|
||
|
+ KEEP (*(.dynsym))
|
||
|
+ HIDDEN(__dynsym_end = .);
|
||
|
}
|
||
|
- __dynsym_len = __dynsym_end - __dynsym_start;
|
||
|
+ HIDDEN(__dynsym_len = __dynsym_end - __dynsym_start);
|
||
|
|
||
|
.dynstr : AT(ADDR(.dynstr) + __vma_to_lma) {
|
||
|
- __dynstr_start = .;
|
||
|
- *(.dynstr)
|
||
|
- __dynstr_end = .;
|
||
|
+ HIDDEN(__dynstr_start = .);
|
||
|
+ KEEP (*(.dynstr))
|
||
|
+ HIDDEN(__dynstr_end = .);
|
||
|
}
|
||
|
- __dynstr_len = __dynstr_end - __dynstr_start;
|
||
|
+ HIDDEN(__dynstr_len = __dynstr_end - __dynstr_start);
|
||
|
|
||
|
.gnu.hash : AT(ADDR(.gnu.hash) + __vma_to_lma) {
|
||
|
- __gnu_hash_start = .;
|
||
|
- *(.gnu.hash)
|
||
|
- __gnu_hash_end = .;
|
||
|
+ HIDDEN(__gnu_hash_start = .);
|
||
|
+ KEEP (*(.gnu.hash))
|
||
|
+ HIDDEN(__gnu_hash_end = .);
|
||
|
}
|
||
|
|
||
|
|
||
|
.dynlink : AT(ADDR(.dynlink) + __vma_to_lma) {
|
||
|
- __dynlink_start = .;
|
||
|
- *(.dynlink)
|
||
|
- __dynlink_end = .;
|
||
|
+ HIDDEN(__dynlink_start = .);
|
||
|
+ KEEP (*(.dynlink))
|
||
|
+ HIDDEN(__dynlink_end = .);
|
||
|
}
|
||
|
|
||
|
.got : AT(ADDR(.got) + __vma_to_lma) {
|
||
|
- __got_start = .;
|
||
|
- KEEP (*(.got.plt))
|
||
|
+ HIDDEN(__got_start = .);
|
||
|
KEEP (*(.got))
|
||
|
- __got_end = .;
|
||
|
+ KEEP (*(.got.plt))
|
||
|
+ HIDDEN(__got_end = .);
|
||
|
}
|
||
|
|
||
|
.dynamic : AT(ADDR(.dynamic) + __vma_to_lma) {
|
||
|
- __dynamic_start = .;
|
||
|
- *(.dynamic)
|
||
|
- __dynamic_end = .;
|
||
|
+ HIDDEN(__dynamic_start = .);
|
||
|
+ KEEP (*(.dynamic))
|
||
|
+ HIDDEN(__dynamic_end = .);
|
||
|
}
|
||
|
|
||
|
.data : AT(ADDR(.data) + __vma_to_lma) {
|
||
|
- __data_start = .;
|
||
|
+ HIDDEN(__data_start = .);
|
||
|
*(.data)
|
||
|
*(.data.*)
|
||
|
- __data_end = .;
|
||
|
+ HIDDEN(__data_end = .);
|
||
|
}
|
||
|
|
||
|
- __pm_code_end = .;
|
||
|
- __pm_code_len = ABSOLUTE(__pm_code_end) - ABSOLUTE(__pm_code_start);
|
||
|
- __pm_code_dwords = (__pm_code_len + 3) >> 2;
|
||
|
+ HIDDEN(__pm_code_end = .);
|
||
|
+ HIDDEN(__pm_code_len = ABSOLUTE(__pm_code_end) - ABSOLUTE(__pm_code_start));
|
||
|
+ HIDDEN(__pm_code_dwords = (__pm_code_len + 3) >> 2);
|
||
|
|
||
|
. = ALIGN(128);
|
||
|
|
||
|
- __bss_vma = .;
|
||
|
- __bss_lma = .; /* Dummy */
|
||
|
+ HIDDEN(__bss_vma = .);
|
||
|
+ HIDDEN(__bss_lma = ABSOLUTE(.)); /* Dummy */
|
||
|
.bss (NOLOAD) : AT (__bss_lma) {
|
||
|
- __bss_start = .;
|
||
|
+ HIDDEN(__bss_start = .);
|
||
|
*(.bss)
|
||
|
*(.bss.*)
|
||
|
*(COMMON)
|
||
|
- __bss_end = .;
|
||
|
+ HIDDEN(__bss_end = .);
|
||
|
}
|
||
|
- __bss_len = ABSOLUTE(__bss_end) - ABSOLUTE(__bss_start);
|
||
|
- __bss_dwords = (__bss_len + 3) >> 2;
|
||
|
+ HIDDEN(__bss_len = ABSOLUTE(__bss_end) - ABSOLUTE(__bss_start));
|
||
|
+ HIDDEN(__bss_dwords = (__bss_len + 3) >> 2);
|
||
|
|
||
|
/* Very large objects which don't need to be zeroed */
|
||
|
|
||
|
- __hugebss_vma = .;
|
||
|
- __hugebss_lma = .; /* Dummy */
|
||
|
+ HIDDEN(__hugebss_vma = .);
|
||
|
+ HIDDEN(__hugebss_lma = ABSOLUTE(.)); /* Dummy */
|
||
|
.hugebss (NOLOAD) : AT (__hugebss_lma) {
|
||
|
- __hugebss_start = .;
|
||
|
+ HIDDEN(__hugebss_start = .);
|
||
|
*(.hugebss)
|
||
|
*(.hugebss.*)
|
||
|
- __hugebss_end = .;
|
||
|
+ HIDDEN(__hugebss_end = .);
|
||
|
}
|
||
|
- __hugebss_len = ABSOLUTE(__hugebss_end) - ABSOLUTE(__hugebss_start);
|
||
|
- __hugebss_dwords = (__hugebss_len + 3) >> 2;
|
||
|
+ HIDDEN(__hugebss_len = ABSOLUTE(__hugebss_end) - ABSOLUTE(__hugebss_start));
|
||
|
+ HIDDEN(__hugebss_dwords = (__hugebss_len + 3) >> 2);
|
||
|
|
||
|
|
||
|
/* XXX: This stack should be unified with the COM32 stack */
|
||
|
- __stack_vma = .;
|
||
|
- __stack_lma = .; /* Dummy */
|
||
|
+ HIDDEN(__stack_vma = .);
|
||
|
+ HIDDEN(__stack_lma = ABSOLUTE(.)); /* Dummy */
|
||
|
.stack (NOLOAD) : AT(__stack_lma) {
|
||
|
- __stack_start = .;
|
||
|
+ HIDDEN(__stack_start = .);
|
||
|
*(.stack)
|
||
|
- __stack_end = .;
|
||
|
+ HIDDEN(__stack_end = .);
|
||
|
}
|
||
|
- __stack_len = ABSOLUTE(__stack_end) - ABSOLUTE(__stack_start);
|
||
|
- __stack_dwords = (__stack_len + 3) >> 2;
|
||
|
+ HIDDEN(__stack_len = ABSOLUTE(__stack_end) - ABSOLUTE(__stack_start));
|
||
|
+ HIDDEN(__stack_dwords = (__stack_len + 3) >> 2);
|
||
|
|
||
|
- _end = .;
|
||
|
+ HIDDEN(_end = .);
|
||
|
|
||
|
/* COM32R and kernels are loaded after our own PM code */
|
||
|
. = ALIGN(65536);
|
||
|
- free_high_memory = .;
|
||
|
+ HIDDEN(free_high_memory = .);
|
||
|
|
||
|
/* Stuff we don't need... */
|
||
|
/DISCARD/ : {
|
||
|
*(.eh_frame)
|
||
|
+ *(.interp)
|
||
|
}
|
||
|
}
|
||
|
diff --git a/core/layout.inc b/core/layout.inc
|
||
|
index 53ca783d..635df537 100644
|
||
|
--- a/core/layout.inc
|
||
|
+++ b/core/layout.inc
|
||
|
@@ -139,17 +139,6 @@ serial_buf_size equ 4096 ; Should be a power of 2
|
||
|
core_xfer_buf resb 65536
|
||
|
|
||
|
;
|
||
|
-; Segment for the real mode code (needed as long as we have a in-kernel
|
||
|
-; loader and/or COM16 support.
|
||
|
-; One symbol for the segment number, one for the absolute address
|
||
|
-;
|
||
|
- extern real_mode_seg
|
||
|
- section .real_mode write nobits align=65536
|
||
|
- global core_real_mode:data hidden
|
||
|
-core_real_mode resb 65536
|
||
|
-comboot_seg equ real_mode_seg ; COMBOOT image loading zone
|
||
|
-
|
||
|
-;
|
||
|
; At the very end, the lowmem heap
|
||
|
;
|
||
|
extern __lowmem_heap
|
||
|
--
|
||
|
2.13.3
|
||
|
|