From 444c3224563f21fbbbacafa55575bc47310de2e0 Mon Sep 17 00:00:00 2001 From: Pedro Alves Date: Sat, 9 Aug 2008 21:26:22 +0000 Subject: [PATCH] * go32-nat.c: Include "gdbthread.h". (go32_stop, go32_kill_inferior): Delete the main thread. (go32_create_inferior): Add it. (go32_thread_alive, go32_pid_to_str): New. (init_go32_ops): Register go32_thread_alive and go32_pid_to_str. --- gdb/ChangeLog | 8 ++++++++ gdb/go32-nat.c | 24 ++++++++++++++++++++++++ 2 files changed, 32 insertions(+) diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 34baaa4e8fb..ffcbe3cf24f 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,11 @@ +2008-08-09 Pedro Alves + + * go32-nat.c: Include "gdbthread.h". + (go32_stop, go32_kill_inferior): Delete the main thread. + (go32_create_inferior): Add it. + (go32_thread_alive, go32_pid_to_str): New. + (init_go32_ops): Register go32_thread_alive and go32_pid_to_str. + 2008-08-09 Pedro Alves * go32-nat.c (fetch_register, store_register): Pass the regcache diff --git a/gdb/go32-nat.c b/gdb/go32-nat.c index 6c14160f553..88bbddffc77 100644 --- a/gdb/go32-nat.c +++ b/gdb/go32-nat.c @@ -22,6 +22,7 @@ #include "defs.h" #include "inferior.h" +#include "gdbthread.h" #include "gdb_wait.h" #include "gdbcore.h" #include "command.h" @@ -566,7 +567,9 @@ go32_stop (ptid_t ptid) { normal_stop (); cleanup_client (); + ptid = inferior_ptid; inferior_ptid = null_ptid; + delete_thread_silent (ptid); prog_has_started = 0; } @@ -576,6 +579,8 @@ go32_kill_inferior (void) redir_cmdline_delete (&child_cmd); resume_signal = -1; resume_is_step = 0; + if (!ptid_equal (inferior_ptid, null_ptid)) + delete_thread_silent (inferior_ptid); unpush_target (&go32_ops); } @@ -658,6 +663,9 @@ go32_create_inferior (char *exec_file, char *args, char **env, int from_tty) inferior_ptid = pid_to_ptid (SOME_PID); push_target (&go32_ops); + + add_thread_silent (inferior_ptid); + clear_proceed_status (); insert_breakpoints (); prog_has_started = 1; @@ -848,6 +856,20 @@ go32_terminal_ours (void) } } +static int +go32_thread_alive (ptid_t ptid) +{ + return 1; +} + +static char * +go32_pid_to_str (ptid_t ptid) +{ + static char buf[64]; + xsnprintf (buf, sizeof buf, "Thread
"); + return buf; +} + static void init_go32_ops (void) { @@ -878,6 +900,8 @@ init_go32_ops (void) go32_ops.to_mourn_inferior = go32_mourn_inferior; go32_ops.to_can_run = go32_can_run; go32_ops.to_stop = go32_stop; + go32_ops.to_thread_alive = go32_thread_alive; + go32_ops.to_pid_to_str = go32_pid_to_str; go32_ops.to_stratum = process_stratum; go32_ops.to_has_all_memory = 1; go32_ops.to_has_memory = 1; -- 2.30.2