diff options
author | Cary Coutant <ccoutant@google.com> | 2013-04-15 16:37:30 +0000 |
---|---|---|
committer | Cary Coutant <ccoutant@google.com> | 2013-04-15 16:37:30 +0000 |
commit | 2199fbe773f0795a92afb9a2383b463ccd936008 (patch) | |
tree | b733a6387cf85cd3e671744c17be74bb6f809daf | |
parent | 502e8a84302cfcc70166bd60cc6465a3e913cb8c (diff) | |
download | gdb-2199fbe773f0795a92afb9a2383b463ccd936008.zip gdb-2199fbe773f0795a92afb9a2383b463ccd936008.tar.gz gdb-2199fbe773f0795a92afb9a2383b463ccd936008.tar.bz2 |
gold/
* script-sections.cc (Orphan_output_section): Reset address
to zero after each orphaned section for relocatable links.
-rw-r--r-- | gold/ChangeLog | 5 | ||||
-rw-r--r-- | gold/script-sections.cc | 14 |
2 files changed, 15 insertions, 4 deletions
diff --git a/gold/ChangeLog b/gold/ChangeLog index a635214..595c017 100644 --- a/gold/ChangeLog +++ b/gold/ChangeLog @@ -1,5 +1,10 @@ 2013-04-15 Cary Coutant <ccoutant@google.com> + * script-sections.cc (Orphan_output_section): Reset address + to zero after each orphaned section for relocatable links. + +2013-04-15 Cary Coutant <ccoutant@google.com> + * symtab.cc (Symbol_table::sized_write_globals): Subtract section starting address for relocatable link. * testsuite/Makefile.am (script_test_11): New test. diff --git a/gold/script-sections.cc b/gold/script-sections.cc index 2fb8cbb..a57e53f 100644 --- a/gold/script-sections.cc +++ b/gold/script-sections.cc @@ -2918,11 +2918,17 @@ Orphan_output_section::set_section_addresses(Symbol_table*, Layout*, address += size; } - // An SHF_TLS/SHT_NOBITS section does not take up any address space. - if (this->os_ == NULL - || (this->os_->flags() & elfcpp::SHF_TLS) == 0 - || this->os_->type() != elfcpp::SHT_NOBITS) + if (parameters->options().relocatable()) + { + // For a relocatable link, reset DOT_VALUE to 0. + *dot_value = 0; + *load_address = 0; + } + else if (this->os_ == NULL + || (this->os_->flags() & elfcpp::SHF_TLS) == 0 + || this->os_->type() != elfcpp::SHT_NOBITS) { + // An SHF_TLS/SHT_NOBITS section does not take up any address space. if (!have_load_address) *load_address = address; else |