mirror of https://github.com/nodejs/node.git
benchmark: remove querystring forced optimization
This removes all instances of %OptimizeFunctionOnNextCall from querystring benchmarks PR-URL: https://github.com/nodejs/node/pull/9615 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Matteo Collina <matteo.collina@gmail.com>pull/11716/head
parent
eba2c62bb1
commit
57b5ce1d8e
|
@ -1,7 +1,6 @@
|
||||||
'use strict';
|
'use strict';
|
||||||
var common = require('../common.js');
|
var common = require('../common.js');
|
||||||
var querystring = require('querystring');
|
var querystring = require('querystring');
|
||||||
var v8 = require('v8');
|
|
||||||
var inputs = require('../fixtures/url-inputs.js').searchParams;
|
var inputs = require('../fixtures/url-inputs.js').searchParams;
|
||||||
|
|
||||||
var bench = common.createBenchmark(main, {
|
var bench = common.createBenchmark(main, {
|
||||||
|
@ -9,23 +8,13 @@ var bench = common.createBenchmark(main, {
|
||||||
n: [1e6],
|
n: [1e6],
|
||||||
});
|
});
|
||||||
|
|
||||||
// A deopt followed by a reopt of main() can happen right when the timed loop
|
|
||||||
// starts, which seems to have a noticeable effect on the benchmark results.
|
|
||||||
// So we explicitly disable optimization of main() to avoid this potential
|
|
||||||
// issue.
|
|
||||||
v8.setFlagsFromString('--allow_natives_syntax');
|
|
||||||
eval('%NeverOptimizeFunction(main)');
|
|
||||||
|
|
||||||
function main(conf) {
|
function main(conf) {
|
||||||
var type = conf.type;
|
var type = conf.type;
|
||||||
var n = conf.n | 0;
|
var n = conf.n | 0;
|
||||||
var input = inputs[type];
|
var input = inputs[type];
|
||||||
var i;
|
var i;
|
||||||
|
// Execute the function a "sufficient" number of times before the timed
|
||||||
// Note: we do *not* use OptimizeFunctionOnNextCall() here because currently
|
// loop to ensure the function is optimized just once.
|
||||||
// it causes a deopt followed by a reopt, which could make its way into the
|
|
||||||
// timed loop. Instead, just execute the function a "sufficient" number of
|
|
||||||
// times before the timed loop to ensure the function is optimized just once.
|
|
||||||
if (type === 'multicharsep') {
|
if (type === 'multicharsep') {
|
||||||
for (i = 0; i < n; i += 1)
|
for (i = 0; i < n; i += 1)
|
||||||
querystring.parse(input, '&&&&&&&&&&');
|
querystring.parse(input, '&&&&&&&&&&');
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
'use strict';
|
'use strict';
|
||||||
var common = require('../common.js');
|
var common = require('../common.js');
|
||||||
var querystring = require('querystring');
|
var querystring = require('querystring');
|
||||||
var v8 = require('v8');
|
|
||||||
|
|
||||||
var bench = common.createBenchmark(main, {
|
var bench = common.createBenchmark(main, {
|
||||||
type: ['noencode', 'encodemany', 'encodelast'],
|
type: ['noencode', 'encodemany', 'encodelast'],
|
||||||
|
@ -36,10 +35,6 @@ function main(conf) {
|
||||||
for (var name in inputs)
|
for (var name in inputs)
|
||||||
querystring.stringify(inputs[name]);
|
querystring.stringify(inputs[name]);
|
||||||
|
|
||||||
v8.setFlagsFromString('--allow_natives_syntax');
|
|
||||||
eval('%OptimizeFunctionOnNextCall(querystring.stringify)');
|
|
||||||
querystring.stringify(input);
|
|
||||||
|
|
||||||
bench.start();
|
bench.start();
|
||||||
for (var i = 0; i < n; i += 1)
|
for (var i = 0; i < n; i += 1)
|
||||||
querystring.stringify(input);
|
querystring.stringify(input);
|
||||||
|
|
Loading…
Reference in New Issue