RUSTSEC-2022-0007

See a problem?
Source
https://rustsec.org/advisories/RUSTSEC-2022-0007
Import Source
https://github.com/rustsec/advisory-db/blob/osv/crates/RUSTSEC-2022-0007.json
JSON Data
https://api.osv.dev/v1/vulns/RUSTSEC-2022-0007
Aliases
Published
2022-01-24T12:00:00Z
Modified
2023-11-08T04:17:51.156433Z
Summary
A malicious coder can get unsound access to TCell or TLCell memory
Details

This is impossible to do by accident, but by carefully constructing marker types to be covariant, a malicious coder can cheat the singleton check in TCellOwner and TLCellOwner, giving unsound access to cell memory. This could take the form of getting two mutable references to the same memory, or a mutable reference and an immutable reference.

The fix is for the crate to internally force the marker type to be invariant. This blocks the conversion between covariant types which Rust normally allows.

References

Affected packages

crates.io / qcell

Package

Affected ranges

Type
SEMVER
Events
Introduced
0.0.0-0
Fixed
0.4.3

Ecosystem specific

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

Database specific

{
    "cvss": null,
    "informational": "unsound",
    "categories": []
}