diff options
author | Jie Zhang <jie.zhang@analog.com> | 2008-07-11 19:24:39 +0000 |
---|---|---|
committer | Jie Zhang <jie.zhang@analog.com> | 2008-07-11 19:24:39 +0000 |
commit | 8c6845782707f98080fa789050c9d70afadb1842 (patch) | |
tree | e2d2297cb36dec999b811c330fe3ad93bb75297f /ld | |
parent | a0d21d280839472b02a86175045b7482ae301fb9 (diff) | |
download | gdb-8c6845782707f98080fa789050c9d70afadb1842.zip gdb-8c6845782707f98080fa789050c9d70afadb1842.tar.gz gdb-8c6845782707f98080fa789050c9d70afadb1842.tar.bz2 |
bfd/
* elf.c (_bfd_elf_map_sections_to_segments): Don't put
executable sections into the same segment with other
read only sections if --sep-code.
* elf32-bfin.c (elf32_bfin_code_in_l1): New variable.
(elf32_bfin_data_in_l1): New variable.
(elf32_bfin_final_write_processing): New.
(elf32_bfin_special_sections[]): New.
(elf_backend_final_write_processing): Define.
(elf_backend_special_sections): Define.
binutils/
* readelf.c (get_machine_flags): Deal with Blackfin specific
flags.
include/
* bfdlink.h (struct bfd_link_info): Add sep_code member
variable.
* elf/bfin.h (EF_BFIN_CODE_IN_L1): Define.
(EF_BFIN_DATA_IN_L1): Define.
ld/
* Makefile.am (eelf32bfin.c): Depend on bfin.em.
(eelf32bfinfd.c): Likewise.
* Makefile.in: Regenerate.
* gen-doc.texi: Set Blackfin.
* ld.texinfo: Document --sep-code and Blackfin specific
options.
* ldmain.c (main): Initialize link_info.sep_code.
* lexsup.c (enum option_values): Add OPTION_SEP_CODE.
(ld_options[]): Add --sep-code.
(parse_args): Deal with --sep-code.
* emulparams/bfin.sh (EXTRA_EM_FILE): Define.
* emulparams/elf32bfinfd.sh (OTHER_SECTIONS): Define.
* emultempl/bfin.em: New file.
Diffstat (limited to 'ld')
-rw-r--r-- | ld/ChangeLog | 16 | ||||
-rw-r--r-- | ld/Makefile.am | 4 | ||||
-rw-r--r-- | ld/Makefile.in | 4 | ||||
-rwxr-xr-x | ld/emulparams/bfin.sh | 1 | ||||
-rw-r--r-- | ld/emulparams/elf32bfinfd.sh | 21 | ||||
-rw-r--r-- | ld/emultempl/bfin.em | 64 | ||||
-rw-r--r-- | ld/gen-doc.texi | 1 | ||||
-rw-r--r-- | ld/ld.texinfo | 36 | ||||
-rw-r--r-- | ld/ldmain.c | 1 | ||||
-rw-r--r-- | ld/lexsup.c | 6 |
10 files changed, 150 insertions, 4 deletions
diff --git a/ld/ChangeLog b/ld/ChangeLog index 8e6d62a..91bae67 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,3 +1,19 @@ +2008-07-12 Jie Zhang <jie.zhang@analog.com> + + * Makefile.am (eelf32bfin.c): Depend on bfin.em. + (eelf32bfinfd.c): Likewise. + * Makefile.in: Regenerate. + * gen-doc.texi: Set Blackfin. + * ld.texinfo: Document --sep-code and Blackfin specific + options. + * ldmain.c (main): Initialize link_info.sep_code. + * lexsup.c (enum option_values): Add OPTION_SEP_CODE. + (ld_options[]): Add --sep-code. + (parse_args): Deal with --sep-code. + * emulparams/bfin.sh (EXTRA_EM_FILE): Define. + * emulparams/elf32bfinfd.sh (OTHER_SECTIONS): Define. + * emultempl/bfin.em: New file. + 2008-07-09 Danny Smith <dannysmith@users.sourceforge.net> *pe-dll.c (autofilter_symbolprefixlist): Excude all symbols diff --git a/ld/Makefile.am b/ld/Makefile.am index 80c53d8..fe8edf0 100644 --- a/ld/Makefile.am +++ b/ld/Makefile.am @@ -653,11 +653,11 @@ edelta68.c: $(srcdir)/emulparams/delta68.sh \ $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/delta68.sc ${GEN_DEPENDS} ${GENSCRIPTS} delta68 "$(tdir_delta68)" eelf32bfin.c: $(srcdir)/emulparams/bfin.sh \ - $(ELF_DEPS) \ + $(ELF_DEPS) $(srcdir)/emultempl/bfin.em \ $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS} ${GENSCRIPTS} elf32bfin "$(tdir_elf32bfin)" bfin eelf32bfinfd.c: $(srcdir)/emulparams/elf32bfinfd.sh $(srcdir)/emulparams/bfin.sh \ - $(ELF_DEPS) \ + $(ELF_DEPS) $(srcdir)/emultempl/bfin.em \ $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS} ${GENSCRIPTS} elf32bfinfd "$(tdir_elf32bfinfd)" elf32bfinfd eelf32_dlx.c: $(srcdir)/emulparams/elf32_dlx.sh \ diff --git a/ld/Makefile.in b/ld/Makefile.in index 94e5d68..06b4846 100644 --- a/ld/Makefile.in +++ b/ld/Makefile.in @@ -1482,11 +1482,11 @@ edelta68.c: $(srcdir)/emulparams/delta68.sh \ $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/delta68.sc ${GEN_DEPENDS} ${GENSCRIPTS} delta68 "$(tdir_delta68)" eelf32bfin.c: $(srcdir)/emulparams/bfin.sh \ - $(ELF_DEPS) \ + $(ELF_DEPS) $(srcdir)/emultempl/bfin.em \ $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS} ${GENSCRIPTS} elf32bfin "$(tdir_elf32bfin)" bfin eelf32bfinfd.c: $(srcdir)/emulparams/elf32bfinfd.sh $(srcdir)/emulparams/bfin.sh \ - $(ELF_DEPS) \ + $(ELF_DEPS) $(srcdir)/emultempl/bfin.em \ $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS} ${GENSCRIPTS} elf32bfinfd "$(tdir_elf32bfinfd)" elf32bfinfd eelf32_dlx.c: $(srcdir)/emulparams/elf32_dlx.sh \ diff --git a/ld/emulparams/bfin.sh b/ld/emulparams/bfin.sh index 1c764e8..f33baf5 100755 --- a/ld/emulparams/bfin.sh +++ b/ld/emulparams/bfin.sh @@ -10,3 +10,4 @@ TEMPLATE_NAME=elf32 GENERATE_SHLIB_SCRIPT=yes EMBEDDED=yes USER_LABEL_PREFIX=_ +EXTRA_EM_FILE=bfin diff --git a/ld/emulparams/elf32bfinfd.sh b/ld/emulparams/elf32bfinfd.sh index 19ec748..588a53f 100644 --- a/ld/emulparams/elf32bfinfd.sh +++ b/ld/emulparams/elf32bfinfd.sh @@ -14,3 +14,24 @@ OTHER_READONLY_SECTIONS=" ${RELOCATING+__ROFIXUP_END__ = .;} } " +# 0xff700000, 0xff800000, 0xff900000 and 0xffa00000 are also used in +# Dynamic linker and linux kernel. They need to be keep synchronized. +OTHER_SECTIONS=" + .l1.data 0xff700000 : + { + *(.l1.data) + } + .l1.data.A 0xff800000 : + { + *(.l1.data.A) + } + .l1.data.B 0xff900000 : + { + *(.l1.data.B) + } + .l1.text 0xffa00000 : + { + *(.l1.text) + } +" +EXTRA_EM_FILE=bfin diff --git a/ld/emultempl/bfin.em b/ld/emultempl/bfin.em new file mode 100644 index 0000000..326537d --- /dev/null +++ b/ld/emultempl/bfin.em @@ -0,0 +1,64 @@ +# This shell script emits a C file. -*- C -*- +# Copyright 2006 Free Software Foundation, Inc. +# +# This file is part of GLD, the Gnu Linker. +# +# 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; either version 2 of the License, or +# (at your option) any later version. +# +# 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 +# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. +# + +# This file is sourced from elf32.em, and defines extra bfin-elf +# specific routines. +# +cat >>e${EMULATION_NAME}.c <<EOF + +#include "elf-bfd.h" + +/* Whether to put code in Blackfin L1 SRAM. */ +extern bfd_boolean elf32_bfin_code_in_l1; + +/* Whether to put (writable) data in Blackfin L1 SRAM. */ +extern bfd_boolean elf32_bfin_data_in_l1; + +EOF + + +# Define some shell vars to insert bits of code into the standard elf +# parse_args and list_options functions. +# +PARSE_AND_LIST_PROLOGUE=' +#define OPTION_CODE_IN_L1 300 +#define OPTION_DATA_IN_L1 301 +' + +PARSE_AND_LIST_LONGOPTS=' + { "code-in-l1", no_argument, NULL, OPTION_CODE_IN_L1 }, + { "data-in-l1", no_argument, NULL, OPTION_DATA_IN_L1 }, +' + +PARSE_AND_LIST_OPTIONS=' + fprintf (file, _("\ + --code-in-l1 Put code in l1.\n\ + --data-in-l1 Put data in l1.\n" + )); +' + +PARSE_AND_LIST_ARGS_CASES=' + case OPTION_CODE_IN_L1: + elf32_bfin_code_in_l1 = TRUE; + break; + case OPTION_DATA_IN_L1: + elf32_bfin_data_in_l1 = TRUE; + break; +' diff --git a/ld/gen-doc.texi b/ld/gen-doc.texi index 7434edb..f7e75cf 100644 --- a/ld/gen-doc.texi +++ b/ld/gen-doc.texi @@ -4,6 +4,7 @@ @c 2. Specific target machines @set ARM +@set Blackfin @set H8300 @set HPPA @set I960 diff --git a/ld/ld.texinfo b/ld/ld.texinfo index 4400524..a37d7d5 100644 --- a/ld/ld.texinfo +++ b/ld/ld.texinfo @@ -21,6 +21,7 @@ @set UsesEnvVars @set GENERIC @set ARM +@set Blackfin @set H8300 @set HPPA @set I960 @@ -140,6 +141,9 @@ section entitled ``GNU Free Documentation License''. @ifset ARM * ARM:: ld and the ARM family @end ifset +@ifset Blackfin +* Blackfin:: ld and the Blackfin family +@end ifset @ifset HPPA * HPPA ELF32:: ld and HPPA 32-bit ELF @end ifset @@ -825,6 +829,11 @@ For compatibility with other ELF linkers, if the @option{-R} option is followed by a directory name, rather than a file name, it is treated as the @option{-rpath} option. +@kindex --sep-code +@cindex input files, displaying +@itemx --sep-code +Put code in a seperate segment, not along with other read only data. + @kindex -s @kindex --strip-all @cindex strip all symbols @@ -5362,6 +5371,9 @@ functionality are not listed. @ifset ARM * ARM:: @command{ld} and the ARM family @end ifset +@ifset Blackfin +* Blackfin:: @command{ld} and the Blackfin family +@end ifset @ifset HPPA * HPPA ELF32:: @command{ld} and HPPA 32-bit ELF @end ifset @@ -5752,6 +5764,30 @@ otherwise. @end ifclear @end ifset +@ifset Blackfin +@ifclear GENERIC +@raisesections +@end ifclear + +@node Blackfin +@section @command{ld} and the Blackfin family + +@cindex Put code in L1 instruction SRAM +@kindex --code-in-l1 +The @samp{--code-in-l1} option adds a specific flag in the ELF header. +This flag tells loader to put the code segments into Blackfin +L1 instruction SRAM. + +@cindex Put code in L1 data SRAM +@kindex --data-in-l1 +The @samp{--data-in-l1} option adds a specific flag in the ELF header. +This flag tells loader to put the data segments into Blackfin L1 data SRAM. + +@ifclear GENERIC +@lowersections +@end ifclear +@end ifset + @ifset HPPA @ifclear GENERIC @raisesections diff --git a/ld/ldmain.c b/ld/ldmain.c index e7b9c0f..d094afa 100644 --- a/ld/ldmain.c +++ b/ld/ldmain.c @@ -277,6 +277,7 @@ main (int argc, char **argv) link_info.pei386_auto_import = -1; link_info.spare_dynamic_tags = 5; link_info.path_separator = ':'; + link_info.sep_code = FALSE; ldfile_add_arch (""); emulation = get_emulation (argc, argv); diff --git a/ld/lexsup.c b/ld/lexsup.c index 60a8167..3f63060 100644 --- a/ld/lexsup.c +++ b/ld/lexsup.c @@ -92,6 +92,7 @@ enum option_values OPTION_RETAIN_SYMBOLS_FILE, OPTION_RPATH, OPTION_RPATH_LINK, + OPTION_SEP_CODE, OPTION_SHARED, OPTION_SONAME, OPTION_SORT_COMMON, @@ -477,6 +478,8 @@ static const struct ld_option ld_options[] = '\0', NULL, N_("Create a position independent executable"), ONE_DASH }, { {"pic-executable", no_argument, NULL, OPTION_PIE}, '\0', NULL, NULL, TWO_DASHES }, + { {"sep-code", no_argument, NULL, OPTION_SEP_CODE}, + '\0', NULL, N_("Put code into separate segment"), TWO_DASHES }, { {"sort-common", optional_argument, NULL, OPTION_SORT_COMMON}, '\0', N_("[=ascending|descending]"), N_("Sort common symbols by alignment [in specified order]"), @@ -1143,6 +1146,9 @@ parse_args (unsigned argc, char **argv) else einfo (_("%P%F: -pie not supported\n")); break; + case OPTION_SEP_CODE: + link_info.sep_code = TRUE; + break; case 'h': /* Used on Solaris. */ case OPTION_SONAME: command_line.soname = optarg; |