Merge branch 'master' into msp430
[llvm/msp430.git] / test / CodeGen / ARM / fp.ll
blobba199dbf56080588d4f417bba7bca0eec8e91337
1 ; RUN: llvm-as < %s | llc -march=arm -mattr=+vfp2 > %t
2 ; RUN: grep fmsr %t | count 4
3 ; RUN: grep fsitos %t
4 ; RUN: grep fmrs %t | count 2
5 ; RUN: grep fsitod %t
6 ; RUN: grep fmrrd %t | count 3
7 ; RUN: not grep fmdrr %t 
8 ; RUN: grep fldd %t
9 ; RUN: grep fuitod %t
10 ; RUN: grep fuitos %t
11 ; RUN: grep 1065353216 %t
13 define float @f(i32 %a) {
14 entry:
15         %tmp = sitofp i32 %a to float           ; <float> [#uses=1]
16         ret float %tmp
19 define double @g(i32 %a) {
20 entry:
21         %tmp = sitofp i32 %a to double          ; <double> [#uses=1]
22         ret double %tmp
25 define double @uint_to_double(i32 %a) {
26 entry:
27         %tmp = uitofp i32 %a to double          ; <double> [#uses=1]
28         ret double %tmp
31 define float @uint_to_float(i32 %a) {
32 entry:
33         %tmp = uitofp i32 %a to float           ; <float> [#uses=1]
34         ret float %tmp
37 define double @h(double* %v) {
38 entry:
39         %tmp = load double* %v          ; <double> [#uses=1]
40         ret double %tmp
43 define float @h2() {
44 entry:
45         ret float 1.000000e+00
48 define double @f2(double %a) {
49         ret double %a
52 define void @f3() {
53 entry:
54         %tmp = call double @f5( )               ; <double> [#uses=1]
55         call void @f4( double %tmp )
56         ret void
59 declare void @f4(double)
61 declare double @f5()