summaryrefslogtreecommitdiffstats
path: root/llvm/lib/VMCore/Verifier.cpp
diff options
context:
space:
mode:
authorChandler Carruth <chandlerc@gmail.com>2011-12-12 04:36:02 +0000
committerChandler Carruth <chandlerc@gmail.com>2011-12-12 04:36:02 +0000
commit026cc37e48ab6309d1d6f8b2bf91cbfe9eda7608 (patch)
tree4ceb8892368d10265f6c32ee8d630b1f7707344d /llvm/lib/VMCore/Verifier.cpp
parenta31b95cacf02800189f70a55040924a64470e8f6 (diff)
downloadbcm5719-llvm-026cc37e48ab6309d1d6f8b2bf91cbfe9eda7608.tar.gz
bcm5719-llvm-026cc37e48ab6309d1d6f8b2bf91cbfe9eda7608.zip
Teach the verifier to reject all non-constant arguments to the second
argument of the cttz and ctlz intrinsics. llvm-svn: 146360
Diffstat (limited to 'llvm/lib/VMCore/Verifier.cpp')
-rw-r--r--llvm/lib/VMCore/Verifier.cpp6
1 files changed, 6 insertions, 0 deletions
diff --git a/llvm/lib/VMCore/Verifier.cpp b/llvm/lib/VMCore/Verifier.cpp
index f74d762be94..003de442d61 100644
--- a/llvm/lib/VMCore/Verifier.cpp
+++ b/llvm/lib/VMCore/Verifier.cpp
@@ -1688,6 +1688,12 @@ void Verifier::visitIntrinsicFunctionCall(Intrinsic::ID ID, CallInst &CI) {
switch (ID) {
default:
break;
+ case Intrinsic::ctlz: // llvm.ctlz
+ case Intrinsic::cttz: // llvm.cttz
+ Assert1(isa<ConstantInt>(CI.getArgOperand(1)),
+ "is_zero_undef argument of bit counting intrinsics must be a "
+ "constant int", &CI);
+ break;
case Intrinsic::dbg_declare: { // llvm.dbg.declare
Assert1(CI.getArgOperand(0) && isa<MDNode>(CI.getArgOperand(0)),
"invalid llvm.dbg.declare intrinsic call 1", &CI);
OpenPOWER on IntegriCloud