| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036 |
- /*
- * Copyright (C) 2019 Intel Corporation. All rights reserved.
- * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- */
- #ifndef _WASM_RUNTIME_H
- #define _WASM_RUNTIME_H
- #include "wasm.h"
- #include "bh_atomic.h"
- #include "bh_bitmap.h"
- #include "bh_hashmap.h"
- #include "../common/wasm_runtime_common.h"
- #include "../common/wasm_exec_env.h"
- #ifdef __cplusplus
- extern "C" {
- #endif
- #define EXCEPTION_BUF_LEN 128
- typedef struct WASMModuleInstance WASMModuleInstance;
- typedef struct WASMFunctionInstance WASMFunctionInstance;
- typedef struct WASMMemoryInstance WASMMemoryInstance;
- typedef struct WASMTableInstance WASMTableInstance;
- typedef struct WASMGlobalInstance WASMGlobalInstance;
- #if WASM_ENABLE_TAGS != 0
- typedef struct WASMTagInstance WASMTagInstance;
- #endif
- /**
- * When LLVM JIT, WAMR compiler or AOT is enabled, we should ensure that
- * some offsets of the same field in the interpreter module instance and
- * aot module instance are the same, so that the LLVM JITed/AOTed code
- * can smoothly access the interpreter module instance.
- * Same for the memory instance and table instance.
- * We use the macro DefPointer to define some related pointer fields.
- */
- #if (WASM_ENABLE_JIT != 0 || WASM_ENABLE_WAMR_COMPILER != 0 \
- || WASM_ENABLE_AOT != 0) \
- && UINTPTR_MAX == UINT32_MAX
- /* Add u32 padding if LLVM JIT, WAMR compiler or AOT is enabled on
- 32-bit platform */
- #define DefPointer(type, field) \
- type field; \
- uint32 field##_padding
- #else
- #define DefPointer(type, field) type field
- #endif
- typedef enum WASMExceptionID {
- EXCE_UNREACHABLE = 0,
- EXCE_OUT_OF_MEMORY,
- EXCE_OUT_OF_BOUNDS_MEMORY_ACCESS,
- EXCE_INTEGER_OVERFLOW,
- EXCE_INTEGER_DIVIDE_BY_ZERO,
- EXCE_INVALID_CONVERSION_TO_INTEGER,
- EXCE_INVALID_FUNCTION_TYPE_INDEX,
- EXCE_INVALID_FUNCTION_INDEX,
- EXCE_UNDEFINED_ELEMENT,
- EXCE_UNINITIALIZED_ELEMENT,
- EXCE_CALL_UNLINKED_IMPORT_FUNC,
- EXCE_NATIVE_STACK_OVERFLOW,
- EXCE_UNALIGNED_ATOMIC,
- EXCE_AUX_STACK_OVERFLOW,
- EXCE_AUX_STACK_UNDERFLOW,
- EXCE_OUT_OF_BOUNDS_TABLE_ACCESS,
- EXCE_OPERAND_STACK_OVERFLOW,
- EXCE_FAILED_TO_COMPILE_FAST_JIT_FUNC,
- /* GC related exceptions */
- EXCE_NULL_FUNC_OBJ,
- EXCE_NULL_STRUCT_OBJ,
- EXCE_NULL_ARRAY_OBJ,
- EXCE_NULL_I31_OBJ,
- EXCE_NULL_REFERENCE,
- EXCE_FAILED_TO_CREATE_RTT_TYPE,
- EXCE_FAILED_TO_CREATE_STRUCT_OBJ,
- EXCE_FAILED_TO_CREATE_ARRAY_OBJ,
- EXCE_FAILED_TO_CREATE_EXTERNREF_OBJ,
- EXCE_CAST_FAILURE,
- EXCE_ARRAY_IDX_OOB,
- EXCE_FAILED_TO_CREATE_STRING,
- EXCE_FAILED_TO_CREATE_STRINGREF,
- EXCE_FAILED_TO_CREATE_STRINGVIEW,
- EXCE_FAILED_TO_ENCODE_STRING,
- EXCE_ALREADY_THROWN,
- EXCE_NUM,
- } WASMExceptionID;
- typedef union {
- uint64 u64;
- uint32 u32[2];
- } MemBound;
- typedef struct WASMSharedHeap {
- struct WASMSharedHeap *next;
- void *heap_handle;
- uint8 *base_addr;
- uint64 size;
- uint64 start_off_mem64;
- uint64 start_off_mem32;
- } WASMSharedHeap;
- struct WASMMemoryInstance {
- /* Module type */
- uint32 module_type;
- /* Whether the memory is shared */
- uint8 is_shared_memory;
- /* Whether the memory has 64-bit memory addresses */
- uint8 is_memory64;
- /* Reference count of the memory instance:
- 0: non-shared memory, > 0: shared memory */
- bh_atomic_16_t ref_count;
- /* Four-byte paddings to ensure the layout of WASMMemoryInstance is the same
- * in both 64-bit and 32-bit */
- uint8 _paddings[4];
- /* Number bytes per page */
- uint32 num_bytes_per_page;
- /* Current page count */
- uint32 cur_page_count;
- /* Maximum page count */
- uint32 max_page_count;
- /* Memory data size */
- uint64 memory_data_size;
- /**
- * Memory data begin address, Note:
- * the app-heap might be inserted in to the linear memory,
- * when memory is re-allocated, the heap data and memory data
- * must be copied to new memory also
- */
- DefPointer(uint8 *, memory_data);
- /* Memory data end address */
- DefPointer(uint8 *, memory_data_end);
- /* Heap data base address */
- DefPointer(uint8 *, heap_data);
- /* Heap data end address */
- DefPointer(uint8 *, heap_data_end);
- /* The heap created */
- DefPointer(void *, heap_handle);
- /* TODO: use it to replace the g_shared_memory_lock */
- DefPointer(korp_mutex *, memory_lock);
- #if WASM_ENABLE_FAST_JIT != 0 || WASM_ENABLE_JIT != 0 \
- || WASM_ENABLE_WAMR_COMPILER != 0 || WASM_ENABLE_AOT != 0
- MemBound mem_bound_check_1byte;
- MemBound mem_bound_check_2bytes;
- MemBound mem_bound_check_4bytes;
- MemBound mem_bound_check_8bytes;
- MemBound mem_bound_check_16bytes;
- #endif
- };
- /* WASMTableInstance is used to represent table instance in
- * runtime, to compute the table element address with index
- * we need to know the element type and the element ref type.
- * For pointer type, it's 32-bit or 64-bit, align up to 8 bytes
- * to simplify the computation.
- * And each struct member should be 4-byte or 8-byte aligned.
- */
- struct WASMTableInstance {
- /* The element type */
- uint8 elem_type;
- /* TODO: may not used in AOTTableInstance */
- uint8 is_table64;
- uint8 __padding__[6];
- union {
- #if WASM_ENABLE_GC != 0
- WASMRefType *elem_ref_type;
- #endif
- uint64 __padding__;
- } elem_ref_type;
- /* Current size */
- uint32 cur_size;
- /* Maximum size */
- uint32 max_size;
- /* Table elements */
- /*
- * if imported tables, it is table_elem_type_t[0][cur_size]
- * if local tables, it is table_elem_type_t[cur_size]
- */
- table_elem_type_t elems[1];
- };
- struct WASMGlobalInstance {
- /* value type, VALUE_TYPE_I32/I64/F32/F64 */
- uint8 type;
- /* mutable or constant */
- bool is_mutable;
- /* data offset to the address of initial_value, started from the end of
- * WASMMemoryInstance(start of WASMGlobalInstance)*/
- uint32 data_offset;
- /*
- * initial value (before instantiation stage)
- * - host creation. store initial value directly. no init expr
- * - as a temp value before storing in global_data
- */
- WASMValue initial_value;
- /* just for import, keep the reference here */
- DefPointer(WASMModuleInstance *, import_module_inst);
- DefPointer(WASMGlobalInstance *, import_global_inst);
- /* WASMRefType *ref_type */
- DefPointer(void *, ref_type);
- };
- struct WASMFunctionInstance {
- /* whether it is import function or WASM function */
- bool is_import_func;
- /* parameter count */
- uint16 param_count;
- /* local variable count, 0 for import function */
- uint16 local_count;
- /* cell num of parameters */
- uint16 param_cell_num;
- /* cell num of return type */
- uint16 ret_cell_num;
- /* cell num of local variables, 0 for import function */
- uint16 local_cell_num;
- #if WASM_ENABLE_FAST_INTERP != 0
- /* cell num of consts */
- uint16 const_cell_num;
- #endif
- uint16 *local_offsets;
- /* parameter types */
- uint8 *param_types;
- /* local types, NULL for import function */
- uint8 *local_types;
- union {
- /* setup by wasm_native */
- WASMFunctionImport *func_import;
- /* local bytecode */
- WASMFunction *func;
- } u;
- /* from other .wasm */
- WASMModuleInstance *import_module_inst;
- WASMFunctionInstance *import_func_inst;
- /* copy it from WASMFunctionImport */
- bool call_conv_raw;
- /* write it from wasm_c_api */
- bool call_conv_wasm_c_api;
- /* WASMModuleInstance collects it to form c_api_func_imports */
- CApiFuncImport import_func_c_api;
- #if WASM_ENABLE_PERF_PROFILING != 0
- /* total execution time */
- uint64 total_exec_time;
- /* total execution count */
- uint32 total_exec_cnt;
- /* children execution time */
- uint64 children_exec_time;
- #endif
- };
- #if WASM_ENABLE_TAGS != 0
- struct WASMTagInstance {
- bool is_import_tag;
- /* tag attribute */
- uint8 attribute;
- /* tag type index */
- uint32 type;
- union {
- WASMTagImport *tag_import;
- WASMTag *tag;
- } u;
- #if WASM_ENABLE_MULTI_MODULE != 0
- WASMModuleInstance *import_module_inst;
- WASMTagInstance *import_tag_inst;
- #endif
- };
- #endif
- #if WASM_ENABLE_EXCE_HANDLING != 0
- #define INVALID_TAGINDEX ((uint32)0xFFFFFFFF)
- #define SET_INVALID_TAGINDEX(tag) (tag = INVALID_TAGINDEX)
- #define IS_INVALID_TAGINDEX(tag) ((tag & INVALID_TAGINDEX) == INVALID_TAGINDEX)
- #endif
- typedef struct WASMExportFuncInstance {
- char *name;
- WASMFunctionInstance *function;
- } WASMExportFuncInstance;
- typedef struct WASMExportGlobInstance {
- char *name;
- WASMGlobalInstance *global;
- } WASMExportGlobInstance;
- typedef struct WASMExportTabInstance {
- char *name;
- WASMTableInstance *table;
- } WASMExportTabInstance;
- typedef struct WASMExportMemInstance {
- char *name;
- WASMMemoryInstance *memory;
- } WASMExportMemInstance;
- #if WASM_ENABLE_TAGS != 0
- typedef struct WASMExportTagInstance {
- char *name;
- WASMTagInstance *tag;
- } WASMExportTagInstance;
- #endif
- /* The common part of WASMModuleInstanceExtra and AOTModuleInstanceExtra */
- typedef struct WASMModuleInstanceExtraCommon {
- #if WASM_ENABLE_MODULE_INST_CONTEXT != 0
- void *contexts[WASM_MAX_INSTANCE_CONTEXTS];
- #endif
- #if WASM_CONFIGURABLE_BOUNDS_CHECKS != 0
- /* Disable bounds checks or not */
- bool disable_bounds_checks;
- #endif
- #if WASM_ENABLE_BULK_MEMORY != 0
- bh_bitmap *data_dropped;
- #endif
- #if WASM_ENABLE_REF_TYPES != 0
- bh_bitmap *elem_dropped;
- #endif
- #if WASM_ENABLE_GC != 0
- /* The gc heap memory pool */
- uint8 *gc_heap_pool;
- /* The gc heap created */
- void *gc_heap_handle;
- #endif
- } WASMModuleInstanceExtraCommon;
- /* Extra info of WASM module instance for interpreter/jit mode */
- typedef struct WASMModuleInstanceExtra {
- WASMModuleInstanceExtraCommon common;
- WASMGlobalInstance *globals;
- WASMFunctionInstance *functions;
- uint32 global_count;
- uint32 function_count;
- WASMFunctionInstance *start_function;
- WASMFunctionInstance *malloc_function;
- WASMFunctionInstance *free_function;
- WASMFunctionInstance *retain_function;
- RunningMode running_mode;
- #if WASM_ENABLE_MULTI_MODULE != 0
- bh_list sub_module_inst_list_head;
- bh_list *sub_module_inst_list;
- /* linked table instances of import table instances */
- WASMTableInstance **table_insts_linked;
- #endif
- #if WASM_ENABLE_TAGS != 0
- uint32 tag_count;
- uint32 export_tag_count;
- WASMTagInstance *tags;
- WASMExportTagInstance *export_tags;
- void **import_tag_ptrs;
- #endif
- #if WASM_ENABLE_MEMORY_PROFILING != 0
- uint32 max_aux_stack_used;
- #endif
- #if WASM_ENABLE_SHARED_HEAP != 0
- WASMSharedHeap *shared_heap;
- #if WASM_ENABLE_JIT != 0
- /*
- * Adjusted shared heap based addr to simple the calculation
- * in the aot code. The value is:
- * shared_heap->base_addr - shared_heap->start_off
- */
- uint8 *shared_heap_base_addr_adj;
- MemBound shared_heap_start_off;
- #endif
- #endif
- #if WASM_ENABLE_DEBUG_INTERP != 0 \
- || (WASM_ENABLE_FAST_JIT != 0 && WASM_ENABLE_JIT != 0 \
- && WASM_ENABLE_LAZY_JIT != 0)
- WASMModuleInstance *next;
- #endif
- } WASMModuleInstanceExtra;
- struct AOTFuncPerfProfInfo;
- struct WASMModuleInstance {
- /* Module instance type, for module instance loaded from
- WASM bytecode binary, this field is Wasm_Module_Bytecode;
- for module instance loaded from AOT file, this field is
- Wasm_Module_AoT, and this structure should be treated as
- AOTModuleInstance structure. */
- uint32 module_type;
- uint32 memory_count;
- DefPointer(WASMMemoryInstance **, memories);
- /* global and table info */
- uint32 global_data_size;
- uint32 table_count;
- DefPointer(uint8 *, global_data);
- /* For AOTModuleInstance, it denotes `AOTTableInstance *` */
- DefPointer(WASMTableInstance **, tables);
- /* import func ptrs + llvm jit func ptrs */
- DefPointer(void **, func_ptrs);
- /* function type indexes */
- DefPointer(uint32 *, func_type_indexes);
- uint32 export_func_count;
- uint32 export_global_count;
- uint32 export_memory_count;
- uint32 export_table_count;
- /* For AOTModuleInstance, it denotes `AOTFunctionInstance *` */
- DefPointer(WASMExportFuncInstance *, export_functions);
- DefPointer(WASMExportGlobInstance *, export_globals);
- DefPointer(WASMExportMemInstance *, export_memories);
- DefPointer(WASMExportTabInstance *, export_tables);
- /* The exception buffer of wasm interpreter for current thread. */
- char cur_exception[EXCEPTION_BUF_LEN];
- /* The WASM module or AOT module, for AOTModuleInstance,
- it denotes `AOTModule *` */
- DefPointer(WASMModule *, module);
- DefPointer(WASMExecEnv *, exec_env_singleton);
- /*
- * TODO: is able to be removed.
- * interp and fast-jit can use func_ptrs instead of this.
- */
- /* Array of function pointers to import functions,
- not available in AOTModuleInstance */
- DefPointer(void **, import_func_ptrs);
- /* Array of function pointers to fast jit functions,
- not available in AOTModuleInstance:
- Only when the multi-tier JIT macros are all enabled and the running
- mode of current module instance is set to Mode_Fast_JIT, runtime
- will allocate new memory for it, otherwise it always points to the
- module->fast_jit_func_ptrs */
- DefPointer(void **, fast_jit_func_ptrs);
- /* The custom data that can be set/get by wasm_{get|set}_custom_data */
- DefPointer(void *, custom_data);
- /* Stack frames, used in call stack dump and perf profiling */
- DefPointer(Vector *, frames);
- /* Function performance profiling info list, only available
- in AOTModuleInstance */
- DefPointer(struct AOTFuncPerfProfInfo *, func_perf_profilings);
- DefPointer(CApiFuncImport *, c_api_func_imports);
- /* Pointer to the exec env currently used */
- DefPointer(WASMExecEnv *, cur_exec_env);
- /* WASM/AOT module extra info, for AOTModuleInstance,
- it denotes `AOTModuleInstanceExtra *` */
- DefPointer(WASMModuleInstanceExtra *, e);
- /* Default WASM operand stack size */
- uint32 default_wasm_stack_size;
- uint32 reserved[7];
- /*
- * +------------------------------+ <-- memories
- * | WASMMemoryInstance[mem_count], mem_count is always 1 for LLVM JIT/AOT
- * +------------------------------+ <-- global_data
- * | global data
- * +------------------------------+ <-- tables
- * | WASMTableInstance[table_count]
- * +------------------------------+ <-- e
- * | WASMModuleInstanceExtra
- * +------------------------------+
- */
- union {
- uint64 _make_it_8_byte_aligned_;
- WASMMemoryInstance memory_instances[1];
- uint8 bytes[1];
- } global_table_data;
- };
- struct WASMInterpFrame;
- typedef struct WASMInterpFrame WASMRuntimeFrame;
- /**
- * Return the code block of a function.
- *
- * @param func the WASM function instance
- *
- * @return the code block of the function
- */
- static inline uint8 *
- wasm_get_func_code(WASMFunctionInstance *func)
- {
- #if WASM_ENABLE_FAST_INTERP == 0
- return func->is_import_func ? NULL : func->u.func->code;
- #else
- return func->is_import_func ? NULL : func->u.func->code_compiled;
- #endif
- }
- /**
- * Return the code block end of a function.
- *
- * @param func the WASM function instance
- *
- * @return the code block end of the function
- */
- static inline uint8 *
- wasm_get_func_code_end(WASMFunctionInstance *func)
- {
- #if WASM_ENABLE_FAST_INTERP == 0
- return func->is_import_func ? NULL
- : func->u.func->code + func->u.func->code_size;
- #else
- return func->is_import_func
- ? NULL
- : func->u.func->code_compiled + func->u.func->code_compiled_size;
- #endif
- }
- static inline table_elem_type_t *
- wasm_locate_table_elems(const WASMModule *module, WASMTableInstance *table,
- uint32 table_index)
- {
- #if WASM_ENABLE_MULTI_MODULE == 0
- if (table_index < module->import_table_count) {
- table_elem_type_t **table_elems =
- (table_elem_type_t **)(uintptr_t)table->elems;
- return *table_elems;
- }
- #endif
- return table->elems;
- }
- static inline WASMFunctionInstance *
- wasm_locate_function_instance(const WASMModuleInstance *module_inst,
- uint32 func_idx)
- {
- WASMModuleInstanceExtra *e = (WASMModuleInstanceExtra *)module_inst->e;
- WASMFunctionInstance *func = e->functions + func_idx;
- return func;
- }
- static inline uint32
- wasm_calc_function_index(const WASMModuleInstance *module_inst,
- const WASMFunctionInstance *func)
- {
- return (uint32)(func
- - ((WASMModuleInstanceExtra *)module_inst->e)->functions);
- }
- static inline uint32
- wasm_get_tbl_data_slots(const WASMTableType *table_type,
- const WASMTableImport *import_type)
- {
- #if WASM_ENABLE_MULTI_MODULE != 0
- if (import_type) {
- if (import_type->import_module) {
- /* linked with other modules */
- return table_type->max_size;
- }
- /* else linked with built-ins */
- }
- return table_type->max_size;
- #else
- /* in order to save memory, alloc resource as few as possible */
- return table_type->possible_grow ? table_type->max_size
- : table_type->init_size;
- #endif
- }
- static inline uint8 *
- get_global_addr(uint8 *global_data, WASMGlobalInstance *global)
- {
- /*
- * global->import_global_inst != NULL means the global is imported
- * from another module.
- * global->import_module_isnt != NULL means the data is stored in
- * local module instance.
- *
- * A host created global doesn't have its own global_data need to
- * be maintained.
- */
- return global->import_module_inst
- ? global->import_module_inst->global_data
- + global->import_global_inst->data_offset
- : global_data + global->data_offset;
- }
- WASMModule *
- wasm_load(uint8 *buf, uint32 size,
- #if WASM_ENABLE_MULTI_MODULE != 0
- bool main_module,
- #endif
- const LoadArgs *args, char *error_buf, uint32 error_buf_size);
- WASMModule *
- wasm_load_from_sections(WASMSection *section_list, char *error_buf,
- uint32 error_buf_size);
- void
- wasm_unload(WASMModule *module);
- bool
- wasm_resolve_symbols(WASMModule *module);
- bool
- wasm_resolve_import_func(const WASMModule *module,
- WASMFunctionImport *function);
- WASMModuleInstance *
- wasm_instantiate(WASMModule *module, WASMModuleInstance *parent,
- WASMExecEnv *exec_env_main, uint32 stack_size,
- uint32 heap_size, uint32 max_memory_pages,
- const WASMExternInstance *imports, uint32 import_count,
- char *error_buf, uint32 error_buf_size);
- void
- wasm_dump_perf_profiling(const WASMModuleInstance *module_inst);
- double
- wasm_summarize_wasm_execute_time(const WASMModuleInstance *inst);
- double
- wasm_get_wasm_func_exec_time(const WASMModuleInstance *inst,
- const char *func_name);
- void
- wasm_deinstantiate(WASMModuleInstance *module_inst, bool is_spawned);
- bool
- wasm_set_running_mode(WASMModuleInstance *module_inst,
- RunningMode running_mode);
- WASMMemoryInstance *
- wasm_create_memory(const WASMModule *module, const WASMMemoryType *type);
- WASMFunctionInstance *
- wasm_lookup_function(const WASMModuleInstance *module_inst, const char *name);
- WASMMemoryInstance *
- wasm_lookup_memory(const WASMModuleInstance *module_inst, const char *name);
- #if WASM_ENABLE_MULTI_MODULE != 0
- WASMGlobalInstance *
- wasm_lookup_global(const WASMModuleInstance *module_inst, const char *name);
- WASMTableInstance *
- wasm_lookup_table(const WASMModuleInstance *module_inst, const char *name);
- #if WASM_ENABLE_TAGS != 0
- WASMTagInstance *
- wasm_lookup_tag(const WASMModuleInstance *module_inst, const char *name,
- const char *signature);
- #endif
- #endif /* WASM_ENABLE_MULTI_MODULE != 0 */
- void
- wasm_destroy_memory(WASMMemoryInstance *memory);
- bool
- wasm_call_function(WASMExecEnv *exec_env, WASMFunctionInstance *function,
- unsigned argc, uint32 argv[]);
- void
- wasm_set_exception(WASMModuleInstance *module, const char *exception);
- void
- wasm_set_exception_with_id(WASMModuleInstance *module_inst, uint32 id);
- const char *
- wasm_get_exception(WASMModuleInstance *module);
- /**
- * @brief Copy exception in buffer passed as parameter. Thread-safe version of
- * `wasm_get_exception()`
- * @note Buffer size must be no smaller than EXCEPTION_BUF_LEN
- * @return true if exception found
- */
- bool
- wasm_copy_exception(WASMModuleInstance *module_inst, char *exception_buf);
- uint64
- wasm_module_malloc_internal(WASMModuleInstance *module_inst,
- WASMExecEnv *exec_env, uint64 size,
- void **p_native_addr);
- uint64
- wasm_module_realloc_internal(WASMModuleInstance *module_inst,
- WASMExecEnv *exec_env, uint64 ptr, uint64 size,
- void **p_native_addr);
- void
- wasm_module_free_internal(WASMModuleInstance *module_inst,
- WASMExecEnv *exec_env, uint64 ptr);
- uint64
- wasm_module_malloc(WASMModuleInstance *module_inst, uint64 size,
- void **p_native_addr);
- uint64
- wasm_module_realloc(WASMModuleInstance *module_inst, uint64 ptr, uint64 size,
- void **p_native_addr);
- void
- wasm_module_free(WASMModuleInstance *module_inst, uint64 ptr);
- uint64
- wasm_module_dup_data(WASMModuleInstance *module_inst, const char *src,
- uint64 size);
- /**
- * Check whether the app address and the buf is inside the linear memory,
- * and convert the app address into native address
- */
- bool
- wasm_check_app_addr_and_convert(WASMModuleInstance *module_inst, bool is_str,
- uint64 app_buf_addr, uint64 app_buf_size,
- void **p_native_addr);
- WASMMemoryInstance *
- wasm_get_default_memory(WASMModuleInstance *module_inst);
- WASMMemoryInstance *
- wasm_get_memory_with_idx(WASMModuleInstance *module_inst, uint32 index);
- bool
- wasm_enlarge_memory(WASMModuleInstance *module_inst, uint32 inc_page_count);
- bool
- wasm_enlarge_memory_with_idx(WASMModuleInstance *module_inst,
- uint32 inc_page_count, uint32 memidx);
- bool
- wasm_call_indirect(WASMExecEnv *exec_env, uint32 tbl_idx, uint32 elem_idx,
- uint32 argc, uint32 argv[]);
- #if WASM_ENABLE_THREAD_MGR != 0
- bool
- wasm_set_aux_stack(WASMExecEnv *exec_env, uint64 start_offset, uint32 size);
- bool
- wasm_get_aux_stack(WASMExecEnv *exec_env, uint64 *start_offset, uint32 *size);
- #endif
- void
- wasm_get_module_mem_consumption(const WASMModule *module,
- WASMModuleMemConsumption *mem_conspn);
- void
- wasm_get_module_inst_mem_consumption(const WASMModuleInstance *module,
- WASMModuleInstMemConsumption *mem_conspn);
- #if WASM_ENABLE_REF_TYPES != 0 || WASM_ENABLE_GC != 0
- static inline bool
- wasm_elem_is_active(uint32 mode)
- {
- return (mode & 0x1) == 0x0;
- }
- static inline bool
- wasm_elem_is_passive(uint32 mode)
- {
- return (mode & 0x1) == 0x1;
- }
- static inline bool
- wasm_elem_is_declarative(uint32 mode)
- {
- return (mode & 0x3) == 0x3;
- }
- bool
- wasm_enlarge_table(WASMModuleInstance *module_inst, uint32 table_idx,
- uint32 inc_entries, table_elem_type_t init_val);
- #endif /* WASM_ENABLE_REF_TYPES != 0 || WASM_ENABLE_GC != 0 */
- #if WASM_ENABLE_GC != 0
- void *
- wasm_create_func_obj(WASMModuleInstance *module_inst, uint32 func_idx,
- bool throw_exce, char *error_buf, uint32 error_buf_size);
- bool
- wasm_traverse_gc_rootset(WASMExecEnv *exec_env, void *heap);
- #endif
- static inline WASMTableInstance *
- wasm_get_table_inst(const WASMModuleInstance *module_inst, uint32 tbl_idx)
- {
- /* careful, it might be a table in another module */
- WASMTableInstance *tbl_inst = module_inst->tables[tbl_idx];
- #if WASM_ENABLE_MULTI_MODULE != 0
- if (tbl_idx < module_inst->module->import_table_count
- && module_inst->e->table_insts_linked[tbl_idx]) {
- tbl_inst = module_inst->e->table_insts_linked[tbl_idx];
- }
- #endif
- bh_assert(tbl_inst);
- return tbl_inst;
- }
- #if WASM_ENABLE_DUMP_CALL_STACK != 0
- bool
- wasm_interp_create_call_stack(struct WASMExecEnv *exec_env);
- /**
- * @brief Dump wasm call stack or get the size
- *
- * @param exec_env the execution environment
- * @param print whether to print to stdout or not
- * @param buf buffer to store the dumped content
- * @param len length of the buffer
- *
- * @return when print is true, return the bytes printed out to stdout; when
- * print is false and buf is NULL, return the size required to store the
- * callstack content; when print is false and buf is not NULL, return the size
- * dumped to the buffer, 0 means error and data in buf may be invalid
- */
- uint32
- wasm_interp_dump_call_stack(struct WASMExecEnv *exec_env, bool print, char *buf,
- uint32 len);
- #endif
- const uint8 *
- wasm_loader_get_custom_section(WASMModule *module, const char *name,
- uint32 *len);
- #if WASM_ENABLE_FAST_JIT != 0 || WASM_ENABLE_JIT != 0 \
- || WASM_ENABLE_WAMR_COMPILER != 0
- void
- jit_set_exception_with_id(WASMModuleInstance *module_inst, uint32 id);
- /**
- * Check whether the app address and the buf is inside the linear memory,
- * and convert the app address into native address
- */
- bool
- jit_check_app_addr_and_convert(WASMModuleInstance *module_inst, bool is_str,
- uint64 app_buf_addr, uint64 app_buf_size,
- void **p_native_addr);
- #endif /* end of WASM_ENABLE_FAST_JIT != 0 || WASM_ENABLE_JIT != 0 \
- || WASM_ENABLE_WAMR_COMPILER != 0 */
- #if WASM_ENABLE_FAST_JIT != 0
- bool
- fast_jit_call_indirect(WASMExecEnv *exec_env, uint32 tbl_idx, uint32 elem_idx,
- uint32 type_idx, uint32 argc, uint32 *argv);
- bool
- fast_jit_invoke_native(WASMExecEnv *exec_env, uint32 func_idx,
- struct WASMInterpFrame *prev_frame);
- #endif
- #if WASM_ENABLE_JIT != 0 || WASM_ENABLE_WAMR_COMPILER != 0
- bool
- llvm_jit_call_indirect(WASMExecEnv *exec_env, uint32 tbl_idx, uint32 elem_idx,
- uint32 argc, uint32 *argv);
- bool
- llvm_jit_invoke_native(WASMExecEnv *exec_env, uint32 func_idx, uint32 argc,
- uint32 *argv);
- #if WASM_ENABLE_BULK_MEMORY != 0
- bool
- llvm_jit_memory_init(WASMModuleInstance *module_inst, uint32 seg_index,
- uint32 offset, uint32 len, size_t dst);
- bool
- llvm_jit_data_drop(WASMModuleInstance *module_inst, uint32 seg_index);
- #endif
- #if WASM_ENABLE_REF_TYPES != 0
- void
- llvm_jit_drop_table_seg(WASMModuleInstance *module_inst, uint32 tbl_seg_idx);
- void
- llvm_jit_table_init(WASMModuleInstance *module_inst, uint32 tbl_idx,
- uint32 tbl_seg_idx, uint32 length, uint32 src_offset,
- uint32 dst_offset);
- void
- llvm_jit_table_copy(WASMModuleInstance *module_inst, uint32 src_tbl_idx,
- uint32 dst_tbl_idx, uint32 length, uint32 src_offset,
- uint32 dst_offset);
- void
- llvm_jit_table_fill(WASMModuleInstance *module_inst, uint32 tbl_idx,
- uint32 length, uintptr_t val, uint32 data_offset);
- uint32
- llvm_jit_table_grow(WASMModuleInstance *module_inst, uint32 tbl_idx,
- uint32 inc_entries, uintptr_t init_val);
- #endif
- #if WASM_ENABLE_DUMP_CALL_STACK != 0 || WASM_ENABLE_PERF_PROFILING != 0 \
- || WASM_ENABLE_AOT_STACK_FRAME != 0
- bool
- llvm_jit_alloc_frame(WASMExecEnv *exec_env, uint32 func_index);
- void
- llvm_jit_free_frame(WASMExecEnv *exec_env);
- void
- llvm_jit_frame_update_profile_info(WASMExecEnv *exec_env, bool alloc_frame);
- #endif
- #if WASM_ENABLE_GC != 0
- void *
- llvm_jit_create_func_obj(WASMModuleInstance *module_inst, uint32 func_idx,
- bool throw_exce, char *error_buf,
- uint32 error_buf_size);
- bool
- llvm_jit_obj_is_instance_of(WASMModuleInstance *module_inst,
- WASMObjectRef gc_obj, uint32 type_index);
- /* Whether func type1 is one of super types of func type2 */
- bool
- llvm_jit_func_type_is_super_of(WASMModuleInstance *module_inst,
- uint32 type_idx1, uint32 type_idx2);
- WASMRttTypeRef
- llvm_jit_rtt_type_new(WASMModuleInstance *module_inst, uint32 type_index);
- bool
- llvm_array_init_with_data(WASMModuleInstance *module_inst, uint32 seg_index,
- uint32 data_seg_offset, WASMArrayObjectRef array_obj,
- uint32 elem_size, uint32 array_len);
- #endif
- #endif /* end of WASM_ENABLE_JIT != 0 || WASM_ENABLE_WAMR_COMPILER != 0 */
- #if WASM_ENABLE_LIBC_WASI != 0 && WASM_ENABLE_MULTI_MODULE != 0
- void
- wasm_propagate_wasi_args(WASMModule *module);
- #endif
- #if WASM_ENABLE_THREAD_MGR != 0
- void
- exception_lock(WASMModuleInstance *module_inst);
- void
- exception_unlock(WASMModuleInstance *module_inst);
- #else
- #define exception_lock(module_inst) (void)(module_inst)
- #define exception_unlock(module_inst) (void)(module_inst)
- #endif
- bool
- wasm_check_utf8_str(const uint8 *str, uint32 len);
- char *
- wasm_const_str_list_insert(const uint8 *str, uint32 len, WASMModule *module,
- bool is_load_from_file_buf, char *error_buf,
- uint32 error_buf_size);
- bool
- wasm_set_module_name(WASMModule *module, const char *name, char *error_buf,
- uint32_t error_buf_size);
- const char *
- wasm_get_module_name(WASMModule *module);
- #if WASM_ENABLE_LIB_WASI_THREADS != 0 || WASM_ENABLE_THREAD_MGR != 0
- int32
- wasm_inherit_imports(WASMModule *module, WASMModuleInstance *inst,
- WASMExternInstance *out, uint32 out_len);
- void
- wasm_disinherit_imports(WASMModule *module, WASMExternInstance *imports,
- uint32 import_count);
- #endif /* WASM_ENABLE_LIB_WASI_THREADS != 0 || WASM_ENABLE_THREAD_MGR != 0 */
- WASMTableInstance *
- wasm_create_table(const WASMModule *module, const WASMTableType *type);
- bool
- wasm_set_table_elem(const WASMModule *module, WASMTableInstance *table,
- uint32 index, uint32 func_idx);
- void
- wasm_destroy_table(WASMTableInstance *table);
- WASMGlobalInstance *
- wasm_create_global(const WASMModule *module, WASMModuleInstance *dep_inst,
- WASMGlobalType *type);
- void
- wasm_set_global_value(WASMGlobalInstance *global, const WASMValue *value);
- void
- wasm_destroy_global(WASMGlobalInstance *global);
- WASMFunctionInstance *
- wasm_create_function_empty(const WASMModule *module);
- void
- wasm_destroy_function(WASMFunctionInstance *function);
- static inline void
- wasm_function_import_from_wasm(WASMFunctionInstance *func,
- WASMModuleInstance *dep_inst,
- WASMFunctionInstance *dep_func)
- {
- func->import_module_inst = dep_inst;
- func->import_func_inst = dep_func;
- }
- static inline void
- wasm_function_import_from_c_api(WASMFunctionInstance *func,
- CApiFuncImport *c_api_func_import)
- {
- func->import_func_c_api = *c_api_func_import;
- }
- /*might be unused*/
- static inline void
- wasm_function_import_from_native(WASMFunctionInstance *func, void *callback)
- {
- func->u.func_import->func_ptr_linked = callback;
- }
- #ifdef __cplusplus
- }
- #endif
- #endif /* end of _WASM_RUNTIME_H */
|