ftrace: Remove data field from ftrace_func_probe structure

No users of the function probes uses the data field anymore. Remove it, and
change the init function to take a void *data parameter instead of a
void **data, because the init will just get the data that the registering
function was received, and there's no state after it is called.

The other functions for ftrace_probe_ops still take the data parameter, but
it will currently only be passed NULL. It will stay as a parameter for
future data to be passed to these functions.
Signed-off-by: default avatarSteven Rostedt (VMware) <rostedt@goodmis.org>
parent 02b77e2a
...@@ -1102,7 +1102,6 @@ struct ftrace_func_probe { ...@@ -1102,7 +1102,6 @@ struct ftrace_func_probe {
struct hlist_node node; struct hlist_node node;
struct ftrace_probe_ops *ops; struct ftrace_probe_ops *ops;
unsigned long ip; unsigned long ip;
void *data;
struct list_head free_list; struct list_head free_list;
}; };
...@@ -3152,7 +3151,7 @@ t_hash_show(struct seq_file *m, struct ftrace_iterator *iter) ...@@ -3152,7 +3151,7 @@ t_hash_show(struct seq_file *m, struct ftrace_iterator *iter)
return -EIO; return -EIO;
if (rec->ops->print) if (rec->ops->print)
return rec->ops->print(m, rec->ip, rec->ops, rec->data); return rec->ops->print(m, rec->ip, rec->ops, NULL);
seq_printf(m, "%ps:%ps\n", (void *)rec->ip, (void *)rec->ops->func); seq_printf(m, "%ps:%ps\n", (void *)rec->ip, (void *)rec->ops->func);
...@@ -3735,7 +3734,7 @@ static void function_trace_probe_call(unsigned long ip, unsigned long parent_ip, ...@@ -3735,7 +3734,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->ops, &entry->data); entry->ops->func(ip, parent_ip, entry->ops, NULL);
} }
preempt_enable_notrace(); preempt_enable_notrace();
} }
...@@ -3800,7 +3799,7 @@ static bool __disable_ftrace_function_probe(void) ...@@ -3800,7 +3799,7 @@ static bool __disable_ftrace_function_probe(void)
static void ftrace_free_entry(struct ftrace_func_probe *entry) static void ftrace_free_entry(struct ftrace_func_probe *entry)
{ {
if (entry->ops->free) if (entry->ops->free)
entry->ops->free(entry->ops, entry->ip, &entry->data); entry->ops->free(entry->ops, entry->ip, NULL);
kfree(entry); kfree(entry);
} }
...@@ -4007,15 +4006,13 @@ register_ftrace_function_probe(char *glob, struct ftrace_probe_ops *ops, ...@@ -4007,15 +4006,13 @@ register_ftrace_function_probe(char *glob, struct ftrace_probe_ops *ops,
count++; count++;
entry->data = data;
/* /*
* The caller might want to do something special * The caller might want to do something special
* for each function we find. We call the callback * for each function we find. We call the callback
* to give the caller an opportunity to do so. * to give the caller an opportunity to do so.
*/ */
if (ops->init) { if (ops->init) {
if (ops->init(ops, rec->ip, &entry->data) < 0) { if (ops->init(ops, rec->ip, data) < 0) {
/* caller does not like this func */ /* caller does not like this func */
kfree(entry); kfree(entry);
continue; continue;
......
...@@ -6786,11 +6786,11 @@ ftrace_snapshot_print(struct seq_file *m, unsigned long ip, ...@@ -6786,11 +6786,11 @@ ftrace_snapshot_print(struct seq_file *m, unsigned long ip,
static int static int
ftrace_snapshot_init(struct ftrace_probe_ops *ops, unsigned long ip, ftrace_snapshot_init(struct ftrace_probe_ops *ops, unsigned long ip,
void **data) void *data)
{ {
struct ftrace_func_mapper *mapper = ops->private_data; struct ftrace_func_mapper *mapper = ops->private_data;
return ftrace_func_mapper_add_ip(mapper, ip, *data); return ftrace_func_mapper_add_ip(mapper, ip, data);
} }
static void static void
......
...@@ -937,7 +937,7 @@ struct ftrace_probe_ops { ...@@ -937,7 +937,7 @@ struct ftrace_probe_ops {
struct ftrace_probe_ops *ops, 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);
void (*free)(struct ftrace_probe_ops *ops, void (*free)(struct ftrace_probe_ops *ops,
unsigned long ip, void **data); unsigned long ip, void **data);
int (*print)(struct seq_file *m, int (*print)(struct seq_file *m,
......
...@@ -2543,11 +2543,10 @@ event_enable_print(struct seq_file *m, unsigned long ip, ...@@ -2543,11 +2543,10 @@ event_enable_print(struct seq_file *m, unsigned long ip,
static int static int
event_enable_init(struct ftrace_probe_ops *ops, unsigned long ip, event_enable_init(struct ftrace_probe_ops *ops, unsigned long ip,
void **_data) void *_data)
{ {
struct ftrace_func_mapper *mapper = ops->private_data; struct ftrace_func_mapper *mapper = ops->private_data;
struct event_probe_data **pdata = (struct event_probe_data **)_data; struct event_probe_data *data = _data;
struct event_probe_data *data = *pdata;
int ret; int ret;
ret = ftrace_func_mapper_add_ip(mapper, ip, data); ret = ftrace_func_mapper_add_ip(mapper, ip, data);
......
...@@ -509,11 +509,11 @@ ftrace_cpudump_print(struct seq_file *m, unsigned long ip, ...@@ -509,11 +509,11 @@ ftrace_cpudump_print(struct seq_file *m, unsigned long ip,
static int static int
ftrace_count_init(struct ftrace_probe_ops *ops, unsigned long ip, ftrace_count_init(struct ftrace_probe_ops *ops, unsigned long ip,
void **data) void *data)
{ {
struct ftrace_func_mapper *mapper = ops->private_data; struct ftrace_func_mapper *mapper = ops->private_data;
return ftrace_func_mapper_add_ip(mapper, ip, *data); return ftrace_func_mapper_add_ip(mapper, ip, data);
} }
static void static void
......
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