Provides most commonly used filters that most users of uprobes can reuse. However this would be useful once we can dynamically associate a filter with a uprobe-event tracer. Signed-off-by: Srikar Dronamraju <srikar@xxxxxxxxxxxxxxxxxx> --- include/linux/uprobes.h | 5 +++++ kernel/uprobes.c | 50 +++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 55 insertions(+), 0 deletions(-) diff --git a/include/linux/uprobes.h b/include/linux/uprobes.h index b7fd925..a7a8d5a 100644 --- a/include/linux/uprobes.h +++ b/include/linux/uprobes.h @@ -65,6 +65,11 @@ struct uprobe_consumer { struct uprobe_consumer *next; }; +struct uprobe_simple_consumer { + struct uprobe_consumer consumer; + pid_t fvalue; +}; + struct uprobe { struct rb_node rb_node; /* node in the rb tree */ atomic_t ref; diff --git a/kernel/uprobes.c b/kernel/uprobes.c index e3a3051..328053e 100644 --- a/kernel/uprobes.c +++ b/kernel/uprobes.c @@ -1262,6 +1262,56 @@ int uprobe_post_notifier(struct pt_regs *regs) return 0; } +bool uprobes_pid_filter(struct uprobe_consumer *self, struct task_struct *t) +{ + struct uprobe_simple_consumer *usc; + + usc = container_of(self, struct uprobe_simple_consumer, consumer); + if (t->tgid == usc->fvalue) + return true; + return false; +} + +bool uprobes_tid_filter(struct uprobe_consumer *self, struct task_struct *t) +{ + struct uprobe_simple_consumer *usc; + + usc = container_of(self, struct uprobe_simple_consumer, consumer); + if (t->pid == usc->fvalue) + return true; + return false; +} + +bool uprobes_ppid_filter(struct uprobe_consumer *self, struct task_struct *t) +{ + pid_t pid; + struct uprobe_simple_consumer *usc; + + usc = container_of(self, struct uprobe_simple_consumer, consumer); + rcu_read_lock(); + pid = task_tgid_vnr(t->real_parent); + rcu_read_unlock(); + + if (pid == usc->fvalue) + return true; + return false; +} + +bool uprobes_sid_filter(struct uprobe_consumer *self, struct task_struct *t) +{ + pid_t pid; + struct uprobe_simple_consumer *usc; + + usc = container_of(self, struct uprobe_simple_consumer, consumer); + rcu_read_lock(); + pid = pid_vnr(task_session(t)); + rcu_read_unlock(); + + if (pid == usc->fvalue) + return true; + return false; +} + struct notifier_block uprobes_exception_nb = { .notifier_call = uprobes_exception_notify, .priority = 0x7ffffff0, -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxxx For more info on Linux MM, see: http://www.linux-mm.org/ . Fight unfair telecom internet charges in Canada: sign http://stopthemeter.ca/ Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>