Skip to content
This repository has been archived by the owner on Aug 17, 2022. It is now read-only.

Commit

Permalink
gdb, remote, btrace: move switch_to_thread call right before xfer call
Browse files Browse the repository at this point in the history
In remote_target::remote_btrace_maybe_reopen, we switch to the currently
iterated thread in order to set inferior_ptid for a subsequent xfer.

Move the switch_to_thread call directly before the target_read_stralloc
call to clarify why we need to switch threads.
  • Loading branch information
markus-metzger committed Jan 27, 2022
1 parent 696c0d5 commit 0d8cbc5
Showing 1 changed file with 8 additions and 9 deletions.
17 changes: 8 additions & 9 deletions gdb/remote.c
Original file line number Diff line number Diff line change
Expand Up @@ -14103,12 +14103,15 @@ remote_target::btrace_sync_conf (const btrace_config *conf)
}
}

/* Read the current thread's btrace configuration from the target and
store it into CONF. */
/* Read TP's btrace configuration from the target and store it into CONF. */

static void
btrace_read_config (struct btrace_config *conf)
btrace_read_config (thread_info *tp, struct btrace_config *conf)
{
/* target_read_stralloc relies on INFERIOR_PTID. */
scoped_restore_current_thread restore_thread;
switch_to_thread (tp);

gdb::optional<gdb::char_vector> xml
= target_read_stralloc (current_inferior ()->top_target (),
TARGET_OBJECT_BTRACE_CONF, "");
Expand All @@ -14132,14 +14135,10 @@ remote_target::remote_btrace_maybe_reopen ()
if (packet_support (PACKET_qXfer_btrace_conf) != PACKET_ENABLE)
return;

scoped_restore_current_thread restore_thread;

for (thread_info *tp : all_non_exited_threads (this))
{
switch_to_thread (tp);

memset (&rs->btrace_config, 0x00, sizeof (struct btrace_config));
btrace_read_config (&rs->btrace_config);
btrace_read_config (tp, &rs->btrace_config);

if (rs->btrace_config.format == BTRACE_FORMAT_NONE)
continue;
Expand Down Expand Up @@ -14227,7 +14226,7 @@ remote_target::enable_btrace (thread_info *tp,
tracing itself is not impacted. */
try
{
btrace_read_config (&tinfo->conf);
btrace_read_config (tp, &tinfo->conf);
}
catch (const gdb_exception_error &err)
{
Expand Down

0 comments on commit 0d8cbc5

Please sign in to comment.