Documentation ¶
Overview ¶
Package exec provides functions for executing WebAssembly bytecode.
Index ¶
- Constants
- Variables
- func GetCaller(engine *ExecutionEngine) (bool, error)
- func GetCodeHash(engine *ExecutionEngine) (bool, error)
- type Args
- type EnvCall
- type ExecutionEngine
- func (e *ExecutionEngine) Call(caller common.Address, code, input []byte) (returnbytes []byte, er error)
- func (e *ExecutionEngine) CallInf(caller common.Address, code []byte, input []interface{}, message []interface{}) ([]byte, error)
- func (e *ExecutionEngine) Create(caller common.Address, code []byte) ([]byte, error)
- func (e *ExecutionEngine) GetMemory() *memory.VMmemory
- func (e *ExecutionEngine) GetVM() *VM
- func (e *ExecutionEngine) RestoreVM() error
- func (e *ExecutionEngine) SetNewVM(vm *VM) error
- type InteropService
- func (i *InteropService) Exists(name string) bool
- func (i *InteropService) GetServiceMap() map[string]func(*ExecutionEngine) (bool, error)
- func (i *InteropService) Invoke(methodName string, engine *ExecutionEngine) (bool, error)
- func (i *InteropService) MergeMap(mMap map[string]func(*ExecutionEngine) (bool, error)) bool
- func (i *InteropService) Register(name string, handler func(*ExecutionEngine) (bool, error)) bool
- type InteropServiceInterface
- type InvalidFunctionIndexError
- type InvalidReturnTypeError
- type Param
- type Result
- type VM
- func (vm *VM) CallContract(module *wasm.Module, methodName string, args ...uint64) (uint64, error)
- func (vm *VM) CallProductContract(module *wasm.Module, actionName []byte, arg []byte) (uint64, error)
- func (vm *VM) ExecCode(insideCall bool, fnIndex int64, args ...uint64) (interface{}, error)
- func (vm *VM) GetEnvCall() *EnvCall
- func (vm *VM) GetMemory() *memory.VMmemory
- func (vm *VM) GetMessageBytes() ([]byte, error)
- func (vm *VM) GetPointerMemSize(addr uint64) int
- func (vm *VM) GetPointerMemory(addr uint64) ([]byte, error)
- func (vm *VM) Malloc(size int) (int, error)
- func (vm *VM) MallocPointer(size int, ptype memory.PType) (int, error)
- func (vm *VM) Memory() []byte
- func (vm *VM) PushResult(res uint64)
- func (vm *VM) RestoreCtx() bool
- func (vm *VM) SetMemory(val interface{}) (int, error)
- func (vm *VM) SetMessage(message []interface{})
- func (vm *VM) SetPointerMemory(val interface{}) (int, error)
- func (vm *VM) SetStructMemory(val interface{}) (int, error)
Constants ¶
const ( CONTRACT_METHOD_NAME = "invoke" PARAM_SPLITER = "|" VM_STACK_DEPTH = 10 )
Variables ¶
var ( // ErrSignatureMismatch is the error value used while trapping the VM when // a signature mismatch between the table entry and the type entry is found // in a call_indirect operation. ErrSignatureMismatch = errors.New("exec: signature mismatch in call_indirect") // ErrUndefinedElementIndex is the error value used while trapping the VM when // an invalid index to the module's table space is used as an operand to // call_indirect ErrUndefinedElementIndex = errors.New("exec: undefined element index") )
var ( // ErrMultipleLinearMemories is returned by (*VM).NewVM when the module // has more then one entries in the linear memory space. ErrMultipleLinearMemories = errors.New("exec: more than one linear memories in module") // ErrInvalidArgumentCount is returned by (*VM).ExecCode when an invalid // number of arguments to the WebAssembly function are passed to it. ErrInvalidArgumentCount = errors.New("exec: invalid number of arguments to function") )
var ErrOutOfBoundsMemoryAccess = errors.New("exec: out of bounds memory access")
ErrOutOfBoundsMemoryAccess is the error value used while trapping the VM when it detects an out of bounds access to the linear memory.
var ErrUnreachable = errors.New("exec: reached unreachable")
ErrUnreachable is the error value used while trapping the VM when an unreachable operator is reached during execution.
Functions ¶
func GetCaller ¶
func GetCaller(engine *ExecutionEngine) (bool, error)
func GetCodeHash ¶
func GetCodeHash(engine *ExecutionEngine) (bool, error)
Types ¶
type EnvCall ¶
type EnvCall struct { Message []interface{} //the 'Message' field is for the EOS contract like parameters // contains filtered or unexported fields }
store env call message
func (*EnvCall) GetReturns ¶
type ExecutionEngine ¶
type ExecutionEngine struct {
// contains filtered or unexported fields
}
func NewExecutionEngine ¶
func NewExecutionEngine(container interfaces.CodeContainer, crypto interfaces.Crypto, table interfaces.CodeTable, service InteropServiceInterface, ver string) *ExecutionEngine
todo add parameters
func (*ExecutionEngine) Call ¶
func (e *ExecutionEngine) Call(caller common.Address, code, input []byte) (returnbytes []byte, er error)
the input format should be "methodname | args"
func (*ExecutionEngine) CallInf ¶
func (e *ExecutionEngine) CallInf(caller common.Address, code []byte, input []interface{}, message []interface{}) ([]byte, error)
use this method just for test
func (*ExecutionEngine) GetMemory ¶
func (e *ExecutionEngine) GetMemory() *memory.VMmemory
func (*ExecutionEngine) GetVM ¶
func (e *ExecutionEngine) GetVM() *VM
func (*ExecutionEngine) RestoreVM ¶
func (e *ExecutionEngine) RestoreVM() error
for call other contract, 1.pop stored vm 2.reset vm
func (*ExecutionEngine) SetNewVM ¶
func (e *ExecutionEngine) SetNewVM(vm *VM) error
for call other contract, 1.store current vm 2.load new vm
type InteropService ¶
type InteropService struct {
// contains filtered or unexported fields
}
func NewInteropService ¶
func NewInteropService() *InteropService
func (*InteropService) Exists ¶
func (i *InteropService) Exists(name string) bool
func (*InteropService) GetServiceMap ¶
func (i *InteropService) GetServiceMap() map[string]func(*ExecutionEngine) (bool, error)
func (*InteropService) Invoke ¶
func (i *InteropService) Invoke(methodName string, engine *ExecutionEngine) (bool, error)
func (*InteropService) MergeMap ¶
func (i *InteropService) MergeMap(mMap map[string]func(*ExecutionEngine) (bool, error)) bool
func (*InteropService) Register ¶
func (i *InteropService) Register(name string, handler func(*ExecutionEngine) (bool, error)) bool
type InteropServiceInterface ¶
type InteropServiceInterface interface { Register(method string, handler func(*ExecutionEngine) (bool, error)) bool GetServiceMap() map[string]func(*ExecutionEngine) (bool, error) }
type InvalidFunctionIndexError ¶
type InvalidFunctionIndexError int64
InvalidFunctionIndexError is returned by (*VM).ExecCode when the function index provided is invalid.
func (InvalidFunctionIndexError) Error ¶
func (e InvalidFunctionIndexError) Error() string
type InvalidReturnTypeError ¶
type InvalidReturnTypeError int8
InvalidReturnTypeError is returned by (*VM).ExecCode when the module specifies an invalid return type value for the executed function.
func (InvalidReturnTypeError) Error ¶
func (e InvalidReturnTypeError) Error() string
type VM ¶
type VM struct { Services map[string]func(engine *ExecutionEngine) (bool, error) //store a engine pointer CodeHash common.Address Caller common.Address Engine *ExecutionEngine // contains filtered or unexported fields }
VM is the execution context for executing WebAssembly bytecode.
func NewVM ¶
NewVM creates a new VM from a given module. If the module defines a start function, it will be executed.
func (*VM) CallContract ¶
todo implement the "call other contract function" this is for the "test" version call
func (*VM) CallProductContract ¶
func (vm *VM) CallProductContract(module *wasm.Module, actionName []byte, arg []byte) (uint64, error)
start a new vm
func (*VM) ExecCode ¶
ExecCode calls the function with the given index and arguments. fnIndex should be a valid index into the function index space of the VM's module. insideCall :true (call contract)
func (*VM) GetEnvCall ¶
func (*VM) GetMessageBytes ¶
func (*VM) GetPointerMemSize ¶
func (*VM) GetPointerMemory ¶
when wasm returns a pointer, call this function to get the pointed memory
func (*VM) MallocPointer ¶
alloc memory for pointer and return the first index
func (*VM) PushResult ¶
func (*VM) RestoreCtx ¶
func (*VM) SetPointerMemory ¶
alloc memory for any pointer type
func (*VM) SetStructMemory ¶
alloc memory for struct todo move to the SetPointerMemory
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
internal
|
|
compile
Package compile is used internally by wagon to convert standard structured WebAssembly bytecode into an unstructured form suitable for execution by it's VM.
|
Package compile is used internally by wagon to convert standard structured WebAssembly bytecode into an unstructured form suitable for execution by it's VM. |