+2021-05-09 Andrew Burgess <andrew.burgess@embecosm.com>
+
+ * python/py-breakpoint.c (pybp_debug): New static global.
+ (show_pybp_debug): New function.
+ (pybp_debug_printf): Define.
+ (PYBP_SCOPED_DEBUG_ENTER_EXIT): Define.
+ (gdbpy_breakpoint_created): Add some debugging.
+ (gdbpy_breakpoint_deleted): Likewise.
+ (gdbpy_breakpoint_modified): Likewise.
+ (_initialize_py_breakpoint): New function.
+
2021-05-09 Andrew Burgess <andrew.burgess@embecosm.com>
* python/py-unwind.c (pyuw_debug): Convert to bool.
#include "py-event.h"
#include "linespec.h"
+/* Debugging of Python breakpoints. */
+
+static bool pybp_debug;
+
+/* Implementation of "show debug py-breakpoint". */
+
+static void
+show_pybp_debug (struct ui_file *file, int from_tty,
+ struct cmd_list_element *c, const char *value)
+{
+ fprintf_filtered (file, _("Python breakpoint debugging is %s.\n"), value);
+}
+
+/* Print a "py-breakpoint" debug statement. */
+
+#define pybp_debug_printf(fmt, ...) \
+ debug_prefixed_printf_cond (pybp_debug, "py-breakpoint", fmt, ##__VA_ARGS__)
+
+/* Print a "py-breakpoint" enter/exit debug statements. */
+
+#define PYBP_SCOPED_DEBUG_ENTER_EXIT \
+ scoped_debug_enter_exit (pybp_debug, "py-breakpoint")
+
/* Number of live breakpoints. */
static int bppy_live;
static void
gdbpy_breakpoint_created (struct breakpoint *bp)
{
+ PYBP_SCOPED_DEBUG_ENTER_EXIT;
+
gdbpy_breakpoint_object *newbp;
if (!user_breakpoint_p (bp) && bppy_pending_object == NULL)
- return;
+ {
+ pybp_debug_printf ("not attaching python object to this breakpoint");
+ return;
+ }
if (bp->type != bp_breakpoint
&& bp->type != bp_hardware_breakpoint
&& bp->type != bp_hardware_watchpoint
&& bp->type != bp_read_watchpoint
&& bp->type != bp_access_watchpoint)
- return;
+ {
+ pybp_debug_printf ("is not a breakpoint or watchpoint");
+ return;
+ }
struct gdbarch *garch = bp->gdbarch ? bp->gdbarch : get_current_arch ();
gdbpy_enter enter_py (garch, current_language);
newbp = bppy_pending_object;
Py_INCREF (newbp);
bppy_pending_object = NULL;
+ pybp_debug_printf ("attaching existing breakpoint object");
}
else
- newbp = PyObject_New (gdbpy_breakpoint_object, &breakpoint_object_type);
+ {
+ newbp = PyObject_New (gdbpy_breakpoint_object, &breakpoint_object_type);
+ pybp_debug_printf ("attaching new breakpoint object");
+ }
if (newbp)
{
newbp->number = bp->number;
static void
gdbpy_breakpoint_deleted (struct breakpoint *b)
{
+ PYBP_SCOPED_DEBUG_ENTER_EXIT;
+
int num = b->number;
struct breakpoint *bp = NULL;
static void
gdbpy_breakpoint_modified (struct breakpoint *b)
{
+ PYBP_SCOPED_DEBUG_ENTER_EXIT;
+
int num = b->number;
struct breakpoint *bp = NULL;
bppy_init, /* tp_init */
0, /* tp_alloc */
};
+
+void _initialize_py_breakpoint ();
+void
+_initialize_py_breakpoint ()
+{
+ add_setshow_boolean_cmd
+ ("py-breakpoint", class_maintenance, &pybp_debug,
+ _("Set Python breakpoint debugging."),
+ _("Show Python breakpoint debugging."),
+ _("When on, Python breakpoint debugging is enabled."),
+ NULL,
+ show_pybp_debug,
+ &setdebuglist, &showdebuglist);
+}