convert to_can_execute_reverse
authorTom Tromey <tromey@redhat.com>
Wed, 18 Dec 2013 18:12:28 +0000 (11:12 -0700)
committerTom Tromey <tromey@redhat.com>
Wed, 19 Feb 2014 14:47:35 +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_can_execute_reverse.
* target.h (struct target_ops) <to_can_execute_reverse>: Use
TARGET_DEFAULT_RETURN.
(target_can_execute_reverse): Unconditionally delegate.

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

index d68cd3fba0bf40d84fec08bef152a5551895b479..48940193a8a61cb956f8e11c675929317d98b743 100644 (file)
@@ -1,3 +1,12 @@
+2014-02-19  Tom Tromey  <tromey@redhat.com>
+
+       * target-delegates.c: Rebuild.
+       * target.c (update_current_target): Don't inherit or default
+       to_can_execute_reverse.
+       * target.h (struct target_ops) <to_can_execute_reverse>: Use
+       TARGET_DEFAULT_RETURN.
+       (target_can_execute_reverse): Unconditionally delegate.
+
 2014-02-19  Tom Tromey  <tromey@redhat.com>
 
        * target-delegates.c: Rebuild.
index cb03f54c7b29ce91c1080ba1814fef542dc19261..573f9b5f92c7e9e0ec41692a45c69ea889524d6e 100644 (file)
@@ -564,6 +564,19 @@ tdefault_xfer_partial (struct target_ops *self, enum target_object  arg1, const
   return TARGET_XFER_E_IO;
 }
 
+static int
+delegate_can_execute_reverse (struct target_ops *self)
+{
+  self = self->beneath;
+  return self->to_can_execute_reverse (self);
+}
+
+static int
+tdefault_can_execute_reverse (struct target_ops *self)
+{
+  return 0;
+}
+
 static int
 delegate_supports_btrace (struct target_ops *self)
 {
@@ -678,6 +691,8 @@ install_delegators (struct target_ops *ops)
     ops->to_goto_bookmark = delegate_goto_bookmark;
   if (ops->to_xfer_partial == NULL)
     ops->to_xfer_partial = delegate_xfer_partial;
+  if (ops->to_can_execute_reverse == NULL)
+    ops->to_can_execute_reverse = delegate_can_execute_reverse;
   if (ops->to_supports_btrace == NULL)
     ops->to_supports_btrace = delegate_supports_btrace;
 }
@@ -734,5 +749,6 @@ install_dummy_methods (struct target_ops *ops)
   ops->to_get_bookmark = tdefault_get_bookmark;
   ops->to_goto_bookmark = tdefault_goto_bookmark;
   ops->to_xfer_partial = tdefault_xfer_partial;
+  ops->to_can_execute_reverse = tdefault_can_execute_reverse;
   ops->to_supports_btrace = tdefault_supports_btrace;
 }
index 5aefda9b3b0fcadc39cf2504f524bfa42c0449d3..1f60aa0f4d2b6ca55b77ca4815996cb83d7456df 100644 (file)
@@ -673,7 +673,7 @@ update_current_target (void)
       /* Do not inherit to_get_bookmark.  */
       /* Do not inherit to_goto_bookmark.  */
       /* Do not inherit to_get_thread_local_address.  */
-      INHERIT (to_can_execute_reverse, t);
+      /* Do not inherit to_can_execute_reverse.  */
       INHERIT (to_execution_direction, t);
       INHERIT (to_thread_architecture, t);
       /* Do not inherit to_read_description.  */
index 05a6b1a69f355d8e7723a81cccaa1bbbc658be35..9b0ad98f21116832a0b80d69d9a0977eb94e3e37 100644 (file)
@@ -701,7 +701,8 @@ struct target_ops
                             CORE_ADDR *found_addrp);
 
     /* Can target execute in reverse?  */
-    int (*to_can_execute_reverse) (struct target_ops *);
+    int (*to_can_execute_reverse) (struct target_ops *)
+      TARGET_DEFAULT_RETURN (0);
 
     /* The direction the target is currently executing.  Must be
        implemented on targets that support reverse execution and async
@@ -1759,8 +1760,7 @@ extern int target_masked_watch_num_registers (CORE_ADDR addr, CORE_ADDR mask);
 
 /* Target can execute in reverse?  */
 #define target_can_execute_reverse \
-     (current_target.to_can_execute_reverse ? \
-      current_target.to_can_execute_reverse (&current_target) : 0)
+      current_target.to_can_execute_reverse (&current_target)
 
 extern const struct target_desc *target_read_description (struct target_ops *);
 
This page took 0.033419 seconds and 4 git commands to generate.