diff options
author | Doug Kwan <dougkwan@google.com> | 2009-12-17 00:00:26 +0000 |
---|---|---|
committer | Doug Kwan <dougkwan@google.com> | 2009-12-17 00:00:26 +0000 |
commit | d6344fb5ba8bfe0219f91c52e296707dbcdb07e3 (patch) | |
tree | 2a6c65ec60d4c8c400166139e1dc436368182b1f /gold/object.cc | |
parent | 21f8908e380ed50e16a153aae25ba9cffd6f28af (diff) | |
download | gdb-d6344fb5ba8bfe0219f91c52e296707dbcdb07e3.zip gdb-d6344fb5ba8bfe0219f91c52e296707dbcdb07e3.tar.gz gdb-d6344fb5ba8bfe0219f91c52e296707dbcdb07e3.tar.bz2 |
2009-12-16 Doug Kwan <dougkwan@google.com>
* arm.cc (Arm_relobj::scan_sections_for_stubs): Exclude ICF-eliminated
sections.
* object.cc (Sized_relobj::do_finalize_local_symbols): Handle
relaxed input sections.
* output.cc (Output_section::find_relaxed_input_section): Change
return type to Output_relaxed_input_section pointer. Adjust code
for new type of relaxed_input_section_map_.
* output.h (Output_section::find_relaxed_input_section): Change
return type to Output_relaxed_input_section pointer.
(Output_section::Output_relaxed_input_section_by_input_section_map):
New type.
(Output_section::relaxed_input_section_map_): Change type to
Output_section::Output_relaxed_input_section_by_input_section_map.
* symtab.cc (Symbol_table::compute_final_value): Handle relaxed
input section.
Diffstat (limited to 'gold/object.cc')
-rw-r--r-- | gold/object.cc | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/gold/object.cc b/gold/object.cc index 798e42d..9baf227 100644 --- a/gold/object.cc +++ b/gold/object.cc @@ -1683,7 +1683,15 @@ Sized_relobj<size, big_endian>::do_finalize_local_symbols(unsigned int index, os = folded_obj->output_section(folded.second); gold_assert(os != NULL); secoffset = folded_obj->get_output_section_offset(folded.second); - gold_assert(secoffset != invalid_address); + + // This could be a relaxed input section. + if (secoffset == invalid_address) + { + const Output_relaxed_input_section* relaxed_section = + os->find_relaxed_input_section(folded_obj, folded.second); + gold_assert(relaxed_section != NULL); + secoffset = relaxed_section->address() - os->address(); + } } if (os == NULL) |