In some rare cases, the register allocator can spill registers but end up not utilizi...
[llvm/msp430.git] / test / CodeGen / X86 / pre-split5.ll
blobd3538250b3c580af0bfa0bdc01dd8b911daed8ca
1 ; RUN: llvm-as < %s | llc -march=x86 -mattr=+sse2 -pre-alloc-split
3 target triple = "i386-apple-darwin9.5"
4         %struct.FILE = type { i8*, i32, i32, i16, i16, %struct.__sbuf, i32, i8*, i32 (i8*)*, i32 (i8*, i8*, i32)*, i64 (i8*, i64, i32)*, i32 (i8*, i8*, i32)*, %struct.__sbuf, %struct.__sFILEX*, i32, [3 x i8], [1 x i8], %struct.__sbuf, i32, i64 }
5         %struct.__sFILEX = type opaque
6         %struct.__sbuf = type { i8*, i32 }
7 @"\01LC1" = external constant [48 x i8]         ; <[48 x i8]*> [#uses=1]
9 define i32 @main() nounwind {
10 entry:
11         br label %bb5.us
13 bb5.us:         ; preds = %bb8.split, %bb5.us, %entry
14         %i.0.reg2mem.0.ph = phi i32 [ 0, %entry ], [ %indvar.next53, %bb8.split ], [ %i.0.reg2mem.0.ph, %bb5.us ]               ; <i32> [#uses=2]
15         %j.0.reg2mem.0.us = phi i32 [ %indvar.next47, %bb5.us ], [ 0, %bb8.split ], [ 0, %entry ]               ; <i32> [#uses=1]
16         %indvar.next47 = add i32 %j.0.reg2mem.0.us, 1           ; <i32> [#uses=2]
17         %exitcond48 = icmp eq i32 %indvar.next47, 256           ; <i1> [#uses=1]
18         br i1 %exitcond48, label %bb8.split, label %bb5.us
20 bb8.split:              ; preds = %bb5.us
21         %indvar.next53 = add i32 %i.0.reg2mem.0.ph, 1           ; <i32> [#uses=2]
22         %exitcond54 = icmp eq i32 %indvar.next53, 256           ; <i1> [#uses=1]
23         br i1 %exitcond54, label %bb11, label %bb5.us
25 bb11:           ; preds = %bb11, %bb8.split
26         %i.1.reg2mem.0 = phi i32 [ %indvar.next44, %bb11 ], [ 0, %bb8.split ]           ; <i32> [#uses=1]
27         %indvar.next44 = add i32 %i.1.reg2mem.0, 1              ; <i32> [#uses=2]
28         %exitcond45 = icmp eq i32 %indvar.next44, 63            ; <i1> [#uses=1]
29         br i1 %exitcond45, label %bb14, label %bb11
31 bb14:           ; preds = %bb14, %bb11
32         %indvar = phi i32 [ %indvar.next40, %bb14 ], [ 0, %bb11 ]               ; <i32> [#uses=1]
33         %indvar.next40 = add i32 %indvar, 1             ; <i32> [#uses=2]
34         %exitcond41 = icmp eq i32 %indvar.next40, 32768         ; <i1> [#uses=1]
35         br i1 %exitcond41, label %bb28, label %bb14
37 bb28:           ; preds = %bb14
38         %0 = fdiv double 2.550000e+02, 0.000000e+00             ; <double> [#uses=1]
39         br label %bb30
41 bb30:           ; preds = %bb36, %bb28
42         %m.1.reg2mem.0 = phi i32 [ %m.0, %bb36 ], [ 0, %bb28 ]          ; <i32> [#uses=1]
43         %1 = mul double 0.000000e+00, %0                ; <double> [#uses=1]
44         %2 = fptosi double %1 to i32            ; <i32> [#uses=1]
45         br i1 false, label %bb36, label %bb35
47 bb35:           ; preds = %bb30
48         %3 = tail call i32 (%struct.FILE*, i8*, ...)* @fprintf(%struct.FILE* null, i8* getelementptr ([48 x i8]* @"\01LC1", i32 0, i32 0), i32 0, i32 0, i32 0, i32 %2) nounwind                ; <i32> [#uses=0]
49         br label %bb36
51 bb36:           ; preds = %bb35, %bb30
52         %m.0 = phi i32 [ 0, %bb35 ], [ %m.1.reg2mem.0, %bb30 ]          ; <i32> [#uses=1]
53         br label %bb30
56 declare i32 @fprintf(%struct.FILE*, i8*, ...) nounwind