Lucene search

K
osvGoogleOSV:GHSA-RH4W-94HH-9943
HistoryMay 24, 2022 - 5:37 p.m.

MutexGuard::map can cause a data race in safe code

2022-05-2417:37:49
Google
osv.dev
9
mutexguard
data race
safe rust
send/sync
mappedmutexguard
data race risk
phantomdata marker

EPSS

0

Percentile

12.8%

Affected versions of the crate had a Send/Sync implementation for MappedMutexGuard that only considered variance on T, while MappedMutexGuard dereferenced to U.

This could of led to data races in safe Rust code when a closure used in MutexGuard::map() returns U that is unrelated to T.

The issue was fixed by fixing Send and Sync implementations, and by adding a PhantomData<&'a mut U> marker to the MappedMutexGuard type to tell the compiler that the guard is over U too.

EPSS

0

Percentile

12.8%

Related for OSV:GHSA-RH4W-94HH-9943