2015-03-20 16:42:51 +00:00
|
|
|
// Copyright 2015 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 f(a, i, bool) {
|
|
|
|
var result;
|
|
|
|
if (bool) {
|
|
|
|
// Make sure i - -0x80000000 doesn't overflow in BCE, missing a check for
|
|
|
|
// x-0 later on.
|
|
|
|
result = f2(a, 0x7fffffff, i, i, -0x80000000);
|
|
|
|
} else {
|
|
|
|
result = f2(a, -3, 4, i, 0);
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
2019-06-17 11:48:08 +00:00
|
|
|
%PrepareFunctionForOptimization(f);
|
2015-03-20 16:42:51 +00:00
|
|
|
|
|
|
|
function f2(a, c, x, i, d) {
|
|
|
|
return a[x + c] + a[x - 0] + a[i - d];
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
var a = [];
|
|
|
|
var i = 0;
|
|
|
|
a.push(i++);
|
|
|
|
a.push(i++);
|
|
|
|
a.push(i++);
|
|
|
|
a.push(i++);
|
|
|
|
a.push(i++);
|
|
|
|
f(a, 0, false);
|
|
|
|
f(a, 0, false);
|
|
|
|
f(a, 0, false);
|
|
|
|
%OptimizeFunctionOnNextCall(f);
|
|
|
|
%DebugPrint(f(a, -0x7fffffff, true));
|