summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorNick Lewycky <nicholas@mxc.ca>2009-09-08 05:46:15 +0000
committerNick Lewycky <nicholas@mxc.ca>2009-09-08 05:46:15 +0000
commit12c77d73a90ca1a4c1448e3814560b0c3b55a850 (patch)
treecdd86b7edee5a1c8727ef8fe531b76911a4a50fd /llvm
parent9b712b3c8d7e477dc4d607f445983afe2633a49a (diff)
downloadbcm5719-llvm-12c77d73a90ca1a4c1448e3814560b0c3b55a850.tar.gz
bcm5719-llvm-12c77d73a90ca1a4c1448e3814560b0c3b55a850.zip
Hoist out the test+insert to CheckedTypes. This doesn't seem to affect
performance. llvm-svn: 81193
Diffstat (limited to 'llvm')
-rw-r--r--llvm/lib/VMCore/Verifier.cpp14
1 files changed, 4 insertions, 10 deletions
diff --git a/llvm/lib/VMCore/Verifier.cpp b/llvm/lib/VMCore/Verifier.cpp
index c7e7179c041..5d9d7ad2bf6 100644
--- a/llvm/lib/VMCore/Verifier.cpp
+++ b/llvm/lib/VMCore/Verifier.cpp
@@ -1447,12 +1447,10 @@ void Verifier::visitInstruction(Instruction &I) {
/// VerifyType - Verify that a type is well formed.
///
void Verifier::VerifyType(const Type *Ty) {
- // We insert complex types into CheckedTypes even if they failed verification
- // to prevent emitting messages about them multiple times if
+ if (!CheckedTypes.insert(Ty)) return;
switch (Ty->getTypeID()) {
case Type::FunctionTyID: {
- if (!CheckedTypes.insert(Ty)) return;
const FunctionType *FTy = cast<FunctionType>(Ty);
const Type *RetTy = FTy->getReturnType();
@@ -1468,7 +1466,6 @@ void Verifier::VerifyType(const Type *Ty) {
}
} break;
case Type::StructTyID: {
- if (!CheckedTypes.insert(Ty)) return;
const StructType *STy = cast<StructType>(Ty);
for (unsigned i = 0, e = STy->getNumElements(); i != e; ++i) {
const Type *ElTy = STy->getElementType(i);
@@ -1478,28 +1475,25 @@ void Verifier::VerifyType(const Type *Ty) {
}
} break;
case Type::ArrayTyID: {
- if (!CheckedTypes.insert(Ty)) return;
const ArrayType *ATy = cast<ArrayType>(Ty);
Assert1(ArrayType::isValidElementType(ATy->getElementType()),
"Array type with invalid element type", ATy);
VerifyType(ATy->getElementType());
} break;
case Type::PointerTyID: {
- if (!CheckedTypes.insert(Ty)) return;
const PointerType *PTy = cast<PointerType>(Ty);
Assert1(PointerType::isValidElementType(PTy->getElementType()),
"Pointer type with invalid element type", PTy);
VerifyType(PTy->getElementType());
- }
+ } break;
case Type::VectorTyID: {
- if (!CheckedTypes.insert(Ty)) return;
const VectorType *VTy = cast<VectorType>(Ty);
Assert1(VectorType::isValidElementType(VTy->getElementType()),
"Vector type with invalid element type", VTy);
VerifyType(VTy->getElementType());
- }
+ } break;
default:
- return;
+ break;
}
}
OpenPOWER on IntegriCloud