[PATCH] Fix incorrect truncation at the overflow boundary
Pirama Arumuga Nainar
pirama at google.com
Tue Jun 23 13:29:17 PDT 2015
REPOSITORY
rL LLVM
http://reviews.llvm.org/D10594
Files:
compiler-rt/trunk/lib/builtins/fp_trunc_impl.inc
compiler-rt/trunk/test/builtins/Unit/fp_test.h
compiler-rt/trunk/test/builtins/Unit/truncdfhf2_test.c
compiler-rt/trunk/test/builtins/Unit/truncdfsf2_test.c
compiler-rt/trunk/test/builtins/Unit/truncsfhf2_test.c
Index: compiler-rt/trunk/lib/builtins/fp_trunc_impl.inc
===================================================================
--- compiler-rt/trunk/lib/builtins/fp_trunc_impl.inc
+++ compiler-rt/trunk/lib/builtins/fp_trunc_impl.inc
@@ -99,7 +99,7 @@
absResult |= dstQNaN;
absResult |= ((aAbs & srcNaNCode) >> (srcSigBits - dstSigBits)) & dstNaNCode;
}
- else if (aAbs > overflow) {
+ else if (aAbs >= overflow) {
// a overflows to infinity.
absResult = (dst_rep_t)dstInfExp << dstSigBits;
}
Index: compiler-rt/trunk/test/builtins/Unit/fp_test.h
===================================================================
--- compiler-rt/trunk/test/builtins/Unit/fp_test.h
+++ compiler-rt/trunk/test/builtins/Unit/fp_test.h
@@ -14,6 +14,7 @@
#include <stdlib.h>
#include <limits.h>
#include <string.h>
+#include <stdint.h>
enum EXPECTED_RESULT {
LESS_0, LESS_EQUAL_0, EQUAL_0, GREATER_0, GREATER_EQUAL_0, NEQUAL_0
Index: compiler-rt/trunk/test/builtins/Unit/truncdfsf2_test.c
===================================================================
--- compiler-rt/trunk/test/builtins/Unit/truncdfsf2_test.c
+++ compiler-rt/trunk/test/builtins/Unit/truncdfsf2_test.c
@@ -0,0 +1,38 @@
+//===--------------- truncdfsf2_test.c - Test __truncdfsf2 ----------------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is dual licensed under the MIT and the University of Illinois Open
+// Source Licenses. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+//
+// This file tests __truncdfsf2 for the compiler_rt library.
+//
+//===----------------------------------------------------------------------===//
+
+#include <stdio.h>
+
+#include "fp_test.h"
+
+float __truncdfsf2(double a);
+
+int test__truncdfsf2(double a)
+{
+ float actual = __truncdfsf2(a);
+ float expected = a;
+
+ if (actual != expected) {
+ printf("error in test__truncdfsf2(%lf) = %f, "
+ "expected %f\n", a, actual, expected);
+ return 1;
+ }
+ return 0;
+}
+
+int main()
+{
+ if (test__truncdfsf2(340282366920938463463374607431768211456.0))
+ return 1;
+ return 0;
+}
Index: compiler-rt/trunk/test/builtins/Unit/truncsfhf2_test.c
===================================================================
--- compiler-rt/trunk/test/builtins/Unit/truncsfhf2_test.c
+++ compiler-rt/trunk/test/builtins/Unit/truncsfhf2_test.c
@@ -104,6 +104,9 @@
if (test__truncsfhf2(65520.0f,
UINT16_C(0x7c00)))
return 1;
+ if (test__truncsfhf2(65536.0f,
+ UINT16_C(0x7c00)))
+ return 1;
if (test__truncsfhf2(-65520.0f,
UINT16_C(0xfc00)))
return 1;
Index: compiler-rt/trunk/test/builtins/Unit/truncdfhf2_test.c
===================================================================
--- compiler-rt/trunk/test/builtins/Unit/truncdfhf2_test.c
+++ compiler-rt/trunk/test/builtins/Unit/truncdfhf2_test.c
@@ -107,5 +107,8 @@
if (test__truncdfhf2(-65520.0,
UINT16_C(0xfc00)))
return 1;
+ if (test__truncdfhf2(65536.0,
+ UINT16_C(0x7c00)))
+ return 1;
return 0;
}
EMAIL PREFERENCES
http://reviews.llvm.org/settings/panel/emailpreferences/
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D10594.28279.patch
Type: text/x-patch
Size: 3291 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20150623/27a6d61b/attachment.bin>
More information about the llvm-commits
mailing list