From: ccoutant Date: Wed, 10 Dec 2008 19:50:14 +0000 (+0000) Subject: * layout.cc (Layout::add_comdat): Allow COMDAT group from a replacement X-Git-Tag: cgen-snapshot-20091101~4523 X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=778f32cf77ef6611d66a51c6ce601500552778a8;p=pf3gnuchains%2Fpf3gnuchains4x.git * layout.cc (Layout::add_comdat): Allow COMDAT group from a replacement object to override a kept COMDAT group from a plugin object. --- diff --git a/gold/ChangeLog b/gold/ChangeLog index dbfe8f636d..85482bb20e 100644 --- a/gold/ChangeLog +++ b/gold/ChangeLog @@ -1,3 +1,8 @@ +2008-12-10 Cary Coutant + + * layout.cc (Layout::add_comdat): Allow COMDAT group from a replacement + object to override a kept COMDAT group from a plugin object. + 2008-12-09 Ian Lance Taylor PR 7088 diff --git a/gold/layout.cc b/gold/layout.cc index 2097b6de7d..a4f17e5355 100644 --- a/gold/layout.cc +++ b/gold/layout.cc @@ -47,6 +47,7 @@ #include "reloc.h" #include "descriptors.h" #include "layout.h" +#include "plugin.h" namespace gold { @@ -2959,6 +2960,14 @@ Layout::add_comdat(Relobj* object, unsigned int shndx, if (ins.first->second.group_) { // We've already seen a real section group with this signature. + // If the kept group is from a plugin object, and we're in + // the replacement phase, accept the new one as a replacement. + if (ins.first->second.object_ == NULL + && parameters->options().plugins()->in_replacement_phase()) + { + ins.first->second = kept; + return true; + } return false; } else if (group)