2004-02-11 04:35:04 +01:00
|
|
|
; Test a bunch of cases where the cfg simplification code should
|
|
|
|
; be able to fold PHI nodes into computation in common cases. Folding the PHI
|
|
|
|
; nodes away allows the branches to be eliminated, performing a simple form of
|
|
|
|
; 'if conversion'.
|
|
|
|
|
2009-09-11 20:01:28 +02:00
|
|
|
; RUN: opt < %s -simplifycfg -S > %t.xform
|
2007-04-15 11:21:47 +02:00
|
|
|
; RUN: not grep phi %t.xform
|
|
|
|
; RUN: grep ret %t.xform
|
2004-02-11 04:35:04 +01:00
|
|
|
|
2008-03-18 04:45:45 +01:00
|
|
|
declare void @use(i1)
|
2004-02-11 04:35:04 +01:00
|
|
|
|
2008-03-18 04:45:45 +01:00
|
|
|
declare void @use.upgrd.1(i32)
|
2005-12-03 19:26:41 +01:00
|
|
|
|
2008-03-18 04:45:45 +01:00
|
|
|
define void @test2(i1 %c, i1 %d, i32 %V, i32 %V2) {
|
|
|
|
; <label>:0
|
|
|
|
br i1 %d, label %X, label %F
|
|
|
|
X: ; preds = %0
|
|
|
|
br i1 %c, label %T, label %F
|
|
|
|
T: ; preds = %X
|
|
|
|
br label %F
|
|
|
|
F: ; preds = %T, %X, %0
|
|
|
|
%B1 = phi i1 [ true, %0 ], [ false, %T ], [ false, %X ] ; <i1> [#uses=1]
|
|
|
|
%I7 = phi i32 [ %V, %0 ], [ %V2, %T ], [ %V2, %X ] ; <i32> [#uses=1]
|
|
|
|
call void @use( i1 %B1 )
|
|
|
|
call void @use.upgrd.1( i32 %I7 )
|
|
|
|
ret void
|
2005-12-03 19:26:41 +01:00
|
|
|
}
|
|
|
|
|
2008-03-18 04:45:45 +01:00
|
|
|
define void @test(i1 %c, i32 %V, i32 %V2) {
|
|
|
|
; <label>:0
|
|
|
|
br i1 %c, label %T, label %F
|
|
|
|
T: ; preds = %0
|
|
|
|
br label %F
|
|
|
|
F: ; preds = %T, %0
|
|
|
|
%B1 = phi i1 [ true, %0 ], [ false, %T ] ; <i1> [#uses=1]
|
|
|
|
%I6 = phi i32 [ %V, %0 ], [ 0, %T ] ; <i32> [#uses=1]
|
|
|
|
call void @use( i1 %B1 )
|
|
|
|
call void @use.upgrd.1( i32 %I6 )
|
|
|
|
ret void
|
2004-02-11 04:35:04 +01:00
|
|
|
}
|
2008-03-18 04:45:45 +01:00
|
|
|
|