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}
32 lines
785 B
JavaScript
32 lines
785 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
|
|
// The deopt count is stored in the feedback vector which gets cleared when
|
|
// bytecode is flushed, which --gc-interval can cause in stress modes.
|
|
// Flags: --noflush-bytecode --nostress-flush-bytecode
|
|
|
|
function foo() {}
|
|
|
|
assertEquals(0, %GetDeoptCount(foo));
|
|
|
|
foo();
|
|
foo();
|
|
%OptimizeFunctionOnNextCall(foo);
|
|
foo();
|
|
|
|
assertOptimized(foo);
|
|
assertEquals(0, %GetDeoptCount(foo));
|
|
|
|
// Unlink the function.
|
|
%DeoptimizeFunction(foo);
|
|
|
|
assertUnoptimized(foo);
|
|
assertEquals(1, %GetDeoptCount(foo));
|
|
|
|
foo();
|
|
|
|
assertUnoptimized(foo);
|
|
assertEquals(1, %GetDeoptCount(foo));
|