convert to_supports_multi_process
authorTom Tromey <tromey@redhat.com>
Wed, 18 Dec 2013 20:54:06 +0000 (13:54 -0700)
committerTom Tromey <tromey@redhat.com>
Wed, 19 Feb 2014 14:47:39 +0000 (07:47 -0700)
2014-02-19  Tom Tromey  <tromey@redhat.com>

* target-delegates.c: Rebuild.
* target.c (update_current_target): Don't inherit or default
to_supports_multi_process.
* target.h (struct target_ops) <to_supports_multi_process>: Use
TARGET_DEFAULT_RETURN.

gdb/ChangeLog
gdb/target-delegates.c
gdb/target.c
gdb/target.h

index fc14e4888625639d605709095444d46d18eadfe0..73ffdf89dfdade4c69bda5f9b86ae4135fd0d062 100644 (file)
@@ -1,3 +1,11 @@
+2014-02-19  Tom Tromey  <tromey@redhat.com>
+
+       * target-delegates.c: Rebuild.
+       * target.c (update_current_target): Don't inherit or default
+       to_supports_multi_process.
+       * target.h (struct target_ops) <to_supports_multi_process>: Use
+       TARGET_DEFAULT_RETURN.
+
 2014-02-19  Tom Tromey  <tromey@redhat.com>
 
        * target-delegates.c: Rebuild.
index f92b0963dc6b9b91897037864b8e29ae86d6db2b..3a322c11fe897e3002a9590a79b940b408172b0d 100644 (file)
@@ -591,6 +591,19 @@ delegate_execution_direction (struct target_ops *self)
   return self->to_execution_direction (self);
 }
 
+static int
+delegate_supports_multi_process (struct target_ops *self)
+{
+  self = self->beneath;
+  return self->to_supports_multi_process (self);
+}
+
+static int
+tdefault_supports_multi_process (struct target_ops *self)
+{
+  return 0;
+}
+
 static struct gdbarch *
 delegate_thread_architecture (struct target_ops *self, ptid_t arg1)
 {
@@ -718,6 +731,8 @@ install_delegators (struct target_ops *ops)
     ops->to_can_execute_reverse = delegate_can_execute_reverse;
   if (ops->to_execution_direction == NULL)
     ops->to_execution_direction = delegate_execution_direction;
+  if (ops->to_supports_multi_process == NULL)
+    ops->to_supports_multi_process = delegate_supports_multi_process;
   if (ops->to_thread_architecture == NULL)
     ops->to_thread_architecture = delegate_thread_architecture;
   if (ops->to_supports_btrace == NULL)
@@ -779,6 +794,7 @@ install_dummy_methods (struct target_ops *ops)
   ops->to_get_ada_task_ptid = default_get_ada_task_ptid;
   ops->to_can_execute_reverse = tdefault_can_execute_reverse;
   ops->to_execution_direction = default_execution_direction;
+  ops->to_supports_multi_process = tdefault_supports_multi_process;
   ops->to_thread_architecture = default_thread_architecture;
   ops->to_supports_btrace = tdefault_supports_btrace;
 }
index 083d6b56d3c291e6eee1aeec027adb0926b40bde..bfa36350f2a691e958068d78c742ceca7832dc37 100644 (file)
@@ -685,7 +685,7 @@ update_current_target (void)
       /* Do not inherit to_read_description.  */
       /* Do not inherit to_get_ada_task_ptid.  */
       /* Do not inherit to_search_memory.  */
-      INHERIT (to_supports_multi_process, t);
+      /* Do not inherit to_supports_multi_process.  */
       INHERIT (to_supports_enable_disable_tracepoint, t);
       INHERIT (to_supports_string_tracing, t);
       INHERIT (to_trace_init, t);
@@ -752,9 +752,6 @@ update_current_target (void)
            (void (*) (struct target_ops *, ptid_t))
            target_ignore);
   current_target.to_read_description = NULL;
-  de_fault (to_supports_multi_process,
-           (int (*) (struct target_ops *))
-           return_zero);
   de_fault (to_supports_enable_disable_tracepoint,
            (int (*) (struct target_ops *))
            return_zero);
index fc90a8bd2c7cfdd9f16b6f88f46bd62c59bea7dd..390201d598c41f8609a629dcb46142dedba0d650 100644 (file)
@@ -713,7 +713,8 @@ struct target_ops
 
     /* Does this target support debugging multiple processes
        simultaneously?  */
-    int (*to_supports_multi_process) (struct target_ops *);
+    int (*to_supports_multi_process) (struct target_ops *)
+      TARGET_DEFAULT_RETURN (0);
 
     /* Does this target support enabling and disabling tracepoints while a trace
        experiment is running?  */