Don't write to inferior_ptid in remote-sim.c

gdb/ChangeLog:
2020-06-18  Pedro Alves  <palves@redhat.com>

	* remote-sim.c (gdbsim_target::create_inferior): Switch to thread
	after creating it, instead of writing to inferior_ptid.
	(gdbsim_target_open): Use switch_to_no_thread instead of writing
	to inferior_ptid directly.
	(gdbsim_target::wait): Don't write to inferior_ptid.
This commit is contained in:
Pedro Alves 2020-06-18 21:28:25 +01:00
parent 0ac553107c
commit 191f02e593
2 changed files with 13 additions and 5 deletions

View File

@ -1,3 +1,11 @@
2020-06-18 Pedro Alves <palves@redhat.com>
* remote-sim.c (gdbsim_target::create_inferior): Switch to thread
after creating it, instead of writing to inferior_ptid.
(gdbsim_target_open): Use switch_to_no_thread instead of writing
to inferior_ptid directly.
(gdbsim_target::wait): Don't write to inferior_ptid.
2020-06-18 Pedro Alves <palves@redhat.com>
* remote.c (remote_target::remote_notice_new_inferior): Use

View File

@ -653,9 +653,10 @@ gdbsim_target::create_inferior (const char *exec_file,
!= SIM_RC_OK)
error (_("Unable to create sim inferior."));
inferior_ptid = sim_data->remote_sim_ptid;
inferior_appeared (current_inferior (), inferior_ptid.pid ());
add_thread_silent (this, inferior_ptid);
inferior_appeared (current_inferior (),
sim_data->remote_sim_ptid.pid ());
thread_info *thr = add_thread_silent (this, sim_data->remote_sim_ptid);
switch_to_thread (thr);
insert_breakpoints (); /* Needed to get correct instruction
in cache. */
@ -761,7 +762,7 @@ gdbsim_target_open (const char *args, int from_tty)
/* There's nothing running after "target sim" or "load"; not until
"run". */
inferior_ptid = null_ptid;
switch_to_no_thread ();
gdbsim_is_open = 1;
}
@ -945,7 +946,6 @@ gdbsim_target::wait (ptid_t ptid, struct target_waitstatus *status, int options)
if (sim_data == NULL)
error (_("Unable to wait for pid %d. Inferior not found."),
ptid.pid ());
inferior_ptid = ptid;
}
if (remote_debug)