diff options
author | Duncan P. N. Exon Smith <dexonsmith@apple.com> | 2015-04-06 17:04:58 +0000 |
---|---|---|
committer | Duncan P. N. Exon Smith <dexonsmith@apple.com> | 2015-04-06 17:04:58 +0000 |
commit | 936c56393c99e9268e787baee382614c1df12451 (patch) | |
tree | 9470550f84d2a952f0d88b92356c4f224020f06c /llvm/lib/IR/Verifier.cpp | |
parent | 220d08d942ab0df3211388e602ed34fa6139ca61 (diff) | |
download | bcm5719-llvm-936c56393c99e9268e787baee382614c1df12451.tar.gz bcm5719-llvm-936c56393c99e9268e787baee382614c1df12451.zip |
Verifier: Check composite type template params
Add missing checks for `templateParams:` in `MDCompositeType`. Pull the
current check for `MDSubprogram` to reduce duplicated code and fix it up
to print a good message when the immediate operand isn't an `MDTuple`
(as a drive-by, make the same fix to `variables:` in `MDSubprogram`).
llvm-svn: 234177
Diffstat (limited to 'llvm/lib/IR/Verifier.cpp')
-rw-r--r-- | llvm/lib/IR/Verifier.cpp | 29 |
1 files changed, 18 insertions, 11 deletions
diff --git a/llvm/lib/IR/Verifier.cpp b/llvm/lib/IR/Verifier.cpp index accd5cd8940..480c2e5581e 100644 --- a/llvm/lib/IR/Verifier.cpp +++ b/llvm/lib/IR/Verifier.cpp @@ -307,6 +307,8 @@ private: void visitMDLexicalBlockBase(const MDLexicalBlockBase &N); void visitMDTemplateParameter(const MDTemplateParameter &N); + void visitTemplateParams(const MDNode &N, const Metadata &RawParams); + /// \brief Check for a valid string-based type reference. /// /// Checks if \c MD is a string-based type reference. If it is, keeps track @@ -826,6 +828,15 @@ static bool hasConflictingReferenceFlags(unsigned Flags) { (Flags & DebugNode::FlagRValueReference); } +void Verifier::visitTemplateParams(const MDNode &N, const Metadata &RawParams) { + auto *Params = dyn_cast<MDTuple>(&RawParams); + Assert(Params, "invalid template params", &N, &RawParams); + for (Metadata *Op : Params->operands()) { + Assert(Op && isa<MDTemplateParameter>(Op), "invalid template parameter", &N, + Params, Op); + } +} + void Verifier::visitMDCompositeType(const MDCompositeType &N) { // Common derived type checks. visitMDDerivedTypeBase(N); @@ -846,6 +857,8 @@ void Verifier::visitMDCompositeType(const MDCompositeType &N) { "invalid composite elements", &N, N.getRawElements()); Assert(!hasConflictingReferenceFlags(N.getFlags()), "invalid reference flags", &N); + if (auto *Params = N.getRawTemplateParams()) + visitTemplateParams(N, *Params); } void Verifier::visitMDSubroutineType(const MDSubroutineType &N) { @@ -924,21 +937,15 @@ void Verifier::visitMDSubprogram(const MDSubprogram &N) { Assert(F && FT && isa<FunctionType>(FT->getElementType()), "invalid function", &N, F, FT); } - if (N.getRawTemplateParams()) { - auto *Params = dyn_cast<MDTuple>(N.getRawTemplateParams()); - Assert(Params, "invalid template params", &N, Params); - for (Metadata *Op : Params->operands()) { - Assert(Op && isa<MDTemplateParameter>(Op), "invalid template parameter", - &N, Params, Op); - } - } + if (auto *Params = N.getRawTemplateParams()) + visitTemplateParams(N, *Params); if (auto *S = N.getRawDeclaration()) { Assert(isa<MDSubprogram>(S) && !cast<MDSubprogram>(S)->isDefinition(), "invalid subprogram declaration", &N, S); } - if (N.getRawVariables()) { - auto *Vars = dyn_cast<MDTuple>(N.getRawVariables()); - Assert(Vars, "invalid variable list", &N, Vars); + if (auto *RawVars = N.getRawVariables()) { + auto *Vars = dyn_cast<MDTuple>(RawVars); + Assert(Vars, "invalid variable list", &N, RawVars); for (Metadata *Op : Vars->operands()) { Assert(Op && isa<MDLocalVariable>(Op), "invalid local variable", &N, Vars, Op); |