Index: src/wasm/wasm-interpreter.h |
diff --git a/src/wasm/wasm-interpreter.h b/src/wasm/wasm-interpreter.h |
index 1f6e2a76139fcdde12946840f32017ae9fbf802a..91b592c0c1bafcd8e8a69c82fa1f4aad041185d6 100644 |
--- a/src/wasm/wasm-interpreter.h |
+++ b/src/wasm/wasm-interpreter.h |
@@ -28,7 +28,15 @@ |
const pc_t kInvalidPc = 0x80000000; |
-typedef ZoneMap<pc_t, pcdiff_t> ControlTransferMap; |
+// Visible for testing. A {ControlTransfer} helps the interpreter figure out |
+// the target program counter and stack manipulations for a branch. |
+struct ControlTransfer { |
+ enum StackAction { kNoAction, kPopAndRepush, kPushVoid }; |
+ pcdiff_t pcdiff; // adjustment to the program counter (positive or negative). |
+ spdiff_t spdiff; // number of elements to pop off the stack. |
+ StackAction action; // action to perform on the stack. |
+}; |
+typedef ZoneMap<pc_t, ControlTransfer> ControlTransferMap; |
// Macro for defining union members. |
#define FOREACH_UNION_MEMBER(V) \ |
@@ -124,7 +132,7 @@ |
virtual int GetFrameCount() = 0; |
virtual const WasmFrame* GetFrame(int index) = 0; |
virtual WasmFrame* GetMutableFrame(int index) = 0; |
- virtual WasmVal GetReturnValue(int index = 0) = 0; |
+ virtual WasmVal GetReturnValue() = 0; |
// Thread-specific breakpoints. |
bool SetBreakpoint(const WasmFunction* function, int pc, bool enabled); |
@@ -181,8 +189,9 @@ |
bool SetFunctionCodeForTesting(const WasmFunction* function, |
const byte* start, const byte* end); |
- // Computes the control transfers for the given bytecode. Used internally in |
- // the interpreter, but exposed for testing. |
+ // Computes the control targets for the given bytecode as {pc offset, sp |
+ // offset} |
+ // pairs. Used internally in the interpreter, but exposed for testing. |
static ControlTransferMap ComputeControlTransfersForTesting(Zone* zone, |
const byte* start, |
const byte* end); |