jaybarbhaiya added the bug label to Issue #10287.
jaybarbhaiya opened issue #10287:
Thanks for filing a bug report! Please fill out the TODOs below.
Note: if you want to report a security issue, please read our security policy!
Test Case
Steps to Reproduce
- Clone the repo
git clone https://github.com/jaybarbhaiya/wasmtime-module-drop-test.git
- Run bench command
cargo bench
Expected Results
The time taken to drop a
wasmtime::Module
should be comparable across different operating systems.Actual Results
The drop of a
wasmtime::Module
in MacOS is significantly higher than that of Linux and Windows.Versions and Environment
Wasmtime version or commit: 30.0.1
Operating system: MacOS 15.3.1
Architecture: arm64
Extra Info
1000
wasmtime::Module
are created with thewasm
binary attached above and then dropped. GitHub actions are set up in the repo, which runs thecargo bench
command inubuntu-latest
,windows-latest
, andmacos-latest
runners. The screenshot below shows the results:ubuntu-latest
data:image/s3,"s3://crabby-images/f9dc6/f9dc6e6f4e145fca924d0b4558d599da4cecb5df" alt="Image"windows-latest
data:image/s3,"s3://crabby-images/15321/153216b6b64fdd272b7ad4865510f84df364c2a7" alt="Image"macos-latest
data:image/s3,"s3://crabby-images/ba0c9/ba0c98acc44153cb7214bcf0978f576e6ad0dabe" alt="Image"The difference that was observed, in MacOS, the
wasmtime::CodeMemory
drop takes a significant amount of time which is not the case in Linux. It would be valuable to get some insights.Thank you.
alexcrichton commented on issue #10287:
Thanks for the report! This is likely the cause of
Config::native_unwind_info
being default-on. OSes have widely varying implementations of how information is unregistered, and IIRC I've also seen macOS be significantly slower than other platforms.If that option is disabled, though, does it improve the performance you're seeing?
jaybarbhaiya closed issue #10287:
Thanks for filing a bug report! Please fill out the TODOs below.
Note: if you want to report a security issue, please read our security policy!
Test Case
Steps to Reproduce
- Clone the repo
git clone https://github.com/jaybarbhaiya/wasmtime-module-drop-test.git
- Run bench command
cargo bench
Expected Results
The time taken to drop a
wasmtime::Module
should be comparable across different operating systems.Actual Results
The drop of a
wasmtime::Module
in MacOS is significantly higher than that of Linux and Windows.Versions and Environment
Wasmtime version or commit: 30.0.1
Operating system: MacOS 15.3.1
Architecture: arm64
Extra Info
1000
wasmtime::Module
are created with thewasm
binary attached above and then dropped. GitHub actions are set up in the repo, which runs thecargo bench
command inubuntu-latest
,windows-latest
, andmacos-latest
runners. The screenshot below shows the results:ubuntu-latest
data:image/s3,"s3://crabby-images/f9dc6/f9dc6e6f4e145fca924d0b4558d599da4cecb5df" alt="Image"windows-latest
data:image/s3,"s3://crabby-images/15321/153216b6b64fdd272b7ad4865510f84df364c2a7" alt="Image"macos-latest
data:image/s3,"s3://crabby-images/ba0c9/ba0c98acc44153cb7214bcf0978f576e6ad0dabe" alt="Image"The difference that was observed, in MacOS, the
wasmtime::CodeMemory
drop takes a significant amount of time which is not the case in Linux. It would be valuable to get some insights.Thank you.
jaybarbhaiya commented on issue #10287:
Hi @alexcrichton
Thank you for the quick response!
DisablingConfig::native_unwind_info
improved performance. Please see below the updated benchmark from the macOS GitHub runner.<img width="578" alt="Image" src="https://github.com/user-attachments/assets/4b501ade-bb9e-4d70-8bf2-63b6b14e6ca9" />
Thank you again for the clarification :blush:
Last updated: Feb 28 2025 at 01:30 UTC