2013-01-09 06:05:06 +01:00
|
|
|
/*
|
|
|
|
* This file is part of the coreboot project.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2006 Advanced Micro Devices, Inc.
|
|
|
|
* Copyright (C) 2008-2010 coresystems GmbH
|
|
|
|
*
|
|
|
|
* 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
|
|
|
|
* the Free Software Foundation; version 2 of the License.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
2013-02-23 18:37:27 +01:00
|
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
2013-01-09 06:05:06 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
/* We use ELF as output format. So that we can debug the code in some form. */
|
|
|
|
OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm")
|
|
|
|
OUTPUT_ARCH(arm)
|
2013-09-29 12:02:55 +02:00
|
|
|
INCLUDE ldoptions
|
2013-01-09 06:05:06 +01:00
|
|
|
|
ARM: Define custom ELF headers for ARM.
At least when building with the gnu toolchain, the headers the linker
automatically generate save space for the actual ELF headers in one of the
loadable segments. This creates two problems. First, the data you intended to
be at the start of the image doesn't actually show up there, it's actually the
ELF headers. Second, the ELF headers are essentially useless for firmware
since there's currently nothing to tell you where they are, and even if there
was, there isn't much of a reason to look at them. They're useful in userspace
for, for instance, the dynamic linker, but not really in firmware.
This change adds a PHDRS construct to each of the linker scripts used on ARM
which define a single segment called to_load which does not have the flag set
which would tell the linker to put headers in it. The first section defined in
the script has ": to_load" to tell the linker which segment to put it in, and
from that point on the other sections go in there by default.
Change-Id: I24b721eb436d17afd234002ae82f9166d2fcf65d
Signed-off-by: Gabe Black <gabeblack@chromium.org>
Reviewed-on: http://review.coreboot.org/3580
Tested-by: build bot (Jenkins)
Reviewed-by: Ronald G. Minnich <rminnich@gmail.com>
2013-07-01 14:03:47 +02:00
|
|
|
PHDRS
|
|
|
|
{
|
|
|
|
to_load PT_LOAD;
|
|
|
|
}
|
|
|
|
|
2013-10-16 02:36:17 +02:00
|
|
|
ENTRY(_start)
|
2013-01-09 06:05:06 +01:00
|
|
|
TARGET(binary)
|
|
|
|
SECTIONS
|
|
|
|
{
|
2013-10-16 02:36:17 +02:00
|
|
|
. = CONFIG_BOOTBLOCK_BASE;
|
2013-01-09 06:05:06 +01:00
|
|
|
|
2013-10-16 02:36:17 +02:00
|
|
|
.bootblock . : {
|
2014-01-25 01:23:08 +01:00
|
|
|
*(.text._start);
|
2013-10-16 02:36:17 +02:00
|
|
|
KEEP(*(.id));
|
2013-01-09 06:05:06 +01:00
|
|
|
*(.text);
|
|
|
|
*(.text.*);
|
2013-10-16 02:36:17 +02:00
|
|
|
*(.rodata);
|
2013-01-09 06:05:06 +01:00
|
|
|
*(.rodata.*);
|
2013-10-16 02:36:17 +02:00
|
|
|
*(.data);
|
|
|
|
*(.data.*);
|
|
|
|
*(.bss);
|
|
|
|
*(.bss.*);
|
|
|
|
*(.sbss);
|
|
|
|
*(.sbss.*);
|
ARM: Define custom ELF headers for ARM.
At least when building with the gnu toolchain, the headers the linker
automatically generate save space for the actual ELF headers in one of the
loadable segments. This creates two problems. First, the data you intended to
be at the start of the image doesn't actually show up there, it's actually the
ELF headers. Second, the ELF headers are essentially useless for firmware
since there's currently nothing to tell you where they are, and even if there
was, there isn't much of a reason to look at them. They're useful in userspace
for, for instance, the dynamic linker, but not really in firmware.
This change adds a PHDRS construct to each of the linker scripts used on ARM
which define a single segment called to_load which does not have the flag set
which would tell the linker to put headers in it. The first section defined in
the script has ": to_load" to tell the linker which segment to put it in, and
from that point on the other sections go in there by default.
Change-Id: I24b721eb436d17afd234002ae82f9166d2fcf65d
Signed-off-by: Gabe Black <gabeblack@chromium.org>
Reviewed-on: http://review.coreboot.org/3580
Tested-by: build bot (Jenkins)
Reviewed-by: Ronald G. Minnich <rminnich@gmail.com>
2013-07-01 14:03:47 +02:00
|
|
|
} : to_load = 0xff
|
2013-01-09 06:05:06 +01:00
|
|
|
|
|
|
|
/DISCARD/ : {
|
|
|
|
*(.comment)
|
|
|
|
*(.note)
|
|
|
|
*(.comment.*)
|
|
|
|
*(.note.*)
|
|
|
|
*(.ARM.*)
|
|
|
|
}
|
2014-01-25 01:23:08 +01:00
|
|
|
}
|