+2018-05-02 Pedro Alves <palves@redhat.com>
+
+ * procfs.c (procfs_stopped_by_watchpoint)
+ (procfs_insert_watchpoint, procfs_remove_watchpoint)
+ (procfs_region_ok_for_hw_watchpoint, procfs_stopped_data_address):
+ Forward declare.
+ (procfs_use_watchpoints): Delete, move contents...
+ (procfs_target): ... here.
+ * procfs.h (procfs_use_watchpoints): Delete declaration.
+ * i386-sol2-nat.c (_initialize_amd64_sol2_nat): Don't call
+ procfs_use_watchpoints.
+ * sparc-sol2-nat.c (_initialize_sparc_sol2_nat): Don't call
+ procfs_use_watchpoints.
+
2018-05-02 Tom Tromey <tom@tromey.com>
PR python/20084:
static void procfs_info_proc (struct target_ops *, const char *,
enum info_proc_what);
+static int procfs_stopped_by_watchpoint (struct target_ops *);
+
+static int procfs_insert_watchpoint (struct target_ops *,
+ CORE_ADDR, int,
+ enum target_hw_bp_type,
+ struct expression *);
+
+static int procfs_remove_watchpoint (struct target_ops *,
+ CORE_ADDR, int,
+ enum target_hw_bp_type,
+ struct expression *);
+
+static int procfs_region_ok_for_hw_watchpoint (struct target_ops *,
+ CORE_ADDR, int);
+static int procfs_stopped_data_address (struct target_ops *, CORE_ADDR *);
+
#if defined (PR_MODEL_NATIVE) && (PR_MODEL_NATIVE == PR_MODEL_LP64)
/* When GDB is built as 64-bit application on Solaris, the auxv data
is presented in 64-bit format. We need to provide a custom parser
t->to_auxv_parse = procfs_auxv_parse;
#endif
+ t->to_stopped_by_watchpoint = procfs_stopped_by_watchpoint;
+ t->to_insert_watchpoint = procfs_insert_watchpoint;
+ t->to_remove_watchpoint = procfs_remove_watchpoint;
+ t->to_region_ok_for_hw_watchpoint = procfs_region_ok_for_hw_watchpoint;
+ t->to_can_use_hw_breakpoint = procfs_can_use_hw_breakpoint;
+ t->to_stopped_data_address = procfs_stopped_data_address;
+
t->to_magic = OPS_MAGIC;
return t;
return 1;
}
-void
-procfs_use_watchpoints (struct target_ops *t)
-{
- t->to_stopped_by_watchpoint = procfs_stopped_by_watchpoint;
- t->to_insert_watchpoint = procfs_insert_watchpoint;
- t->to_remove_watchpoint = procfs_remove_watchpoint;
- t->to_region_ok_for_hw_watchpoint = procfs_region_ok_for_hw_watchpoint;
- t->to_can_use_hw_breakpoint = procfs_can_use_hw_breakpoint;
- t->to_stopped_data_address = procfs_stopped_data_address;
-}
-
/* Memory Mappings Functions: */
/* Call a callback function once for each mapping, passing it the
extern struct target_ops *procfs_target (void);
-/* Call this in the native _initialize routine that creates and
- customizes the prototype target returned by procfs_target, if the
- native debug interface supports procfs watchpoints. */
-
-extern void procfs_use_watchpoints (struct target_ops *t);
-
/* Return a ptid for which we guarantee we will be able to find a
'live' procinfo. */