Refactor APIs and data structures as preliminary work for Memory64 (#3209)
# Change the data type representing linear memory address from u32 to u64
## APIs signature changes
- (Export)wasm_runtime_module_malloc
- wasm_module_malloc
- wasm_module_malloc_internal
- aot_module_malloc
- aot_module_malloc_internal
- wasm_runtime_module_realloc
- wasm_module_realloc
- wasm_module_realloc_internal
- aot_module_realloc
- aot_module_realloc_internal
- (Export)wasm_runtime_module_free
- wasm_module_free
- wasm_module_free_internal
- aot_module_malloc
- aot_module_free_internal
- (Export)wasm_runtime_module_dup_data
- wasm_module_dup_data
- aot_module_dup_data
- (Export)wasm_runtime_validate_app_addr
- (Export)wasm_runtime_validate_app_str_addr
- (Export)wasm_runtime_validate_native_addr
- (Export)wasm_runtime_addr_app_to_native
- (Export)wasm_runtime_addr_native_to_app
- (Export)wasm_runtime_get_app_addr_range
- aot_set_aux_stack
- aot_get_aux_stack
- wasm_set_aux_stack
- wasm_get_aux_stack
- aot_check_app_addr_and_convert, wasm_check_app_addr_and_convert
and jit_check_app_addr_and_convert
- wasm_exec_env_set_aux_stack
- wasm_exec_env_get_aux_stack
- wasm_cluster_create_thread
- wasm_cluster_allocate_aux_stack
- wasm_cluster_free_aux_stack
## Data structure changes
- WASMModule and AOTModule
- field aux_data_end, aux_heap_base and aux_stack_bottom
- WASMExecEnv
- field aux_stack_boundary and aux_stack_bottom
- AOTCompData
- field aux_data_end, aux_heap_base and aux_stack_bottom
- WASMMemoryInstance(AOTMemoryInstance)
- field memory_data_size and change __padding to is_memory64
- WASMModuleInstMemConsumption
- field total_size and memories_size
- WASMDebugExecutionMemory
- field start_offset and current_pos
- WASMCluster
- field stack_tops
## Components that are affected by the APIs and data structure changes
- libc-builtin
- libc-emcc
- libc-uvwasi
- libc-wasi
- Python and Go Language Embedding
- Interpreter Debug engine
- Multi-thread: lib-pthread, wasi-threads and thread manager
This commit is contained in:
@ -1167,8 +1167,8 @@ check_app_addr_and_convert(AOTCompContext *comp_ctx, AOTFuncContext *func_ctx,
|
||||
/* prepare function type of aot_check_app_addr_and_convert */
|
||||
func_param_types[0] = comp_ctx->aot_inst_type; /* module_inst */
|
||||
func_param_types[1] = INT8_TYPE; /* is_str_arg */
|
||||
func_param_types[2] = I32_TYPE; /* app_offset */
|
||||
func_param_types[3] = I32_TYPE; /* buf_size */
|
||||
func_param_types[2] = I64_TYPE; /* app_offset */
|
||||
func_param_types[3] = I64_TYPE; /* buf_size */
|
||||
func_param_types[4] =
|
||||
comp_ctx->basic_types.int8_pptr_type; /* p_native_addr */
|
||||
if (!(func_type =
|
||||
@ -1555,7 +1555,19 @@ aot_compile_op_call(AOTCompContext *comp_ctx, AOTFuncContext *func_ctx,
|
||||
if (signature[i + 2] == '~')
|
||||
native_addr_size = param_values[i + 2];
|
||||
else
|
||||
native_addr_size = I32_ONE;
|
||||
native_addr_size = I64_CONST(1);
|
||||
if (!(native_addr_size = LLVMBuildZExtOrBitCast(
|
||||
comp_ctx->builder, native_addr_size, I64_TYPE,
|
||||
"native_addr_size_i64"))) {
|
||||
aot_set_last_error("llvm build zextOrBitCast failed.");
|
||||
goto fail;
|
||||
}
|
||||
if (!(param_values[j] = LLVMBuildZExtOrBitCast(
|
||||
comp_ctx->builder, param_values[j], I64_TYPE,
|
||||
"native_addr_i64"))) {
|
||||
aot_set_last_error("llvm build zextOrBitCast failed.");
|
||||
goto fail;
|
||||
}
|
||||
if (!check_app_addr_and_convert(
|
||||
comp_ctx, func_ctx, false, param_values[j],
|
||||
native_addr_size, &native_addr)) {
|
||||
@ -1564,7 +1576,13 @@ aot_compile_op_call(AOTCompContext *comp_ctx, AOTFuncContext *func_ctx,
|
||||
param_values[j] = native_addr;
|
||||
}
|
||||
else if (signature[i + 1] == '$') {
|
||||
native_addr_size = I32_ZERO;
|
||||
native_addr_size = I64_ZERO;
|
||||
if (!(param_values[j] = LLVMBuildZExtOrBitCast(
|
||||
comp_ctx->builder, param_values[j], I64_TYPE,
|
||||
"native_addr_i64"))) {
|
||||
aot_set_last_error("llvm build zextOrBitCast failed.");
|
||||
goto fail;
|
||||
}
|
||||
if (!check_app_addr_and_convert(
|
||||
comp_ctx, func_ctx, true, param_values[j],
|
||||
native_addr_size, &native_addr)) {
|
||||
|
||||
Reference in New Issue
Block a user