VYPR
Low severityNVD Advisory· Published Nov 10, 2022· Updated Apr 23, 2025

wasmtime_trap_code C API function has out of bounds write vulnerability

CVE-2022-39394

Description

Wasmtime is a standalone runtime for WebAssembly. Prior to version 2.0.2, there is a bug in Wasmtime's C API implementation where the definition of the wasmtime_trap_code does not match its declared signature in the wasmtime/trap.h header file. This discrepancy causes the function implementation to perform a 4-byte write into a 1-byte buffer provided by the caller. This can lead to three zero bytes being written beyond the 1-byte location provided by the caller. This bug has been patched and users should upgrade to Wasmtime 2.0.2. This bug can be worked around by providing a 4-byte buffer casted to a 1-byte buffer when calling wasmtime_trap_code. Users of the wasmtime crate are not affected by this issue, only users of the C API function wasmtime_trap_code are affected.

Affected packages

Versions sourced from the GitHub Security Advisory.

PackageAffected versionsPatched versions
wasmtimecrates.io
>= 2.0.0, < 2.0.22.0.2
wasmtimecrates.io
< 1.0.21.0.2

Affected products

1

Patches

2
087d9d7becf7

Merge pull request from GHSA-h84q-m8rr-3v9q

https://github.com/bytecodealliance/wasmtimeAlex CrichtonNov 10, 2022via ghsa
1 file changed · +1 1
  • crates/c-api/src/trap.rs+1 1 modified
    @@ -92,7 +92,7 @@ pub extern "C" fn wasm_trap_trace(raw: &wasm_trap_t, out: &mut wasm_frame_vec_t)
     }
     
     #[no_mangle]
    -pub extern "C" fn wasmtime_trap_code(raw: &wasm_trap_t, code: &mut i32) -> bool {
    +pub extern "C" fn wasmtime_trap_code(raw: &wasm_trap_t, code: &mut u8) -> bool {
         match raw.trap.trap_code() {
             Some(c) => {
                 *code = match c {
    
5b6d5e78de10

Merge pull request from GHSA-h84q-m8rr-3v9q

https://github.com/bytecodealliance/wasmtimeAlex CrichtonNov 10, 2022via ghsa
1 file changed · +1 1
  • crates/c-api/src/trap.rs+1 1 modified
    @@ -116,7 +116,7 @@ pub(crate) fn error_trace<'a>(error: &'a Error, out: &mut wasm_frame_vec_t<'a>)
     }
     
     #[no_mangle]
    -pub extern "C" fn wasmtime_trap_code(raw: &wasm_trap_t, code: &mut i32) -> bool {
    +pub extern "C" fn wasmtime_trap_code(raw: &wasm_trap_t, code: &mut u8) -> bool {
         let trap = match raw.error.downcast_ref::<Trap>() {
             Some(trap) => trap,
             None => return false,
    

Vulnerability mechanics

Generated by null/stub on May 9, 2026. Inputs: CWE entries + fix-commit diffs from this CVE's patches. Citations validated against bundle.

References

7

News mentions

0

No linked articles in our index yet.