| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513 |
- /*
- * Copyright (C) 2019 Intel Corporation. All rights reserved.
- * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- */
- #ifndef _GC_EXPORT_H
- #define _GC_EXPORT_H
- #include "wasm_export.h"
- typedef uint8_t wasm_value_type_t;
- typedef enum wasm_value_type_enum {
- VALUE_TYPE_I32 = 0x7F,
- VALUE_TYPE_I64 = 0x7E,
- VALUE_TYPE_F32 = 0x7D,
- VALUE_TYPE_F64 = 0x7C,
- VALUE_TYPE_V128 = 0x7B,
- VALUE_TYPE_FUNCREF = 0x70,
- VALUE_TYPE_EXTERNREF = 0x6F,
- VALUE_TYPE_ANYREF = 0x6E,
- VALUE_TYPE_EQREF = 0x6D,
- VALUE_TYPE_HT_NULLABLE_REF = 0x6C,
- VALUE_TYPE_HT_NON_NULLABLE_REF = 0x6B,
- VALUE_TYPE_I31REF = 0x6A,
- VALUE_TYPE_NULLFUNCREF = 0x69,
- VALUE_TYPE_NULLEXTERNREF = 0x68,
- VALUE_TYPE_STRUCTREF = 0x67,
- VALUE_TYPE_ARRAYREF = 0x66,
- VALUE_TYPE_NULLREF = 0x65,
- } wasm_value_type_enum;
- typedef int32_t wasm_heap_type_t;
- enum wasm_heap_type_enum {
- HEAP_TYPE_FUNC = -0x10,
- HEAP_TYPE_EXTERN = -0x11,
- HEAP_TYPE_ANY = -0x12,
- HEAP_TYPE_EQ = -0x13,
- HEAP_TYPE_I31 = -0x16,
- HEAP_TYPE_NOFUNC = -0x17,
- HEAP_TYPE_NOEXTERN = -0x18,
- HEAP_TYPE_STRUCT = -0x19,
- HEAP_TYPE_ARRAY = -0x1A,
- HEAP_TYPE_NONE = -0x1B
- } wasm_heap_type_enum;
- struct WASMObject;
- typedef struct WASMObject *wasm_obj_t;
- #ifndef WASM_VALUE_DEFINED
- #define WASM_VALUE_DEFINED
- typedef union V128 {
- int8_t i8x16[16];
- int16_t i16x8[8];
- int32_t i32x8[4];
- int64_t i64x2[2];
- float f32x4[4];
- double f64x2[2];
- } V128;
- typedef union WASMValue {
- int32_t i32;
- uint32_t u32;
- uint32_t global_index;
- uint32_t ref_index;
- int64_t i64;
- uint64_t u64;
- float f32;
- double f64;
- V128 v128;
- wasm_obj_t *gc_obj;
- uint32_t type_index;
- struct {
- uint32_t type_index;
- uint32_t N;
- } array_new_canon_fixed;
- } WASMValue;
- #endif /* end of WASM_VALUE_DEFINED */
- typedef union WASMValue wasm_value_t;
- /* Reference type, the layout is same as WasmRefType in wasm.h */
- typedef struct wasm_ref_type_t {
- wasm_value_type_t value_type;
- bool nullable;
- int32_t heap_type;
- } wasm_ref_type_t;
- /**
- * Local object reference that can be traced when GC occurs. All
- * native functions that need to hold WASM objects which may not be
- * referenced from other elements of GC root set may be hold with
- * this type of variable so that they can be traced when GC occurs.
- * Before using such a variable, it must be pushed onto the stack
- * (implemented as a chain) of such variables, and before leaving the
- * frame of the variables, they must be popped from the stack.
- */
- typedef struct WASMLocalObjectRef {
- /* Previous local object reference variable on the stack */
- struct WASMLocalObjectRef *prev;
- /* The reference of WASM object hold by this variable */
- wasm_obj_t val;
- } WASMLocalObjectRef, wasm_local_obj_ref_t;
- struct WASMType;
- struct WASMFuncType;
- struct WASMStructType;
- struct WASMArrayType;
- typedef struct WASMType *wasm_defined_type_t;
- typedef struct WASMFuncType *wasm_func_type_t;
- typedef struct WASMStructType *wasm_struct_type_t;
- typedef struct WASMArrayType *wasm_array_type_t;
- struct WASMExternrefObject;
- struct WASMAnyrefObject;
- struct WASMStructObject;
- struct WASMArrayObject;
- struct WASMFuncObject;
- typedef struct WASMExternrefObject *wasm_externref_obj_t;
- typedef struct WASMAnyrefObject *wasm_anyref_obj_t;
- typedef struct WASMStructObject *wasm_struct_obj_t;
- typedef struct WASMArrayObject *wasm_array_obj_t;
- typedef struct WASMFuncObject *wasm_func_obj_t;
- typedef uintptr_t wasm_i31_obj_t;
- /* Defined type related operations */
- /**
- * Get the defined type count of a WASM module
- */
- WASM_RUNTIME_API_EXTERN uint32_t
- wasm_get_defined_type_count(const wasm_module_t module);
- /**
- * Get the specified defined type of a WASM module
- */
- WASM_RUNTIME_API_EXTERN wasm_defined_type_t
- wasm_get_defined_type(const wasm_module_t module, uint32_t index);
- /**
- * Check whether a defined type is a function type
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_defined_type_is_func_type(const wasm_defined_type_t def_type);
- /**
- * Check whether a defined type is a struct type
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_defined_type_is_struct_type(const wasm_defined_type_t def_type);
- /**
- * Check whether a defined type is an array type
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_defined_type_is_array_type(const wasm_defined_type_t def_type);
- /**
- * Get parameter count of a function type
- */
- WASM_RUNTIME_API_EXTERN uint32_t
- wasm_func_type_get_param_count(const wasm_func_type_t func_type);
- /**
- * Get type of a specified parameter of a function type
- */
- WASM_RUNTIME_API_EXTERN wasm_ref_type_t
- wasm_func_type_get_param_type(const wasm_func_type_t func_type,
- uint32_t param_idx);
- /**
- * Get result count of a function type
- */
- WASM_RUNTIME_API_EXTERN uint32_t
- wasm_func_type_get_result_count(const wasm_func_type_t func_type);
- /**
- * Get type of a specified result of a function type
- */
- WASM_RUNTIME_API_EXTERN wasm_ref_type_t
- wasm_func_type_get_result_type(const wasm_func_type_t func_type,
- uint32_t result_idx);
- /**
- * Get field count of a struct type
- */
- WASM_RUNTIME_API_EXTERN uint32_t
- wasm_struct_type_get_field_count(const wasm_struct_type_t struct_type);
- /**
- * Get type of a specified field of a struct type
- */
- WASM_RUNTIME_API_EXTERN wasm_ref_type_t
- wasm_struct_type_get_field_type(const wasm_struct_type_t struct_type,
- uint32_t field_idx, bool *p_is_mutable);
- /**
- * Get element type of an array type
- */
- WASM_RUNTIME_API_EXTERN wasm_ref_type_t
- wasm_array_type_get_elem_type(const wasm_array_type_t array_type,
- bool *p_is_mutable);
- /**
- * Check whether two defined types are equal
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_defined_type_equal(const wasm_defined_type_t def_type1,
- const wasm_defined_type_t def_type2,
- const wasm_module_t module);
- /**
- * Check whether def_type1 is subtype of def_type2
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_defined_type_is_subtype_of(const wasm_defined_type_t def_type1,
- const wasm_defined_type_t def_type2,
- const wasm_module_t module);
- /* ref type related operations */
- /**
- * Set the ref_type to be (ref null? type_idx)
- */
- WASM_RUNTIME_API_EXTERN void
- wasm_ref_type_set_type_idx(wasm_ref_type_t *ref_type, bool nullable,
- int32_t type_idx);
- /**
- * Set the ref_type to be (ref null? func/extern/any/eq/i31/struct/array/..)
- */
- WASM_RUNTIME_API_EXTERN void
- wasm_ref_type_set_heap_type(wasm_ref_type_t *ref_type, bool nullable,
- int32_t heap_type);
- /**
- * Check whether two ref types are equal
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_ref_type_equal(const wasm_ref_type_t *ref_type1,
- const wasm_ref_type_t *ref_type2,
- const wasm_module_t module);
- /**
- * Check whether ref_type1 is subtype of ref_type2
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_ref_type_is_subtype_of(const wasm_ref_type_t *ref_type1,
- const wasm_ref_type_t *ref_type2,
- const wasm_module_t module);
- /* wasm object related operations */
- /**
- * Create a struct object with the index of defined type
- */
- WASM_RUNTIME_API_EXTERN wasm_struct_obj_t
- wasm_struct_obj_new_with_typeidx(wasm_exec_env_t exec_env, uint32_t type_idx);
- /**
- * Create a struct object with the struct type
- */
- WASM_RUNTIME_API_EXTERN wasm_struct_obj_t
- wasm_struct_obj_new_with_type(wasm_exec_env_t exec_env,
- const wasm_struct_type_t type);
- /**
- * Set the field value of a struct object
- */
- WASM_RUNTIME_API_EXTERN void
- wasm_struct_obj_set_field(wasm_struct_obj_t obj, uint32_t field_idx,
- const wasm_value_t *value);
- /**
- * Get the field value of a struct object
- */
- WASM_RUNTIME_API_EXTERN void
- wasm_struct_obj_get_field(const wasm_struct_obj_t obj, uint32_t field_idx,
- bool sign_extend, wasm_value_t *value);
- /**
- * Create an array object with the index of defined type
- */
- WASM_RUNTIME_API_EXTERN wasm_array_obj_t
- wasm_array_obj_new_with_typeidx(wasm_exec_env_t exec_env, uint32_t type_idx);
- /**
- * Create an array object with the array type
- */
- WASM_RUNTIME_API_EXTERN wasm_array_obj_t
- wasm_array_obj_new_with_type(wasm_exec_env_t exec_env,
- const wasm_array_type_t type);
- /**
- * Set the specified element's value of an array object
- */
- WASM_RUNTIME_API_EXTERN void
- wasm_array_obj_set_elem(wasm_array_obj_t array_obj, uint32_t elem_idx,
- const wasm_value_t *value);
- /**
- * Get the specified element's value of an array object
- */
- WASM_RUNTIME_API_EXTERN void
- wasm_array_obj_get_elem(const wasm_array_obj_t array_obj, uint32_t elem_idx,
- bool sign_extend, wasm_value_t *value);
- /**
- * Copy elements from one array to another
- */
- WASM_RUNTIME_API_EXTERN void
- wasm_array_obj_copy(wasm_array_obj_t dst_obj, uint32_t dst_idx,
- const wasm_array_obj_t src_obj, uint32_t src_idx,
- uint32_t len);
- /**
- * Return the length of an array object
- */
- WASM_RUNTIME_API_EXTERN uint32_t
- wasm_array_obj_length(const wasm_array_obj_t array_obj);
- /**
- * Get the address of the first element of an array object
- */
- WASM_RUNTIME_API_EXTERN void *
- wasm_array_obj_first_elem_addr(const wasm_array_obj_t array_obj);
- /**
- * Get the address of the i-th element of an array object
- */
- WASM_RUNTIME_API_EXTERN void *
- wasm_array_obj_elem_addr(const wasm_array_obj_t array_obj, uint32_t elem_idx);
- /**
- * Create a function object with the index of defined type
- */
- WASM_RUNTIME_API_EXTERN wasm_func_obj_t
- wasm_func_obj_new_with_typeidx(wasm_exec_env_t exec_env, uint32_t type_idx);
- /**
- * Create a function object with the function type
- */
- WASM_RUNTIME_API_EXTERN wasm_func_obj_t
- wasm_func_obj_new_with_type(wasm_exec_env_t exec_env, wasm_func_type_t type);
- /**
- * Get the function index bound of a function object
- */
- WASM_RUNTIME_API_EXTERN uint32_t
- wasm_func_obj_get_func_idx_bound(const wasm_func_obj_t func_obj);
- /**
- * Get the function type of a function object
- */
- WASM_RUNTIME_API_EXTERN wasm_func_type_t
- wasm_func_obj_get_func_type(const wasm_func_obj_t func_obj);
- /**
- * Create an externref object with host object
- */
- WASM_RUNTIME_API_EXTERN wasm_externref_obj_t
- wasm_externref_obj_new(wasm_exec_env_t exec_env, const void *host_obj);
- /**
- * Get the host value of an externref object
- */
- WASM_RUNTIME_API_EXTERN const void *
- wasm_externref_obj_get_value(const wasm_externref_obj_t externref_obj);
- /**
- * Create an anyref object with host object
- */
- WASM_RUNTIME_API_EXTERN wasm_anyref_obj_t
- wasm_anyref_obj_new(wasm_exec_env_t exec_env, const void *host_obj);
- /**
- * Get the host object value of an anyref object
- */
- WASM_RUNTIME_API_EXTERN const void *
- wasm_anyref_obj_get_value(const wasm_anyref_obj_t anyref_obj);
- /**
- * Get the internal object inside the externref object, same as
- * the operation of opcode extern.internalize
- */
- WASM_RUNTIME_API_EXTERN wasm_obj_t
- wasm_externref_obj_to_internal_obj(const wasm_externref_obj_t externref_obj);
- /**
- * Create an externref object from an internal object, same as
- * the operation of opcode extern.externalize
- */
- WASM_RUNTIME_API_EXTERN wasm_externref_obj_t
- wasm_internal_obj_to_externref_obj(wasm_exec_env_t exec_env,
- const wasm_obj_t internal_obj);
- /**
- * Create an i31 object
- */
- WASM_RUNTIME_API_EXTERN wasm_i31_obj_t
- wasm_i31_obj_new(uint32_t i31_value);
- WASM_RUNTIME_API_EXTERN uint32_t
- wasm_i31_obj_get_value(wasm_i31_obj_t i31_obj, bool sign_extend);
- /**
- * Pin an object to make it traced during GC
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_runtime_pin_object(wasm_exec_env_t exec_env, wasm_obj_t obj);
- /**
- * Unpin an object
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_runtime_unpin_object(wasm_exec_env_t exec_env, wasm_obj_t obj);
- /**
- * Check whether an object is a struct object
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_obj_is_struct_obj(const wasm_obj_t obj);
- /**
- * Check whether an object is an array object
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_obj_is_array_obj(const wasm_obj_t obj);
- /**
- * Check whether an object is a function object
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_obj_is_func_obj(const wasm_obj_t obj);
- /**
- * Check whether an object is an i31 object
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_obj_is_i31_obj(const wasm_obj_t obj);
- /**
- * Check whether an object is an externref object
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_obj_is_externref_obj(const wasm_obj_t obj);
- /**
- * Check whether an object is an anyref object
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_obj_is_anyref_obj(const wasm_obj_t obj);
- /**
- * Check whether an object is a struct object, or, an i31/struct/array object
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_obj_is_internal_obj(const wasm_obj_t obj);
- /**
- * Check whether an object is an eq object
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_obj_is_eq_obj(const wasm_obj_t obj);
- /**
- * Check whether an object is an instance of a defined type
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_obj_is_instance_of_defined_type(const wasm_obj_t obj,
- const wasm_defined_type_t defined_type,
- const wasm_module_t module);
- /**
- * Check whether an object is an instance of a defined type with
- * index type_idx
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_obj_is_instance_of_type_idx(const wasm_obj_t obj, uint32_t type_idx,
- const wasm_module_t module);
- /**
- * Check whether an object is an instance of a ref type
- */
- WASM_RUNTIME_API_EXTERN bool
- wasm_obj_is_instance_of_ref_type(const wasm_obj_t obj,
- const wasm_ref_type_t *ref_type);
- /**
- * Push a local object ref into stack, note that we should set its value
- * after pushing to retain it during GC, and should pop it from stack
- * before returning from the current function
- */
- WASM_RUNTIME_API_EXTERN void
- wasm_runtime_push_local_object_ref(wasm_exec_env_t exec_env,
- wasm_local_obj_ref_t *local_obj_ref);
- /**
- * Pop a local object ref from stack
- */
- WASM_RUNTIME_API_EXTERN wasm_local_obj_ref_t *
- wasm_runtime_pop_local_object_ref(wasm_exec_env_t exec_env);
- /**
- * Pop n local object refs from stack
- */
- WASM_RUNTIME_API_EXTERN void
- wasm_runtime_pop_local_object_refs(wasm_exec_env_t exec_env, uint32_t n);
- #endif /* end of _GC_EXPORT_H */
|