[ARM] Cortex-M4 schedule additions
[llvm-complete.git] / test / CodeGen / ARM / 2009-08-21-PostRAKill3.ll
blobb7a252beefbda3ad568fbd0e2e74c9978ddd5096
1 ; RUN: llc < %s -asm-verbose=false -O3 -relocation-model=pic -frame-pointer=all -mtriple=thumbv7-apple-darwin -mcpu=cortex-a8 -post-RA-scheduler
3 ; ModuleID = '<stdin>'
4 target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:32-f32:32:32-f64:32:32-v64:64:64-v128:128:128-a0:0:64"
5 target triple = "armv7-apple-darwin9"
7 %struct.Hosp = type { i32, i32, i32, %struct.List, %struct.List, %struct.List, %struct.List }
8 %struct.List = type { %struct.List*, %struct.Patient*, %struct.List* }
9 %struct.Patient = type { i32, i32, i32, %struct.Village* }
10 %struct.Village = type { [4 x %struct.Village*], %struct.Village*, %struct.List, %struct.Hosp, i32, i32 }
12 define %struct.Village* @alloc_tree(i32 %level, i32 %label, %struct.Village* %back, i1 %p) nounwind {
13 entry:
14   br i1 %p, label %bb8, label %bb1
16 bb1:                                              ; preds = %entry
17   %malloccall = tail call i8* @malloc(i32 ptrtoint (%struct.Village* getelementptr (%struct.Village, %struct.Village* null, i32 1) to i32))
18   %0 = bitcast i8* %malloccall to %struct.Village*
19   %exp2 = call double @ldexp(double 1.000000e+00, i32 %level) nounwind ; <double> [#uses=1]
20   %.c = fptosi double %exp2 to i32                ; <i32> [#uses=1]
21   store i32 %.c, i32* null
22   %1 = getelementptr %struct.Village, %struct.Village* %0, i32 0, i32 3, i32 6, i32 0 ; <%struct.List**> [#uses=1]
23   store %struct.List* null, %struct.List** %1
24   %2 = getelementptr %struct.Village, %struct.Village* %0, i32 0, i32 3, i32 6, i32 2 ; <%struct.List**> [#uses=1]
25   store %struct.List* null, %struct.List** %2
26   ret %struct.Village* %0
28 bb8:                                              ; preds = %entry
29   ret %struct.Village* null
32 declare double @ldexp(double, i32)
33 declare noalias i8* @malloc(i32)