Skip to content

Commit

Permalink
report build corruption in PyO3 0.23 (#2159)
Browse files Browse the repository at this point in the history
* report build corruption in PyO3 0.23

* Update crates/pyo3/RUSTSEC-0000-0000.md

Co-authored-by: Kornel <kornel@geekhood.net>

---------

Co-authored-by: Sergey "Shnatsel" Davidoff <shnatsel@gmail.com>
Co-authored-by: Kornel <kornel@geekhood.net>
  • Loading branch information
3 people authored Dec 5, 2024
1 parent f34e889 commit 9498cb5
Showing 1 changed file with 19 additions and 0 deletions.
19 changes: 19 additions & 0 deletions crates/pyo3/RUSTSEC-0000-0000.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
```toml
[advisory]
id = "RUSTSEC-0000-0000"
package = "pyo3"
date = "2024-12-04"
url = "https://github.com/PyO3/pyo3/issues/4757"
categories = ["memory-corruption"]
keywords = ["memory-corruption", "ffi", "corrupted-build"]

[versions]
patched = [">= 0.23.3"]
unaffected = ["< 0.23.0"]
```

# Build corruption when using `PYO3_CONFIG_FILE` environment variable

In PyO3 0.23.0 the `PYO3_CONFIG_FILE` environment variable used to configure builds regressed such that changing the environment variable would no longer trigger PyO3 to reconfigure and recompile. In combination with workflows using tools such as `maturin` to build for multiple versions in a single build, this leads to Python wheels being compiled against the wrong Python API version.

All users who distribute artefacts for multiple Python versions are encouraged to update and rebuild with PyO3 0.23.3. Affected wheels produced from PyO3 0.23.0 through 0.23.2 are highly unstable and will crash the Python interpreter in unpredictable ways.

0 comments on commit 9498cb5

Please sign in to comment.