diff options
author | Cary Coutant <ccoutant@gmail.com> | 2016-12-21 16:21:23 -0800 |
---|---|---|
committer | Cary Coutant <ccoutant@gmail.com> | 2016-12-21 16:21:23 -0800 |
commit | eb3908448bfe295e49bc7bd8a88b90deaa1ba95f (patch) | |
tree | c705db9301c8b59e10ee5964c06e64e6b56485d8 /gold/symtab.cc | |
parent | 514b85276b5521256e1688005e94f1d69fc10c27 (diff) | |
download | gdb-eb3908448bfe295e49bc7bd8a88b90deaa1ba95f.zip gdb-eb3908448bfe295e49bc7bd8a88b90deaa1ba95f.tar.gz gdb-eb3908448bfe295e49bc7bd8a88b90deaa1ba95f.tar.bz2 |
Make linker-created symbols relocatable where appropriate.
Linker-created symbols like __ehdr_start, __etext, __edata, and end
should be relocatable, not absolute.
gold/
* output.cc (Output_segment::first_section): Return NULL if there are
no sections in the segment.
* output.h (Output_segment::first_section_load_address): Assert that
first section is not NULL.
* symtab.cc (Symbol_table::sized_write_globals): Attach linker-created
segment-relative symbols to first section of the segment.
Diffstat (limited to 'gold/symtab.cc')
-rw-r--r-- | gold/symtab.cc | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/gold/symtab.cc b/gold/symtab.cc index 6865190..35989f0 100644 --- a/gold/symtab.cc +++ b/gold/symtab.cc @@ -3120,7 +3120,14 @@ Symbol_table::sized_write_globals(const Stringpool* sympool, break; case Symbol::IN_OUTPUT_SEGMENT: - shndx = elfcpp::SHN_ABS; + { + Output_segment* oseg = sym->output_segment(); + Output_section* osect = oseg->first_section(); + if (osect == NULL) + shndx = elfcpp::SHN_ABS; + else + shndx = osect->out_shndx(); + } break; case Symbol::IS_CONSTANT: |