aboutsummaryrefslogtreecommitdiff
path: root/gold/output.cc
diff options
context:
space:
mode:
authorIan Lance Taylor <ian@airs.com>2008-04-15 04:06:41 +0000
committerIan Lance Taylor <ian@airs.com>2008-04-15 04:06:41 +0000
commit154e0e9aa714f93206c01ab62920a8ce9220fd9c (patch)
treeaebc9ca53e196a0c1f6b1ba7a26ad85a5a5ba25a /gold/output.cc
parent9380031c3f42602e95f277a96b4c90d81f429915 (diff)
downloadgdb-154e0e9aa714f93206c01ab62920a8ce9220fd9c.zip
gdb-154e0e9aa714f93206c01ab62920a8ce9220fd9c.tar.gz
gdb-154e0e9aa714f93206c01ab62920a8ce9220fd9c.tar.bz2
* layout.cc (Layout::Layout): Initialize sections_are_attached_.
(Layout::get_output_section): Ignore SHF_WRITE and SHF_EXECINSTR in the name/type/flags to section mapping. Don't call allocate_output_section. (Layout::choose_output_section): Change parameter from adjust_name to is_input_section. Don't permit input sections after sections are attached to segments. Don't call allocate_output_section. (Layout::layout_eh_frame): Call update_flags_for_input_section, not write_enable_output_section. (Layout::make_output_section): Don't push to unattached_section_list_ nor call attach_to_segment. Call attach_section_to_segment if sections are attached. (Layout::attach_sections_to_segments): New function. (Layout::attach_section_to_segment): New function. (Layout::attach_allocated_section_to_segment): Rename from attach_to_segment. Remove flags parameter. (Layout::allocate_output_section): Remove function. (Layout::write_enable_output_section): Remove function. * layout.h (class Layout): Update for above changes. Add new field sections_are_attached_. * output.h (Output_section::update_flags_for_input_section): New function. * output.cc (Output_section::add_input_section): Call update_flags_for_input_section. * gold.cc (queue_middle_tasks): Call attach_sections_to_segments.
Diffstat (limited to 'gold/output.cc')
-rw-r--r--gold/output.cc5
1 files changed, 1 insertions, 4 deletions
diff --git a/gold/output.cc b/gold/output.cc
index 48609a2..09b7312 100644
--- a/gold/output.cc
+++ b/gold/output.cc
@@ -1673,10 +1673,7 @@ Output_section::add_input_section(Sized_relobj<size, big_endian>* object,
this->addralign_ = addralign;
typename elfcpp::Elf_types<size>::Elf_WXword sh_flags = shdr.get_sh_flags();
- this->flags_ |= (sh_flags
- & (elfcpp::SHF_WRITE
- | elfcpp::SHF_ALLOC
- | elfcpp::SHF_EXECINSTR));
+ this->update_flags_for_input_section(sh_flags);
uint64_t entsize = shdr.get_sh_entsize();