v8/test/mjsunit/regress/regress-6838-3.js
Michael Starzinger 02d999abad [asm.js] Fix Math.abs signature to return unsigned.
This fixes the signature of "Math.abs" from "(signed) -> signed" to
"(signed) -> unsigned" and hence fixes cases where the absolute value
would overflow the range of signed 32-bit values. This is in sync with
spec erratas (and ECMAScript semantics).

Note that this also switches the underlying implementation of the above
absolute value function to a branch-free version.

R=clemensh@chromium.org
TEST=mjsunit/regress/regress-6838-3
BUG=v8:6838

Change-Id: Ib13b7ecd336ae386cbde7c574e727bf52f841e00
Reviewed-on: https://chromium-review.googlesource.com/684181
Commit-Queue: Michael Starzinger <mstarzinger@chromium.org>
Reviewed-by: Clemens Hammacher <clemensh@chromium.org>
Cr-Commit-Position: refs/heads/master@{#48169}
2017-09-26 13:02:53 +00:00

40 lines
988 B
JavaScript

// Copyright 2017 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Flags: --allow-natives-syntax
(function TestMathAbsReturningUnsigned() {
function Module(stdlib) {
"use asm";
var abs=stdlib.Math.abs;
function f(a, b) {
a = a | 0;
b = b | 0;
return (abs(a >> 0) == (b >>> 0)) | 0;
}
return f;
}
var f = Module(this);
assertEquals(0, f(1, 2));
assertEquals(1, f(23, 23));
assertEquals(1, f(-42, 42));
assertEquals(1, f(-0x7fffffff, 0x7fffffff));
assertEquals(1, f(-0x80000000, 0x80000000));
assertTrue(%IsAsmWasmCode(Module));
})();
(function TestMathAbsOverflowSignedValue() {
function Module(stdlib) {
"use asm";
var abs=stdlib.Math.abs;
function f() {
return (abs(-0x80000000) > 0) | 0;
}
return f;
}
var f = Module(this);
assertEquals(1, f());
assertTrue(%IsAsmWasmCode(Module));
})();