* emultempl/elf32.em (_place_orphan): If an input section doesn't
match an existing output section, but an unused output section statement does match, use it. * emultempl/pe.em (_place_orphan): Likewise. * emultempl/pep.em (_place_orphan): Likewise. * ld-elf/orphan4.d: New. * ld-elf/orphan4.ld: New. * ld-elf/orphan4.s: New.
This commit is contained in:
parent
62fb9fe1fc
commit
b5f14a6dff
8 changed files with 80 additions and 0 deletions
|
@ -1,3 +1,11 @@
|
|||
2010-01-13 DJ Delorie <dj@redhat.com>
|
||||
|
||||
* emultempl/elf32.em (_place_orphan): If an input section doesn't
|
||||
match an existing output section, but an unused output section
|
||||
statement does match, use it.
|
||||
* emultempl/pe.em (_place_orphan): Likewise.
|
||||
* emultempl/pep.em (_place_orphan): Likewise.
|
||||
|
||||
2010-01-09 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
|
||||
|
||||
* configure: Regenerate.
|
||||
|
|
|
@ -1782,6 +1782,7 @@ gld${EMULATION_NAME}_place_orphan (asection *s,
|
|||
struct orphan_save *place;
|
||||
lang_output_section_statement_type *after;
|
||||
lang_output_section_statement_type *os;
|
||||
lang_output_section_statement_type *match_by_name = NULL;
|
||||
int isdyn = 0;
|
||||
int iself = s->owner->xvec->flavour == bfd_target_elf_flavour;
|
||||
unsigned int sh_type = iself ? elf_section_type (s) : SHT_NULL;
|
||||
|
@ -1837,8 +1838,21 @@ gld${EMULATION_NAME}_place_orphan (asection *s,
|
|||
lang_add_section (&os->children, s, os);
|
||||
return os;
|
||||
}
|
||||
|
||||
/* Save unused output sections in case we can match them
|
||||
against orphans later. */
|
||||
if (os->bfd_section == NULL)
|
||||
match_by_name = os;
|
||||
}
|
||||
|
||||
/* If we didn't match an active output section, see if we matched an
|
||||
unused one and use that. */
|
||||
if (match_by_name)
|
||||
{
|
||||
lang_add_section (&match_by_name->children, s, match_by_name);
|
||||
return match_by_name;
|
||||
}
|
||||
|
||||
if (!orphan_init_done)
|
||||
{
|
||||
lang_output_section_statement_type *lookup;
|
||||
|
|
|
@ -1816,6 +1816,7 @@ gld_${EMULATION_NAME}_place_orphan (asection *s,
|
|||
char *dollar = NULL;
|
||||
lang_output_section_statement_type *os;
|
||||
lang_statement_list_type add_child;
|
||||
lang_output_section_statement_type *match_by_name = NULL;
|
||||
lang_statement_union_type **pl;
|
||||
|
||||
/* Look through the script to see where to place this section. */
|
||||
|
@ -1854,8 +1855,21 @@ gld_${EMULATION_NAME}_place_orphan (asection *s,
|
|||
lang_add_section (&add_child, s, os);
|
||||
break;
|
||||
}
|
||||
|
||||
/* Save unused output sections in case we can match them
|
||||
against orphans later. */
|
||||
if (os->bfd_section == NULL)
|
||||
match_by_name = os;
|
||||
}
|
||||
|
||||
/* If we didn't match an active output section, see if we matched an
|
||||
unused one and use that. */
|
||||
if (os == NULL && match_by_name)
|
||||
{
|
||||
lang_add_section (&match_by_name->children, s, match_by_name);
|
||||
return match_by_name;
|
||||
}
|
||||
|
||||
if (os == NULL)
|
||||
{
|
||||
static struct orphan_save hold[] =
|
||||
|
|
|
@ -1582,6 +1582,7 @@ gld_${EMULATION_NAME}_place_orphan (asection *s,
|
|||
char *dollar = NULL;
|
||||
lang_output_section_statement_type *os;
|
||||
lang_statement_list_type add_child;
|
||||
lang_output_section_statement_type *match_by_name = NULL;
|
||||
lang_statement_union_type **pl;
|
||||
|
||||
/* Look through the script to see where to place this section. */
|
||||
|
@ -1620,8 +1621,21 @@ gld_${EMULATION_NAME}_place_orphan (asection *s,
|
|||
lang_add_section (&add_child, s, os);
|
||||
break;
|
||||
}
|
||||
|
||||
/* Save unused output sections in case we can match them
|
||||
against orphans later. */
|
||||
if (os->bfd_section == NULL)
|
||||
match_by_name = os;
|
||||
}
|
||||
|
||||
/* If we didn't match an active output section, see if we matched an
|
||||
unused one and use that. */
|
||||
if (os == NULL && match_by_name)
|
||||
{
|
||||
lang_add_section (&match_by_name->children, s, match_by_name);
|
||||
return match_by_name;
|
||||
}
|
||||
|
||||
if (os == NULL)
|
||||
{
|
||||
static struct orphan_save hold[] =
|
||||
|
|
|
@ -1,3 +1,9 @@
|
|||
2010-01-13 DJ Delorie <dj@redhat.com>
|
||||
|
||||
* ld-elf/orphan4.d: New.
|
||||
* ld-elf/orphan4.ld: New.
|
||||
* ld-elf/orphan4.s: New.
|
||||
|
||||
2010-01-13 Chao-ying Fu <fu@mips.com>
|
||||
|
||||
* ld-mips-elf/jr-to-b-1.d, ld-mips-elf/jr-to-b-2.d: New tests.
|
||||
|
|
7
ld/testsuite/ld-elf/orphan4.d
Normal file
7
ld/testsuite/ld-elf/orphan4.d
Normal file
|
@ -0,0 +1,7 @@
|
|||
#source: orphan4.s
|
||||
#ld: -T orphan4.ld
|
||||
#objdump: -h
|
||||
|
||||
#...
|
||||
1 \.foo 00000001 00001000 00001000 00000080 2\*\*0
|
||||
#pass
|
13
ld/testsuite/ld-elf/orphan4.ld
Normal file
13
ld/testsuite/ld-elf/orphan4.ld
Normal file
|
@ -0,0 +1,13 @@
|
|||
/* The .foo section doesn't specify *any* objects, but the object
|
||||
we're linking has sections named ".foo". Make sure these sections
|
||||
are linked into the .foo output section anyway. The bug that was
|
||||
fixed was that a new .foo output section would be created at
|
||||
address 0. */
|
||||
|
||||
SECTIONS {
|
||||
.foo 0x00001000 : {
|
||||
}
|
||||
.text 0x00002000 : {
|
||||
*(.text);
|
||||
}
|
||||
}
|
4
ld/testsuite/ld-elf/orphan4.s
Normal file
4
ld/testsuite/ld-elf/orphan4.s
Normal file
|
@ -0,0 +1,4 @@
|
|||
.section ".foo", "ax"
|
||||
.byte 45
|
||||
.text
|
||||
.byte 15
|
Loading…
Reference in a new issue