mirror of
https://github.com/bytecodealliance/wasm-micro-runtime.git
synced 2024-11-26 23:42:05 +00:00
2.1 KiB
2.1 KiB
Wasm Function
Internal data structure
Module level data (function)
WASMModule: Data structure created for loading a module.
WASMImport *import_functions
: initialized from the Wasm file function sectionWASMImport *import_functions
: initialized from the Wasm file import section. The runtime will try to solve the imports from the native API registration, refer to Export native API to WASM application.
WASMFunction: represent a Wasm function located in Wasm file code section. Track the links to the compiled function body.
WASMImport: represent a imported Wasm function which can be a solved as a native function or another Wasm module exported function.
Instance level data (function)
WASMModuleInstance: Data structure created for instantiating a module
WASMModuleInstanceExtra::functions
: combined the imported and internal functions into single array of structureWASMFunctionInstance
WASMModuleInstance::import_func_ptrs
: pointer array for solved function imports. This array is referred during calling imported native function. Note it is initialzed with the module level solved imports, but may points to different native function later due to c-api calls.
Execution paths
Interpreter:
-
Execute internal bytecode function:
WASMModuleInstance::e -> WASMModuleInstanceExtra::functions[..] -> WASMFunctionInstance::func -> WASMFunction::code
-
Execute imported function from other module:
WASMModuleInstance::e -> WASMModuleInstanceExtra::functions[..] (WASMFunctionInstance flag indicates an import) -> WASMFunctionInstance::import_func_inst -> WASMModuleInstance(second)::func -> WASMFunction (second module)::code
-
Execute imported native function:
WASMModuleInstance::e -> WASMModuleInstanceExtra::functions[..] (flag indicates imported native) WASMModuleInstance::import_func_ptrs[..] -> native function