aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom Tromey <tromey@adacore.com>2019-07-11 09:09:52 -0600
committerTom Tromey <tromey@adacore.com>2019-07-11 09:15:18 -0600
commit72ee03ff58d954dbed886b672032c8c9db0a0dcc (patch)
treefe284b1f674e18918daf38ed7e594aa7ae1e884c
parent00db9531969db8b6ab984da996d0411fad938589 (diff)
downloadgdb-72ee03ff58d954dbed886b672032c8c9db0a0dcc.zip
gdb-72ee03ff58d954dbed886b672032c8c9db0a0dcc.tar.gz
gdb-72ee03ff58d954dbed886b672032c8c9db0a0dcc.tar.bz2
Fix use-after-move bug in add_thread_object
commit 05b08ac1608 ("Reduce manual reference counting in py-inferior.c") introduced a use-after-move bug in add_thread_object, causing a test suite failure. This patch fixes the bug. Tested on x86-64 Fedora 29. gdb/ChangeLog 2019-07-11 Tom Tromey <tromey@adacore.com> * python/py-inferior.c (add_thread_object): Don't use thread_obj after it has been moved.
-rw-r--r--gdb/ChangeLog5
-rw-r--r--gdb/python/py-inferior.c2
2 files changed, 6 insertions, 1 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index 49ccba7..b5585b4 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,3 +1,8 @@
+2019-07-11 Tom Tromey <tromey@adacore.com>
+
+ * python/py-inferior.c (add_thread_object): Don't use thread_obj
+ after it has been moved.
+
2019-07-10 Simon Marchi <simon.marchi@polymtl.ca>
* valops.c (value_must_coerce_to_target): Change return type to
diff --git a/gdb/python/py-inferior.c b/gdb/python/py-inferior.c
index bf43012..2888222 100644
--- a/gdb/python/py-inferior.c
+++ b/gdb/python/py-inferior.c
@@ -344,7 +344,7 @@ add_thread_object (struct thread_info *tp)
return;
gdbpy_ref<> event = create_thread_event_object (&new_thread_event_object_type,
- (PyObject *) thread_obj.get ());
+ (PyObject *) inf_obj);
if (event == NULL
|| evpy_emit_event (event.get (), gdb_py_events.new_thread) < 0)
gdbpy_print_stack ();