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; |
+})(); |