aboutsummaryrefslogtreecommitdiffstats
path: root/test/CodeGen/X86/2006-10-19-SwitchUnnecessaryBranching.ll
blob: d583e5964dc2b47a611fe49e0caeea301f309bf6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
; RUN: llc < %s -march=x86 -asm-verbose | FileCheck %s

@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]

define i32 @test(i32 %argc, i8** %argv) nounwind {
entry:
; CHECK: cmpl	$2
; CHECK-NEXT: jne
; CHECK-NEXT: %bb2

	switch i32 %argc, label %UnifiedReturnBlock [
		 i32 1, label %bb
		 i32 2, label %bb2
	]

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

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

UnifiedReturnBlock:		; preds = %entry
	ret i32 0
}

declare i32 @printf(i8*, ...)