RUSTSEC-2020-0142

See a problem?
Source
https://rustsec.org/advisories/RUSTSEC-2020-0142
Import Source
https://github.com/rustsec/advisory-db/blob/osv/crates/RUSTSEC-2020-0142.json
JSON Data
https://api.osv.dev/v1/vulns/RUSTSEC-2020-0142
Aliases
Published
2020-11-29T12:00:00Z
Modified
2023-11-08T04:03:46.319786Z
Severity
  • 8.1 (High) CVSS_V3 - CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H CVSS Calculator
Summary
Send bound needed on T (for Send impl of `Bucket2`)
Details

Affected versions of this crate unconditionally implements Send for Bucket2. This allows sending non-Send types to other threads.

This can lead to data races when non Send types like Cell<T> or Rc<T> are contained inside Bucket2 and sent across thread boundaries. The data races can potentially lead to memory corruption (as demonstrated in the PoC from the original report issue).

The flaw was corrected in commit 15b2828 by adding a T: Send bound to the Send impl of Bucket2<T>.

References

Affected packages

crates.io / syncpool

Package

Affected ranges

Type
SEMVER
Events
Introduced
0.0.0-0
Fixed
0.1.6

Ecosystem specific

{
    "affected_functions": null,
    "affects": {
        "os": [],
        "functions": [],
        "arch": []
    }
}

Database specific

{
    "cvss": "CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H",
    "informational": null,
    "categories": [
        "memory-corruption"
    ]
}