alexcrichton labeled issue #4840:
A fuzz bug was discovered last night where this driver program:
use anyhow::Result; use wasmtime::*; fn main() -> Result<()> { let mut cfg = Config::new(); let a = run(&cfg)?; cfg.cranelift_opt_level(OptLevel::None); let b = run(&cfg)?; if a == b { println!("same"); } else { anyhow::bail!("{} != {}", a, b); } Ok(()) } fn run(config: &Config) -> Result<f64> { let engine = Engine::new(config)?; let file = std::env::args().nth(1).unwrap(); let module = Module::from_file(&engine, file)?; let mut store = Store::new(&engine, ()); let instance = Instance::new(&mut store, &module, &[])?; let func = instance.get_typed_func::<(f32, i32), (), _>(&mut store, "")?; func.call(&mut store, (f32::from_bits(2143289344), -2147483648))?; let global = instance.get_global(&mut store, "3").unwrap(); Ok(global.get(&mut store).unwrap_f64()) }
will produce an error with this wasm input:
(module (func (param f32 i32) local.get 1 f64.convert_i32_u i32.trunc_f64_u f64.convert_i32_s local.get 1 f64.convert_i32_u global.set 0 drop ) (global (;0;) (mut f64) f64.const 0) (export "" (func 0)) (export "3" (global 0)) )
where the program will print
Error: 0 != 2147483648
Bisection shows that this was introduced in #4811 so looks like no need for a point release or anything, just a bug to fix
alexcrichton opened issue #4840:
A fuzz bug was discovered last night where this driver program:
use anyhow::Result; use wasmtime::*; fn main() -> Result<()> { let mut cfg = Config::new(); let a = run(&cfg)?; cfg.cranelift_opt_level(OptLevel::None); let b = run(&cfg)?; if a == b { println!("same"); } else { anyhow::bail!("{} != {}", a, b); } Ok(()) } fn run(config: &Config) -> Result<f64> { let engine = Engine::new(config)?; let file = std::env::args().nth(1).unwrap(); let module = Module::from_file(&engine, file)?; let mut store = Store::new(&engine, ()); let instance = Instance::new(&mut store, &module, &[])?; let func = instance.get_typed_func::<(f32, i32), (), _>(&mut store, "")?; func.call(&mut store, (f32::from_bits(2143289344), -2147483648))?; let global = instance.get_global(&mut store, "3").unwrap(); Ok(global.get(&mut store).unwrap_f64()) }
will produce an error with this wasm input:
(module (func (param f32 i32) local.get 1 f64.convert_i32_u i32.trunc_f64_u f64.convert_i32_s local.get 1 f64.convert_i32_u global.set 0 drop ) (global (;0;) (mut f64) f64.const 0) (export "" (func 0)) (export "3" (global 0)) )
where the program will print
Error: 0 != 2147483648
Bisection shows that this was introduced in #4811 so looks like no need for a point release or anything, just a bug to fix
cfallin closed issue #4840:
A fuzz bug was discovered last night where this driver program:
use anyhow::Result; use wasmtime::*; fn main() -> Result<()> { let mut cfg = Config::new(); let a = run(&cfg)?; cfg.cranelift_opt_level(OptLevel::None); let b = run(&cfg)?; if a == b { println!("same"); } else { anyhow::bail!("{} != {}", a, b); } Ok(()) } fn run(config: &Config) -> Result<f64> { let engine = Engine::new(config)?; let file = std::env::args().nth(1).unwrap(); let module = Module::from_file(&engine, file)?; let mut store = Store::new(&engine, ()); let instance = Instance::new(&mut store, &module, &[])?; let func = instance.get_typed_func::<(f32, i32), (), _>(&mut store, "")?; func.call(&mut store, (f32::from_bits(2143289344), -2147483648))?; let global = instance.get_global(&mut store, "3").unwrap(); Ok(global.get(&mut store).unwrap_f64()) }
will produce an error with this wasm input:
(module (func (param f32 i32) local.get 1 f64.convert_i32_u i32.trunc_f64_u f64.convert_i32_s local.get 1 f64.convert_i32_u global.set 0 drop ) (global (;0;) (mut f64) f64.const 0) (export "" (func 0)) (export "3" (global 0)) )
where the program will print
Error: 0 != 2147483648
Bisection shows that this was introduced in #4811 so looks like no need for a point release or anything, just a bug to fix
Last updated: Jan 24 2025 at 00:11 UTC