mirror of
https://github.com/RPCS3/llvm.git
synced 2025-03-02 15:45:44 +00:00
make the verifier accept @llvm.donothing as the only intrinsic that can be invoked
While at it, merge 2 tests and FileCheckize them git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@159388 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
7f71f5f6b8
commit
917f97c580
@ -1636,9 +1636,11 @@ void Verifier::visitInstruction(Instruction &I) {
|
|||||||
if (Function *F = dyn_cast<Function>(I.getOperand(i))) {
|
if (Function *F = dyn_cast<Function>(I.getOperand(i))) {
|
||||||
// Check to make sure that the "address of" an intrinsic function is never
|
// Check to make sure that the "address of" an intrinsic function is never
|
||||||
// taken.
|
// taken.
|
||||||
CallSite CS(&I);
|
Assert1(!F->isIntrinsic() || i == (isa<CallInst>(I) ? e-1 : 0),
|
||||||
Assert1(!F->isIntrinsic() || (CS && i == (CS.isCall() ? e-1 : 2)),
|
|
||||||
"Cannot take the address of an intrinsic!", &I);
|
"Cannot take the address of an intrinsic!", &I);
|
||||||
|
Assert1(!F->isIntrinsic() || isa<CallInst>(I) ||
|
||||||
|
F->getIntrinsicID() == Intrinsic::donothing,
|
||||||
|
"Cannot invoke an intrinsinc other than donothing", &I);
|
||||||
Assert1(F->getParent() == Mod, "Referencing function in another module!",
|
Assert1(F->getParent() == Mod, "Referencing function in another module!",
|
||||||
&I);
|
&I);
|
||||||
} else if (BasicBlock *OpBB = dyn_cast<BasicBlock>(I.getOperand(i))) {
|
} else if (BasicBlock *OpBB = dyn_cast<BasicBlock>(I.getOperand(i))) {
|
||||||
|
@ -1,10 +0,0 @@
|
|||||||
; RUN: not llvm-as < %s |& grep {not verify as correct}
|
|
||||||
; PR1042
|
|
||||||
|
|
||||||
define i32 @foo() {
|
|
||||||
%A = invoke i32 @foo( )
|
|
||||||
to label %L unwind label %L ; <i32> [#uses=1]
|
|
||||||
L: ; preds = %0, %0
|
|
||||||
ret i32 %A
|
|
||||||
}
|
|
||||||
|
|
@ -1,14 +0,0 @@
|
|||||||
; RUN: not llvm-as %s |& grep {not verify as correct}
|
|
||||||
; PR1042
|
|
||||||
|
|
||||||
define i32 @foo() {
|
|
||||||
br i1 false, label %L1, label %L2
|
|
||||||
L1: ; preds = %0
|
|
||||||
%A = invoke i32 @foo( )
|
|
||||||
to label %L unwind label %L ; <i32> [#uses=1]
|
|
||||||
L2: ; preds = %0
|
|
||||||
br label %L
|
|
||||||
L: ; preds = %L2, %L1, %L1
|
|
||||||
ret i32 %A
|
|
||||||
}
|
|
||||||
|
|
65
test/Verifier/invoke.ll
Normal file
65
test/Verifier/invoke.ll
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
; RUN: not llvm-as < %s -o /dev/null |& FileCheck %s
|
||||||
|
|
||||||
|
; PR1042
|
||||||
|
define i32 @foo() {
|
||||||
|
; CHECK: The unwind destination does not have a landingpad instruction
|
||||||
|
%A = invoke i32 @foo( )
|
||||||
|
to label %L unwind label %L ; <i32> [#uses=1]
|
||||||
|
L: ; preds = %0, %0
|
||||||
|
ret i32 %A
|
||||||
|
}
|
||||||
|
|
||||||
|
; PR1042
|
||||||
|
define i32 @bar() {
|
||||||
|
br i1 false, label %L1, label %L2
|
||||||
|
L1: ; preds = %0
|
||||||
|
%A = invoke i32 @bar( )
|
||||||
|
to label %L unwind label %L ; <i32> [#uses=1]
|
||||||
|
L2: ; preds = %0
|
||||||
|
br label %L
|
||||||
|
L: ; preds = %L2, %L1, %L1
|
||||||
|
; CHECK: The unwind destination does not have a landingpad instruction
|
||||||
|
; CHECK: Instruction does not dominate all uses
|
||||||
|
ret i32 %A
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
declare i32 @__gxx_personality_v0(...)
|
||||||
|
declare void @llvm.donothing()
|
||||||
|
declare void @llvm.trap()
|
||||||
|
declare i8 @llvm.expect.i8(i8,i8)
|
||||||
|
declare i32 @fn(i8 (i8, i8)*)
|
||||||
|
|
||||||
|
define void @f1() {
|
||||||
|
entry:
|
||||||
|
; OK
|
||||||
|
invoke void @llvm.donothing()
|
||||||
|
to label %cont unwind label %cont
|
||||||
|
|
||||||
|
cont:
|
||||||
|
%0 = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*)
|
||||||
|
filter [0 x i8*] zeroinitializer
|
||||||
|
ret void
|
||||||
|
}
|
||||||
|
|
||||||
|
define i8 @f2() {
|
||||||
|
entry:
|
||||||
|
; CHECK: Cannot invoke an intrinsinc other than donothing
|
||||||
|
invoke void @llvm.trap()
|
||||||
|
to label %cont unwind label %lpad
|
||||||
|
|
||||||
|
cont:
|
||||||
|
ret i8 3
|
||||||
|
|
||||||
|
lpad:
|
||||||
|
%0 = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*)
|
||||||
|
filter [0 x i8*] zeroinitializer
|
||||||
|
ret i8 2
|
||||||
|
}
|
||||||
|
|
||||||
|
define i32 @f3() {
|
||||||
|
entry:
|
||||||
|
; CHECK: Cannot take the address of an intrinsic
|
||||||
|
%call = call i32 @fn(i8 (i8, i8)* @llvm.expect.i8)
|
||||||
|
ret i32 %call
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user