1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-01 00:12:50 +01:00
llvm-mirror/test/CodeGen/X86/2006-10-19-SwitchUnnecessaryBranching.ll

30 lines
824 B
LLVM
Raw Normal View History

; RUN: llc < %s -march=x86 -asm-verbose | FileCheck %s
2006-10-20 01:21:59 +02:00
@str = internal constant [14 x i8] c"Hello world!\0A\00" ; <[14 x i8]*> [#uses=1]
@str.upgrd.1 = internal constant [13 x i8] c"Blah world!\0A\00" ; <[13 x i8]*> [#uses=1]
2006-10-20 01:21:59 +02:00
define i32 @test(i32 %argc, i8** %argv) nounwind {
2006-10-20 01:21:59 +02:00
entry:
; CHECK: cmpl $2
; CHECK-NEXT: jne
; CHECK-NEXT: %bb2
switch i32 %argc, label %UnifiedReturnBlock [
i32 1, label %bb
i32 2, label %bb2
2006-10-20 01:21:59 +02:00
]
bb: ; preds = %entry
%tmp1 = tail call i32 (i8*, ...)* @printf( i8* getelementptr ([14 x i8]* @str, i32 0, i64 0) ) ; <i32> [#uses=0]
ret i32 0
2006-10-20 01:21:59 +02:00
bb2: ; preds = %entry
%tmp4 = tail call i32 (i8*, ...)* @printf( i8* getelementptr ([13 x i8]* @str.upgrd.1, i32 0, i64 0) ) ; <i32> [#uses=0]
ret i32 0
2006-10-20 01:21:59 +02:00
UnifiedReturnBlock: ; preds = %entry
ret i32 0
2006-10-20 01:21:59 +02:00
}
declare i32 @printf(i8*, ...)