[SimplifyLibCalls] Remove useless bits of this tests.
[oota-llvm.git] / test / Transforms / InstCombine / r600-intrinsics.ll
1 ; RUN: opt -instcombine -S < %s | FileCheck %s
2
3 declare float @llvm.AMDGPU.rcp.f32(float) nounwind readnone
4 declare double @llvm.AMDGPU.rcp.f64(double) nounwind readnone
5
6 ; CHECK-LABEL: @test_constant_fold_rcp_f32_1
7 ; CHECK-NEXT: ret float 1.000000e+00
8 define float @test_constant_fold_rcp_f32_1() nounwind {
9   %val = call float @llvm.AMDGPU.rcp.f32(float 1.0) nounwind readnone
10   ret float %val
11 }
12
13 ; CHECK-LABEL: @test_constant_fold_rcp_f64_1
14 ; CHECK-NEXT:  ret double 1.000000e+00
15 define double @test_constant_fold_rcp_f64_1() nounwind {
16   %val = call double @llvm.AMDGPU.rcp.f64(double 1.0) nounwind readnone
17   ret double %val
18 }
19
20 ; CHECK-LABEL: @test_constant_fold_rcp_f32_half
21 ; CHECK-NEXT: ret float 2.000000e+00
22 define float @test_constant_fold_rcp_f32_half() nounwind {
23   %val = call float @llvm.AMDGPU.rcp.f32(float 0.5) nounwind readnone
24   ret float %val
25 }
26
27 ; CHECK-LABEL: @test_constant_fold_rcp_f64_half
28 ; CHECK-NEXT:  ret double 2.000000e+00
29 define double @test_constant_fold_rcp_f64_half() nounwind {
30   %val = call double @llvm.AMDGPU.rcp.f64(double 0.5) nounwind readnone
31   ret double %val
32 }
33
34 ; CHECK-LABEL: @test_constant_fold_rcp_f32_43
35 ; CHECK-NEXT: call float @llvm.AMDGPU.rcp.f32(float 4.300000e+01)
36 define float @test_constant_fold_rcp_f32_43() nounwind {
37  %val = call float @llvm.AMDGPU.rcp.f32(float 4.300000e+01) nounwind readnone
38  ret float %val
39 }
40
41 ; CHECK-LABEL: @test_constant_fold_rcp_f64_43
42 ; CHECK-NEXT: call double @llvm.AMDGPU.rcp.f64(double 4.300000e+01)
43 define double @test_constant_fold_rcp_f64_43() nounwind {
44   %val = call double @llvm.AMDGPU.rcp.f64(double 4.300000e+01) nounwind readnone
45   ret double %val
46 }
47