1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- /*
- * Copyright (c) 2021, Ali Mohammad Pur <mpfard@serenityos.org>
- *
- * SPDX-License-Identifier: BSD-2-Clause
- */
- #pragma once
- #include <LibWasm/AbstractMachine/AbstractMachine.h>
- namespace Wasm {
- class Configuration {
- public:
- explicit Configuration(Store& store)
- : m_store(store)
- {
- }
- Optional<Label> nth_label(size_t);
- void set_frame(Frame&& frame)
- {
- m_current_frame_index = m_stack.size();
- Label label(frame.arity(), frame.expression().instructions().size());
- m_stack.push(move(frame));
- m_stack.push(label);
- }
- auto& frame() const { return m_stack.entries()[m_current_frame_index].get<Frame>(); }
- auto& frame() { return m_stack.entries()[m_current_frame_index].get<Frame>(); }
- auto& ip() const { return m_ip; }
- auto& ip() { return m_ip; }
- auto& depth() const { return m_depth; }
- auto& depth() { return m_depth; }
- auto& stack() const { return m_stack; }
- auto& stack() { return m_stack; }
- auto& store() const { return m_store; }
- auto& store() { return m_store; }
- struct CallFrameHandle {
- explicit CallFrameHandle(Configuration& configuration)
- : frame_index(configuration.m_current_frame_index)
- , stack_size(configuration.m_stack.size())
- , ip(configuration.ip())
- , configuration(configuration)
- {
- configuration.depth()++;
- }
- ~CallFrameHandle()
- {
- configuration.unwind({}, *this);
- }
- size_t frame_index { 0 };
- size_t stack_size { 0 };
- InstructionPointer ip { 0 };
- Configuration& configuration;
- };
- void unwind(Badge<CallFrameHandle>, const CallFrameHandle&);
- Result call(Interpreter&, FunctionAddress, Vector<Value> arguments);
- Result execute(Interpreter&);
- void dump_stack();
- private:
- Store& m_store;
- size_t m_current_frame_index { 0 };
- Stack m_stack;
- size_t m_depth { 0 };
- InstructionPointer m_ip;
- };
- }
|