diff options
author | Kaz Kojima <kkojima@rr.iij4u.or.jp> | 2003-07-04 08:41:57 +0000 |
---|---|---|
committer | Kaz Kojima <kkojima@rr.iij4u.or.jp> | 2003-07-04 08:41:57 +0000 |
commit | 35cad4c475cf2bb3c7a99fa2d2c1303a5d2cb00e (patch) | |
tree | db25b1444892d819e20bd345d29ee79e1cf4476d | |
parent | 03151a5a117d288e01d3118697154c307d407fd7 (diff) | |
download | gdb-35cad4c475cf2bb3c7a99fa2d2c1303a5d2cb00e.zip gdb-35cad4c475cf2bb3c7a99fa2d2c1303a5d2cb00e.tar.gz gdb-35cad4c475cf2bb3c7a99fa2d2c1303a5d2cb00e.tar.bz2 |
* elf32-sh.c (sh_elf_create_dynamic_sections): Return if dynamic
sections were created already. Remove unnecessary tests of
the previous change.
-rw-r--r-- | bfd/ChangeLog | 6 | ||||
-rw-r--r-- | bfd/elf32-sh.c | 51 |
2 files changed, 27 insertions, 30 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index b497118..be245f0 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,5 +1,11 @@ 2003-07-04 Kaz Kojima <kkojima@rr.iij4u.or.jp> + * elf32-sh.c (sh_elf_create_dynamic_sections): Return if dynamic + sections were created already. Remove unnecessary tests of + the previous change. + +2003-07-04 Kaz Kojima <kkojima@rr.iij4u.or.jp> + * elf32-sh.c (sh_elf_create_dynamic_sections): Don't call bfd_make_section for existing sections. diff --git a/bfd/elf32-sh.c b/bfd/elf32-sh.c index 2d1698c..5306a25 100644 --- a/bfd/elf32-sh.c +++ b/bfd/elf32-sh.c @@ -3754,6 +3754,8 @@ sh_elf_create_dynamic_sections (abfd, info) } htab = sh_elf_hash_table (info); + if (htab->root.dynamic_sections_created) + return TRUE; /* We need to create .plt, .rel[a].plt, .got, .got.plt, .dynbss, and .rel[a].bss sections. */ @@ -3768,16 +3770,12 @@ sh_elf_create_dynamic_sections (abfd, info) if (bed->plt_readonly) pltflags |= SEC_READONLY; - s = htab->splt; - if (s == NULL) - { - s = bfd_make_section (abfd, ".plt"); - htab->splt = s; - if (s == NULL - || ! bfd_set_section_flags (abfd, s, pltflags) - || ! bfd_set_section_alignment (abfd, s, bed->plt_alignment)) - return FALSE; - } + s = bfd_make_section (abfd, ".plt"); + htab->splt = s; + if (s == NULL + || ! bfd_set_section_flags (abfd, s, pltflags) + || ! bfd_set_section_alignment (abfd, s, bed->plt_alignment)) + return FALSE; if (bed->want_plt_sym) { @@ -3801,17 +3799,13 @@ sh_elf_create_dynamic_sections (abfd, info) return FALSE; } - if (htab->srelplt == NULL) - { - s = bfd_make_section (abfd, - (bed->default_use_rela_p ? - ".rela.plt" : ".rel.plt")); - htab->srelplt = s; - if (s == NULL - || ! bfd_set_section_flags (abfd, s, flags | SEC_READONLY) - || ! bfd_set_section_alignment (abfd, s, ptralign)) - return FALSE; - } + s = bfd_make_section (abfd, + bed->default_use_rela_p ? ".rela.plt" : ".rel.plt"); + htab->srelplt = s; + if (s == NULL + || ! bfd_set_section_flags (abfd, s, flags | SEC_READONLY) + || ! bfd_set_section_alignment (abfd, s, ptralign)) + return FALSE; if (htab->sgot == NULL && !create_got_section (abfd, info)) @@ -3851,14 +3845,11 @@ sh_elf_create_dynamic_sections (abfd, info) image and use a R_*_COPY reloc to tell the dynamic linker to initialize them at run time. The linker script puts the .dynbss section into the .bss section of the final image. */ - if (htab->sdynbss == NULL) - { - s = bfd_make_section (abfd, ".dynbss"); - htab->sdynbss = s; - if (s == NULL - || ! bfd_set_section_flags (abfd, s, SEC_ALLOC)) - return FALSE; - } + s = bfd_make_section (abfd, ".dynbss"); + htab->sdynbss = s; + if (s == NULL + || ! bfd_set_section_flags (abfd, s, SEC_ALLOC)) + return FALSE; /* The .rel[a].bss section holds copy relocs. This section is not normally needed. We need to create it here, though, so that the @@ -3871,7 +3862,7 @@ sh_elf_create_dynamic_sections (abfd, info) be needed, we can discard it later. We will never need this section when generating a shared object, since they do not use copy relocs. */ - if (! info->shared && htab->srelbss == NULL) + if (! info->shared) { s = bfd_make_section (abfd, (bed->default_use_rela_p |