CVE-2026-27195

MEDIUM
中文标题:
(暂无数据)
英文标题:
Wasmtime is vulnerable to panic when dropping a `[Typed]Func::call_async` future
CVSS分数: 6.9
发布时间: 2026-02-24 21:15:20
漏洞类型: (暂无数据)
状态: PUBLISHED
数据质量分数: 0.40
数据版本: v3
漏洞描述
中文描述:

(暂无数据)

英文描述:

Wasmtime is a runtime for WebAssembly. Starting with Wasmtime 39.0.0, the `component-model-async` feature became the default, which brought with it a new implementation of `[Typed]Func::call_async` which made it capable of calling async-typed guest export functions. However, that implementation had a bug leading to a panic under certain circumstances: First, the host embedding calls `[Typed]Func::call_async` on a function exported by a component, polling the returned `Future` once. Second, the component function yields control to the async runtime (e.g. Tokio), e.g. due to a call to host function registered using `LinkerInstance::func_wrap_async` which yields, or due an epoch interruption. Third, the host embedding drops the `Future` after polling it once. This leaves the component instance in a non-reenterable state since the call never had a chance to complete. Fourth, the host embedding calls `[Typed]Func::call_async` again, polling the returned `Future`. Since the component instance cannot be entered at this point, the call traps, but not before allocating a task and thread for the call. Fifth, the host embedding ignores the trap and drops the `Future`. This panics due to the runtime attempting to dispose of the task created above, which panics since the thread has not yet exited. When a host embedder using the affected versions of Wasmtime calls `wasmtime::component::[Typed]Func::call_async` on a guest export and then drops the returned future without waiting for it to resolve, and then does so again with the same component instance, Wasmtime will panic. Embeddings that have the `component-model-async` compile-time feature disabled are unaffected. Wasmtime 40.0.4 and 41.0.4 have been patched to fix this issue. Versions 42.0.0 and later are not affected. If an embedding is not actually using any component-model-async features then disabling the `component-model-async` Cargo feature can work around this issue. This issue can also be worked around by either ensuring every `call_async` future is awaited until it completes or refraining from using the `Store` again after dropping a not-yet-resolved `call_async` future.

CWE类型:
CWE-755
标签:
(暂无数据)
受影响产品
厂商 产品 版本 版本范围 平台 CPE
bytecodealliance wasmtime >= 39.0.0, < 40.0.4 - - cpe:2.3:a:bytecodealliance:wasmtime:>=_39.0.0,_<_40.0.4:*:*:*:*:*:*:*
bytecodealliance wasmtime >= 41.0.0, < 41.0.4 - - cpe:2.3:a:bytecodealliance:wasmtime:>=_41.0.0,_<_41.0.4:*:*:*:*:*:*:*
bytecodealliance wasmtime * - - cpe:2.3:a:bytecodealliance:wasmtime:*:*:*:*:*:rust:*:*
解决方案
中文解决方案:
(暂无数据)
英文解决方案:
(暂无数据)
临时解决方案:
(暂无数据)
参考链接
https://github.com/bytecodealliance/wasmtime/security/advisories/GHSA-xjhv-v822-pf94 x_refsource_CONFIRM
cve.org
访问
https://github.com/bytecodealliance/wasmtime/commit/9e51c0d9a240a9613d279c061f82286bd11383fd x_refsource_MISC
cve.org
访问
https://github.com/bytecodealliance/wasmtime/commit/d86b00736b9ece60b3c81e52f7a7e4cdd9f7d895 x_refsource_MISC
cve.org
访问
https://bytecodealliance.zulipchat.com/#narrow/channel/206238-general/topic/.E2.9C.94.20Panic.20in.20Wasmtime.2041.2E0.2E3.20.28runtime.2Fconcurrent.2Fcomponent.29/with/574438798 x_refsource_MISC
cve.org
访问
https://github.com/bytecodealliance/wasmtime/releases/tag/v40.0.4 x_refsource_MISC
cve.org
访问
https://github.com/bytecodealliance/wasmtime/releases/tag/v41.0.4 x_refsource_MISC
cve.org
访问
CVSS评分详情
4.0 (cna)
MEDIUM
6.9
CVSS向量: CVSS:4.0/AV:N/AC:H/AT:P/PR:L/UI:P/VC:N/VI:N/VA:H/SC:N/SI:N/SA:H
机密性
NONE
完整性
NONE
可用性
HIGH
后续系统影响 (Subsequent):
机密性
NONE
完整性
NONE
可用性
HIGH
时间信息
发布时间:
2026-02-24 21:15:20
修改时间:
2026-02-24 21:36:54
创建时间:
2026-02-25 06:00:01
更新时间:
2026-02-26 06:00:04
利用信息
暂无可利用代码信息
数据源详情
数据源 记录ID 版本 提取时间
CVE cve_CVE-2026-27195 2026-02-25 03:19:54 2026-02-24 22:00:01
NVD nvd_CVE-2026-27195 2026-02-25 02:00:04 2026-02-24 22:00:03
版本与语言
当前版本: v3
主要语言: EN
支持语言:
EN
安全公告
暂无安全公告信息
变更历史
v3 NVD
2026-02-26 06:00:04
affected_products_count: 2 → 3
查看详细变更
  • affected_products_count: 2 -> 3
v2 NVD
2026-02-25 06:00:03
data_sources: ['cve'] → ['cve', 'nvd']
查看详细变更
  • data_sources: ['cve'] -> ['cve', 'nvd']