{{ message }}
[3.13] gh-137400: Fix thread-safety issues when profiling all threads (gh-137518)#137733
Merged
colesbury merged 6 commits intoOct 9, 2025
Merged
[3.13] gh-137400: Fix thread-safety issues when profiling all threads (gh-137518)#137733colesbury merged 6 commits into
colesbury merged 6 commits into
Conversation
…hreads (pythongh-137518) There were a few thread-safety issues when profiling or tracing all threads via PyEval_SetProfileAllThreads or PyEval_SetTraceAllThreads: * The loop over thread states could crash if a thread exits concurrently (in both the free threading and default build) * The modification of `c_profilefunc` and `c_tracefunc` wasn't thread-safe on the free threading build. (cherry picked from commit a10152f) Co-authored-by: Sam Gross <colesbury@gmail.com>
This was referenced Aug 13, 2025
Member
|
FYI, the ABI change seems fine to me. |
Sorry, something went wrong.
markshannon
reviewed
Oct 3, 2025
encukou
approved these changes
Oct 8, 2025
encukou
left a comment
Member
There was a problem hiding this comment.
The backport looks good to me!
Though, given that 3.13t is experimental and 3.14 is now out, maybe we should start thinking about not doing backports like this any more...
Sorry, something went wrong.
Contributor
Author
I generally agree, but one of the reasons I decided to backport this is that I think it will make the free-threaded CI more stable as well as fixing a thread-safety issue. |
Sorry, something went wrong.
Hide details
View details
colesbury
merged commit
16d2e97
into
python:3.13
Oct 9, 2025
81 of 83 checks passed
This file contains hidden or 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
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.
There were a few thread-safety issues when profiling or tracing all threads via PyEval_SetProfileAllThreads or PyEval_SetTraceAllThreads:
c_profilefuncandc_tracefuncwasn't thread-safe on the free threading build. (cherry picked from commit a10152f)sys._setprofileallthreadsrace condition #137400