From 0e23c7eeb4d54f11065b92da0c7c37bbe3c194c3 Mon Sep 17 00:00:00 2001 From: David Hewitt Date: Wed, 4 Dec 2024 14:56:43 +0000 Subject: [PATCH 1/2] report build corruption in PyO3 0.23 --- crates/pyo3/RUSTSEC-0000-0000.md | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) create mode 100644 crates/pyo3/RUSTSEC-0000-0000.md diff --git a/crates/pyo3/RUSTSEC-0000-0000.md b/crates/pyo3/RUSTSEC-0000-0000.md new file mode 100644 index 000000000..87f5cfdff --- /dev/null +++ b/crates/pyo3/RUSTSEC-0000-0000.md @@ -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-corrution", "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. \ No newline at end of file From dcf33d810f3b2c7f716c5a42bd8de7988ff7989d Mon Sep 17 00:00:00 2001 From: "Sergey \"Shnatsel\" Davidoff" Date: Thu, 5 Dec 2024 03:58:41 +0000 Subject: [PATCH 2/2] Update crates/pyo3/RUSTSEC-0000-0000.md Co-authored-by: Kornel --- crates/pyo3/RUSTSEC-0000-0000.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/crates/pyo3/RUSTSEC-0000-0000.md b/crates/pyo3/RUSTSEC-0000-0000.md index 87f5cfdff..c990c58ba 100644 --- a/crates/pyo3/RUSTSEC-0000-0000.md +++ b/crates/pyo3/RUSTSEC-0000-0000.md @@ -5,7 +5,7 @@ package = "pyo3" date = "2024-12-04" url = "https://github.com/PyO3/pyo3/issues/4757" categories = ["memory-corruption"] -keywords = ["memory-corrution", "ffi", "corrupted-build"] +keywords = ["memory-corruption", "ffi", "corrupted-build"] [versions] patched = [">= 0.23.3"]