-
-
Notifications
You must be signed in to change notification settings - Fork 30.9k
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
gh-127443: Update refcounts data with stable ABI functions. #127444
base: main
Are you sure you want to change the base?
Conversation
d1e6a24
to
b798ba3
Compare
b798ba3
to
ef9793d
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you for your work. I left some questions, but more thoughtful review I can only do in a week.
PyDict_GetItemRef:int::: | ||
PyDict_GetItemRef:PyObject *:p:0: | ||
PyDict_GetItemRef:PyObject *:key:0: | ||
PyDict_GetItemRef:PyObject **:result:+1: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am not sure how does it work with double pointers. Are there precedences?
BTW, are there any recirds with non-empty 5th field, and if there are any, what is its meaning?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am not sure how does it work with double pointers. Are there precedences?
One precedent is
PyErr_GetExcInfo:void:::
PyErr_GetExcInfo:PyObject**:ptype:+1:
PyErr_GetExcInfo:PyObject**:pvalue:+1:
PyErr_GetExcInfo:PyObject**:ptraceback:+1:
I think the convention here is that we set the destination pointer to a new reference of the item we found, effectively increasing the reference count of the underlying object.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
BTW, are there any recirds with non-empty 5th field, and if there are any, what is its meaning?
Yes, the meaning is just a "comment".
PyModule_Add:int::: | ||
PyModule_Add:PyObject *:module:0: | ||
PyModule_Add:const char *:name:0: | ||
PyModule_Add:PyObject *:value:0:stolen |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should not the refcount be -1?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There is a comment at the top of the file that says:
XXX NOTE: the 0/+1/-1 refcount information for arguments is
confusing! Much more useful would be to indicate whether the
function "steals" a reference to the argument or not. Take for
example PyList_SetItem(list, i, item). This lists as a 0 change for
both the list and the item arguments. However, in fact it steals a
reference to the item argument!
Technically, the reference count of the value itself does not change even though you're stealing the reference.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Tangentially related: can we add a stolen
comment to the PyList_SetItem
? Though the comment at the beginning of the file explicitly says this, I still think it would be useful to add it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think it would be good but I'd like to address the stealing references separately (easier for reviewers I think).
Upon reviewing, I've discovered that I hate this format 😄. I'm going to throw together a script to convert this to TOML or something. Would others be interested in using such a script? |
I also don't like this format. We can convert it to TOML but what do you suggest? |
TOML is probably the way to go here. Let's deal with converting later though. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Some other things that I found that you didn't modify:
PyErr_NormalizeException
is missing a reference count effect for a parameter.- So is
PySeqIter_New
. PySequence_FAST_ITEMS
is missing an effect for its return value (double check me on that, it returnsPyObject **
).PyUnicode_AsUTF8AndSize
erroneously has a reference count effect for aPy_ssize_t *
parameter.- Some functions that take
PyModuleDef
are missing reference count effects for the passed module def. Namely,PyModule_Create
,PyModule_Create2
,PyModule_ExecDef
,PyModule_FromDefAndSpec
,PyModule_FromDefAndSpec2
,PyState_AddModule
,PyState_FindModule
,PyState_RemoveModule
, andPyType_GetModuleByDef
.
@@ -1878,6 +2234,26 @@ PyObject_TypeCheck:int::: | |||
PyObject_TypeCheck:PyObject*:o:0: | |||
PyObject_TypeCheck:PyTypeObject*:type:0: | |||
|
|||
PyObject_Vectorcall:PyObject *::+1: | |||
PyObject_Vectorcall:PyObject *:callable:0: | |||
PyObject_Vectorcall:PyObject *const *:args:0: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We don't have a reference count effect for any of the other PyObject *const *
functions. Let's make a decision on whether to have it or not for these.
PyObject_Vectorcall:PyObject *const *:args:0: | |
PyObject_Vectorcall:PyObject *const *:args:: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I prefer to have them. We can think of args as being loosely typed as PyObject **
and since we are also managing double pointers like that, I think we can also manage those.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could you fix the other cases then?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'd like to do it in a separate PR. I don't want to change existing lines in this specific PR.
Doc/data/refcounts.dat
Outdated
PyUnicodeTranslateError_SetStart:int::: | ||
PyUnicodeTranslateError_SetStart:PyObject *:exc:0: | ||
PyUnicodeTranslateError_SetStart:Py_ssize_t:start:: | ||
|
||
PyWeakref_Check:int::: | ||
PyWeakref_Check:PyObject*:ob:: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This, as well as PyWeakref_CheckRef
and PyWeakref_CheckProxy
below it, need reference count effects.
PyWeakref_Check:PyObject*:ob:: | |
PyWeakref_Check:PyObject*:ob:0: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Addressed in #127451.
Some of those are done in the other PR! I'll address the remaining in a few hours . Thanks! |
In PyErr_SetHandledException, the exception's reference count is incremented by 1 since it's being used as `Py_XSETREF(..., Py_NewRef(exc))`. In PyType_FromModuleAndSpec, the module's reference count is incremented by 1 since it's being stored in the new class being created.
PyOS_string_to_double:double::: | ||
PyOS_string_to_double:const char *:s:: | ||
PyOS_string_to_double:char **:endptr:: | ||
PyOS_string_to_double:PyObject *:overflow_exception:+1: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is +1 correct here? It's ±0 on success.
@@ -3016,10 +3812,50 @@ _PyBytes_Resize:int::: | |||
_PyBytes_Resize:PyObject**:bytes:0: | |||
_PyBytes_Resize:Py_ssize_t:newsize:: | |||
|
|||
_PyObject_CallFunction_SizeT:PyObject *::+1:abi-only |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please pick only one of abi_only
or abi-only
.
Since the changes were done manually and are mechanical, I'm pretty sure there are some +1 missing or incorrectly deduced. I've added some comments here and there about questions I had.
Doc/data/refcounts.dat
#127443📚 Documentation preview 📚: https://cpython-previews--127444.org.readthedocs.build/