mirror of
https://github.com/OMGeeky/advisory-db.git
synced 2026-01-10 13:41:11 +01:00
Add advisory for use-after-free in futures-util task::waker
This commit is contained in:
23
crates/futures-task/RUSTSEC-0000-0000.md
Normal file
23
crates/futures-task/RUSTSEC-0000-0000.md
Normal file
@@ -0,0 +1,23 @@
|
||||
```toml
|
||||
[advisory]
|
||||
id = "RUSTSEC-0000-0000"
|
||||
package = "futures-task"
|
||||
date = "2020-09-04"
|
||||
url = "https://github.com/rust-lang/futures-rs/pull/2206"
|
||||
categories = ["code-execution", "memory-corruption"]
|
||||
keywords = ["use-after-free", "arbitrary code execution", "memory-corruption", "memory-management"]
|
||||
|
||||
[versions]
|
||||
patched = [">= 0.3.6"]
|
||||
unaffected = ["<= 0.2.1"]
|
||||
|
||||
[affected]
|
||||
functions = { "futures_task::waker" = [">= 0.3.0"] }
|
||||
```
|
||||
|
||||
# futures_task::waker may cause a use-after-free if used on a type that isn't 'static
|
||||
|
||||
Affected versions of the crate did not properly implement a `'static` lifetime bound on the `waker` function.
|
||||
This resulted in a use-after-free if `Waker::wake()` is called after original data had been dropped.
|
||||
|
||||
The flaw was corrected by adding `'static` lifetime bound to the data `waker` takes.
|
||||
Reference in New Issue
Block a user