aboutsummaryrefslogtreecommitdiffstats
path: root/erts/emulator/test/guard_SUITE.erl
diff options
context:
space:
mode:
authorSverker Eriksson <[email protected]>2017-02-14 15:53:04 +0100
committerSverker Eriksson <[email protected]>2017-02-14 16:02:03 +0100
commitd73423cdba178c166f25e00a4608ccc8d0465937 (patch)
tree78aa57f5dfe7ed6a388d0d28d0c6d9ab335a31f8 /erts/emulator/test/guard_SUITE.erl
parent3b7a6ffddc819bf305353a593904cea9e932e7dc (diff)
downloadotp-d73423cdba178c166f25e00a4608ccc8d0465937.tar.gz
otp-d73423cdba178c166f25e00a4608ccc8d0465937.tar.bz2
otp-d73423cdba178c166f25e00a4608ccc8d0465937.zip
erts: Fix round/1 for large floats
1> round(6209607916799025.0). 6209607916799026 Problem: Adding/subtracting 0.5 and large double floats between (1 bsl 52) and (1 bsl 53) does not give reliable results. Solution: Use round() function in math.h.
Diffstat (limited to 'erts/emulator/test/guard_SUITE.erl')
-rw-r--r--erts/emulator/test/guard_SUITE.erl1
1 files changed, 1 insertions, 0 deletions
diff --git a/erts/emulator/test/guard_SUITE.erl b/erts/emulator/test/guard_SUITE.erl
index e155e5f49f..54ee710363 100644
--- a/erts/emulator/test/guard_SUITE.erl
+++ b/erts/emulator/test/guard_SUITE.erl
@@ -317,6 +317,7 @@ guard_bifs(Config) when is_list(Config) ->
try_gbif('float/1', Big, float(id(Big))),
try_gbif('trunc/1', Float, 387924.0),
try_gbif('round/1', Float, 387925.0),
+ try_gbif('round/1', 6209607916799025.0, 6209607916799025),
try_gbif('length/1', [], 0),
try_gbif('length/1', [a], 1),