From: Pedro Alves Date: Thu, 18 Jun 2020 20:28:28 +0000 (+0100) Subject: Don't write to inferior_ptid in gnu-nat.c X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=975f8708de015fb2b813edbf8b714f4777c57a41;p=binutils-gdb.git Don't write to inferior_ptid in gnu-nat.c Untested. gdb/ChangeLog: 2020-06-18 Pedro Alves * 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. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index eff2fa2093e..88db3be38c8 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,13 @@ +2020-06-18 Pedro Alves + + * 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. + 2020-06-18 Pedro Alves * go32-nat.c (go32_nat_target::create_inferior): Don't write to diff --git a/gdb/gnu-nat.c b/gdb/gnu-nat.c index 44adda5fe12..3cee06dc4db 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 (); }