diff options
Diffstat (limited to 'test/ExecutionEngine/Interpreter/intrinsics.ll')
-rw-r--r-- | test/ExecutionEngine/Interpreter/intrinsics.ll | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/test/ExecutionEngine/Interpreter/intrinsics.ll b/test/ExecutionEngine/Interpreter/intrinsics.ll new file mode 100644 index 0000000..49d0bbe --- /dev/null +++ b/test/ExecutionEngine/Interpreter/intrinsics.ll @@ -0,0 +1,35 @@ +; RUN: lli -O0 -force-interpreter < %s + +; libffi does not support fp128 so we don’t test it +declare float @llvm.sin.f32(float) +declare double @llvm.sin.f64(double) +declare float @llvm.cos.f32(float) +declare double @llvm.cos.f64(double) +declare float @llvm.floor.f32(float) +declare double @llvm.floor.f64(double) +declare float @llvm.ceil.f32(float) +declare double @llvm.ceil.f64(double) +declare float @llvm.trunc.f32(float) +declare double @llvm.trunc.f64(double) +declare float @llvm.round.f32(float) +declare double @llvm.round.f64(double) +declare float @llvm.copysign.f32(float, float) +declare double @llvm.copysign.f64(double, double) + +define i32 @main() { + %sin32 = call float @llvm.sin.f32(float 0.000000e+00) + %sin64 = call double @llvm.sin.f64(double 0.000000e+00) + %cos32 = call float @llvm.cos.f32(float 0.000000e+00) + %cos64 = call double @llvm.cos.f64(double 0.000000e+00) + %floor32 = call float @llvm.floor.f32(float 0.000000e+00) + %floor64 = call double @llvm.floor.f64(double 0.000000e+00) + %ceil32 = call float @llvm.ceil.f32(float 0.000000e+00) + %ceil64 = call double @llvm.ceil.f64(double 0.000000e+00) + %trunc32 = call float @llvm.trunc.f32(float 0.000000e+00) + %trunc64 = call double @llvm.trunc.f64(double 0.000000e+00) + %round32 = call float @llvm.round.f32(float 0.000000e+00) + %round64 = call double @llvm.round.f64(double 0.000000e+00) + %copysign32 = call float @llvm.copysign.f32(float 0.000000e+00, float 0.000000e+00) + %copysign64 = call double @llvm.copysign.f64(double 0.000000e+00, double 0.000000e+00) + ret i32 0 +} |