You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
While testing the WAMR runtime, I observed that the wasm_memory_data_size function returns 98304 bytes for a module with a single memory page, instead of the expected 65536 bytes as defined by the WebAssembly specification. The module does not invoke memory.grow or any similar operations.
In this function I am trying to test memory contents, globals and return of _main to do differential testing. Of that I am using the following main code snippets to do:
// Handle `_memory` exportwasm_memory_t*memory=wasm_extern_as_memory(exports.data[0]);
if (memory) {
constuint8_t*memory_data= (constuint8_t*)wasm_memory_data(memory);
size_tmemory_size=wasm_memory_data_size(memory);
//size_t memory_size = wasm_memory_size(memory);printf("Memory size: %zu bytes\n", memory_size);
// Iterate through aligned words onlyfor (size_ti=0; i+4 <= memory_size; i+=4) {
uint32_tvalue;
memcpy(&value, memory_data+i, sizeof(value));
printf("Memory word at %zu: %u\n", i, value);
update_crc(value);
}
} else {
printf("_memory export not found.\n");
}
However, when I do that size_t memory_size = wasm_memory_data_size(memory); gives the number Memory size: 98304 bytes instead of 65536 which is also reflected in the generated CRC that differs from other runtimes and also differs each run because of memory access that has undefined values each time. Some examples where memory addresses greater that 65536 holds undefined values each time:
FIRST RUN WITH WAMR:
Memory word at 65540: 1610616831
Memory word at 65544: 0
Memory word at 65548: 0
Memory word at 65552: 0
Memory word at 65556: 0
Memory word at 65560: 2809450164
Memory word at 65564: 21919
Memory word at 65568: 32760
Memory word at 65572: 0
Memory word at 65576: 0
SECOND RUN WITH WAMR:
Memory word at 65540: 1610616831
Memory word at 65544: 0
Memory word at 65548: 0
Memory word at 65552: 0
Memory word at 65556: 0
Memory word at 65560: 298987188
Memory word at 65564: 22001
Memory word at 65568: 32760
Memory word at 65572: 0
Memory word at 65576: 0
THIRD RUN WITH WAMR:
Memory word at 65540: 1610616831
Memory word at 65544: 0
Memory word at 65548: 0
Memory word at 65552: 0
Memory word at 65556: 0
Memory word at 65560: 140189364
Memory word at 65564: 21984
Memory word at 65568: 32760
Memory word at 65572: 0
Expected Behavior:
When I change it manually to i + 4 <= memory_size to i + 4 <= 65536 in the for loop it works just fine. It gives the same CRC hash as other 5 runtimes.
The similar API usage from wasm-interp of WABT returns the 65536 and works fine:
if (memory) {
constuint8_t*memory_data=memory->UnsafeData();
size_tmemory_size=memory->ByteSize();
// std::cout << "Processing memory for CRC. Size: " << memory_size << " bytes." << std::endl;for (size_ti=0; i<memory_size; i+=4) {
uint32_tvalue=*reinterpret_cast<constuint32_t*>(memory_data+i);
//std::cout << "Memory word at " << i << ": " << value << std::endl;update_crc(value);
}
}
The other runtimes have the similar API and they work as expected.
I added some debug statements to wasm_memory_data_size API and got the following final result.
API with debug statements:
size_twasm_memory_data_size(constwasm_memory_t*memory)
{
// Check if the memory is validif (!memory|| !memory->inst_comm_rt) {
printf("[DEBUG] Invalid memory or runtime instance.\n");
return0;
}
// Access the common module instanceWASMModuleInstanceCommon*module_inst_comm=memory->inst_comm_rt;
#ifWASM_ENABLE_INTERP!=0// Handle the Bytecode module typeif (module_inst_comm->module_type==Wasm_Module_Bytecode) {
printf("[DEBUG] Module type: Wasm_Module_Bytecode.\n");
WASMModuleInstance*module_inst= (WASMModuleInstance*)module_inst_comm;
WASMMemoryInstance*memory_inst=module_inst->memories[memory->memory_idx_rt];
// Debug print for page count and page sizeprintf("[DEBUG] cur_page_count: %u\n", memory_inst->cur_page_count);
printf("[DEBUG] num_bytes_per_page: %u\n", memory_inst->num_bytes_per_page);
return (size_t)memory_inst->cur_page_count*memory_inst->num_bytes_per_page;
}
#endif#ifWASM_ENABLE_AOT!=0// Handle the AoT module typeif (module_inst_comm->module_type==Wasm_Module_AoT) {
printf("[DEBUG] Module type: Wasm_Module_AoT.\n");
AOTModuleInstance*module_inst= (AOTModuleInstance*)module_inst_comm;
AOTMemoryInstance*memory_inst=
((AOTMemoryInstance**)module_inst->memories)[memory->memory_idx_rt];
// Debug print for page count and page sizeprintf("[DEBUG] cur_page_count: %u\n", memory_inst->cur_page_count);
printf("[DEBUG] num_bytes_per_page: %u\n", memory_inst->num_bytes_per_page);
return (size_t)memory_inst->cur_page_count*memory_inst->num_bytes_per_page;
}
#endif// Handle incorrect module type or compilation flagsprintf("[DEBUG] Unexpected module type or invalid compilation flags.\n");
return0;
}
Hi, I saw you call wasm_instance_new in your code, which set the wasm host managed heap size to 32KB by default. You can use wasm_instance_new_with_args to set the heap_size to 0, in that way, you should have expected 65536 bytes
Observations on
wasm_memory_data_size
API in WAMRWhile testing the WAMR runtime, I observed that the
wasm_memory_data_size
function returns 98304 bytes for a module with a single memory page, instead of the expected 65536 bytes as defined by the WebAssembly specification. The module does not invokememory.grow
or any similar operations.Example module:
In this function I am trying to test memory contents, globals and return of _main to do differential testing. Of that I am using the following main code snippets to do:
However, when I do that
size_t memory_size = wasm_memory_data_size(memory);
gives the numberMemory size: 98304 bytes
instead of65536
which is also reflected in the generated CRC that differs from other runtimes and also differs each run because of memory access that has undefined values each time. Some examples where memory addresses greater that 65536 holds undefined values each time:Expected Behavior:
When I change it manually to
i + 4 <= memory_size
toi + 4 <= 65536
in the for loop it works just fine. It gives the same CRC hash as other 5 runtimes.The similar API usage from wasm-interp of WABT returns the 65536 and works fine:
The other runtimes have the similar API and they work as expected.
I added some debug statements to
wasm_memory_data_size
API and got the following final result.API with debug statements:
Result:
Reproduce
load-wamr.zip
wat2wasm
to convert to wasm.wamr_program on that file
: (Please give correct path to thewasm-micro-runtime
in your machine)Observe:
You have to add Debug statements to the API in question in
wasm-micro-runtime/core/iwasm/common/wasm_c_api.c
to see the outputs with [DEBUG] in it.Wamr version:
iwasm 2.2.0
Build:
The text was updated successfully, but these errors were encountered: