5504068f49
This reverts commit ad1fcd4343
.
Reason for revert: Breaks waterfall.
Original change's description:
> [cleanup] Remove the now-unused deopt_count from feedback vector.
>
> Bug: v8:9183
> Change-Id: Iceeccc8ab1e4e77b428e7e2feec39bff3317f241
> Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1617675
> Commit-Queue: Jaroslav Sevcik <jarin@chromium.org>
> Reviewed-by: Michael Starzinger <mstarzinger@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#61665}
TBR=mstarzinger@chromium.org,jarin@chromium.org
Change-Id: Iea0e6a329f55a3a941f0b976925b2abdf7eece38
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: v8:9183
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1619867
Reviewed-by: Jaroslav Sevcik <jarin@chromium.org>
Commit-Queue: Jaroslav Sevcik <jarin@chromium.org>
Cr-Commit-Position: refs/heads/master@{#61666}
35 lines
796 B
JavaScript
35 lines
796 B
JavaScript
// Copyright 2017 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 --opt --no-always-opt
|
|
|
|
|
|
function foo(i, deopt = false, deoptobj = null) {
|
|
if (i == 0) {
|
|
if (deopt) {
|
|
// Trigger a soft deopt.
|
|
deoptobj.bar();
|
|
}
|
|
} else {
|
|
foo(i - 1, deopt, deoptobj);
|
|
}
|
|
}
|
|
|
|
assertEquals(0, %GetDeoptCount(foo));
|
|
|
|
%PrepareFunctionForOptimization(foo);
|
|
foo(10);
|
|
foo(10);
|
|
%OptimizeFunctionOnNextCall(foo);
|
|
foo(10);
|
|
|
|
assertOptimized(foo);
|
|
assertEquals(0, %GetDeoptCount(foo));
|
|
|
|
foo(10, true, { bar: function(){} });
|
|
|
|
assertUnoptimized(foo);
|
|
// Soft deopts don't count to the deopt count.
|
|
assertEquals(0, %GetDeoptCount(foo));
|