summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorIgor Laevsky <igmyrj@gmail.com>2017-12-14 09:33:58 +0000
committerIgor Laevsky <igmyrj@gmail.com>2017-12-14 09:33:58 +0000
commit753395fa0abe3b612e4b6e36c78b516ddad2b2a7 (patch)
treef9f4611b7a5d53c94cc0dd5508bdc2e0db466117
parentef12b41ef76eb842c64251fc7ee06ad5d6b850c2 (diff)
downloadbcm5719-llvm-753395fa0abe3b612e4b6e36c78b516ddad2b2a7.tar.gz
bcm5719-llvm-753395fa0abe3b612e4b6e36c78b516ddad2b2a7.zip
[Verifier] Check that GEP indexes has correct types
Differential Revision: https://reviews.llvm.org/D40391 llvm-svn: 320680
-rw-r--r--llvm/lib/IR/Verifier.cpp4
-rw-r--r--llvm/test/Verifier/non-integer-gep-index.ll8
-rw-r--r--llvm/test/Verifier/non-integer-gep-index.ll.bcbin0 -> 7392 bytes
3 files changed, 12 insertions, 0 deletions
diff --git a/llvm/lib/IR/Verifier.cpp b/llvm/lib/IR/Verifier.cpp
index 6137faf38a9..f6faf1309d8 100644
--- a/llvm/lib/IR/Verifier.cpp
+++ b/llvm/lib/IR/Verifier.cpp
@@ -3016,7 +3016,11 @@ void Verifier::visitGetElementPtrInst(GetElementPtrInst &GEP) {
Assert(isa<PointerType>(TargetTy),
"GEP base pointer is not a vector or a vector of pointers", &GEP);
Assert(GEP.getSourceElementType()->isSized(), "GEP into unsized type!", &GEP);
+
SmallVector<Value*, 16> Idxs(GEP.idx_begin(), GEP.idx_end());
+ Assert(all_of(
+ Idxs, [](Value* V) { return V->getType()->isIntOrIntVectorTy(); }),
+ "GEP indexes must be integers", &GEP);
Type *ElTy =
GetElementPtrInst::getIndexedType(GEP.getSourceElementType(), Idxs);
Assert(ElTy, "Invalid indices for GEP pointer type!", &GEP);
diff --git a/llvm/test/Verifier/non-integer-gep-index.ll b/llvm/test/Verifier/non-integer-gep-index.ll
new file mode 100644
index 00000000000..ba2dbeab897
--- /dev/null
+++ b/llvm/test/Verifier/non-integer-gep-index.ll
@@ -0,0 +1,8 @@
+; RUN: not opt -verify %s.bc -disable-output
+
+; Test that verifier checks that gep indexes has correct type
+; Specifically we want to check for the following pattern:
+; %A1 = alloca i64
+; %G = getelementptr i64, i64* %A1, %A1
+; IR parser checks for this pattern independently from the verifier, so it's
+; impossible to load from .ll file. Hence in this test we use bytecode input.
diff --git a/llvm/test/Verifier/non-integer-gep-index.ll.bc b/llvm/test/Verifier/non-integer-gep-index.ll.bc
new file mode 100644
index 00000000000..6d31d7b5e4c
--- /dev/null
+++ b/llvm/test/Verifier/non-integer-gep-index.ll.bc
Binary files differ
OpenPOWER on IntegriCloud