blob: adf76e5dc82eb3cacb649c53fc147da68ea62a52 [file] [log] [blame]
Sirish Pande69295b82012-05-10 20:20:25 +00001; RUN: llc -march=hexagon -mcpu=hexagonv5 < %s | FileCheck %s
2; Check that we generate conversion from double precision floating point
3; to 32-bit int value in IEEE complaint mode in V5.
4
5; CHECK: r{{[0-9]+}} = convert_df2w(r{{[0-9]+}}:{{[0-9]+}}):chop
6
7define i32 @main() nounwind {
8entry:
9 %retval = alloca i32, align 4
10 %i = alloca i32, align 4
11 %a = alloca double, align 8
12 %b = alloca double, align 8
13 %c = alloca double, align 8
14 store i32 0, i32* %retval
Nirav Dave65b7ab12017-07-05 13:08:03 +000015 store volatile double 1.540000e+01, double* %a, align 8
16 store volatile double 9.100000e+00, double* %b, align 8
17 %0 = load volatile double, double* %a, align 8
18 %1 = load volatile double, double* %b, align 8
Sirish Pande69295b82012-05-10 20:20:25 +000019 %add = fadd double %0, %1
20 store double %add, double* %c, align 8
David Blaikiea79ac142015-02-27 21:17:42 +000021 %2 = load double, double* %c, align 8
Sirish Pande69295b82012-05-10 20:20:25 +000022 %conv = fptosi double %2 to i32
23 store i32 %conv, i32* %i, align 4
David Blaikiea79ac142015-02-27 21:17:42 +000024 %3 = load i32, i32* %i, align 4
Sirish Pande69295b82012-05-10 20:20:25 +000025 ret i32 %3
26}