summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorOwen Anderson <resistor@mac.com>2015-03-13 06:41:26 +0000
committerOwen Anderson <resistor@mac.com>2015-03-13 06:41:26 +0000
commit08f46e1de67f333b10f4e299b4eccccc84ca6697 (patch)
tree8aa63682991b770921bc6ea4c06b9507ecfa47e1
parent04183242b34d660cc5f265c329eca2fcb4d781e9 (diff)
downloadbcm5719-llvm-08f46e1de67f333b10f4e299b4eccccc84ca6697.tar.gz
bcm5719-llvm-08f46e1de67f333b10f4e299b4eccccc84ca6697.zip
Fix an infinite recursion in the verifier caused by calling isSized on a recursive type.
llvm-svn: 232143
-rw-r--r--llvm/lib/IR/Verifier.cpp3
-rw-r--r--llvm/test/Verifier/recursive-struct-param.ll15
2 files changed, 17 insertions, 1 deletions
diff --git a/llvm/lib/IR/Verifier.cpp b/llvm/lib/IR/Verifier.cpp
index eaad5fb1b98..9e77c32ee4b 100644
--- a/llvm/lib/IR/Verifier.cpp
+++ b/llvm/lib/IR/Verifier.cpp
@@ -1014,7 +1014,8 @@ void Verifier::VerifyParameterAttrs(AttributeSet Attrs, unsigned Idx, Type *Ty,
V);
if (PointerType *PTy = dyn_cast<PointerType>(Ty)) {
- if (!PTy->getElementType()->isSized()) {
+ SmallPtrSet<const Type*, 4> Visited;
+ if (!PTy->getElementType()->isSized(&Visited)) {
Assert(!Attrs.hasAttribute(Idx, Attribute::ByVal) &&
!Attrs.hasAttribute(Idx, Attribute::InAlloca),
"Attributes 'byval' and 'inalloca' do not support unsized types!",
diff --git a/llvm/test/Verifier/recursive-struct-param.ll b/llvm/test/Verifier/recursive-struct-param.ll
new file mode 100644
index 00000000000..4b280a010f0
--- /dev/null
+++ b/llvm/test/Verifier/recursive-struct-param.ll
@@ -0,0 +1,15 @@
+; RUN: opt -verify < %s
+
+%struct.__sFILE = type { %struct.__sFILE }
+
+@.str = private unnamed_addr constant [13 x i8] c"Hello world\0A\00", align 1
+
+; Function Attrs: nounwind ssp
+define void @test(%struct.__sFILE* %stream, i8* %str) {
+ %fputs = call i32 @fputs(i8* %str, %struct.__sFILE* %stream)
+ ret void
+}
+
+; Function Attrs: nounwind
+declare i32 @fputs(i8* nocapture, %struct.__sFILE* nocapture)
+
OpenPOWER on IntegriCloud