SingleAccretion opened issue #9461:
Reproduction:
1) Compile any component, e. g.int main() { int a = 1; return a; }
> & $env:WASI_SDK_PATH/bin/clang main.cpp -o main.wasm -g3 -target wasm32-unknown-wasip2
2) Debug with lldb+wasmtime:
> lldb wasmtime -- -D debug-info -O opt-level=0 main.wasm > (lldb) b main > (lldb) c ; Until you reach WASM's 'main'
3) Observe four
(JIT)
modules (for each core module in a component). All of them have the exact same content.> (lldb) image list
4) Also observe that LLDB needed to index the same DWARF info four times. This means that "startup with debugging" is 4x slower if we exclude the time to compile code and transform DWARF.
The bug is somewhere around here:
https://github.com/bytecodealliance/wasmtime/blob/460a4c0ad5d3655b7dbaec193e726196de848898/crates/wasmtime/src/runtime/instantiate.rs#L72-L79AFAICT, with components, the generated image is a shared (among core modules) resource, so each
Module::from_parts_raw
call here:
https://github.com/bytecodealliance/wasmtime/blob/460a4c0ad5d3655b7dbaec193e726196de848898/crates/wasmtime/src/runtime/component/component.rs#L408-L414Registers the same image.
alexcrichton closed issue #9461:
Reproduction:
1) Compile any component, e. g.int main() { int a = 1; return a; }
> & $env:WASI_SDK_PATH/bin/clang main.cpp -o main.wasm -g3 -target wasm32-unknown-wasip2
2) Debug with lldb+wasmtime:
> lldb wasmtime -- -D debug-info -O opt-level=0 main.wasm > (lldb) b main > (lldb) c ; Until you reach WASM's 'main'
3) Observe four
(JIT)
modules (for each core module in a component). All of them have the exact same content.> (lldb) image list
4) Also observe that LLDB needed to index the same DWARF info four times. This means that "startup with debugging" is 4x slower if we exclude the time to compile code and transform DWARF.
The bug is somewhere around here:
https://github.com/bytecodealliance/wasmtime/blob/460a4c0ad5d3655b7dbaec193e726196de848898/crates/wasmtime/src/runtime/instantiate.rs#L72-L79AFAICT, with components, the generated image is a shared (among core modules) resource, so each
Module::from_parts_raw
call here:
https://github.com/bytecodealliance/wasmtime/blob/460a4c0ad5d3655b7dbaec193e726196de848898/crates/wasmtime/src/runtime/component/component.rs#L408-L414Registers the same image.
Last updated: Jan 24 2025 at 00:11 UTC