v8/test/mjsunit/wasm/ffi-error.js
Ben L. Titzer c02f5e3ab3 [wasm] Store the globals_start in WasmContext.
This CL removes the code specialization for WASM functions that access
globals. Previously, we were embedding the start address of the globals
memory (globals_start) as a constant in the code, which required
patching for every instance. We now put this base in to the WasmContext,
which is available as a parameter to every WasmFunction.

R=ahaas@chromium.org,
CC=mtrofin@chromium.org

Bug: 
Change-Id: I04bb739e898cc5a3b7dd081cc166483022d113fd
Reviewed-on: https://chromium-review.googlesource.com/712595
Commit-Queue: Ben Titzer <titzer@chromium.org>
Reviewed-by: Mircea Trofin <mtrofin@chromium.org>
Reviewed-by: Andreas Haas <ahaas@chromium.org>
Reviewed-by: Bill Budge <bbudge@chromium.org>
Cr-Commit-Position: refs/heads/master@{#48581}
2017-10-16 09:35:47 +00:00

184 lines
4.8 KiB
JavaScript

// Copyright 2015 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: --expose-wasm
load("test/mjsunit/wasm/wasm-constants.js");
load("test/mjsunit/wasm/wasm-module-builder.js");
function instantiateWithFFI(ffi) {
var builder = new WasmModuleBuilder();
var sig_index = kSig_i_dd;
builder.addImport("mod", "fun", sig_index);
builder.addFunction("main", sig_index)
.addBody([
kExprGetLocal, 0, // --
kExprGetLocal, 1, // --
kExprCallFunction, 0, // --
]) // --
.exportFunc();
return builder.instantiate(ffi);
}
// everything is good.
(function() {
var ffi = {"mod": {fun: function(a, b) { print(a, b); }}}
instantiateWithFFI(ffi);
})();
// FFI object should be an object.
assertThrows(function() {
var ffi = 0;
instantiateWithFFI(ffi);
});
// FFI object should have a "mod" property.
assertThrows(function() {
instantiateWithFFI({});
});
// FFI object should have a "fun" property.
assertThrows(function() {
instantiateWithFFI({mod: {}});
});
// "fun" should be a JS function.
assertThrows(function() {
instantiateWithFFI({mod: {fun: new Object()}});
});
// "fun" should be a JS function.
assertThrows(function() {
instantiateWithFFI({mod: {fun: 0}});
});
// "fun" should have signature "i_dd"
assertThrows(function () {
var builder = new WasmModuleBuilder();
var sig_index = kSig_i_dd;
builder.addFunction("exp", kSig_i_i)
.addBody([
kExprGetLocal, 0,
]) // --
.exportFunc();
var exported = builder.instantiate().exports.exp;
instantiateWithFFI({mod: {fun: exported}});
});
// "fun" matches signature "i_dd"
(function () {
var builder = new WasmModuleBuilder();
builder.addFunction("exp", kSig_i_dd)
.addBody([
kExprI32Const, 33,
]) // --
.exportFunc();
var exported = builder.instantiate().exports.exp;
var instance = instantiateWithFFI({mod: {fun: exported}});
assertEquals(33, instance.exports.main());
})();
(function I64InSignatureThrows() {
var builder = new WasmModuleBuilder();
builder.addMemory(1, 1, true);
builder.addFunction("function_with_invalid_signature", kSig_l_ll)
.addBody([ // --
kExprGetLocal, 0, // --
kExprGetLocal, 1, // --
kExprI64Sub]) // --
.exportFunc()
var module = builder.instantiate();
assertThrows(function() {
module.exports.function_with_invalid_signature(33, 88);
}, TypeError);
})();
(function I64ParamsInSignatureThrows() {
var builder = new WasmModuleBuilder();
builder.addMemory(1, 1, true);
builder.addFunction("function_with_invalid_signature", kSig_i_l)
.addBody([
kExprGetLocal, 0,
kExprI32ConvertI64
])
.exportFunc()
var module = builder.instantiate();
assertThrows(function() {
module.exports.function_with_invalid_signature(33);
}, TypeError);
})();
(function I64JSImportThrows() {
var builder = new WasmModuleBuilder();
var sig_index = builder.addType(kSig_i_i);
var sig_i64_index = builder.addType(kSig_i_l);
var index = builder.addImport("", "func", sig_i64_index);
builder.addFunction("main", sig_index)
.addBody([
kExprGetLocal, 0,
kExprI64SConvertI32,
kExprCallFunction, index // --
]) // --
.exportFunc();
var func = function() {return {};};
var main = builder.instantiate({"": {func: func}}).exports.main;
assertThrows(function() {
main(13);
}, TypeError);
})();
(function ImportI64ParamWithF64ReturnThrows() {
// This tests that we generate correct code by using the correct return
// register. See bug 6096.
var builder = new WasmModuleBuilder();
builder.addImport('', 'f', makeSig([kWasmI64], [kWasmF64]));
builder.addFunction('main', kSig_v_v)
.addBody([kExprI64Const, 0, kExprCallFunction, 0, kExprDrop])
.exportFunc();
var instance = builder.instantiate({'': {f: i => i}});
assertThrows(() => instance.exports.main(), TypeError);
})();
(function ImportI64Return() {
// This tests that we generate correct code by using the correct return
// register(s). See bug 6104.
var builder = new WasmModuleBuilder();
builder.addImport('', 'f', makeSig([], [kWasmI64]));
builder.addFunction('main', kSig_v_v)
.addBody([kExprCallFunction, 0, kExprDrop])
.exportFunc();
var instance = builder.instantiate({'': {f: () => 1}});
assertThrows(() => instance.exports.main(), TypeError);
})();
(function ImportSymbolToNumberThrows() {
var builder = new WasmModuleBuilder();
var index = builder.addImport("", "func", kSig_i_v);
builder.addFunction("main", kSig_i_v)
.addBody([kExprCallFunction, 0])
.exportFunc();
var func = () => Symbol();
var main = builder.instantiate({"": {func: func}}).exports.main;
assertThrows(() => main(), TypeError);
})();