c4113c4705
Changes: - Remove TypeCheckBranchResult. Change TypeCheckBranch() to return bool. Refactor call sites to reflect this (decouple current code reachability check from type check). - Unify TypeCheckBranch(), TypeCheckFallthrough(), and the type-checking part of Return() into TypeCheckStackAgainstMerge(). - Make sure all TypeCheck* functions are only called within VALIDATE. - In graph-builder-interface, rename end_env -> merge_env to reflect its function for loops. - Change expected error messages in some tests. Change-Id: I857edc18db9c2454ad12d539ffe7a10e96367710 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2839560 Reviewed-by: Clemens Backes <clemensb@chromium.org> Commit-Queue: Manos Koukoutos <manoskouk@chromium.org> Cr-Commit-Position: refs/heads/master@{#74100}
75 lines
2.9 KiB
JavaScript
75 lines
2.9 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: --experimental-wasm-compilation-hints
|
|
|
|
load('test/mjsunit/wasm/wasm-module-builder.js');
|
|
|
|
(function testCompileWithBadLazyHint() {
|
|
print(arguments.callee.name);
|
|
let builder = new WasmModuleBuilder();
|
|
builder.addFunction('id', kSig_i_i)
|
|
.addBody([kExprLocalGet, 0])
|
|
.setCompilationHint(kCompilationHintStrategyLazy,
|
|
kCompilationHintTierOptimized,
|
|
kCompilationHintTierBaseline)
|
|
.exportFunc();
|
|
let bytes = builder.toBuffer();
|
|
assertPromiseResult(WebAssembly.compile(bytes)
|
|
.then(assertUnreachable,
|
|
error => assertEquals("WebAssembly.compile(): Invalid compilation " +
|
|
"hint 0x19 (forbidden downgrade) @+49", error.message)));
|
|
})();
|
|
|
|
(function testCompileWithBadLazyFunctionBody() {
|
|
print(arguments.callee.name);
|
|
let builder = new WasmModuleBuilder();
|
|
builder.addFunction('id', kSig_i_l)
|
|
.addBody([kExprLocalGet, 0])
|
|
.setCompilationHint(kCompilationHintStrategyLazy,
|
|
kCompilationHintTierDefault,
|
|
kCompilationHintTierDefault)
|
|
.exportFunc();
|
|
let bytes = builder.toBuffer();
|
|
assertPromiseResult(WebAssembly.compile(bytes)
|
|
.then(assertUnreachable,
|
|
error => assertEquals("WebAssembly.compile(): type error in " +
|
|
"fallthru[0] (expected i32, got i64) @+56", error.message)));
|
|
})();
|
|
|
|
(function testCompileEmptyModule() {
|
|
print(arguments.callee.name);
|
|
let builder = new WasmModuleBuilder();
|
|
let bytes = builder.toBuffer();
|
|
assertPromiseResult(WebAssembly.compile(bytes));
|
|
})();
|
|
|
|
(function testCompileLazyModule() {
|
|
print(arguments.callee.name);
|
|
let builder = new WasmModuleBuilder();
|
|
builder.addFunction('id', kSig_i_i)
|
|
.addBody([kExprLocalGet, 0])
|
|
.setCompilationHint(kCompilationHintStrategyLazy,
|
|
kCompilationHintTierDefault,
|
|
kCompilationHintTierDefault)
|
|
.exportFunc();
|
|
let bytes = builder.toBuffer();
|
|
assertPromiseResult(WebAssembly.instantiate(bytes)
|
|
.then(({module, instance}) => assertEquals(42, instance.exports.id(42))));
|
|
})();
|
|
|
|
(function testCompileLazyBaselineEagerTopTierModule() {
|
|
print(arguments.callee.name);
|
|
let builder = new WasmModuleBuilder();
|
|
builder.addFunction('id', kSig_i_i)
|
|
.addBody([kExprLocalGet, 0])
|
|
.setCompilationHint(kCompilationHintStrategyLazyBaselineEagerTopTier,
|
|
kCompilationHintTierDefault,
|
|
kCompilationHintTierDefault)
|
|
.exportFunc();
|
|
let bytes = builder.toBuffer();
|
|
assertPromiseResult(WebAssembly.instantiate(bytes)
|
|
.then(({module, instance}) => assertEquals(42, instance.exports.id(42))));
|
|
})();
|