v8/test/mjsunit/wasm/serialize-lazy-module.js
Andreas Haas eb129a5cf1 Reland "[wasm] Lazy compilation after deserialization"
The original CL introduced a test that does not work when it is executed
concurrently on multiple isolates. This CL skips this test
configuration.

Original change's description:
> [wasm] Lazy compilation after deserialization
>
> The serialization format contains one boolean flag per function which
> specifies whether the function code exists in the serialized module or
> not. With this CL, this boolean flag is extended to a three-value flag
> which indicates whether the function exists, and if not, whether the
> function was executed before serialization. This information can then be
> used upon deserialization to compile only those functions that were
> executed before serialization.
>
> Design doc: https://docs.google.com/document/d/1U3uqq4njqLqFhr1G2sU_bmpQxY-3bvfG55udSb-DvA4/edit?usp=sharing
>
> Bug: v8:12281

Change-Id: I36ce90b37736172aa01c47ab04e154ec8ea2d8aa
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3380590
Reviewed-by: Clemens Backes <clemensb@chromium.org>
Commit-Queue: Andreas Haas <ahaas@chromium.org>
Cr-Commit-Position: refs/heads/main@{#78564}
2022-01-11 13:13:56 +00:00

76 lines
2.2 KiB
JavaScript

// Copyright 2018 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.
// The test needs --no-liftoff because we can't serialize and deserialize
// Liftoff code.
// Flags: --wasm-lazy-compilation --allow-natives-syntax --expose-gc
// Flags: --no-liftoff
d8.file.execute('test/mjsunit/wasm/wasm-module-builder.js');
(function SerializeUncompiledModule() {
print(arguments.callee.name);
const [wire_bytes, i1, buff] = (function GenerateInstance() {
const builder = new WasmModuleBuilder();
// Add 20 functions.
for (let i = 0; i < 20; ++i) {
builder.addFunction('f' + i, kSig_i_i)
.addBody([kExprI32Const, i])
.exportFunc();
}
const wire_bytes = builder.toBuffer();
const module = new WebAssembly.Module(wire_bytes);
// Run one function so that serialization happens.
let instance = new WebAssembly.Instance(module);
instance.exports.f3();
const buff = %SerializeWasmModule(module);
return [wire_bytes, instance, buff];
})();
gc();
const module = %DeserializeWasmModule(buff, wire_bytes);
const i2 = new WebAssembly.Instance(module);
assertEquals(13, i2.exports.f13());
assertEquals(11, i1.exports.f11());
})();
(function SerializePartlyCompiledModule() {
print(arguments.callee.name);
const [wire_bytes, i1, buff] = (function GenerateInstance() {
const builder = new WasmModuleBuilder();
// Add 20 functions.
for (let i = 0; i < 20; ++i) {
builder.addFunction('f' + i, kSig_i_i)
.addBody([kExprI32Const, i])
.exportFunc();
}
const wire_bytes = builder.toBuffer();
const module = new WebAssembly.Module(wire_bytes);
const i1 = new WebAssembly.Instance(module);
// Run one function so that serialization happens.
i1.exports.f3();
const buff = %SerializeWasmModule(module);
assertEquals(2, i1.exports.f2());
assertEquals(11, i1.exports.f11());
return [wire_bytes, i1, buff];
})();
gc();
const module = %DeserializeWasmModule(buff, wire_bytes);
const i2 = new WebAssembly.Instance(module);
assertEquals(13, i2.exports.f13());
assertEquals(11, i1.exports.f11());
assertEquals(9, i1.exports.f9());
})();