Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(679)

Unified Diff: test/mjsunit/wasm/debug-disassembly.js

Issue 2063013004: [wasm] Disassemble wasm code from script (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@wasm-frame-inspection
Patch Set: remove unimplemented wasm SetBreakPoint method Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/wasm/wasm-debug.cc ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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;
+})();
« no previous file with comments | « src/wasm/wasm-debug.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698