v8/test/mjsunit/regress/regress-5286.js
bmeurer 665f0e4020 [turbofan] Fix CheckedInt32Mod lowering for -0 case with negative left hand side.
Properly deoptimize if the left hand side of a CheckedInt32Mod is
negative and the result of the operation is zero.

R=jarin@chromium.org
BUG=v8:5286

Review-Url: https://codereview.chromium.org/2243803002
Cr-Commit-Position: refs/heads/master@{#38615}
2016-08-12 12:13:51 +00:00

42 lines
986 B
JavaScript

// Copyright 2016 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() {
function foo(x, y) { return x % y; }
assertEquals(0, foo(2, 2));
assertEquals(0, foo(4, 4));
%OptimizeFunctionOnNextCall(foo);
assertEquals(-0, foo(-8, 8));
})();
(function() {
function foo(x, y) { return x % y; }
assertEquals(0, foo(1, 1));
assertEquals(0, foo(2, 2));
%OptimizeFunctionOnNextCall(foo);
assertEquals(-0, foo(-3, 3));
})();
(function() {
function foo(x, y) { return x % y; }
assertEquals(0, foo(1, 1));
assertEquals(0, foo(2, 2));
%OptimizeFunctionOnNextCall(foo);
assertEquals(-0, foo(-2147483648, -1));
})();
(function() {
function foo(x, y) { return x % y; }
assertEquals(0, foo(1, 1));
assertEquals(0, foo(2, 2));
%OptimizeFunctionOnNextCall(foo);
assertEquals(-0, foo(-2147483648, -2147483648));
})();