[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1295963773.28776.1054.camel@laptop>
Date: Tue, 25 Jan 2011 14:56:13 +0100
From: Peter Zijlstra <peterz@...radead.org>
To: Srikar Dronamraju <srikar@...ux.vnet.ibm.com>
Cc: Ingo Molnar <mingo@...e.hu>, Steven Rostedt <rostedt@...dmis.org>,
Arnaldo Carvalho de Melo <acme@...radead.org>,
Linus Torvalds <torvalds@...ux-foundation.org>,
Masami Hiramatsu <masami.hiramatsu.pt@...achi.com>,
Christoph Hellwig <hch@...radead.org>,
Andi Kleen <andi@...stfloor.org>,
Oleg Nesterov <oleg@...hat.com>,
LKML <linux-kernel@...r.kernel.org>,
SystemTap <systemtap@...rces.redhat.com>,
Linux-mm <linux-mm@...r.kernel.org>,
Jim Keniston <jkenisto@...ux.vnet.ibm.com>,
Frederic Weisbecker <fweisbec@...il.com>,
Ananth N Mavinakayanahalli <ananth@...ibm.com>,
Andrew Morton <akpm@...ux-foundation.org>,
"Paul E. McKenney" <paulmck@...ux.vnet.ibm.com>
Subject: Re: [RFC] [PATCH 2.6.37-rc5-tip 4/20] 4: uprobes: Adding and
remove a uprobe in a rb tree.
On Thu, 2010-12-16 at 15:28 +0530, Srikar Dronamraju wrote:
> +struct uprobe_consumer {
> + int (*handler)(struct uprobe_consumer *self, struct pt_regs *regs);
> + /*
> + * filter is optional; If a filter exists, handler is run
> + * if and only if filter returns true.
> + */
> + bool (*filter)(struct uprobe_consumer *self, struct task_struct *task);
> +
> + struct uprobe_consumer *next;
> + void *fvalue; /* filter value */
> +};
Since you pass in a pointer to this structure at register_uprobe() its
user allocated, hence you can remove the fvalue thing and let the user
embed this in a larger struct if needed, the filter functions can then
use container_of() to get at the larger data structure.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists