diff options
author | Adrian Prantl <aprantl@apple.com> | 2018-09-08 00:21:55 +0000 |
---|---|---|
committer | Adrian Prantl <aprantl@apple.com> | 2018-09-08 00:21:55 +0000 |
commit | 609bf369525b2e982564243d6767841a6fc2ea2d (patch) | |
tree | a598f630f7f3c8f4acc92d428b2b2a983956bd6c /llvm/lib/IR/Verifier.cpp | |
parent | 4357ca653a3deeddbfa6d4d0420ea994554da6a2 (diff) | |
download | bcm5719-llvm-609bf369525b2e982564243d6767841a6fc2ea2d.tar.gz bcm5719-llvm-609bf369525b2e982564243d6767841a6fc2ea2d.zip |
Remove addBlockByrefAddress(), it is dead code as far as clang is concerned.
This patch removes addBlockByrefAddress(), it is dead code as far as
clang is concerned: Every byref block capture is emitted with a
complex expression that is equivalent to what this function does.
rdar://problem/31629055
Differential Revision: https://reviews.llvm.org/D51763
llvm-svn: 341737
Diffstat (limited to 'llvm/lib/IR/Verifier.cpp')
-rw-r--r-- | llvm/lib/IR/Verifier.cpp | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/llvm/lib/IR/Verifier.cpp b/llvm/lib/IR/Verifier.cpp index fc6bc4ff9d1..e92aeac395e 100644 --- a/llvm/lib/IR/Verifier.cpp +++ b/llvm/lib/IR/Verifier.cpp @@ -4534,6 +4534,14 @@ void Verifier::visitDbgIntrinsic(StringRef Kind, DbgVariableIntrinsic &DII) { &DII, BB, F, Var, Var->getScope()->getSubprogram(), Loc, Loc->getScope()->getSubprogram()); + // This check is redundant with one in visitLocalVariable(). + AssertDI(isType(Var->getRawType()), "invalid type ref", Var, + Var->getRawType()); + if (auto *Type = dyn_cast_or_null<DIType>(Var->getRawType())) + if (Type->isBlockByrefStruct()) + AssertDI(DII.getExpression() && DII.getExpression()->getNumElements(), + "BlockByRef variable without complex expression", Var, &DII); + verifyFnArgs(DII); } |