From d270463e93aa77304932b1df0e2315ec3c0d3be8 Mon Sep 17 00:00:00 2001 From: "H.J. Lu" Date: Fri, 27 Oct 2006 04:15:50 +0000 Subject: [PATCH] 2006-10-26 H.J. Lu * elf.c (_bfd_elf_init_private_section_data): Assert output section ELF type instead of check if it is SHT_NULL. Copy OS/PROC specific flags from input section to output section. --- bfd/ChangeLog | 6 ++++++ bfd/elf.c | 14 +++++++++++--- 2 files changed, 17 insertions(+), 3 deletions(-) diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 1f8d8f090bb..1727234d509 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2006-10-26 H.J. Lu + + * elf.c (_bfd_elf_init_private_section_data): Assert output + section ELF type instead of check if it is SHT_NULL. Copy + OS/PROC specific flags from input section to output section. + 2006-10-27 Alan Modra * section.c (SEC_KEEP): Update comment. diff --git a/bfd/elf.c b/bfd/elf.c index f2cf85f4c6c..24ca6df7c9e 100644 --- a/bfd/elf.c +++ b/bfd/elf.c @@ -5950,9 +5950,17 @@ _bfd_elf_init_private_section_data (bfd *ibfd, output BFD section flags have been set to something different. elf_fake_sections will set ELF section type based on BFD section flags. */ - if (osec->flags == isec->flags - || (osec->flags == 0 && elf_section_type (osec) == SHT_NULL)) - elf_section_type (osec) = elf_section_type (isec); + if (osec->flags == isec->flags || !osec->flags) + { + BFD_ASSERT (osec->flags == isec->flags + || (!osec->flags + && elf_section_type (osec) == SHT_NULL)); + elf_section_type (osec) = elf_section_type (isec); + } + + /* FIXME: Is this correct for all OS/PROC specific flags? */ + elf_section_flags (osec) |= (elf_section_flags (isec) + & (SHF_MASKOS | SHF_MASKPROC)); /* Set things up for objcopy and relocatable link. The output SHT_GROUP section will have its elf_next_in_group pointing back -- 2.30.2