|
|
0b3064 |
From FEDORA_PATCHES Mon Sep 17 00:00:00 2001
|
|
|
0b3064 |
From: Kevin Buettner <kevinb@redhat.com>
|
|
|
0b3064 |
Date: Thu, 16 Apr 2020 05:27:26 -0700
|
|
|
0b3064 |
Subject: gdb-rhbz1822715-fix-python-deprecation.patch
|
|
|
0b3064 |
|
|
|
0b3064 |
;; Backport fix for deprecation of PyEval_InitThreads in Python 3.9.
|
|
|
0b3064 |
|
|
|
0b3064 |
Fix compilation of python/python.c for Python 3.9
|
|
|
0b3064 |
|
|
|
0b3064 |
This commit fixes a compilation warning/error when building GDB
|
|
|
0b3064 |
with Python 3.9:
|
|
|
0b3064 |
|
|
|
0b3064 |
g++ -x c++ -O2 -g -pipe -Wall -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -Wp,-D_GLIBCXX_ASSERTIONS -fexceptions -fstack-protector-strong -grecord-gcc-switches -specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -specs=/usr/lib/rpm/redhat/redhat-annobin-cc1 -m64 -mtune=generic -fasynchronous-unwind-tables -fstack-clash-protection -fcf-protection -DDNF_DEBUGINFO_INSTALL -I. -I../../gdb -I../../gdb/config -DLOCALEDIR="\"/usr/share/locale\"" -DHAVE_CONFIG_H -I../../gdb/../include/opcode -I../bfd -I../../gdb/../bfd -I../../gdb/../include -I../libdecnumber -I../../gdb/../libdecnumber -I../../gdb/../gnulib/import -I../gnulib/import -DTUI=1 -I/usr/include/guile/2.0 -pthread -I/usr/include/python3.9 -I/usr/include/python3.9 -I../../gdb/.. -pthread -Wall -Wpointer-arith -Wno-unused -Wunused-value -Wunused-variable -Wunused-function -Wno-switch -Wno-char-subscripts -Wempty-body -Wunused-but-set-parameter -Wunused-but-set-variable -Wno-sign-compare -Wno-error=maybe-uninitialized -Wno-mismatched-tags -Wsuggest-override -Wimplicit-fallthrough=3 -Wduplicated-cond -Wshadow=local -Wdeprecated-copy -Wdeprecated-copy-dtor -Wredundant-move -Wformat -Wformat-nonliteral -Wno-unused -Werror -c -o ser-tcp.o -MT ser-tcp.o -MMD -MP -MF ./.deps/ser-tcp.Tpo ../../gdb/ser-tcp.c
|
|
|
0b3064 |
../../gdb/python/python.c: In function 'bool do_start_initialization()':
|
|
|
0b3064 |
../../gdb/python/python.c:1621:23: error: 'void PyEval_InitThreads()' is deprecated [-Werror=deprecated-declarations]
|
|
|
0b3064 |
1621 | PyEval_InitThreads ();
|
|
|
0b3064 |
| ^
|
|
|
0b3064 |
In file included from /usr/include/python3.9/Python.h:141,
|
|
|
0b3064 |
from ../../gdb/python/python-internal.h:86,
|
|
|
0b3064 |
from ../../gdb/python/python.c:92:
|
|
|
0b3064 |
/usr/include/python3.9/ceval.h:132:37: note: declared here
|
|
|
0b3064 |
132 | Py_DEPRECATED(3.9) PyAPI_FUNC(void) PyEval_InitThreads(void);
|
|
|
0b3064 |
| ^~~~~~~~~~~~~~~~~~
|
|
|
0b3064 |
|
|
|
0b3064 |
Information about the deprecated function can be found here:
|
|
|
0b3064 |
|
|
|
0b3064 |
https://docs.python.org/3.9/whatsnew/3.9.html#deprecated
|
|
|
0b3064 |
|
|
|
0b3064 |
Specifically, with regard to PyEval_InitThreads(), it says:
|
|
|
0b3064 |
|
|
|
0b3064 |
The PyEval_InitThreads() and PyEval_ThreadsInitialized() functions
|
|
|
0b3064 |
are now deprecated and will be removed in Python 3.11. Calling
|
|
|
0b3064 |
PyEval_InitThreads() now does nothing. The GIL is initialized by
|
|
|
0b3064 |
Py_Initialize() since Python 3.7. (Contributed by Victor Stinner
|
|
|
0b3064 |
in bpo-39877.)
|
|
|
0b3064 |
|
|
|
0b3064 |
I chose to disable the call with a #if test using PY_VERSION_HEX.
|
|
|
0b3064 |
There is precedent for use of PY_VERSION_HEX; it's used in two places
|
|
|
0b3064 |
in python-internal.h. I noticed that under certain circumstances
|
|
|
0b3064 |
python-internal.h defines PyEval_InitThreads to be nothing, which
|
|
|
0b3064 |
accomplishes the same thing. I considered doing something similar for
|
|
|
0b3064 |
this case, but decided against it because, at some point in the future,
|
|
|
0b3064 |
the presence of PyEval_InitThreads() without some explanation will be
|
|
|
0b3064 |
confusing to a reader who won't be able to find PyEval_InitThreads in
|
|
|
0b3064 |
the current (future for us) Python API. IMO, use of the #if along
|
|
|
0b3064 |
with an accompanying comment seemed more straightforward.
|
|
|
0b3064 |
|
|
|
0b3064 |
gdb/ChangeLog:
|
|
|
0b3064 |
|
|
|
0b3064 |
* python/python.c (do_start_initialization): Don't call
|
|
|
0b3064 |
PyEval_InitThreads for Python 3.9 and beyond.
|
|
|
0b3064 |
|
|
|
0b3064 |
Change-Id: I0679fc10b6b76761a99538568f13188c6d8014e0
|
|
|
0b3064 |
|
|
|
0b3064 |
diff --git a/gdb/python/python.c b/gdb/python/python.c
|
|
|
0b3064 |
--- a/gdb/python/python.c
|
|
|
0b3064 |
+++ b/gdb/python/python.c
|
|
|
0b3064 |
@@ -1618,7 +1618,12 @@ do_start_initialization ()
|
|
|
0b3064 |
#endif
|
|
|
0b3064 |
|
|
|
0b3064 |
Py_Initialize ();
|
|
|
0b3064 |
+#if PY_VERSION_HEX < 0x03090000
|
|
|
0b3064 |
+ /* PyEval_InitThreads became deprecated in Python 3.9 and will
|
|
|
0b3064 |
+ be removed in Python 3.11. Prior to Python 3.7, this call was
|
|
|
0b3064 |
+ required to initialize the GIL. */
|
|
|
0b3064 |
PyEval_InitThreads ();
|
|
|
0b3064 |
+#endif
|
|
|
0b3064 |
|
|
|
0b3064 |
#ifdef IS_PY3K
|
|
|
0b3064 |
gdb_module = PyImport_ImportModule ("_gdb");
|