Add floor, ceil, round (truncate) instructions for ia32, x64 (if SSE4.1) and
add floor, ceil, round (truncate and away from zero) for arm64.
R=bmeurer@chromium.org, dcarney@chromium.org, mstarzinger@chromium.org, rodolph.perfetta@arm.com
TEST=test/mjsunit/asm/math-floor.js,test/mjsunit/asm/math-ceil.js,test/unittest/compiler/js-builtin-reducer-unittest.cc
Review URL: https://codereview.chromium.org/677433002
Cr-Commit-Position: refs/heads/master@{#25018}
git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@25018 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
2014-10-30 14:15:20 +00:00
|
|
|
// Copyright 2014 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.
|
|
|
|
|
|
|
|
function Module(stdlib) {
|
|
|
|
"use asm";
|
|
|
|
|
|
|
|
var floor = stdlib.Math.floor;
|
|
|
|
|
|
|
|
// f: double -> float
|
|
|
|
function f(a) {
|
2017-02-14 09:26:52 +00:00
|
|
|
a = +a
|
|
|
|
return +floor(a);
|
Add floor, ceil, round (truncate) instructions for ia32, x64 (if SSE4.1) and
add floor, ceil, round (truncate and away from zero) for arm64.
R=bmeurer@chromium.org, dcarney@chromium.org, mstarzinger@chromium.org, rodolph.perfetta@arm.com
TEST=test/mjsunit/asm/math-floor.js,test/mjsunit/asm/math-ceil.js,test/unittest/compiler/js-builtin-reducer-unittest.cc
Review URL: https://codereview.chromium.org/677433002
Cr-Commit-Position: refs/heads/master@{#25018}
git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@25018 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
2014-10-30 14:15:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return { f: f };
|
|
|
|
}
|
|
|
|
|
|
|
|
var f = Module({ Math: Math }).f;
|
|
|
|
|
|
|
|
assertTrue(isNaN(f(NaN)));
|
|
|
|
assertTrue(isNaN(f(undefined)));
|
|
|
|
assertTrue(isNaN(f(function() {})));
|
|
|
|
|
|
|
|
assertEquals(0, f(0));
|
|
|
|
assertEquals(+0, f(+0));
|
|
|
|
assertEquals(-0, f(-0));
|
|
|
|
assertEquals(0, f(0.49999));
|
|
|
|
assertEquals(+0, f(0.6));
|
|
|
|
assertEquals(+0, f(0.5));
|
|
|
|
assertEquals(-1, f(-0.1));
|
|
|
|
assertEquals(-1, f(-0.5));
|
|
|
|
assertEquals(-1, f(-0.6));
|
|
|
|
assertEquals(-2, f(-1.6));
|
|
|
|
assertEquals(-1, f(-0.50001));
|
|
|
|
|
|
|
|
assertEquals("Infinity", String(f(Infinity)));
|
|
|
|
assertEquals("-Infinity", String(f(-Infinity)));
|