| Index: test/mjsunit/wasm/debug-disassembly.js
|
| diff --git a/test/mjsunit/wasm/debug-disassembly.js b/test/mjsunit/wasm/debug-disassembly.js
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..13b93cb29bf77cd96f4e23e6b2fa4ef8b0129ba9
|
| --- /dev/null
|
| +++ b/test/mjsunit/wasm/debug-disassembly.js
|
| @@ -0,0 +1,139 @@
|
| +// Copyright 2016 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 --expose-debug-as debug
|
| +
|
| +load("test/mjsunit/wasm/wasm-constants.js");
|
| +load("test/mjsunit/wasm/wasm-module-builder.js");
|
| +
|
| +Debug = debug.Debug
|
| +
|
| +// Initialized in setup().
|
| +var exception;
|
| +var break_count;
|
| +var num_wasm_scripts;
|
| +var module;
|
| +
|
| +function listener(event, exec_state, event_data, data) {
|
| + try {
|
| + if (event == Debug.DebugEvent.Break) {
|
| + ++break_count;
|
| + // Request frame details. This should trigger creation of the Script
|
| + // objects for all frames on the stack.
|
| + var num_frames = exec_state.frameCount();
|
| + for (var i = 0; i < num_frames; ++i) {
|
| + var frame = exec_state.frame(i);
|
| + var details = frame.details();
|
| + var script = details.script();
|
| + if (script.type == Debug.ScriptType.Wasm) {
|
| + var pos = frame.sourcePosition();
|
| + var name = script.nameOrSourceURL();
|
| + var disassembly = Debug.disassembleWasmFunction(script.id);
|
| + var offset_table = Debug.getWasmFunctionOffsetTable(script.id);
|
| + assertEquals(0, offset_table.length % 3);
|
| + var lineNr = null;
|
| + var columnNr = null;
|
| + for (var p = 0; p < offset_table.length; p += 3) {
|
| + if (offset_table[p] != pos) continue;
|
| + lineNr = offset_table[p+1];
|
| + columnNr = offset_table[p+2];
|
| + }
|
| + assertNotNull(lineNr, "position should occur in offset table");
|
| + assertNotNull(columnNr, "position should occur in offset table");
|
| + var line = disassembly.split("\n")[lineNr];
|
| + assertTrue(!!line, "line number must occur in disassembly");
|
| + assertTrue(line.length > columnNr, "column number must be valid");
|
| + var expected_string;
|
| + if (name.endsWith("/0")) {
|
| + // Function 0 calls the imported function.
|
| + expected_string = "kExprCallImport,";
|
| + } else if (name.endsWith("/1")) {
|
| + // Function 1 calls function 0.
|
| + expected_string = "kExprCallFunction,";
|
| + } else {
|
| + assertTrue(false, "Unexpected wasm script: " + name);
|
| + }
|
| + assertTrue(line.substr(columnNr).startsWith(expected_string),
|
| + "offset " + columnNr + " should start with '" + expected_string
|
| + + "': " + line);
|
| + }
|
| + }
|
| + } else if (event == Debug.DebugEvent.AfterCompile) {
|
| + var script = event_data.script();
|
| + if (script.scriptType() == Debug.ScriptType.Wasm) {
|
| + ++num_wasm_scripts;
|
| + }
|
| + }
|
| + } catch (e) {
|
| + print("exception: " + e);
|
| + exception = e;
|
| + }
|
| +};
|
| +
|
| +var builder = new WasmModuleBuilder();
|
| +
|
| +builder.addImport("func", kSig_v_v);
|
| +
|
| +builder.addFunction("call_import", kSig_v_v)
|
| + .addBody([kExprCallImport, kArity0, 0])
|
| + .exportFunc();
|
| +
|
| +// Add a bit of unneccessary code to increase the byte offset.
|
| +builder.addFunction("call_call_import", kSig_v_v)
|
| + .addLocals({i32_count: 2})
|
| + .addBody([
|
| + kExprI32Const, 27, kExprSetLocal, 0,
|
| + kExprI32Const, (-7 & 0x7f), kExprSetLocal, 1,
|
| + kExprGetLocal, 0, kExprGetLocal, 1, kExprI32Add, kExprI64UConvertI32,
|
| + kExprI64Const, 0,
|
| + kExprI64Ne, kExprIf,
|
| + kExprCallFunction, kArity0, 0,
|
| + kExprEnd
|
| + ])
|
| + .exportFunc();
|
| +
|
| +function call_debugger() {
|
| + debugger;
|
| +}
|
| +
|
| +function setup() {
|
| + module = builder.instantiate({func: call_debugger});
|
| + exception = null;
|
| + break_count = 0;
|
| + num_wasm_scripts = 0;
|
| +}
|
| +
|
| +(function testRegisteredWasmScripts1() {
|
| + setup();
|
| + Debug.setListener(listener);
|
| + // Initially 0 scripts.
|
| + assertEquals(0, num_wasm_scripts);
|
| + // Call the "call_import" function -> 1 script.
|
| + module.exports.call_import();
|
| + assertEquals(1, num_wasm_scripts);
|
| + // Call "call_import" again -> still just 1 script.
|
| + module.exports.call_import();
|
| + assertEquals(1, num_wasm_scripts);
|
| + // Call "call_call_import" -> now 2 scripts.
|
| + module.exports.call_call_import();
|
| + assertEquals(2, num_wasm_scripts);
|
| + Debug.setListener(null);
|
| +
|
| + assertEquals(3, break_count);
|
| + if (exception) throw exception;
|
| +})();
|
| +
|
| +(function testRegisteredWasmScripts2() {
|
| + setup();
|
| + Debug.setListener(listener);
|
| + // Initially 0 scripts.
|
| + assertEquals(0, num_wasm_scripts);
|
| + // Call the "call_call_import" function -> 2 scripts should be registered.
|
| + module.exports.call_call_import();
|
| + assertEquals(2, num_wasm_scripts);
|
| + Debug.setListener(null);
|
| +
|
| + assertEquals(1, break_count);
|
| + if (exception) throw exception;
|
| +})();
|
|
|