From a94907d981327b5b17f0be51b6e0934b1add7bad Mon Sep 17 00:00:00 2001 From: Ian Lance Taylor Date: Thu, 9 Jun 2011 19:25:02 +0000 Subject: * script-sections.cc (Orphan_output_section::set_section_addresses): For a relocatable link set address to 0. --- gold/ChangeLog | 6 ++++++ gold/script-sections.cc | 11 +++++++++++ 2 files changed, 17 insertions(+) diff --git a/gold/ChangeLog b/gold/ChangeLog index 5c705bf..56e073f 100644 --- a/gold/ChangeLog +++ b/gold/ChangeLog @@ -1,3 +1,9 @@ +2011-06-09 Ian Lance Taylor + + * script-sections.cc + (Orphan_output_section::set_section_addresses): For a relocatable + link set address to 0. + 2011-06-09 Cary Coutant PR gold/12804 diff --git a/gold/script-sections.cc b/gold/script-sections.cc index 10af8e1..3bcc9e6 100644 --- a/gold/script-sections.cc +++ b/gold/script-sections.cc @@ -2846,6 +2846,17 @@ Orphan_output_section::set_section_addresses(Symbol_table*, Layout*, uint64_t address = *dot_value; address = align_address(address, this->os_->addralign()); + // For a relocatable link, all orphan sections are put at + // address 0. In general we expect all sections to be at + // address 0 for a relocatable link, but we permit the linker + // script to override that for specific output sections. + if (parameters->options().relocatable()) + { + address = 0; + *load_address = 0; + have_load_address = false; + } + if ((this->os_->flags() & elfcpp::SHF_ALLOC) != 0) { this->os_->set_address(address); -- cgit v1.1