int ftrace_enabled __read_mostly;
static int last_ftrace_enabled;
-/* ftrace_pid_trace >= 0 will only trace threads with this pid */
+/* set when tracing only a pid */
static int ftrace_pid_trace = -1;
/* Quick disabling of function tracer. */
static void ftrace_pid_func(unsigned long ip, unsigned long parent_ip)
{
- if (current->pid != ftrace_pid_trace)
+ if (!test_tsk_trace_trace(current))
return;
ftrace_pid_function(ip, parent_ip);
ftrace_pid_trace = -1;
} else {
+ struct task_struct *p;
+ int found = 0;
if (ftrace_pid_trace == val)
goto out;
- ftrace_pid_trace = val;
+ /*
+ * Find the task that matches this pid.
+ * TODO: use pid namespaces instead.
+ */
+ rcu_read_lock();
+ for_each_process(p) {
+ if (p->pid == val) {
+ found = 1;
+ set_tsk_trace_trace(p);
+ } else if (test_tsk_trace_trace(p))
+ clear_tsk_trace_trace(p);
+ }
+ rcu_read_unlock();
+
+ if (found)
+ ftrace_pid_trace = val;
+ else {
+ if (ftrace_pid_trace < 0)
+ goto out;
+ ftrace_pid_trace = -1;
+ }
}
/* update the function call */