Skip to content

Commit

Permalink
Fix an infinite recursion in the verifier caused by calling isSized o…
Browse files Browse the repository at this point in the history
…n a recursive type.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@232143 91177308-0d34-0410-b5e6-96231b3b80d8
  • Loading branch information
resistor committed Mar 13, 2015
1 parent fcc897c commit 39fcd23
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 1 deletion.
3 changes: 2 additions & 1 deletion lib/IR/Verifier.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -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!",
Expand Down
15 changes: 15 additions & 0 deletions test/Verifier/recursive-struct-param.ll
Original file line number Diff line number Diff line change
@@ -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)

0 comments on commit 39fcd23

Please sign in to comment.