aboutsummaryrefslogtreecommitdiff
path: root/gdb/python
diff options
context:
space:
mode:
authorTom Tromey <tromey@redhat.com>2008-11-21 14:59:56 +0000
committerTom Tromey <tromey@redhat.com>2008-11-21 14:59:56 +0000
commitca30a76297419a1e0eac2ee6a709dff70d30e56a (patch)
treee13c237992ce5984085aee7f424db45b05c1dab9 /gdb/python
parent3c9ab205d3020ddcb720946b4b7b1b6cc8de7bcb (diff)
downloadgdb-ca30a76297419a1e0eac2ee6a709dff70d30e56a.zip
gdb-ca30a76297419a1e0eac2ee6a709dff70d30e56a.tar.gz
gdb-ca30a76297419a1e0eac2ee6a709dff70d30e56a.tar.bz2
* python/python-internal.h (PyGILState_Ensure): New define.
(PyGILState_Release): Likewise. (PyEval_InitThreads): Likewise. (PyThreadState_Swap): Likewise. (PyEval_InitThreads): Likewise. * python/python.c (_initialize_python): Initialize threads. Release GIL. (eval_python_from_control_command): Acquire GIL. (python_command): Likewise. * python/python-internal.h (make_cleanup_py_restore_gil): Declare. * python/python-utils.c (py_gil_restore): New function. (make_cleanup_py_restore_gil): Likewise.
Diffstat (limited to 'gdb/python')
-rw-r--r--gdb/python/python-internal.h12
-rw-r--r--gdb/python/python-utils.c17
-rw-r--r--gdb/python/python.c24
3 files changed, 51 insertions, 2 deletions
diff --git a/gdb/python/python-internal.h b/gdb/python/python-internal.h
index 72f7a5f..dbc0a53 100644
--- a/gdb/python/python-internal.h
+++ b/gdb/python/python-internal.h
@@ -43,6 +43,17 @@ typedef Py_intptr_t Py_ssize_t;
#error "Unable to find usable Python.h"
#endif
+/* If Python.h does not define WITH_THREAD, then the various
+ GIL-related functions will not be defined. However,
+ PyGILState_STATE will be. */
+#ifndef WITH_THREAD
+#define PyGILState_Ensure() ((PyGILState_STATE) 0)
+#define PyGILState_Release(ARG) (ARG)
+#define PyEval_InitThreads() 0
+#define PyThreadState_Swap(ARG) (ARG)
+#define PyEval_InitThreads() 0
+#endif
+
struct value;
extern PyObject *gdb_module;
@@ -57,6 +68,7 @@ struct value *convert_value_from_python (PyObject *obj);
void gdbpy_initialize_values (void);
struct cleanup *make_cleanup_py_decref (PyObject *py);
+struct cleanup *make_cleanup_py_restore_gil (PyGILState_STATE *state);
/* Use this after a TRY_EXCEPT to throw the appropriate Python
exception. */
diff --git a/gdb/python/python-utils.c b/gdb/python/python-utils.c
index 912845f..8db81ec 100644
--- a/gdb/python/python-utils.c
+++ b/gdb/python/python-utils.c
@@ -46,6 +46,23 @@ make_cleanup_py_decref (PyObject *py)
return make_cleanup (py_decref, (void *) py);
}
+/* A cleanup function to restore the thread state. */
+
+static void
+py_gil_restore (void *p)
+{
+ PyGILState_STATE *state = p;
+ PyGILState_Release (*state);
+}
+
+/* Return a new cleanup which will restore the Python GIL state. */
+
+struct cleanup *
+make_cleanup_py_restore_gil (PyGILState_STATE *state)
+{
+ return make_cleanup (py_gil_restore, state);
+}
+
/* Converts a Python 8-bit string to a unicode string object. Assumes the
8-bit string is in the host charset. If an error occurs during conversion,
returns NULL with a python exception set.
diff --git a/gdb/python/python.c b/gdb/python/python.c
index 77d8774..50277d4 100644
--- a/gdb/python/python.c
+++ b/gdb/python/python.c
@@ -103,10 +103,15 @@ void
eval_python_from_control_command (struct command_line *cmd)
{
char *script;
+ struct cleanup *cleanup;
+ PyGILState_STATE state;
if (cmd->body_count != 1)
error (_("Invalid \"python\" block structure."));
+ state = PyGILState_Ensure ();
+ cleanup = make_cleanup_py_restore_gil (&state);
+
script = compute_python_string (cmd->body_list[0]);
PyRun_SimpleString (script);
xfree (script);
@@ -115,6 +120,8 @@ eval_python_from_control_command (struct command_line *cmd)
gdbpy_print_stack ();
error (_("error while executing Python code"));
}
+
+ do_cleanups (cleanup);
}
/* Implementation of the gdb "python" command. */
@@ -122,6 +129,12 @@ eval_python_from_control_command (struct command_line *cmd)
static void
python_command (char *arg, int from_tty)
{
+ struct cleanup *cleanup;
+ PyGILState_STATE state;
+
+ state = PyGILState_Ensure ();
+ cleanup = make_cleanup_py_restore_gil (&state);
+
while (arg && *arg && isspace (*arg))
++arg;
if (arg && *arg)
@@ -136,10 +149,11 @@ python_command (char *arg, int from_tty)
else
{
struct command_line *l = get_command_line (python_control, "");
- struct cleanup *cleanups = make_cleanup_free_command_lines (&l);
+ make_cleanup_free_command_lines (&l);
execute_control_command_untraced (l);
- do_cleanups (cleanups);
}
+
+ do_cleanups (cleanup);
}
@@ -392,6 +406,7 @@ Enables or disables printing of Python stack traces."),
#ifdef HAVE_PYTHON
Py_Initialize ();
+ PyEval_InitThreads ();
gdb_module = Py_InitModule ("gdb", GdbMethods);
@@ -429,5 +444,10 @@ class GdbOutputFile:\n\
sys.stderr = GdbOutputFile()\n\
sys.stdout = GdbOutputFile()\n\
");
+
+ /* Release the GIL while gdb runs. */
+ PyThreadState_Swap (NULL);
+ PyEval_ReleaseLock ();
+
#endif /* HAVE_PYTHON */
}