f6a83e36cd
of optimized JS functions. Bug: v8:6637 Change-Id: Ice94a4a2187f98adcbf25ac1832e13d4b7529f34 Reviewed-on: https://chromium-review.googlesource.com/628198 Commit-Queue: Juliana Patricia Vicente Franco <jupvfranco@google.com> Reviewed-by: Jaroslav Sevcik <jarin@chromium.org> Cr-Commit-Position: refs/heads/master@{#47579}
52 lines
1.3 KiB
JavaScript
52 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();
|
|
|
|
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);
|
|
}
|
|
}
|