diff options
author | Nikita Ermakov <coffe92@gmail.com> | 2020-05-15 08:27:57 +0930 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2020-05-15 08:30:33 +0930 |
commit | 6a31512fd4fdd38ee2b1ea78543d352f961ca172 (patch) | |
tree | 86649141dfab647395689d696875bf0adfca813c | |
parent | 7813437494ac39f3aef392d06ed5416e84fe386b (diff) | |
download | gdb-6a31512fd4fdd38ee2b1ea78543d352f961ca172.zip gdb-6a31512fd4fdd38ee2b1ea78543d352f961ca172.tar.gz gdb-6a31512fd4fdd38ee2b1ea78543d352f961ca172.tar.bz2 |
gold: powerpc: Test whether sym is not a plugin in do_gc_mark_symbol
sym->object() could be either a Plugin or Powerpc_relobj. There could
be a situation when Pluginobj would be proccessed in
ppc_object->get_opd_ent(dst_off) as Powerpc_relobj and it leads to the
segmentation fault.
* powerpc.cc (do_gc_mark_symbol): Don't segfault on plugin symbols.
-rw-r--r-- | gold/ChangeLog | 4 | ||||
-rw-r--r-- | gold/powerpc.cc | 2 |
2 files changed, 5 insertions, 1 deletions
diff --git a/gold/ChangeLog b/gold/ChangeLog index 212c9fa..e85669a 100644 --- a/gold/ChangeLog +++ b/gold/ChangeLog @@ -1,3 +1,7 @@ +2020-05-15 Nikita Ermakov <coffe92@gmail.com> + + * powerpc.cc (do_gc_mark_symbol): Don't segfault on plugin symbols. + 2020-05-14 Nick Clifton <nickc@redhat.com> * po/sr.po: New Serbian translation. diff --git a/gold/powerpc.cc b/gold/powerpc.cc index eae4832..2010c1e 100644 --- a/gold/powerpc.cc +++ b/gold/powerpc.cc @@ -9056,7 +9056,7 @@ Target_powerpc<size, big_endian>::do_gc_mark_symbol( Symbol_table* symtab, Symbol* sym) const { - if (size == 64) + if (size == 64 && sym->object()->pluginobj() == NULL) { Powerpc_relobj<size, big_endian>* ppc_object = static_cast<Powerpc_relobj<size, big_endian>*>(sym->object()); |