d2d99e084a
Reason for revert:
Mac gc stress failures:
https://build.chromium.org/p/client.v8/builders/V8%20Mac%20GC%20Stress/builds/11195
There's also this flake, but maybe unrelated:
https://build.chromium.org/p/client.v8/builders/V8%20Win64/builds/15422
Original issue's description:
> [tests] Make assertOptimized()/assertUnoptimized() great again.
>
> The mentioned asserts did not work properly with interpreted and turbofanned functions.
>
> To fix this issue %GetOptimizationStatus() now returns a set of flags instead of a single value.
>
> This CL also adds more helper functions to mjsunit, like isNeverOptimize(), isAlwaysOptimize(),
> isOptimized(fun), etc.
>
> BUG=v8:5890
>
> Review-Url: https://codereview.chromium.org/2654733004
> Cr-Commit-Position: refs/heads/master@{#42703}
> Committed: d1ddec7857
TBR=mstarzinger@chromium.org,ishell@chromium.org
# Skipping CQ checks because original CL landed less than 1 days ago.
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=v8:5890
Review-Url: https://codereview.chromium.org/2655223003
Cr-Commit-Position: refs/heads/master@{#42704}
42 lines
1.3 KiB
JavaScript
42 lines
1.3 KiB
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: --mark-shared-functions-for-tier-up --allow-natives-syntax --ignition-staging --no-turbo
|
|
|
|
(function() {
|
|
var sum = 0;
|
|
var i = 0;
|
|
for (var i = 0; i < 5; ++i) {
|
|
var f = function(x) {
|
|
return 2 * x;
|
|
}
|
|
sum += f(i);
|
|
|
|
if (%GetOptimizationStatus(f) == 3 || %GetOptimizationStatus(f) == 4) {
|
|
// If we are always or never optimizing f, just exit, this test is useless.
|
|
return;
|
|
}
|
|
|
|
if (i == 1) {
|
|
// f must be interpreted code.
|
|
assertEquals(8, %GetOptimizationStatus(f));
|
|
|
|
// Allow it to run twice (i = 0, 1), then tier-up to baseline.
|
|
%BaselineFunctionOnNextCall(f);
|
|
} else if (i == 2) {
|
|
// Tier-up at i = 2 should only go up to baseline.
|
|
assertEquals(2, %GetOptimizationStatus(f));
|
|
} else if (i == 3) {
|
|
// Now f must be baseline code.
|
|
assertEquals(2, %GetOptimizationStatus(f));
|
|
|
|
// Run two more times (i = 2, 3), then tier-up to optimized.
|
|
%OptimizeFunctionOnNextCall(f);
|
|
} else if (i == 4) {
|
|
// Tier-up at i = 4 should now go up to crankshaft.
|
|
assertEquals(1, %GetOptimizationStatus(f));
|
|
}
|
|
}
|
|
})()
|