v8/test/mjsunit/double-intrinsics.js
mvstanton af293729ad Tests that carefully checks opt/deopt status shouldn't --always-opt.
If we optimize a function before gathering feedback it may be
peppered with soft deoptimizations. So it can't help but deoptimize.
A judicious reading of the code isn't enough to determine what the
optimization state should be in the face of such chaotic gyrations.

BUG=
R=verwaest@chromium.org

Review URL: https://codereview.chromium.org/1069363003

Cr-Commit-Position: refs/heads/master@{#27671}
2015-04-08 15:56:01 +00:00

38 lines
1.1 KiB
JavaScript

// 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.
// Flags: --allow-natives-syntax
// Flags: --noalways-opt
function assertDoubleBits(hi, lo, x) {
hi = hi | 0;
lo = lo | 0;
assertEquals(x, %_ConstructDouble(hi, lo));
assertEquals(hi, %_DoubleHi(x));
assertEquals(lo, %_DoubleLo(x));
assertEquals(x, %_ConstructDouble(%_DoubleHi(x), %_DoubleLo(x)));
}
var tests = [0x7ff00000, 0x00000000, Infinity,
0xfff00000, 0x00000000, -Infinity,
0x80000000, 0x00000000, -0,
0x400921fb, 0x54442d18, Math.PI,
0xc00921fb, 0x54442d18, -Math.PI,
0x4005bf0a, 0x8b145769, Math.E,
0xc005bf0a, 0x8b145769, -Math.E,
0xbfe80000, 0x00000000, -0.75];
for (var i = 0; i < tests.length; i += 3) {
assertDoubleBits(tests[i], tests[i + 1], tests[i + 2]);
}
%OptimizeFunctionOnNextCall(assertDoubleBits);
for (var i = 0; i < tests.length; i += 3) {
assertDoubleBits(tests[i], tests[i + 1], tests[i + 2]);
assertOptimized(assertDoubleBits);
}