aboutsummaryrefslogtreecommitdiff
path: root/gdb/gnu-nat.c
diff options
context:
space:
mode:
authorPedro Alves <palves@redhat.com>2020-06-18 21:28:28 +0100
committerPedro Alves <palves@redhat.com>2020-06-18 23:11:23 +0100
commit975f8708de015fb2b813edbf8b714f4777c57a41 (patch)
treeb8ce29a14c6aa23f7c87d4743c7ff134b50b954f /gdb/gnu-nat.c
parent1a20473059c7a088b9f3c4188c09976eebbc3ab4 (diff)
downloadbinutils-975f8708de015fb2b813edbf8b714f4777c57a41.zip
binutils-975f8708de015fb2b813edbf8b714f4777c57a41.tar.gz
binutils-975f8708de015fb2b813edbf8b714f4777c57a41.tar.bz2
Don't write to inferior_ptid in gnu-nat.c
Untested. gdb/ChangeLog: 2020-06-18 Pedro Alves <palves@redhat.com> * gnu-nat.c (gnu_nat_target::create_inferior): Switch to the added thread. (gnu_nat_target::attach): Don't write to inferior_ptid directly. Instead use switch_to_thread. (gnu_nat_target::detach): Use switch_to_no_thread instead of writing to inferior_ptid directly. Used passed-in inferior instead of looking up the inferior by pid.
Diffstat (limited to 'gdb/gnu-nat.c')
-rw-r--r--gdb/gnu-nat.c15
1 files changed, 7 insertions, 8 deletions
diff --git a/gdb/gnu-nat.c b/gdb/gnu-nat.c
index 44adda5..3cee06d 100644
--- a/gdb/gnu-nat.c
+++ b/gdb/gnu-nat.c
@@ -2121,7 +2121,8 @@ gnu_nat_target::create_inferior (const char *exec_file,
/* We have something that executes now. We'll be running through
the shell at this point (if startup-with-shell is true), but the
pid shouldn't change. */
- add_thread_silent (this, ptid_t (pid));
+ thread_info *thr = add_thread_silent (this, ptid_t (pid));
+ switch_to_thread (thr);
/* Attach to the now stopped child, which is actually a shell... */
inf_debug (inf, "attaching to child: %d", pid);
@@ -2196,7 +2197,9 @@ gnu_nat_target::attach (const char *args, int from_tty)
inf_update_procs (inf);
- inferior_ptid = ptid_t (pid, inf_pick_first_thread (), 0);
+ thread_info *thr
+ = find_thread_ptid (this, ptid_t (pid, inf_pick_first_thread ()));
+ switch_to_thread (thr);
/* We have to initialize the terminal settings now, since the code
below might try to restore them. */
@@ -2225,8 +2228,6 @@ gnu_nat_target::attach (const char *args, int from_tty)
void
gnu_nat_target::detach (inferior *inf, int from_tty)
{
- int pid;
-
if (from_tty)
{
const char *exec_file = get_exec_file (0);
@@ -2238,12 +2239,10 @@ gnu_nat_target::detach (inferior *inf, int from_tty)
printf_unfiltered ("Detaching from pid %d\n", gnu_current_inf->pid);
}
- pid = gnu_current_inf->pid;
-
inf_detach (gnu_current_inf);
- inferior_ptid = null_ptid;
- detach_inferior (find_inferior_pid (this, pid));
+ switch_to_no_thread ();
+ detach_inferior (inf);
maybe_unpush_target ();
}