mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 12:29:58 +00:00
ValueMapper: fix assertion when null-mapping a constant for linking metadata
Summary: When RF_NullMapMissingGlobalValues is set, mapValue can return null for GlobalValue. When mapping the operands of a constant that is referenced from metadata, we need to handle this case and actually return null instead of mapping this constant. Reviewers: dexonsmith, rafael Subscribers: llvm-commits Differential Revision: http://reviews.llvm.org/D20713 llvm-svn: 271129
This commit is contained in:
parent
2c70238f80
commit
12f0648f10
@ -429,13 +429,23 @@ Value *Mapper::mapValue(const Value *V) {
|
||||
if (BlockAddress *BA = dyn_cast<BlockAddress>(C))
|
||||
return mapBlockAddress(*BA);
|
||||
|
||||
auto mapValueOrNull = [this](Value *V) {
|
||||
auto Mapped = mapValue(V);
|
||||
assert((Mapped || (Flags & RF_NullMapMissingGlobalValues)) &&
|
||||
"Unexpected null mapping for constant operand without "
|
||||
"NullMapMissingGlobalValues flag");
|
||||
return Mapped;
|
||||
};
|
||||
|
||||
// Otherwise, we have some other constant to remap. Start by checking to see
|
||||
// if all operands have an identity remapping.
|
||||
unsigned OpNo = 0, NumOperands = C->getNumOperands();
|
||||
Value *Mapped = nullptr;
|
||||
for (; OpNo != NumOperands; ++OpNo) {
|
||||
Value *Op = C->getOperand(OpNo);
|
||||
Mapped = mapValue(Op);
|
||||
Mapped = mapValueOrNull(Op);
|
||||
if (!Mapped)
|
||||
return nullptr;
|
||||
if (Mapped != Op)
|
||||
break;
|
||||
}
|
||||
@ -462,8 +472,12 @@ Value *Mapper::mapValue(const Value *V) {
|
||||
Ops.push_back(cast<Constant>(Mapped));
|
||||
|
||||
// Map the rest of the operands that aren't processed yet.
|
||||
for (++OpNo; OpNo != NumOperands; ++OpNo)
|
||||
Ops.push_back(cast<Constant>(mapValue(C->getOperand(OpNo))));
|
||||
for (++OpNo; OpNo != NumOperands; ++OpNo) {
|
||||
Mapped = mapValueOrNull(C->getOperand(OpNo));
|
||||
if (!Mapped)
|
||||
return nullptr;
|
||||
Ops.push_back(cast<Constant>(Mapped));
|
||||
}
|
||||
}
|
||||
Type *NewSrcTy = nullptr;
|
||||
if (TypeMapper)
|
||||
|
11
test/Linker/null_mapping_constant.ll
Normal file
11
test/Linker/null_mapping_constant.ll
Normal file
@ -0,0 +1,11 @@
|
||||
; RUN: llvm-link %s -S -o - | FileCheck %s
|
||||
; Check that the constant is not linked and the metadata is correctly referencing a nullptr
|
||||
; CHECK: !0 = !{!"foo", null, i64 16}
|
||||
|
||||
|
||||
|
||||
target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
|
||||
target triple = "x86_64-apple-macosx10.12.0"
|
||||
@foo = external unnamed_addr constant { [4 x i8*], [32 x i8] }, align 32
|
||||
!llvm.bitsets = !{!0}
|
||||
!0 = !{!"foo", [4 x i8*]* getelementptr inbounds ({ [4 x i8*], [32 x i8] }, { [4 x i8*], [32 x i8] }* @foo, i32 0, i32 0), i64 16}
|
Loading…
Reference in New Issue
Block a user