2017-08-24 13:30:27 +00:00
|
|
|
// 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();
|
|
|
|
|
2019-04-30 13:39:53 +00:00
|
|
|
%PrepareFunctionForOptimization(f);
|
2017-08-24 13:30:27 +00:00
|
|
|
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);
|
|
|
|
}
|
|
|
|
}
|