Specialize Py_DECREF() for Py_REF_DEBUG#16781
Conversation
Simplify Py_DECREF() code for release mode: don't pass __FILE__ and __LINE__ to the static inline function.
|
In Python 3.7, Py_DECREF() was a macro. I converted it to a static inline function in PR #10079 of https://bugs.python.org/issue35059 The new static inline function always require filename and lineno arguments, even in release mode. I'm not sure that all compilers are smart enough to remove the arguments, so I prefer to help compilers to ensure that the emited machine code is as efficient as Python 3.7. |
Sorry, something went wrong.
|
Why so complicated? Why not use just macros? |
Sorry, something went wrong.
Oh, see https://bugs.python.org/issue35059#msg328367 for the rationale. |
Sorry, something went wrong.
I tested almost all versions of gcc/clang/msvc/icc: All versions have the same behavior: |
Sorry, something went wrong.
Static inline functions have multiple benefits over macros. Let me give you one example. Today we get a bug report on Fedora on Python 3.8 which uses static inline functions rather than macros. Thanks to that, the line number in the gdb traceback was more accurate and so more usefull. (Sadly, the bug report is private because it's an automated crash report and it might contain sensitive information, so I cannot share it.) |
Sorry, something went wrong.
_Py_DECREF() function cannot use I wrote PR #17870 to avoid duplicated code and avoid passing |
Sorry, something went wrong.
Sorry, something went wrong.
Simplify Py_DECREF() code for release mode: don't pass FILE and
LINE to the static inline function.