aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCary Coutant <ccoutant@google.com>2008-12-10 19:50:14 +0000
committerCary Coutant <ccoutant@google.com>2008-12-10 19:50:14 +0000
commit2756a25828e5a0ccdbaa54dd92b44a69a5f2ee30 (patch)
tree6d64cbe40bdd120c237ff84e4eed0937965d7d52
parenta3a219a90a59440cb2a29cee2a4cde87c6bfaf19 (diff)
downloadgdb-2756a25828e5a0ccdbaa54dd92b44a69a5f2ee30.zip
gdb-2756a25828e5a0ccdbaa54dd92b44a69a5f2ee30.tar.gz
gdb-2756a25828e5a0ccdbaa54dd92b44a69a5f2ee30.tar.bz2
* layout.cc (Layout::add_comdat): Allow COMDAT group from a replacement
object to override a kept COMDAT group from a plugin object.
-rw-r--r--gold/ChangeLog5
-rw-r--r--gold/layout.cc9
2 files changed, 14 insertions, 0 deletions
diff --git a/gold/ChangeLog b/gold/ChangeLog
index dbfe8f6..85482bb 100644
--- a/gold/ChangeLog
+++ b/gold/ChangeLog
@@ -1,3 +1,8 @@
+2008-12-10 Cary Coutant <ccoutant@google.com>
+
+ * 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 <iant@google.com>
PR 7088
diff --git a/gold/layout.cc b/gold/layout.cc
index 2097b6d..a4f17e5 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)