41ef63df21
With bytecode flushing and lazy feedback allocation, we need to call %PrepareForOptimization before we call %OptimizeFunctionOnNextCall Bug: v8:8801, v8:8394 Change-Id: I81918f174b2f97cbaa8b8ef2e459080c2581f535 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1588415 Commit-Queue: Mythri Alle <mythria@chromium.org> Commit-Queue: Ross McIlroy <rmcilroy@chromium.org> Reviewed-by: Ross McIlroy <rmcilroy@chromium.org> Cr-Commit-Position: refs/heads/master@{#61122}
53 lines
1.3 KiB
JavaScript
53 lines
1.3 KiB
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 --expose-gc
|
|
|
|
|
|
new BenchmarkSuite('ManyClosures', [1000], [
|
|
new Benchmark('CreateManyClosures', false, true, 1, CreateManyClosures,
|
|
CreateManyClosures_Setup)
|
|
]);
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// This program creates many closures and then allocates many arrays in order
|
|
// to trigger garbage collection cycles. The goal of this micro-benchmark is to
|
|
// evaluate the overhead of keeping the weak-list of optimized JS functions.
|
|
//
|
|
// c.f. https://bugs.chromium.org/p/v8/issues/detail?id=6637#c5
|
|
|
|
|
|
var a = [];
|
|
%NeverOptimizeFunction(CreateManyClosures_Setup);
|
|
function CreateManyClosures_Setup() {
|
|
function g() {
|
|
return (i) => i + 1;
|
|
}
|
|
|
|
// Create a closure and optimize.
|
|
var f = g();
|
|
|
|
%PrepareFunctionForOptimization(f);
|
|
f(0);
|
|
f(0);
|
|
%OptimizeFunctionOnNextCall(f);
|
|
f(0);
|
|
// Create 2M closures, those will get the optimized code.
|
|
a = [];
|
|
for (var i = 0; i < 2000000; i++) {
|
|
var f = g();
|
|
f();
|
|
a.push(f);
|
|
}
|
|
}
|
|
|
|
%NeverOptimizeFunction(CreateManyClosures);
|
|
function CreateManyClosures() {
|
|
// Now cause scavenges.
|
|
for (var i = 0; i < 50; i++) {
|
|
gc(true);
|
|
}
|
|
}
|