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:
@ -2542,8 +2542,9 @@ load_from_sections(WASMModule *module, WASMSection *sections,
|
||||
*buf_func = NULL, *buf_func_end = NULL;
|
||||
WASMGlobal *aux_data_end_global = NULL, *aux_heap_base_global = NULL;
|
||||
WASMGlobal *aux_stack_top_global = NULL, *global;
|
||||
uint32 aux_data_end = (uint32)-1, aux_heap_base = (uint32)-1;
|
||||
uint32 aux_stack_top = (uint32)-1, global_index, func_index, i;
|
||||
uint64 aux_data_end = (uint64)-1, aux_heap_base = (uint64)-1,
|
||||
aux_stack_top = (uint64)-1;
|
||||
uint32 global_index, func_index, i;
|
||||
uint32 aux_data_end_global_index = (uint32)-1;
|
||||
uint32 aux_heap_base_global_index = (uint32)-1;
|
||||
WASMFuncType *func_type;
|
||||
@ -2661,7 +2662,7 @@ load_from_sections(WASMModule *module, WASMSection *sections,
|
||||
&& global->init_expr.init_expr_type
|
||||
== INIT_EXPR_TYPE_I32_CONST) {
|
||||
aux_heap_base_global = global;
|
||||
aux_heap_base = global->init_expr.u.i32;
|
||||
aux_heap_base = (uint64)(uint32)global->init_expr.u.i32;
|
||||
aux_heap_base_global_index = export->index;
|
||||
LOG_VERBOSE("Found aux __heap_base global, value: %d",
|
||||
aux_heap_base);
|
||||
@ -2674,12 +2675,11 @@ load_from_sections(WASMModule *module, WASMSection *sections,
|
||||
&& global->init_expr.init_expr_type
|
||||
== INIT_EXPR_TYPE_I32_CONST) {
|
||||
aux_data_end_global = global;
|
||||
aux_data_end = global->init_expr.u.i32;
|
||||
aux_data_end = (uint64)(uint32)global->init_expr.u.i32;
|
||||
aux_data_end_global_index = export->index;
|
||||
LOG_VERBOSE("Found aux __data_end global, value: %d",
|
||||
aux_data_end);
|
||||
|
||||
aux_data_end = align_uint(aux_data_end, 16);
|
||||
aux_data_end = align_uint64(aux_data_end, 16);
|
||||
}
|
||||
}
|
||||
|
||||
@ -2715,16 +2715,17 @@ load_from_sections(WASMModule *module, WASMSection *sections,
|
||||
&& global->type == VALUE_TYPE_I32
|
||||
&& global->init_expr.init_expr_type
|
||||
== INIT_EXPR_TYPE_I32_CONST
|
||||
&& (uint32)global->init_expr.u.i32 <= aux_heap_base) {
|
||||
&& (uint64)(uint32)global->init_expr.u.i32
|
||||
<= aux_heap_base) {
|
||||
aux_stack_top_global = global;
|
||||
aux_stack_top = (uint32)global->init_expr.u.i32;
|
||||
aux_stack_top = (uint64)(uint32)global->init_expr.u.i32;
|
||||
module->aux_stack_top_global_index =
|
||||
module->import_global_count + global_index;
|
||||
module->aux_stack_bottom = aux_stack_top;
|
||||
module->aux_stack_size =
|
||||
aux_stack_top > aux_data_end
|
||||
? aux_stack_top - aux_data_end
|
||||
: aux_stack_top;
|
||||
? (uint32)(aux_stack_top - aux_data_end)
|
||||
: (uint32)aux_stack_top;
|
||||
LOG_VERBOSE("Found aux stack top global, value: %d, "
|
||||
"global index: %d, stack size: %d",
|
||||
aux_stack_top, global_index,
|
||||
@ -2862,60 +2863,62 @@ load_from_sections(WASMModule *module, WASMSection *sections,
|
||||
if (aux_data_end_global && aux_heap_base_global
|
||||
&& aux_stack_top_global) {
|
||||
uint64 init_memory_size;
|
||||
uint32 shrunk_memory_size = align_uint(aux_heap_base, 8);
|
||||
uint64 shrunk_memory_size = align_uint64(aux_heap_base, 8);
|
||||
|
||||
if (module->import_memory_count) {
|
||||
memory_import = &module->import_memories[0].u.memory;
|
||||
init_memory_size = (uint64)memory_import->num_bytes_per_page
|
||||
* memory_import->init_page_count;
|
||||
if (shrunk_memory_size <= init_memory_size) {
|
||||
/* Reset memory info to decrease memory usage */
|
||||
memory_import->num_bytes_per_page = shrunk_memory_size;
|
||||
memory_import->init_page_count = 1;
|
||||
LOG_VERBOSE("Shrink import memory size to %d",
|
||||
shrunk_memory_size);
|
||||
/* Only resize(shrunk) the memory size if num_bytes_per_page is in
|
||||
* valid range of uint32 */
|
||||
if (shrunk_memory_size <= UINT32_MAX) {
|
||||
if (module->import_memory_count) {
|
||||
memory_import = &module->import_memories[0].u.memory;
|
||||
init_memory_size = (uint64)memory_import->num_bytes_per_page
|
||||
* memory_import->init_page_count;
|
||||
if (shrunk_memory_size <= init_memory_size) {
|
||||
/* Reset memory info to decrease memory usage */
|
||||
memory_import->num_bytes_per_page = shrunk_memory_size;
|
||||
memory_import->init_page_count = 1;
|
||||
LOG_VERBOSE("Shrink import memory size to %d",
|
||||
shrunk_memory_size);
|
||||
}
|
||||
}
|
||||
}
|
||||
if (module->memory_count) {
|
||||
memory = &module->memories[0];
|
||||
init_memory_size = (uint64)memory->num_bytes_per_page
|
||||
* memory->init_page_count;
|
||||
if (shrunk_memory_size <= init_memory_size) {
|
||||
/* Reset memory info to decrease memory usage */
|
||||
memory->num_bytes_per_page = shrunk_memory_size;
|
||||
memory->init_page_count = 1;
|
||||
LOG_VERBOSE("Shrink memory size to %d", shrunk_memory_size);
|
||||
|
||||
if (module->memory_count) {
|
||||
memory = &module->memories[0];
|
||||
init_memory_size = (uint64)memory->num_bytes_per_page
|
||||
* memory->init_page_count;
|
||||
if (shrunk_memory_size <= init_memory_size) {
|
||||
/* Reset memory info to decrease memory usage */
|
||||
memory->num_bytes_per_page = shrunk_memory_size;
|
||||
memory->init_page_count = 1;
|
||||
LOG_VERBOSE("Shrink memory size to %d",
|
||||
shrunk_memory_size);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (module->import_memory_count) {
|
||||
memory_import = &module->import_memories[0].u.memory;
|
||||
if (memory_import->init_page_count < DEFAULT_MAX_PAGES)
|
||||
if (memory_import->init_page_count < DEFAULT_MAX_PAGES) {
|
||||
memory_import->num_bytes_per_page *=
|
||||
memory_import->init_page_count;
|
||||
else
|
||||
memory_import->num_bytes_per_page = UINT32_MAX;
|
||||
|
||||
if (memory_import->init_page_count > 0)
|
||||
memory_import->init_page_count = memory_import->max_page_count =
|
||||
1;
|
||||
else
|
||||
memory_import->init_page_count = memory_import->max_page_count =
|
||||
0;
|
||||
if (memory_import->init_page_count > 0)
|
||||
memory_import->init_page_count =
|
||||
memory_import->max_page_count = 1;
|
||||
else
|
||||
memory_import->init_page_count =
|
||||
memory_import->max_page_count = 0;
|
||||
}
|
||||
}
|
||||
|
||||
if (module->memory_count) {
|
||||
memory = &module->memories[0];
|
||||
if (memory->init_page_count < DEFAULT_MAX_PAGES)
|
||||
if (memory->init_page_count < DEFAULT_MAX_PAGES) {
|
||||
memory->num_bytes_per_page *= memory->init_page_count;
|
||||
else
|
||||
memory->num_bytes_per_page = UINT32_MAX;
|
||||
|
||||
if (memory->init_page_count > 0)
|
||||
memory->init_page_count = memory->max_page_count = 1;
|
||||
else
|
||||
memory->init_page_count = memory->max_page_count = 0;
|
||||
if (memory->init_page_count > 0)
|
||||
memory->init_page_count = memory->max_page_count = 1;
|
||||
else
|
||||
memory->init_page_count = memory->max_page_count = 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user