llvm-mirror/test/CodeGen/Generic/2007-04-13-SwitchLowerBadPhi.ll
Bill Wendling 7546bed590 Second attempt:
Massive check in. This changes the "-fast" flag to "-O#" in llc. If you want to
use the old behavior, the flag is -O0. This change allows for finer-grained
control over which optimizations are run at different -O levels.

Most of this work was pretty mechanical. The majority of the fixes came from
verifying that a "fast" variable wasn't used anymore. The JIT still uses a
"Fast" flag. I'll change the JIT with a follow-up patch.

llvm-svn: 70343
2009-04-29 00:15:41 +00:00

28 lines
886 B
LLVM

; RUN: llvm-as < %s | llc -O0
; PR 1323
; ModuleID = 'test.bc'
target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64"
target triple = "i686-apple-darwin8"
%struct.comp = type { i8*, i32, i8*, [3 x i8], i32 }
define void @regbranch() {
cond_next240.i:
br i1 false, label %cond_true251.i, label %cond_next272.i
cond_true251.i: ; preds = %cond_next240.i
switch i8 0, label %cond_next272.i [
i8 42, label %bb268.i
i8 43, label %bb268.i
i8 63, label %bb268.i
]
bb268.i: ; preds = %cond_true251.i, %cond_true251.i, %cond_true251.i
br label %cond_next272.i
cond_next272.i: ; preds = %bb268.i, %cond_true251.i, %cond_next240.i
%len.2.i = phi i32 [ 0, %bb268.i ], [ 0, %cond_next240.i ], [ 0, %cond_true251.i ] ; <i32> [#uses=1]
%tmp278.i = icmp eq i32 %len.2.i, 1 ; <i1> [#uses=0]
ret void
}