GHSA-r626-fc64-3q28

Suggest an improvement
Source
https://github.com/advisories/GHSA-r626-fc64-3q28
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2021/08/GHSA-r626-fc64-3q28/GHSA-r626-fc64-3q28.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-r626-fc64-3q28
Aliases
Published
2021-08-25T20:59:06Z
Modified
2023-11-08T04:03:45.024840Z
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
Data race in abox
Details

Affected versions of this crate implements Send/Sync for AtomicBox<T> without requiring T: Send/T: Sync. This allows to create data races to T: !Sync and send T: !Send to another thread. Such behavior breaks the compile-time thread safety guarantees of Rust, and allows users to incur undefined behavior using safe Rust (e.g. memory corruption from data race). The flaw was corrected in commit 34c2b9e by adding trait bound T: Send to Send impl for AtomicBox<T> and trait bound T: Sync to Sync impl for AtomicBox<T>.

References

Affected packages

crates.io / abox

Package

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
0.4.1