diff options
author | Nick Clifton <nickc@redhat.com> | 2008-10-22 14:23:44 +0000 |
---|---|---|
committer | Nick Clifton <nickc@redhat.com> | 2008-10-22 14:23:44 +0000 |
commit | b8976b05f26681063c4d4a108c8e7e4ae010cee2 (patch) | |
tree | 2a018966ac5f56efef968dc560607f3625280fea /ld | |
parent | bb52de30f4f880bdb272312829da324cbe774cc1 (diff) | |
download | gdb-b8976b05f26681063c4d4a108c8e7e4ae010cee2.zip gdb-b8976b05f26681063c4d4a108c8e7e4ae010cee2.tar.gz gdb-b8976b05f26681063c4d4a108c8e7e4ae010cee2.tar.bz2 |
* emultempl/armelf.em (arm_elf_after_open): Move check for using a
non-arm output target from here...
(arm_elf_create_output_section_statements): ... to here, so that
the check is made at the earliest possible opportunity.
Diffstat (limited to 'ld')
-rw-r--r-- | ld/ChangeLog | 7 | ||||
-rw-r--r-- | ld/emultempl/armelf.em | 20 |
2 files changed, 17 insertions, 10 deletions
diff --git a/ld/ChangeLog b/ld/ChangeLog index ab15f1e..ab23982 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,3 +1,10 @@ +2008-10-22 Nick Clifton <nickc@redhat.com> + + * emultempl/armelf.em (arm_elf_after_open): Move check for using a + non-arm output target from here... + (arm_elf_create_output_section_statements): ... to here, so that + the check is made at the earliest possible opportunity. + 2008-10-22 Alan Modra <amodra@bigpond.net.au> * emulparams/elf32_i960.sh (TEMPLATE_NAME): "generic", not "elf32". diff --git a/ld/emultempl/armelf.em b/ld/emultempl/armelf.em index bb0e24c..6394105 100644 --- a/ld/emultempl/armelf.em +++ b/ld/emultempl/armelf.em @@ -55,16 +55,6 @@ gld${EMULATION_NAME}_before_parse (void) static void arm_elf_after_open (void) { - if (strstr (bfd_get_target (link_info.output_bfd), "arm") == NULL) - { - /* The arm backend needs special fields in the output hash structure. - These will only be created if the output format is an arm format, - hence we do not support linking and changing output formats at the - same time. Use a link followed by objcopy to change output formats. */ - einfo ("%F%X%P: error: cannot change output format whilst linking ARM binaries\n"); - return; - } - { LANG_FOR_EACH_INPUT_STATEMENT (is) { @@ -439,6 +429,16 @@ gld${EMULATION_NAME}_finish (void) static void arm_elf_create_output_section_statements (void) { + if (strstr (bfd_get_target (link_info.output_bfd), "arm") == NULL) + { + /* The arm backend needs special fields in the output hash structure. + These will only be created if the output format is an arm format, + hence we do not support linking and changing output formats at the + same time. Use a link followed by objcopy to change output formats. */ + einfo ("%F%X%P: error: Cannot change output format whilst linking ARM binaries.\n"); + return; + } + bfd_elf32_arm_set_target_relocs (link_info.output_bfd, &link_info, target1_is_rel, target2_type, fix_v4bx, use_blx, |