-
-
Notifications
You must be signed in to change notification settings - Fork 31.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Reference counting bug with manually allocated heap types #128923
Labels
3.14
new features, bugs and security fixes
topic-free-threading
type-bug
An unexpected behavior, bug, or error
type-crash
A hard crash of the interpreter, possibly with a core dump
Comments
colesbury
added a commit
to colesbury/cpython
that referenced
this issue
Jan 16, 2025
In the free threading build, the per thread reference counting uses a unique id for some objects to index into the local reference count table. Use 0 instead of -1 to indicate that the id is not assigned. This avoids bugs where zero-initialized heap type objects look like they have a unique id assigned.
(And for posterity, we did update our code to use |
Yhg1s
pushed a commit
that referenced
this issue
Jan 17, 2025
In the free threading build, the per thread reference counting uses a unique id for some objects to index into the local reference count table. Use 0 instead of -1 to indicate that the id is not assigned. This avoids bugs where zero-initialized heap type objects look like they have a unique id assigned.
Yhg1s
added a commit
that referenced
this issue
Jan 17, 2025
…128951) Fix pydoc's docclass() for classes inheriting from object without the `__module__` attribute, like `_testcapi.HeapType`.
srinivasreddy
pushed a commit
to srinivasreddy/cpython
that referenced
this issue
Jan 21, 2025
…8925) In the free threading build, the per thread reference counting uses a unique id for some objects to index into the local reference count table. Use 0 instead of -1 to indicate that the id is not assigned. This avoids bugs where zero-initialized heap type objects look like they have a unique id assigned.
srinivasreddy
pushed a commit
to srinivasreddy/cpython
that referenced
this issue
Jan 21, 2025
…le__` (python#128951) Fix pydoc's docclass() for classes inheriting from object without the `__module__` attribute, like `_testcapi.HeapType`.
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Labels
3.14
new features, bugs and security fixes
topic-free-threading
type-bug
An unexpected behavior, bug, or error
type-crash
A hard crash of the interpreter, possibly with a core dump
Bug report
Found by @vfdev-5.
This is specific to the free threading build and 3.14.
XLA/Jax uses the following code to create a heap type:
https://github.com/openxla/xla/blob/19a8e8e05fb34c5c4b8c38c9a8225e89f008c8c1/xla/python/pmap_lib.cc#L1027-L1058
In other words, the heap type is created by by calling
PyType_Type.tp_alloc
and filling in the fields, instead of the more common use ofPyType_FromSpec
. This leavesunique_id
zero initialized. The problem is thatunique_id=0
currently looks like a valid unique id for per-thread reference counting, which leads to reference counting errors and use-after-frees.I think we should change the per-thread reference counting so that
unique_id=0
is the sentinel value indicating that it's not assigned instead of the currentunique_id=-1
convention.Full repro
Linked PRs
__module__
#128951The text was updated successfully, but these errors were encountered: