A Denial of Service vulnerability exists in Binaryen 104 due to an assertion abort in wasm::WasmBinaryBuilder::visitRethrow(wasm::Rethrow*).
The product contains an assert() or similar statement that can be triggered by an attacker, which leads to an application exit or other behavior that is more severe than necessary.
| Name | Vendor | Start Version | End Version | 
|---|---|---|---|
| Binaryen | Webassembly | 104 (including) | 104 (including) | 
| Binaryen | Ubuntu | focal | * | 
| Binaryen | Ubuntu | hirsute | * | 
| Binaryen | Ubuntu | impish | * | 
| Binaryen | Ubuntu | kinetic | * | 
| Binaryen | Ubuntu | lunar | * | 
| Binaryen | Ubuntu | mantic | * | 
| Binaryen | Ubuntu | oracular | * | 
| Binaryen | Ubuntu | trusty | * | 
| Binaryen | Ubuntu | xenial | * | 
While assertion is good for catching logic errors and reducing the chances of reaching more serious vulnerability conditions, it can still lead to a denial of service. For example, if a server handles multiple simultaneous connections, and an assert() occurs in one single connection that causes all other connections to be dropped, this is a reachable assertion that leads to a denial of service.