-
Notifications
You must be signed in to change notification settings - Fork 375
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Report UB in glib::VariantStrIter::impl_get in glib < 0.20.0 (#2176)
- Loading branch information
1 parent
8737f2a
commit fdbeba5
Showing
1 changed file
with
32 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
```toml | ||
[advisory] | ||
id = "RUSTSEC-0000-0000" | ||
package = "glib" | ||
date = "2024-03-30" | ||
url = "https://github.com/gtk-rs/gtk-rs-core/pull/1343" | ||
informational = "unsound" | ||
|
||
[affected.functions] | ||
"glib::VariantStrIter::next" = [">=0.15.0,<0.20.0"] | ||
"glib::VariantStrIter::nth" = [">=0.15.0,<0.20.0"] | ||
"glib::VariantStrIter::last" = [">=0.15.0,<0.20.0"] | ||
"glib::VariantStrIter::next_back" = [">=0.15.0,<0.20.0"] | ||
"glib::VariantStrIter::nth_back" = [">=0.15.0,<0.20.0"] | ||
|
||
[versions] | ||
patched = [">=0.20.0"] | ||
unaffected = ["<0.15.0"] | ||
``` | ||
|
||
# Unsoundness in `Iterator` and `DoubleEndedIterator` impls for `glib::VariantStrIter` | ||
|
||
The `VariantStrIter::impl_get` function (called internally by implementations of the `Iterator` and `DoubleEndedIterator` traits for this type) was unsound, resulting in undefined behaviour. | ||
|
||
An immutable reference `&p` to a `*mut libc::c_char` pointer initialized to `NULL` was passed as an argument to a C function that that mutates the pointer behind `&p` in-place (i.e. as an out-argument), which was unsound. After changes in recent versions of the Rust compiler, these unsound writes through `&p` now seem to be completely disregarded when building the `glib` crate with optimizations. | ||
|
||
This subsequently caused all calls of `VariantStrIter::impl_get` to violate the safety requirements of the `std::ffi::CStr::from_ptr` function - which requires its argument to be a valid pointer to a C-style string - resulting in crashes due to `NULL` pointer dereferences. | ||
|
||
This was fixed by passing the out-argument pointer explitly as `&mut p` instead of `&p`. | ||
|
||
This issue has been present since this code was initially added in `glib` v0.15.0. The mismatch in mutability was likely missed (and not raised as an error by the compiler) because the C function wrapped by `VariantStrIter::impl_get` is variadic (`glib_sys::g_variant_get_child`), and the pointer in question is one of the variadic arguments. | ||
|