ftrace: Pass probe ops to probe function

In preparation to cleaning up the probe function registration code, the
"data" parameter will eventually be removed from the probe->func() call.
Instead it will receive its own "ops" function, in which it can set up its
own data that it needs to map.
Signed-off-by: default avatarSteven Rostedt (VMware) <rostedt@goodmis.org>
parent e51a9896
...@@ -3739,7 +3739,7 @@ static void function_trace_probe_call(unsigned long ip, unsigned long parent_ip, ...@@ -3739,7 +3739,7 @@ static void function_trace_probe_call(unsigned long ip, unsigned long parent_ip,
preempt_disable_notrace(); preempt_disable_notrace();
hlist_for_each_entry_rcu_notrace(entry, hhd, node) { hlist_for_each_entry_rcu_notrace(entry, hhd, node) {
if (entry->ip == ip) if (entry->ip == ip)
entry->ops->func(ip, parent_ip, &entry->data); entry->ops->func(ip, parent_ip, entry->ops, &entry->data);
} }
preempt_enable_notrace(); preempt_enable_notrace();
} }
......
...@@ -6735,13 +6735,15 @@ static const struct file_operations tracing_dyn_info_fops = { ...@@ -6735,13 +6735,15 @@ static const struct file_operations tracing_dyn_info_fops = {
#if defined(CONFIG_TRACER_SNAPSHOT) && defined(CONFIG_DYNAMIC_FTRACE) #if defined(CONFIG_TRACER_SNAPSHOT) && defined(CONFIG_DYNAMIC_FTRACE)
static void static void
ftrace_snapshot(unsigned long ip, unsigned long parent_ip, void **data) ftrace_snapshot(unsigned long ip, unsigned long parent_ip,
struct ftrace_probe_ops *ops, void **data)
{ {
tracing_snapshot(); tracing_snapshot();
} }
static void static void
ftrace_count_snapshot(unsigned long ip, unsigned long parent_ip, void **data) ftrace_count_snapshot(unsigned long ip, unsigned long parent_ip,
struct ftrace_probe_ops *ops, void **data)
{ {
unsigned long *count = (long *)data; unsigned long *count = (long *)data;
......
...@@ -934,6 +934,7 @@ static inline void ftrace_pid_follow_fork(struct trace_array *tr, bool enable) { ...@@ -934,6 +934,7 @@ static inline void ftrace_pid_follow_fork(struct trace_array *tr, bool enable) {
struct ftrace_probe_ops { struct ftrace_probe_ops {
void (*func)(unsigned long ip, void (*func)(unsigned long ip,
unsigned long parent_ip, unsigned long parent_ip,
struct ftrace_probe_ops *ops,
void **data); void **data);
int (*init)(struct ftrace_probe_ops *ops, int (*init)(struct ftrace_probe_ops *ops,
unsigned long ip, void **data); unsigned long ip, void **data);
......
...@@ -2461,7 +2461,8 @@ struct event_probe_data { ...@@ -2461,7 +2461,8 @@ struct event_probe_data {
}; };
static void static void
event_enable_probe(unsigned long ip, unsigned long parent_ip, void **_data) event_enable_probe(unsigned long ip, unsigned long parent_ip,
struct ftrace_probe_ops *ops, void **_data)
{ {
struct event_probe_data **pdata = (struct event_probe_data **)_data; struct event_probe_data **pdata = (struct event_probe_data **)_data;
struct event_probe_data *data = *pdata; struct event_probe_data *data = *pdata;
...@@ -2476,7 +2477,8 @@ event_enable_probe(unsigned long ip, unsigned long parent_ip, void **_data) ...@@ -2476,7 +2477,8 @@ event_enable_probe(unsigned long ip, unsigned long parent_ip, void **_data)
} }
static void static void
event_enable_count_probe(unsigned long ip, unsigned long parent_ip, void **_data) event_enable_count_probe(unsigned long ip, unsigned long parent_ip,
struct ftrace_probe_ops *ops, void **_data)
{ {
struct event_probe_data **pdata = (struct event_probe_data **)_data; struct event_probe_data **pdata = (struct event_probe_data **)_data;
struct event_probe_data *data = *pdata; struct event_probe_data *data = *pdata;
...@@ -2494,7 +2496,7 @@ event_enable_count_probe(unsigned long ip, unsigned long parent_ip, void **_data ...@@ -2494,7 +2496,7 @@ event_enable_count_probe(unsigned long ip, unsigned long parent_ip, void **_data
if (data->count != -1) if (data->count != -1)
(data->count)--; (data->count)--;
event_enable_probe(ip, parent_ip, _data); event_enable_probe(ip, parent_ip, ops, _data);
} }
static int static int
......
...@@ -326,19 +326,22 @@ static void update_traceon_count(void **data, bool on) ...@@ -326,19 +326,22 @@ static void update_traceon_count(void **data, bool on)
} }
static void static void
ftrace_traceon_count(unsigned long ip, unsigned long parent_ip, void **data) ftrace_traceon_count(unsigned long ip, unsigned long parent_ip,
struct ftrace_probe_ops *ops, void **data)
{ {
update_traceon_count(data, 1); update_traceon_count(data, 1);
} }
static void static void
ftrace_traceoff_count(unsigned long ip, unsigned long parent_ip, void **data) ftrace_traceoff_count(unsigned long ip, unsigned long parent_ip,
struct ftrace_probe_ops *ops, void **data)
{ {
update_traceon_count(data, 0); update_traceon_count(data, 0);
} }
static void static void
ftrace_traceon(unsigned long ip, unsigned long parent_ip, void **data) ftrace_traceon(unsigned long ip, unsigned long parent_ip,
struct ftrace_probe_ops *ops, void **data)
{ {
if (tracing_is_on()) if (tracing_is_on())
return; return;
...@@ -347,7 +350,8 @@ ftrace_traceon(unsigned long ip, unsigned long parent_ip, void **data) ...@@ -347,7 +350,8 @@ ftrace_traceon(unsigned long ip, unsigned long parent_ip, void **data)
} }
static void static void
ftrace_traceoff(unsigned long ip, unsigned long parent_ip, void **data) ftrace_traceoff(unsigned long ip, unsigned long parent_ip,
struct ftrace_probe_ops *ops, void **data)
{ {
if (!tracing_is_on()) if (!tracing_is_on())
return; return;
...@@ -365,13 +369,15 @@ ftrace_traceoff(unsigned long ip, unsigned long parent_ip, void **data) ...@@ -365,13 +369,15 @@ ftrace_traceoff(unsigned long ip, unsigned long parent_ip, void **data)
#define STACK_SKIP 4 #define STACK_SKIP 4
static void static void
ftrace_stacktrace(unsigned long ip, unsigned long parent_ip, void **data) ftrace_stacktrace(unsigned long ip, unsigned long parent_ip,
struct ftrace_probe_ops *ops, void **data)
{ {
trace_dump_stack(STACK_SKIP); trace_dump_stack(STACK_SKIP);
} }
static void static void
ftrace_stacktrace_count(unsigned long ip, unsigned long parent_ip, void **data) ftrace_stacktrace_count(unsigned long ip, unsigned long parent_ip,
struct ftrace_probe_ops *ops, void **data)
{ {
long *count = (long *)data; long *count = (long *)data;
long old_count; long old_count;
...@@ -419,7 +425,8 @@ static int update_count(void **data) ...@@ -419,7 +425,8 @@ static int update_count(void **data)
} }
static void static void
ftrace_dump_probe(unsigned long ip, unsigned long parent_ip, void **data) ftrace_dump_probe(unsigned long ip, unsigned long parent_ip,
struct ftrace_probe_ops *ops, void **data)
{ {
if (update_count(data)) if (update_count(data))
ftrace_dump(DUMP_ALL); ftrace_dump(DUMP_ALL);
...@@ -427,7 +434,8 @@ ftrace_dump_probe(unsigned long ip, unsigned long parent_ip, void **data) ...@@ -427,7 +434,8 @@ ftrace_dump_probe(unsigned long ip, unsigned long parent_ip, void **data)
/* Only dump the current CPU buffer. */ /* Only dump the current CPU buffer. */
static void static void
ftrace_cpudump_probe(unsigned long ip, unsigned long parent_ip, void **data) ftrace_cpudump_probe(unsigned long ip, unsigned long parent_ip,
struct ftrace_probe_ops *ops, void **data)
{ {
if (update_count(data)) if (update_count(data))
ftrace_dump(DUMP_ORIG); ftrace_dump(DUMP_ORIG);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment