Commit f4e4703e authored by Victor Stinner's avatar Victor Stinner Committed by GitHub

bpo-36465: Make release and debug ABI compatible (GH-12615)

Release build and debug build are now ABI compatible: the Py_DEBUG
define no longer implies Py_TRACE_REFS define which introduces the
only ABI incompatibility.

A new "./configure --with-trace-refs" build option is now required to
get Py_TRACE_REFS define which adds sys.getobjects() function and
PYTHONDUMPREFS environment variable.

Changes:

* Add ./configure --with-trace-refs
* Py_DEBUG no longer implies Py_TRACE_REFS
parent 888f37bc
...@@ -922,15 +922,18 @@ conflict. ...@@ -922,15 +922,18 @@ conflict.
Debug-mode variables Debug-mode variables
~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~
Setting these variables only has an effect in a debug build of Python, that is, Setting these variables only has an effect in a debug build of Python.
if Python was configured with the ``--with-pydebug`` build option.
.. envvar:: PYTHONTHREADDEBUG .. envvar:: PYTHONTHREADDEBUG
If set, Python will print threading debug info. If set, Python will print threading debug info.
Need Python configured with the ``--with-pydebug`` build option.
.. envvar:: PYTHONDUMPREFS .. envvar:: PYTHONDUMPREFS
If set, Python will dump objects and reference counts still alive after If set, Python will dump objects and reference counts still alive after
shutting down the interpreter. shutting down the interpreter.
Need Python configured with the ``--with-trace-refs`` build option.
...@@ -54,13 +54,8 @@ A standard interface exists for objects that contain an array of items ...@@ -54,13 +54,8 @@ A standard interface exists for objects that contain an array of items
whose size is determined when the object is allocated. whose size is determined when the object is allocated.
*/ */
/* Py_DEBUG implies Py_TRACE_REFS. */ /* Py_DEBUG implies Py_REF_DEBUG. */
#if defined(Py_DEBUG) && !defined(Py_TRACE_REFS) #if defined(Py_DEBUG) && !defined(Py_REF_DEBUG)
#define Py_TRACE_REFS
#endif
/* Py_TRACE_REFS implies Py_REF_DEBUG. */
#if defined(Py_TRACE_REFS) && !defined(Py_REF_DEBUG)
#define Py_REF_DEBUG #define Py_REF_DEBUG
#endif #endif
......
...@@ -1653,7 +1653,7 @@ def python_is_optimized(): ...@@ -1653,7 +1653,7 @@ def python_is_optimized():
_header = 'nP' _header = 'nP'
_align = '0n' _align = '0n'
if hasattr(sys, "gettotalrefcount"): if hasattr(sys, "getobjects"):
_header = '2P' + _header _header = '2P' + _header
_align = '0P' _align = '0P'
_vheader = _header + 'n' _vheader = _header + 'n'
......
Release build and debug build are now ABI compatible: the ``Py_DEBUG`` define
no longer implies ``Py_TRACE_REFS`` define which introduces the only ABI
incompatibility. A new ``./configure --with-trace-refs`` build option is now
required to get ``Py_TRACE_REFS`` define which adds :func:`sys.getobjects`
function and ``PYTHONDUMPREFS`` environment variable.
...@@ -814,6 +814,7 @@ with_suffix ...@@ -814,6 +814,7 @@ with_suffix
enable_shared enable_shared
enable_profiling enable_profiling
with_pydebug with_pydebug
with_trace_refs
with_assertions with_assertions
enable_optimizations enable_optimizations
with_lto with_lto
...@@ -1500,6 +1501,7 @@ Optional Packages: ...@@ -1500,6 +1501,7 @@ Optional Packages:
compiler compiler
--with-suffix=.exe set executable suffix --with-suffix=.exe set executable suffix
--with-pydebug build with Py_DEBUG defined --with-pydebug build with Py_DEBUG defined
--with-trace-refs enable tracing references for debugging purpose
--with-assertions build with C assertions enabled --with-assertions build with C assertions enabled
--with-lto Enable Link Time Optimization in any build. Disabled --with-lto Enable Link Time Optimization in any build. Disabled
by default. by default.
...@@ -6333,8 +6335,30 @@ $as_echo "no" >&6; } ...@@ -6333,8 +6335,30 @@ $as_echo "no" >&6; }
fi fi
# Check for --with-assertions. Py_DEBUG implies assertions, but also changes # Check for --with-trace-refs
# the ABI. This allows enabling assertions without changing the ABI. # --with-trace-refs
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for --with-trace-refs" >&5
$as_echo_n "checking for --with-trace-refs... " >&6; }
# Check whether --with-trace-refs was given.
if test "${with_trace_refs+set}" = set; then :
withval=$with_trace_refs;
else
with_trace_refs=no
fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $with_trace_refs" >&5
$as_echo "$with_trace_refs" >&6; }
if test "$with_trace_refs" = "yes"
then
$as_echo "#define Py_TRACE_REFS 1" >>confdefs.h
fi
# Check for --with-assertions.
# This allows enabling assertions without Py_DEBUG.
assertions='false' assertions='false'
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for --with-assertions" >&5 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for --with-assertions" >&5
$as_echo_n "checking for --with-assertions... " >&6; } $as_echo_n "checking for --with-assertions... " >&6; }
......
...@@ -1228,8 +1228,21 @@ else AC_MSG_RESULT(no); Py_DEBUG='false' ...@@ -1228,8 +1228,21 @@ else AC_MSG_RESULT(no); Py_DEBUG='false'
fi], fi],
[AC_MSG_RESULT(no)]) [AC_MSG_RESULT(no)])
# Check for --with-assertions. Py_DEBUG implies assertions, but also changes # Check for --with-trace-refs
# the ABI. This allows enabling assertions without changing the ABI. # --with-trace-refs
AC_MSG_CHECKING(for --with-trace-refs)
AC_ARG_WITH(trace-refs,
AS_HELP_STRING([--with-trace-refs],[enable tracing references for debugging purpose]),,
with_trace_refs=no)
AC_MSG_RESULT($with_trace_refs)
if test "$with_trace_refs" = "yes"
then
AC_DEFINE(Py_TRACE_REFS, 1, [Define if you want to enable tracing references for debugging purpose])
fi
# Check for --with-assertions.
# This allows enabling assertions without Py_DEBUG.
assertions='false' assertions='false'
AC_MSG_CHECKING(for --with-assertions) AC_MSG_CHECKING(for --with-assertions)
AC_ARG_WITH(assertions, AC_ARG_WITH(assertions,
......
...@@ -1374,6 +1374,9 @@ ...@@ -1374,6 +1374,9 @@
externally defined: 0 */ externally defined: 0 */
#undef Py_HASH_ALGORITHM #undef Py_HASH_ALGORITHM
/* Define if you want to enable tracing references for debugging purpose */
#undef Py_TRACE_REFS
/* assume C89 semantics that RETSIGTYPE is always void */ /* assume C89 semantics that RETSIGTYPE is always void */
#undef RETSIGTYPE #undef RETSIGTYPE
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment