OSDN Git Service

* remote-m32r-sdi.c (m32r_thread_alive, m32r_pid_to_str): New.
authorpalves <palves>
Fri, 8 Aug 2008 02:45:11 +0000 (02:45 +0000)
committerpalves <palves>
Fri, 8 Aug 2008 02:45:11 +0000 (02:45 +0000)
(init_m32r_ops): Register m32r_thread_alive and m32r_pid_to_str.

gdb/ChangeLog
gdb/remote-m32r-sdi.c

index 6df70f2..5317a08 100644 (file)
@@ -1,5 +1,10 @@
 2008-08-08  Pedro Alves  <pedro@codesourcery.com>
 
+       * remote-m32r-sdi.c (m32r_thread_alive, m32r_pid_to_str): New.
+       (init_m32r_ops): Register m32r_thread_alive and m32r_pid_to_str.
+
+2008-08-08  Pedro Alves  <pedro@codesourcery.com>
+
        * remote-m32r-sdi.c: Include "gdbthread.h".
        (remote_m32r_ptid): New.
        (m32r_close): Delete the main thread.
index a8f095c..1caff52 100644 (file)
@@ -1490,6 +1490,34 @@ m32r_stopped_by_watchpoint (void)
   return m32r_stopped_data_address (&current_target, &addr);
 }
 
+/* Check to see if a thread is still alive.  */
+
+static int
+m32r_thread_alive (ptid_t ptid)
+{
+  if (ptid_equal (ptid, remote_m32r_ptid))
+    /* The main task is always alive.  */
+    return 1;
+
+  return 0;
+}
+
+/* Convert a thread ID to a string.  Returns the string in a static
+   buffer.  */
+
+static char *
+m32r_pid_to_str (ptid_t ptid)
+{
+  static char buf[64];
+
+  if (ptid_equal (remote_m32r_ptid, ptid))
+    {
+      xsnprintf (buf, sizeof buf, "Thread <main>");
+      return buf;
+    }
+
+  return normal_pid_to_str (ptid);
+}
 
 static void
 sdireset_command (char *args, int from_tty)
@@ -1612,6 +1640,8 @@ init_m32r_ops (void)
   m32r_ops.to_mourn_inferior = m32r_mourn_inferior;
   m32r_ops.to_stop = m32r_stop;
   m32r_ops.to_log_command = serial_log_command;
+  m32r_ops.to_thread_alive = m32r_thread_alive;
+  m32r_ops.to_pid_to_str = m32r_pid_to_str;
   m32r_ops.to_stratum = process_stratum;
   m32r_ops.to_has_all_memory = 1;
   m32r_ops.to_has_memory = 1;