mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-10 20:33:15 +00:00
Testcase for critical edge splitting with load PRE.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@96385 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
39be8fcfdc
commit
713bc585ef
@ -362,3 +362,30 @@ bb:
|
|||||||
return:
|
return:
|
||||||
ret void
|
ret void
|
||||||
}
|
}
|
||||||
|
|
||||||
|
; Test critical edge splitting.
|
||||||
|
define i32 @test11(i32* %p, i1 %C, i32 %N) {
|
||||||
|
; CHECK: @test11
|
||||||
|
block1:
|
||||||
|
br i1 %C, label %block2, label %block3
|
||||||
|
|
||||||
|
block2:
|
||||||
|
%cond = icmp sgt i32 %N, 1
|
||||||
|
br i1 %cond, label %block4, label %block5
|
||||||
|
; CHECK: load i32* %p
|
||||||
|
; CHECK-NEXT: br label %block4
|
||||||
|
|
||||||
|
block3:
|
||||||
|
store i32 0, i32* %p
|
||||||
|
br label %block4
|
||||||
|
|
||||||
|
block4:
|
||||||
|
%PRE = load i32* %p
|
||||||
|
br label %block5
|
||||||
|
|
||||||
|
block5:
|
||||||
|
%ret = phi i32 [ 0, %block2 ], [ %PRE, %block4 ]
|
||||||
|
ret i32 %ret
|
||||||
|
; CHECK: block4:
|
||||||
|
; CHECK-NEXT: phi i32
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user