From b5bddbbbbcece5d52115bd3e1299cec2a3b362f0 Mon Sep 17 00:00:00 2001 From: Tom Tromey Date: Fri, 13 Jul 2018 12:45:07 -0600 Subject: [PATCH] Check results of get_darwin_inferior I noticed that the existing kill-detach-inferiors-cmd.exp test was causing gdb to crash on macOS 10.13. The bug was that an inferior that hadn't yet been started would cause get_darwin_inferior to return NULL, and this was not checked. I went through the places calling get_darwin_inferior and added checks where appropriate. This makes the test get a bit further. Not all of these spots are exercised by the test, but they seem safe enough in any case. gdb/ChangeLog 2018-08-02 Tom Tromey * darwin-nat.c (find_inferior_task_it, darwin_find_thread) (darwin_suspend_inferior, darwin_resume_inferior) (darwin_decode_notify_message, darwin_resume_inferior_threads) (darwin_check_new_threads): Check result of get_darwin_inferior. --- gdb/ChangeLog | 7 +++++++ gdb/darwin-nat.c | 35 +++++++++++++++++++++-------------- 2 files changed, 28 insertions(+), 14 deletions(-) diff --git a/gdb/ChangeLog b/gdb/ChangeLog index a591c820e4c..e0ea622f7ac 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,10 @@ +2018-08-02 Tom Tromey + + * darwin-nat.c (find_inferior_task_it, darwin_find_thread) + (darwin_suspend_inferior, darwin_resume_inferior) + (darwin_decode_notify_message, darwin_resume_inferior_threads) + (darwin_check_new_threads): Check result of get_darwin_inferior. + 2018-07-31 Joel Brobecker GDB 8.1.1 released. diff --git a/gdb/darwin-nat.c b/gdb/darwin-nat.c index bb46cfbfcfa..6d7b80ddcb1 100644 --- a/gdb/darwin-nat.c +++ b/gdb/darwin-nat.c @@ -259,6 +259,9 @@ darwin_check_new_threads (struct inferior *inf) darwin_inferior *darwin_inf = get_darwin_inferior (inf); std::vector new_thread_vec; + if (darwin_inf == nullptr) + return; + /* Get list of threads. */ kret = task_threads (darwin_inf->task, &thread_list, &new_nbr); MACH_CHECK_ERROR (kret); @@ -374,7 +377,7 @@ find_inferior_task_it (struct inferior *inf, void *port_ptr) { darwin_inferior *priv = get_darwin_inferior (inf); - return priv->task == *(task_t *)port_ptr; + return priv != nullptr && priv->task == *(task_t *)port_ptr; } static int @@ -403,11 +406,12 @@ darwin_find_thread (struct inferior *inf, thread_t thread) { darwin_inferior *priv = get_darwin_inferior (inf); - for (darwin_thread_t *t : priv->threads) - { - if (t->gdb_port == thread) - return t; - } + if (priv != nullptr) + for (darwin_thread_t *t : priv->threads) + { + if (t->gdb_port == thread) + return t; + } return NULL; } @@ -419,7 +423,7 @@ darwin_suspend_inferior (struct inferior *inf) { darwin_inferior *priv = get_darwin_inferior (inf); - if (!priv->suspended) + if (priv != nullptr && !priv->suspended) { kern_return_t kret; @@ -437,7 +441,7 @@ darwin_resume_inferior (struct inferior *inf) { darwin_inferior *priv = get_darwin_inferior (inf); - if (priv->suspended) + if (priv != nullptr && priv->suspended) { kern_return_t kret; @@ -766,11 +770,13 @@ darwin_decode_notify_message (mach_msg_header_t *hdr, struct inferior **pinf) inf = darwin_find_inferior_by_task (task_port); *pinf = inf; - darwin_inferior *priv = get_darwin_inferior (inf); - /* Check message destination. */ - if (inf != NULL && hdr->msgh_local_port != priv->notify_port) - return -4; + if (inf != NULL) + { + darwin_inferior *priv = get_darwin_inferior (inf); + if (hdr->msgh_local_port != priv->notify_port) + return -4; + } return 0; } @@ -882,8 +888,9 @@ darwin_resume_inferior_threads (struct inferior *inf, int step, int nsignal) { darwin_inferior *priv = get_darwin_inferior (inf); - for (darwin_thread_t *thread : priv->threads) - darwin_resume_thread (inf, thread, step, nsignal); + if (priv != nullptr) + for (darwin_thread_t *thread : priv->threads) + darwin_resume_thread (inf, thread, step, nsignal); } struct resume_inferior_threads_param -- 2.30.2