-
Notifications
You must be signed in to change notification settings - Fork 30.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Original commit message: Merged: [wasm] Fix dispatch table instance update This CL fixes a bug where the receiving instance was updated improperly in the dispatch table(s) of an imported table. BUG=chromium:875322 R=[email protected] [email protected] Change-Id: Iff24953a1fb6a8ab794e12a7a976d544b56fc3c2 Originally-reviewed-on: https://chromium-review.googlesource.com/1196886 No-Try: true No-Presubmit: true No-Treechecks: true Reviewed-on: https://chromium-review.googlesource.com/1212922 Reviewed-by: Michael Starzinger <[email protected]> Commit-Queue: Clemens Hammacher <[email protected]> Cr-Commit-Position: refs/branch-heads/6.9@{#45} Cr-Branched-From: d7b61abe7b48928aed739f02bf7695732d359e7e-refs/heads/6.9.427@{#1} Cr-Branched-From: b7e108d6016bf6b7de3a34e6d61cb522f5193460-refs/heads/master@{#54504} Refs: v8/v8@442977e PR-URL: #25242 Reviewed-By: Michaël Zasso <[email protected]>
- Loading branch information
1 parent
450bcde
commit e20e347
Showing
3 changed files
with
252 additions
and
9 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,244 @@ | ||
// 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. | ||
|
||
// Flags: --expose-wasm | ||
|
||
load("test/mjsunit/wasm/wasm-constants.js"); | ||
load("test/mjsunit/wasm/wasm-module-builder.js"); | ||
|
||
function addConstFunc(builder, val) { | ||
return builder.addFunction("const" + val, kSig_i_v) | ||
.addBody(wasmI32Const(val)).index; | ||
} | ||
|
||
function addSigs(builder, pad) { | ||
for (let i = 0; i < pad; i++) { | ||
let params = []; | ||
for (let j = 0; j < i; j++) params.push(kWasmF32); | ||
builder.addType(makeSig(params, [])); | ||
} | ||
|
||
return { i_v: builder.addType(kSig_i_v) }; | ||
} | ||
|
||
let kTableSize = 50; | ||
|
||
(function TestAliasedImportedTable() { | ||
print(arguments.callee.name); | ||
|
||
{ | ||
let builder = new WasmModuleBuilder(); | ||
let signums = addSigs(builder, 1); | ||
|
||
builder.addImportedTable("m", "table", kTableSize, kTableSize); | ||
let f15 = addConstFunc(builder, 15); | ||
let call = builder.addFunction("call", kSig_i_i) | ||
.addBody([ | ||
kExprGetLocal, 0, | ||
kExprCallIndirect, signums.i_v, kTableZero | ||
]) | ||
.exportAs("call"); | ||
let f17 = addConstFunc(builder, 17); | ||
builder.addExport("f15", f15); | ||
builder.addExport("f17", f17); | ||
builder.addFunctionTableInit(15, false, [f15], true); | ||
builder.addFunctionTableInit(1, false, [call.index], true); | ||
|
||
var mod1 = builder.toModule(); | ||
} | ||
|
||
{ | ||
let builder = new WasmModuleBuilder(); | ||
let signums = addSigs(builder, 5); // ensure different sigids | ||
|
||
builder.addImportedTable("m", "table", kTableSize, kTableSize); | ||
let f15 = builder.addImport("m", "f15", kSig_i_v); | ||
let f17 = builder.addImport("m", "f17", kSig_i_v); | ||
let f21 = addConstFunc(builder, 21); | ||
let call = builder.addFunction("call", kSig_i_i) | ||
.addBody([ | ||
kExprGetLocal, 0, | ||
kExprCallIndirect, signums.i_v, kTableZero | ||
]) | ||
.exportAs("call"); | ||
let f26 = addConstFunc(builder, 26); | ||
builder.addFunctionTableInit(17, false, [f17], true); | ||
builder.addFunctionTableInit(21, false, [f21], true); | ||
builder.addFunctionTableInit(26, false, [f26], true); | ||
builder.addFunctionTableInit(5, false, [call.index], true); | ||
|
||
var mod2 = builder.toModule(); | ||
} | ||
|
||
var table = new WebAssembly.Table({initial: kTableSize, | ||
maximum: kTableSize, element: "anyfunc"}); | ||
var i1 = new WebAssembly.Instance(mod1, {m: {table: table}}); | ||
|
||
var i2 = new WebAssembly.Instance(mod2, | ||
{m: {table: table, f15: i1.exports.f15, f17: i1.exports.f17}}); | ||
|
||
for (i of [15, 17, 21, 26]) { | ||
print(i); | ||
assertEquals(i, i1.exports.call(i)); | ||
assertEquals(i, i2.exports.call(i)); | ||
} | ||
for (i of [0, 1, 5, 16]) { | ||
assertThrows(() => i1.exports.call(i)); | ||
assertThrows(() => i2.exports.call(i)); | ||
} | ||
})(); | ||
|
||
function addConstFuncUsingGlobal(builder, val) { | ||
let g = builder.addGlobal(kWasmI32, false); | ||
g.init = val; | ||
return builder.addFunction("global" + val, kSig_i_v) | ||
.addBody([kExprGetGlobal, g.index]).index; | ||
} | ||
|
||
(function TestAliasedImportedTableInstanceGlobals() { | ||
print(arguments.callee.name); | ||
|
||
{ | ||
let builder = new WasmModuleBuilder(); | ||
let signums = addSigs(builder, 1); | ||
|
||
builder.addImportedTable("m", "table", kTableSize, kTableSize); | ||
let f14 = addConstFuncUsingGlobal(builder, 14); | ||
let call = builder.addFunction("call", kSig_i_i) | ||
.addBody([ | ||
kExprGetLocal, 0, | ||
kExprCallIndirect, signums.i_v, kTableZero | ||
]) | ||
.exportAs("call"); | ||
let f18 = addConstFuncUsingGlobal(builder, 18); | ||
builder.addExport("f14", f14); | ||
builder.addExport("f18", f18); | ||
builder.addFunctionTableInit(14, false, [f14], true); | ||
builder.addFunctionTableInit(1, false, [call.index], true); | ||
|
||
var mod1 = builder.toModule(); | ||
} | ||
|
||
{ | ||
let builder = new WasmModuleBuilder(); | ||
let signums = addSigs(builder, 3); // ensure different sigids | ||
|
||
builder.addImportedTable("m", "table", kTableSize, kTableSize); | ||
let f14 = builder.addImport("m", "f14", kSig_i_v); | ||
let f18 = builder.addImport("m", "f18", kSig_i_v); | ||
let f22 = addConstFuncUsingGlobal(builder, 22); | ||
let call = builder.addFunction("call", kSig_i_i) | ||
.addBody([ | ||
kExprGetLocal, 0, | ||
kExprCallIndirect, signums.i_v, kTableZero | ||
]) | ||
.exportAs("call"); | ||
let f28 = addConstFuncUsingGlobal(builder, 28); | ||
builder.addFunctionTableInit(18, false, [f18], true); | ||
builder.addFunctionTableInit(22, false, [f22], true); | ||
builder.addFunctionTableInit(28, false, [f28], true); | ||
builder.addFunctionTableInit(5, false, [call.index], true); | ||
|
||
var mod2 = builder.toModule(); | ||
} | ||
|
||
var table = new WebAssembly.Table({initial: kTableSize, | ||
maximum: kTableSize, element: "anyfunc"}); | ||
var i1 = new WebAssembly.Instance(mod1, {m: {table: table}}); | ||
|
||
var i2 = new WebAssembly.Instance(mod2, | ||
{m: {table: table, f14: i1.exports.f14, f18: i1.exports.f18}}); | ||
|
||
for (i of [14, 18, 22, 28]) { | ||
print(i); | ||
assertEquals(i, i1.exports.call(i)); | ||
assertEquals(i, i2.exports.call(i)); | ||
} | ||
for (i of [0, 1, 5, 16]) { | ||
assertThrows(() => i1.exports.call(i)); | ||
assertThrows(() => i2.exports.call(i)); | ||
} | ||
})(); | ||
|
||
|
||
function addConstFuncUsingMemory(builder, val) { | ||
var addr = builder.address; | ||
builder.address += 8; | ||
var bytes = [val & 0xff, (val>>8) & 0xff, (val>>16) & 0xff, (val>>24) & 0xff]; | ||
builder.addDataSegment(addr, bytes); | ||
return builder.addFunction("mem" + val, kSig_i_v) | ||
.addBody([ | ||
...wasmI32Const(addr), | ||
kExprI32LoadMem, 0, 0 | ||
]).index; | ||
} | ||
|
||
(function TestAliasedImportedTableInstanceMemories() { | ||
print(arguments.callee.name); | ||
|
||
{ | ||
let builder = new WasmModuleBuilder(); | ||
builder.address = 8; | ||
let signums = addSigs(builder, 1); | ||
|
||
builder.addMemory(1, 1, false); | ||
builder.addImportedTable("m", "table", kTableSize, kTableSize); | ||
let f13 = addConstFuncUsingMemory(builder, 13); | ||
let call = builder.addFunction("call", kSig_i_i) | ||
.addBody([ | ||
kExprGetLocal, 0, | ||
kExprCallIndirect, signums.i_v, kTableZero | ||
]) | ||
.exportAs("call"); | ||
let f19 = addConstFuncUsingMemory(builder, 19); | ||
builder.addExport("f13", f13); | ||
builder.addExport("f19", f19); | ||
builder.addFunctionTableInit(13, false, [f13], true); | ||
builder.addFunctionTableInit(1, false, [call.index], true); | ||
|
||
var mod1 = builder.toModule(); | ||
} | ||
|
||
{ | ||
let builder = new WasmModuleBuilder(); | ||
builder.address = 8; | ||
let signums = addSigs(builder, 4); // ensure different sigids | ||
|
||
builder.addMemory(1, 1, false); | ||
builder.addImportedTable("m", "table", kTableSize, kTableSize); | ||
let f13 = builder.addImport("m", "f13", kSig_i_v); | ||
let f19 = builder.addImport("m", "f19", kSig_i_v); | ||
let f23 = addConstFuncUsingMemory(builder, 23); | ||
let call = builder.addFunction("call", kSig_i_i) | ||
.addBody([ | ||
kExprGetLocal, 0, | ||
kExprCallIndirect, signums.i_v, kTableZero | ||
]) | ||
.exportAs("call"); | ||
let f29 = addConstFuncUsingMemory(builder, 29); | ||
builder.addFunctionTableInit(19, false, [f19], true); | ||
builder.addFunctionTableInit(23, false, [f23], true); | ||
builder.addFunctionTableInit(29, false, [f29], true); | ||
builder.addFunctionTableInit(5, false, [call.index], true); | ||
|
||
var mod2 = builder.toModule(); | ||
} | ||
|
||
var table = new WebAssembly.Table({initial: kTableSize, | ||
maximum: kTableSize, element: "anyfunc"}); | ||
var i1 = new WebAssembly.Instance(mod1, {m: {table: table}}); | ||
|
||
var i2 = new WebAssembly.Instance(mod2, | ||
{m: {table: table, f13: i1.exports.f13, f19: i1.exports.f19}}); | ||
|
||
for (i of [13, 19, 23, 29]) { | ||
print(i); | ||
assertEquals(i, i1.exports.call(i)); | ||
assertEquals(i, i2.exports.call(i)); | ||
} | ||
for (i of [0, 1, 5, 16]) { | ||
assertThrows(() => i1.exports.call(i)); | ||
assertThrows(() => i2.exports.call(i)); | ||
} | ||
})(); |