Petr Machata d4e3c89
From 56134ff5442bee4e128b189bb86cfc97dcb6f60a Mon Sep 17 00:00:00 2001
Petr Machata d4e3c89
From: Petr Machata <pmachata@redhat.com>
Petr Machata d4e3c89
Date: Fri, 10 Jan 2014 20:05:15 +0100
Petr Machata d4e3c89
Subject: [PATCH 1/2] Add a new per-breakpoint callback on_install
Petr Machata d4e3c89
Petr Machata d4e3c89
---
Petr Machata d4e3c89
 breakpoint.h  |    9 ++++++++-
Petr Machata d4e3c89
 breakpoints.c |   11 ++++++++++-
Petr Machata d4e3c89
 2 files changed, 18 insertions(+), 2 deletions(-)
Petr Machata d4e3c89
Petr Machata d4e3c89
diff --git a/breakpoint.h b/breakpoint.h
Petr Machata d4e3c89
index 95964a8..c36f673 100644
Petr Machata d4e3c89
--- a/breakpoint.h
Petr Machata d4e3c89
+++ b/breakpoint.h
Petr Machata d4e3c89
@@ -1,6 +1,6 @@
Petr Machata d4e3c89
 /*
Petr Machata d4e3c89
  * This file is part of ltrace.
Petr Machata d4e3c89
- * Copyright (C) 2012, 2013 Petr Machata, Red Hat Inc.
Petr Machata d4e3c89
+ * Copyright (C) 2012,2013,2014 Petr Machata, Red Hat Inc.
Petr Machata d4e3c89
  * Copyright (C) 2009 Juan Cespedes
Petr Machata d4e3c89
  *
Petr Machata d4e3c89
  * This program is free software; you can redistribute it and/or
Petr Machata d4e3c89
@@ -46,6 +46,7 @@
Petr Machata d4e3c89
 struct bp_callbacks {
Petr Machata d4e3c89
 	void (*on_hit)(struct breakpoint *bp, struct process *proc);
Petr Machata d4e3c89
 	void (*on_continue)(struct breakpoint *bp, struct process *proc);
Petr Machata d4e3c89
+	void (*on_install)(struct breakpoint *bp, struct process *proc);
Petr Machata d4e3c89
 	void (*on_retract)(struct breakpoint *bp, struct process *proc);
Petr Machata d4e3c89
 
Petr Machata d4e3c89
 	/* Create a new breakpoint that should handle return from the
Petr Machata d4e3c89
@@ -84,6 +85,12 @@ void breakpoint_on_continue(struct breakpoint *bp, struct process *proc);
Petr Machata d4e3c89
  * the instruction underneath it).  */
Petr Machata d4e3c89
 void breakpoint_on_retract(struct breakpoint *bp, struct process *proc);
Petr Machata d4e3c89
 
Petr Machata d4e3c89
+/* Call ON_INSTALL handler of BP, if any is set.  This should be
Petr Machata d4e3c89
+ * called after the breakpoint is enabled for the first time, not
Petr Machata d4e3c89
+ * every time it's enabled (such as after stepping over a site of a
Petr Machata d4e3c89
+ * temporarily disabled breakpoint).  */
Petr Machata d4e3c89
+void breakpoint_on_install(struct breakpoint *bp, struct process *proc);
Petr Machata d4e3c89
+
Petr Machata d4e3c89
 /* Call GET_RETURN_BP handler of BP, if any is set.  If none is set,
Petr Machata d4e3c89
  * call CREATE_DEFAULT_RETURN_BP to obtain one.  */
Petr Machata d4e3c89
 int breakpoint_get_return_bp(struct breakpoint **ret,
Petr Machata d4e3c89
diff --git a/breakpoints.c b/breakpoints.c
Petr Machata d4e3c89
index 947cb71..c3fa275 100644
Petr Machata d4e3c89
--- a/breakpoints.c
Petr Machata d4e3c89
+++ b/breakpoints.c
Petr Machata d4e3c89
@@ -1,6 +1,6 @@
Petr Machata d4e3c89
 /*
Petr Machata d4e3c89
  * This file is part of ltrace.
Petr Machata d4e3c89
- * Copyright (C) 2006,2007,2011,2012,2013 Petr Machata, Red Hat Inc.
Petr Machata d4e3c89
+ * Copyright (C) 2006,2007,2011,2012,2013,2014 Petr Machata, Red Hat Inc.
Petr Machata d4e3c89
  * Copyright (C) 2009 Juan Cespedes
Petr Machata d4e3c89
  * Copyright (C) 1998,2001,2002,2003,2007,2008,2009 Juan Cespedes
Petr Machata d4e3c89
  * Copyright (C) 2006 Ian Wienand
Petr Machata d4e3c89
@@ -85,6 +85,14 @@ breakpoint_on_retract(struct breakpoint *bp, struct process *proc)
Petr Machata d4e3c89
 		(bp->cbs->on_retract)(bp, proc);
Petr Machata d4e3c89
 }
Petr Machata d4e3c89
 
Petr Machata d4e3c89
+void
Petr Machata d4e3c89
+breakpoint_on_install(struct breakpoint *bp, struct process *proc)
Petr Machata d4e3c89
+{
Petr Machata d4e3c89
+	assert(bp != NULL);
Petr Machata d4e3c89
+	if (bp->cbs != NULL && bp->cbs->on_install != NULL)
Petr Machata d4e3c89
+		(bp->cbs->on_install)(bp, proc);
Petr Machata d4e3c89
+}
Petr Machata d4e3c89
+
Petr Machata d4e3c89
 int
Petr Machata d4e3c89
 breakpoint_get_return_bp(struct breakpoint **ret,
Petr Machata d4e3c89
 			 struct breakpoint *bp, struct process *proc)
Petr Machata d4e3c89
@@ -229,6 +237,7 @@ breakpoint_turn_on(struct breakpoint *bp, struct process *proc)
Petr Machata d4e3c89
 	if (bp->enabled == 1) {
Petr Machata d4e3c89
 		assert(proc->pid != 0);
Petr Machata d4e3c89
 		enable_breakpoint(proc, bp);
Petr Machata d4e3c89
+		breakpoint_on_install(bp, proc);
Petr Machata d4e3c89
 	}
Petr Machata d4e3c89
 	return 0;
Petr Machata d4e3c89
 }
Petr Machata d4e3c89
-- 
Petr Machata d4e3c89
1.7.6.5
Petr Machata d4e3c89