gdbstub: Introduce gdb_handle_set_thread_user()

The upcoming follow-fork-mode child support needs to perform certain
actions when GDB switches between the stopped parent and the stopped
child. Introduce a user-specific hook for this.

Signed-off-by: Ilya Leoshkevich <iii@linux.ibm.com>
Message-Id: <20240219141628.246823-10-iii@linux.ibm.com>
Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
Message-Id: <20240305121005.3528075-11-alex.bennee@linaro.org>
This commit is contained in:
Ilya Leoshkevich 2024-03-05 12:09:46 +00:00 committed by Alex Bennée
parent 6d923112fd
commit e454f2fe24
3 changed files with 15 additions and 2 deletions

View File

@ -1099,6 +1099,7 @@ static void handle_cont_with_sig(GArray *params, void *user_ctx)
static void handle_set_thread(GArray *params, void *user_ctx) static void handle_set_thread(GArray *params, void *user_ctx)
{ {
uint32_t pid, tid;
CPUState *cpu; CPUState *cpu;
if (params->len != 2) { if (params->len != 2) {
@ -1116,8 +1117,14 @@ static void handle_set_thread(GArray *params, void *user_ctx)
return; return;
} }
cpu = gdb_get_cpu(get_param(params, 1)->thread_id.pid, pid = get_param(params, 1)->thread_id.pid;
get_param(params, 1)->thread_id.tid); tid = get_param(params, 1)->thread_id.tid;
#ifdef CONFIG_USER_ONLY
if (gdb_handle_set_thread_user(pid, tid)) {
return;
}
#endif
cpu = gdb_get_cpu(pid, tid);
if (!cpu) { if (!cpu) {
gdb_put_packet("E22"); gdb_put_packet("E22");
return; return;

View File

@ -197,6 +197,7 @@ void gdb_handle_v_file_readlink(GArray *params, void *user_ctx); /* user */
void gdb_handle_query_xfer_exec_file(GArray *params, void *user_ctx); /* user */ void gdb_handle_query_xfer_exec_file(GArray *params, void *user_ctx); /* user */
void gdb_handle_set_catch_syscalls(GArray *params, void *user_ctx); /* user */ void gdb_handle_set_catch_syscalls(GArray *params, void *user_ctx); /* user */
void gdb_handle_query_supported_user(const char *gdb_supported); /* user */ void gdb_handle_query_supported_user(const char *gdb_supported); /* user */
bool gdb_handle_set_thread_user(uint32_t pid, uint32_t tid); /* user */
void gdb_handle_query_attached(GArray *params, void *user_ctx); /* both */ void gdb_handle_query_attached(GArray *params, void *user_ctx); /* both */

View File

@ -386,6 +386,11 @@ void gdb_handle_query_supported_user(const char *gdb_supported)
{ {
} }
bool gdb_handle_set_thread_user(uint32_t pid, uint32_t tid)
{
return false;
}
/* /*
* Execution state helpers * Execution state helpers
*/ */