summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms/Utils
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2015-12-01 15:19:48 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2015-12-01 15:19:48 +0000
commitbaa3bf8f76568de6198613fb2ba7695a76c29109 (patch)
treeec15e39aac1505fc951253627c2ee9f094b4abdf /llvm/lib/Transforms/Utils
parent6c800eb3f02f2a57cceae862f9602318f9b7b9cc (diff)
downloadbcm5719-llvm-baa3bf8f76568de6198613fb2ba7695a76c29109.tar.gz
bcm5719-llvm-baa3bf8f76568de6198613fb2ba7695a76c29109.zip
Bring r254336 back:
The difference is that now we don't error on out-of-comdat access to internal global values. We copy them instead. This seems to match the expectation of COFF linkers (see pr25686). Original message: Start deciding earlier what to link. A traditional linker is roughly split in symbol resolution and "copying stuff". The two tasks are badly mixed in lib/Linker. This starts splitting them apart. With this patch there are no direct call to linkGlobalValueBody or linkGlobalValueProto. Everything is linked via WapValue. This also includes a few fixes: * A GV goes undefined if the comdat is dropped (comdat11.ll). * We error if an internal GV goes undefined (comdat13.ll). * We don't link an unused comdat. The first two match the behavior of an ELF linker. The second one is equivalent to running globaldce on the input. llvm-svn: 254418
Diffstat (limited to 'llvm/lib/Transforms/Utils')
-rw-r--r--llvm/lib/Transforms/Utils/ValueMapper.cpp6
1 files changed, 3 insertions, 3 deletions
diff --git a/llvm/lib/Transforms/Utils/ValueMapper.cpp b/llvm/lib/Transforms/Utils/ValueMapper.cpp
index 0a63c1d5153..00a8984845d 100644
--- a/llvm/lib/Transforms/Utils/ValueMapper.cpp
+++ b/llvm/lib/Transforms/Utils/ValueMapper.cpp
@@ -41,9 +41,9 @@ Value *llvm::MapValue(const Value *V, ValueToValueMapTy &VM, RemapFlags Flags,
if (Value *NewV =
Materializer->materializeDeclFor(const_cast<Value *>(V))) {
VM[V] = NewV;
- if (auto *GV = dyn_cast<GlobalValue>(V))
- Materializer->materializeInitFor(cast<GlobalValue>(NewV),
- const_cast<GlobalValue *>(GV));
+ if (auto *NewGV = dyn_cast<GlobalValue>(NewV))
+ Materializer->materializeInitFor(
+ NewGV, const_cast<GlobalValue *>(cast<GlobalValue>(V)));
return NewV;
}
}
OpenPOWER on IntegriCloud