[PATCH] D25265: [C API] Add test for D25259 and new LLVMIsExact function.
Manuel Jacob via llvm-commits
llvm-commits at lists.llvm.org
Tue Oct 4 22:19:50 PDT 2016
mjacob created this revision.
mjacob added reviewers: mehdi_amini, deadalnix.
mjacob added a subscriber: llvm-commits.
The LLVMIsExact function was added to make this test possible, but it is
generally useful.
https://reviews.llvm.org/D25265
Files:
include/llvm-c/Core.h
lib/IR/Core.cpp
test/Bindings/llvm-c/echo.ll
tools/llvm-c-test/echo.cpp
Index: tools/llvm-c-test/echo.cpp
===================================================================
--- tools/llvm-c-test/echo.cpp
+++ tools/llvm-c-test/echo.cpp
@@ -480,13 +480,19 @@
case LLVMUDiv: {
LLVMValueRef LHS = CloneValue(LLVMGetOperand(Src, 0));
LLVMValueRef RHS = CloneValue(LLVMGetOperand(Src, 1));
- Dst = LLVMBuildUDiv(Builder, LHS, RHS, Name);
+ if (LLVMIsExact(Src))
+ Dst = LLVMBuildExactUDiv(Builder, LHS, RHS, Name);
+ else
+ Dst = LLVMBuildUDiv(Builder, LHS, RHS, Name);
break;
}
case LLVMSDiv: {
LLVMValueRef LHS = CloneValue(LLVMGetOperand(Src, 0));
LLVMValueRef RHS = CloneValue(LLVMGetOperand(Src, 1));
- Dst = LLVMBuildSDiv(Builder, LHS, RHS, Name);
+ if (LLVMIsExact(Src))
+ Dst = LLVMBuildExactSDiv(Builder, LHS, RHS, Name);
+ else
+ Dst = LLVMBuildSDiv(Builder, LHS, RHS, Name);
break;
}
case LLVMURem: {
Index: test/Bindings/llvm-c/echo.ll
===================================================================
--- test/Bindings/llvm-c/echo.ll
+++ test/Bindings/llvm-c/echo.ll
@@ -51,6 +51,8 @@
%3 = sub i32 %2, %1
%4 = udiv i32 %3, %b
%5 = sdiv i32 %2, %4
+ %e4 = udiv exact i32 %3, %b
+ %e5 = sdiv exact i32 %2, %4
%6 = urem i32 %3, %5
%7 = srem i32 %2, %6
%8 = shl i32 %1, %b
Index: lib/IR/Core.cpp
===================================================================
--- lib/IR/Core.cpp
+++ lib/IR/Core.cpp
@@ -2724,6 +2724,10 @@
return wrap(unwrap(B)->CreateNot(unwrap(V), Name));
}
+LLVMBool LLVMIsExact(LLVMValueRef V) {
+ return cast<PossiblyExactOperator>(unwrap(V))->isExact();
+}
+
/*--.. Memory ..............................................................--*/
LLVMValueRef LLVMBuildMalloc(LLVMBuilderRef B, LLVMTypeRef Ty,
Index: include/llvm-c/Core.h
===================================================================
--- include/llvm-c/Core.h
+++ include/llvm-c/Core.h
@@ -3000,6 +3000,8 @@
LLVMValueRef LLVMBuildFNeg(LLVMBuilderRef, LLVMValueRef V, const char *Name);
LLVMValueRef LLVMBuildNot(LLVMBuilderRef, LLVMValueRef V, const char *Name);
+LLVMBool LLVMIsExact(LLVMValueRef V);
+
/* Memory */
LLVMValueRef LLVMBuildMalloc(LLVMBuilderRef, LLVMTypeRef Ty, const char *Name);
LLVMValueRef LLVMBuildArrayMalloc(LLVMBuilderRef, LLVMTypeRef Ty,
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D25265.73590.patch
Type: text/x-patch
Size: 2405 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20161005/1520d1a7/attachment.bin>
More information about the llvm-commits
mailing list