[ARM] Generate 8.1-m CSINC, CSNEG and CSINV instructions.
[llvm-core.git] / test / CodeGen / Thumb2 / 2009-08-04-SubregLoweringBug3.ll
blob66ed876f98e3eace56d5c15a5d38850c102e15d9
1 ; RUN: llc < %s -mtriple=thumbv7-apple-darwin9 -mcpu=cortex-a8
2 ; rdar://7117307
4         %struct.Hosp = type { i32, i32, i32, %struct.List, %struct.List, %struct.List, %struct.List }
5         %struct.List = type { %struct.List*, %struct.Patient*, %struct.List* }
6         %struct.Patient = type { i32, i32, i32, %struct.Village* }
7         %struct.Village = type { [4 x %struct.Village*], %struct.Village*, %struct.List, %struct.Hosp, i32, i32 }
9 define %struct.List* @sim(%struct.Village* %village) nounwind {
10 entry:
11         br i1 undef, label %bb14, label %bb3.preheader
13 bb3.preheader:          ; preds = %entry
14         br label %bb5
16 bb5:            ; preds = %bb5, %bb3.preheader
17         br i1 undef, label %bb11, label %bb5
19 bb11:           ; preds = %bb5
20         %0 = load i32, i32* undef, align 4              ; <i32> [#uses=1]
21         %1 = xor i32 %0, 123459876              ; <i32> [#uses=1]
22         %2 = sdiv i32 %1, 127773                ; <i32> [#uses=1]
23         %3 = mul i32 %2, 2836           ; <i32> [#uses=1]
24         %4 = sub i32 0, %3              ; <i32> [#uses=1]
25         %5 = xor i32 %4, 123459876              ; <i32> [#uses=1]
26         %idum_addr.0.i.i = select i1 undef, i32 undef, i32 %5           ; <i32> [#uses=1]
27         %6 = sitofp i32 %idum_addr.0.i.i to double              ; <double> [#uses=1]
28         %7 = fmul double %6, 0x3E00000000200000         ; <double> [#uses=1]
29         %8 = fptrunc double %7 to float         ; <float> [#uses=2]
30         %9 = fmul float %8, 0x41E0000000000000          ; <float> [#uses=1]
31         %10 = fptosi float %9 to i32            ; <i32> [#uses=1]
32         store i32 %10, i32* undef, align 4
33         %11 = fpext float %8 to double          ; <double> [#uses=1]
34         %12 = fcmp ogt double %11, 6.660000e-01         ; <i1> [#uses=1]
35         br i1 %12, label %generate_patient.exit, label %generate_patient.exit.thread
37 generate_patient.exit.thread:           ; preds = %bb11
38         ret %struct.List* null
40 generate_patient.exit:          ; preds = %bb11
41         br i1 undef, label %bb14, label %bb12
43 bb12:           ; preds = %generate_patient.exit
44         br i1 undef, label %bb.i, label %bb1.i
46 bb.i:           ; preds = %bb12
47         ret %struct.List* null
49 bb1.i:          ; preds = %bb12
50         ret %struct.List* null
52 bb14:           ; preds = %generate_patient.exit, %entry
53         ret %struct.List* undef