v8/test/mjsunit/wasm/multiple-code-spaces.js
Clemens Backes 5ad8474a1e [wasm] Remove always-on --wasm-far-jump-table flag
This shipped in v7.9, which is stable since six weeks. We do not test
the previous configuration any more and don't plan to move back, hence
remove the flag and clean up the code.

R=ahaas@chromium.org

Bug: v8:10155
Change-Id: I6b981f4be686473a911f041952cb684749d9fe7e
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2030732
Commit-Queue: Clemens Backes <clemensb@chromium.org>
Reviewed-by: Andreas Haas <ahaas@chromium.org>
Cr-Commit-Position: refs/heads/master@{#66063}
2020-01-31 09:39:04 +00:00

55 lines
2.3 KiB
JavaScript

// Copyright 2019 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 --randomize-all-allocations
// Flags: --wasm-max-initial-code-space-reservation=1
load('test/mjsunit/wasm/wasm-module-builder.js');
// Instantiate bigger modules, until at least four separate code spaces have
// been allocated.
// Each function calls through many of the previous functions to execute the
// jump table(s) sufficiently.
let num_functions = 50;
while (true) {
print(`Trying ${num_functions} functions...`);
if (num_functions > 1e6) {
throw new Error('We should have hit four code spaces by now');
}
const builder = new WasmModuleBuilder();
builder.addMemory(1, 1, false);
builder.addFunction('f0', kSig_i_i).addBody([kExprLocalGet, 0]);
// Generate some code per function to fill the code space.
// Each function contains a number of loads that will not be executed
// (inside an "if (i == 0)" block). They increase the code size a bit so we
// do not need too many functions.
// Each function f<n> with argument {i} then calls f<n/10> with argument
// {i + 1} and returns whatever that function returns.
const body_template = [
kExprLocalGet, 0, kExprI32Eqz, kExprIf, kWasmStmt, // if (i == 0)
kExprLocalGet, 0 // get i
];
for (let i = 0; i < 1000; ++i) body_template.push(kExprI32LoadMem, 0, 0);
body_template.push(
kExprDrop, kExprEnd, // end if
kExprLocalGet, 0, kExprI32Const, 1, kExprI32Add, // i + 1
kExprCallFunction // call f<?>
);
for (let i = 1; i < num_functions; ++i) {
const body = body_template.slice();
body.push(...wasmSignedLeb(Math.floor(i / 10)));
builder.addFunction('f' + i, kSig_i_i).addBody(body);
}
builder.addExport('f', num_functions - 1);
const instance = builder.instantiate();
let expected = 17;
for (let i = num_functions - 1; i > 0; i = Math.floor(i / 10)) ++expected;
assertEquals(expected, instance.exports.f(17));
const num_code_spaces = %WasmNumCodeSpaces(instance);
print(`--> ${num_code_spaces} code spaces.`);
if (num_code_spaces >= 4) break;
num_functions *= 2;
}