summaryrefslogtreecommitdiff
path: root/test/CodeGen/X86/SafeDivRemIntrinsics.ll
diff options
context:
space:
mode:
Diffstat (limited to 'test/CodeGen/X86/SafeDivRemIntrinsics.ll')
-rw-r--r--test/CodeGen/X86/SafeDivRemIntrinsics.ll144
1 files changed, 144 insertions, 0 deletions
diff --git a/test/CodeGen/X86/SafeDivRemIntrinsics.ll b/test/CodeGen/X86/SafeDivRemIntrinsics.ll
new file mode 100644
index 0000000000..f71705fa7b
--- /dev/null
+++ b/test/CodeGen/X86/SafeDivRemIntrinsics.ll
@@ -0,0 +1,144 @@
+; RUN: llc < %s -march=x86-64 | FileCheck %s
+target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
+
+%divovf8 = type { i8, i1 }
+%divovf16 = type { i16, i1 }
+%divovf32 = type { i32, i1 }
+%divovf64 = type { i64, i1 }
+
+declare %divovf8 @llvm.safe.sdiv.i8(i8, i8) nounwind readnone
+declare %divovf16 @llvm.safe.sdiv.i16(i16, i16) nounwind readnone
+declare %divovf32 @llvm.safe.sdiv.i32(i32, i32) nounwind readnone
+declare %divovf64 @llvm.safe.sdiv.i64(i64, i64) nounwind readnone
+
+declare %divovf8 @llvm.safe.srem.i8(i8, i8) nounwind readnone
+declare %divovf16 @llvm.safe.srem.i16(i16, i16) nounwind readnone
+declare %divovf32 @llvm.safe.srem.i32(i32, i32) nounwind readnone
+declare %divovf64 @llvm.safe.srem.i64(i64, i64) nounwind readnone
+
+declare %divovf8 @llvm.safe.udiv.i8(i8, i8) nounwind readnone
+declare %divovf16 @llvm.safe.udiv.i16(i16, i16) nounwind readnone
+declare %divovf32 @llvm.safe.udiv.i32(i32, i32) nounwind readnone
+declare %divovf64 @llvm.safe.udiv.i64(i64, i64) nounwind readnone
+
+declare %divovf8 @llvm.safe.urem.i8(i8, i8) nounwind readnone
+declare %divovf16 @llvm.safe.urem.i16(i16, i16) nounwind readnone
+declare %divovf32 @llvm.safe.urem.i32(i32, i32) nounwind readnone
+declare %divovf64 @llvm.safe.urem.i64(i64, i64) nounwind readnone
+
+; CHECK-LABEL: sdiv8
+; CHECK: idivb{{[ ]}}
+define %divovf8 @sdiv8(i8 %x, i8 %y) {
+entry:
+ %divr = call %divovf8 @llvm.safe.sdiv.i8(i8 %x, i8 %y)
+ ret %divovf8 %divr
+}
+; CHECK-LABEL: sdiv16
+; CHECK: idivw{{[ ]}}
+define %divovf16 @sdiv16(i16 %x, i16 %y) {
+entry:
+ %divr = call %divovf16 @llvm.safe.sdiv.i16(i16 %x, i16 %y)
+ ret %divovf16 %divr
+}
+; CHECK-LABEL: sdiv32
+; CHECK: idivl{{[ ]}}
+define %divovf32 @sdiv32(i32 %x, i32 %y) {
+entry:
+ %divr = call %divovf32 @llvm.safe.sdiv.i32(i32 %x, i32 %y)
+ ret %divovf32 %divr
+}
+; CHECK-LABEL: sdiv64
+; CHECK: idivq{{[ ]}}
+define %divovf64 @sdiv64(i64 %x, i64 %y) {
+entry:
+ %divr = call %divovf64 @llvm.safe.sdiv.i64(i64 %x, i64 %y)
+ ret %divovf64 %divr
+}
+; CHECK-LABEL: udiv8
+; CHECK: {{[ ]}}divb{{[ ]}}
+define %divovf8 @udiv8(i8 %x, i8 %y) {
+entry:
+ %divr = call %divovf8 @llvm.safe.udiv.i8(i8 %x, i8 %y)
+ ret %divovf8 %divr
+}
+; CHECK-LABEL: udiv16
+; CHECK: {{[ ]}}divw{{[ ]}}
+define %divovf16 @udiv16(i16 %x, i16 %y) {
+entry:
+ %divr = call %divovf16 @llvm.safe.udiv.i16(i16 %x, i16 %y)
+ ret %divovf16 %divr
+}
+; CHECK-LABEL: udiv32
+; CHECK: {{[ ]}}divl{{[ ]}}
+define %divovf32 @udiv32(i32 %x, i32 %y) {
+entry:
+ %divr = call %divovf32 @llvm.safe.udiv.i32(i32 %x, i32 %y)
+ ret %divovf32 %divr
+}
+; CHECK-LABEL: udiv64
+; CHECK: {{[ ]}}divq{{[ ]}}
+define %divovf64 @udiv64(i64 %x, i64 %y) {
+entry:
+ %divr = call %divovf64 @llvm.safe.udiv.i64(i64 %x, i64 %y)
+ ret %divovf64 %divr
+}
+; CHECK-LABEL: srem8
+; CHECK: idivb{{[ ]}}
+define %divovf8 @srem8(i8 %x, i8 %y) {
+entry:
+ %remr = call %divovf8 @llvm.safe.srem.i8(i8 %x, i8 %y)
+ ret %divovf8 %remr
+}
+; CHECK-LABEL: srem16
+; CHECK: idivw{{[ ]}}
+define %divovf16 @srem16(i16 %x, i16 %y) {
+entry:
+ %remr = call %divovf16 @llvm.safe.srem.i16(i16 %x, i16 %y)
+ ret %divovf16 %remr
+}
+; CHECK-LABEL: srem32
+; CHECK: idivl{{[ ]}}
+define %divovf32 @srem32(i32 %x, i32 %y) {
+entry:
+ %remr = call %divovf32 @llvm.safe.srem.i32(i32 %x, i32 %y)
+ ret %divovf32 %remr
+}
+; CHECK-LABEL: srem64
+; CHECK: idivq{{[ ]}}
+define %divovf64 @srem64(i64 %x, i64 %y) {
+entry:
+ %remr = call %divovf64 @llvm.safe.srem.i64(i64 %x, i64 %y)
+ ret %divovf64 %remr
+}
+; CHECK-LABEL: urem8
+; CHECK: {{[ ]}}divb{{[ ]}}
+define %divovf8 @urem8(i8 %x, i8 %y) {
+entry:
+ %remr = call %divovf8 @llvm.safe.urem.i8(i8 %x, i8 %y)
+ ret %divovf8 %remr
+}
+; CHECK-LABEL: urem16
+; CHECK: {{[ ]}}divw{{[ ]}}
+define %divovf16 @urem16(i16 %x, i16 %y) {
+entry:
+ %remr = call %divovf16 @llvm.safe.urem.i16(i16 %x, i16 %y)
+ ret %divovf16 %remr
+}
+; CHECK-LABEL: urem32
+; CHECK: {{[ ]}}divl{{[ ]}}
+define %divovf32 @urem32(i32 %x, i32 %y) {
+entry:
+ %remr = call %divovf32 @llvm.safe.urem.i32(i32 %x, i32 %y)
+ ret %divovf32 %remr
+}
+; CHECK-LABEL: urem64
+; CHECK: {{[ ]}}divq{{[ ]}}
+define %divovf64 @urem64(i64 %x, i64 %y) {
+entry:
+ %remr = call %divovf64 @llvm.safe.urem.i64(i64 %x, i64 %y)
+ ret %divovf64 %remr
+}
+
+!llvm.ident = !{!0}
+
+!0 = metadata !{metadata !"clang version 3.5.0 "}