mirror of
https://github.com/bytecodealliance/wasm-micro-runtime.git
synced 2025-10-23 17:34:03 +00:00

Adding a new cmake flag (cache variable) `WAMR_BUILD_MEMORY64` to enable the memory64 feature, it can only be enabled on the 64-bit platform/target and can only use software boundary check. And when it is enabled, it can support both i32 and i64 linear memory types. The main modifications are: - wasm loader & mini-loader: loading and bytecode validating process - wasm runtime: memory instantiating process - classic-interpreter: wasm code executing process - Support memory64 memory in related runtime APIs - Modify main function type check when it's memory64 wasm file - Modify `wasm_runtime_invoke_native` and `wasm_runtime_invoke_native_raw` to handle registered native function pointer argument when memory64 is enabled - memory64 classic-interpreter spec test in `test_wamr.sh` and in CI Currently, it supports memory64 memory wasm file that uses core spec (including bulk memory proposal) opcodes and threads opcodes. ps. https://github.com/bytecodealliance/wasm-micro-runtime/issues/3091 https://github.com/bytecodealliance/wasm-micro-runtime/pull/3240 https://github.com/bytecodealliance/wasm-micro-runtime/pull/3260
76 lines
2.1 KiB
C
76 lines
2.1 KiB
C
/*
|
|
* Copyright (C) 2019 Intel Corporation. All rights reserved.
|
|
* SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
*/
|
|
|
|
#ifndef _WASM_MEMORY_H
|
|
#define _WASM_MEMORY_H
|
|
|
|
#include "bh_common.h"
|
|
#include "../include/wasm_export.h"
|
|
#include "../interpreter/wasm_runtime.h"
|
|
#include "../common/wasm_shared_memory.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#if WASM_ENABLE_SHARED_MEMORY != 0 && BH_ATOMIC_64_IS_ATOMIC != 0
|
|
#define GET_LINEAR_MEMORY_SIZE(memory) \
|
|
BH_ATOMIC_64_LOAD(memory->memory_data_size)
|
|
#define SET_LINEAR_MEMORY_SIZE(memory, size) \
|
|
BH_ATOMIC_64_STORE(memory->memory_data_size, size)
|
|
#elif WASM_ENABLE_SHARED_MEMORY != 0
|
|
static inline uint64
|
|
GET_LINEAR_MEMORY_SIZE(const WASMMemoryInstance *memory)
|
|
{
|
|
SHARED_MEMORY_LOCK(memory);
|
|
uint64 memory_data_size = BH_ATOMIC_64_LOAD(memory->memory_data_size);
|
|
SHARED_MEMORY_UNLOCK(memory);
|
|
return memory_data_size;
|
|
}
|
|
static inline void
|
|
SET_LINEAR_MEMORY_SIZE(WASMMemoryInstance *memory, uint64 size)
|
|
{
|
|
SHARED_MEMORY_LOCK(memory);
|
|
BH_ATOMIC_64_STORE(memory->memory_data_size, size);
|
|
SHARED_MEMORY_UNLOCK(memory);
|
|
}
|
|
#else
|
|
#define GET_LINEAR_MEMORY_SIZE(memory) memory->memory_data_size
|
|
#define SET_LINEAR_MEMORY_SIZE(memory, size) memory->memory_data_size = size
|
|
#endif
|
|
|
|
bool
|
|
wasm_runtime_memory_init(mem_alloc_type_t mem_alloc_type,
|
|
const MemAllocOption *alloc_option);
|
|
|
|
void
|
|
wasm_runtime_memory_destroy();
|
|
|
|
unsigned
|
|
wasm_runtime_memory_pool_size();
|
|
|
|
void
|
|
wasm_runtime_set_mem_bound_check_bytes(WASMMemoryInstance *memory,
|
|
uint64 memory_data_size);
|
|
|
|
void
|
|
wasm_runtime_set_enlarge_mem_error_callback(
|
|
const enlarge_memory_error_callback_t callback, void *user_data);
|
|
|
|
void
|
|
wasm_deallocate_linear_memory(WASMMemoryInstance *memory_inst);
|
|
|
|
int
|
|
wasm_allocate_linear_memory(uint8 **data, bool is_shared_memory,
|
|
bool is_memory64, uint64 num_bytes_per_page,
|
|
uint64 init_page_count, uint64 max_page_count,
|
|
uint64 *memory_data_size);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* end of _WASM_MEMORY_H */
|