Fixed some bugs in register stack pass.
[llvm/zpu.git] / test / CodeGen / X86 / 2010-01-19-OptExtBug.ll
blobcd8960b9ed7b4e74e1b4a42d03a13f20265ba9a8
1 ; RUN: llc < %s -mtriple=x86_64-apple-darwin11 -relocation-model=pic -disable-fp-elim -stats |& not grep ext-opt
3 define fastcc i8* @S_scan_str(i8* %start, i32 %keep_quoted, i32 %keep_delims) nounwind ssp {
4 entry:
5   switch i8 undef, label %bb6 [
6     i8 9, label %bb5
7     i8 32, label %bb5
8     i8 10, label %bb5
9     i8 13, label %bb5
10     i8 12, label %bb5
11   ]
13 bb5:                                              ; preds = %entry, %entry, %entry, %entry, %entry
14   br label %bb6
16 bb6:                                              ; preds = %bb5, %entry
17   br i1 undef, label %bb7, label %bb9
19 bb7:                                              ; preds = %bb6
20   unreachable
22 bb9:                                              ; preds = %bb6
23   %0 = load i8* undef, align 1                    ; <i8> [#uses=3]
24   br i1 undef, label %bb12, label %bb10
26 bb10:                                             ; preds = %bb9
27   br i1 undef, label %bb12, label %bb11
29 bb11:                                             ; preds = %bb10
30   unreachable
32 bb12:                                             ; preds = %bb10, %bb9
33   br i1 undef, label %bb13, label %bb14
35 bb13:                                             ; preds = %bb12
36   store i8 %0, i8* undef, align 1
37   %1 = zext i8 %0 to i32                          ; <i32> [#uses=1]
38   br label %bb18
40 bb14:                                             ; preds = %bb12
41   br label %bb18
43 bb18:                                             ; preds = %bb14, %bb13
44   %termcode.0 = phi i32 [ %1, %bb13 ], [ undef, %bb14 ] ; <i32> [#uses=2]
45   %2 = icmp eq i8 %0, 0                           ; <i1> [#uses=1]
46   br i1 %2, label %bb21, label %bb19
48 bb19:                                             ; preds = %bb18
49   br i1 undef, label %bb21, label %bb20
51 bb20:                                             ; preds = %bb19
52   br label %bb21
54 bb21:                                             ; preds = %bb20, %bb19, %bb18
55   %termcode.1 = phi i32 [ %termcode.0, %bb18 ], [ %termcode.0, %bb19 ], [ undef, %bb20 ] ; <i32> [#uses=0]
56   unreachable