[for-next][PATCH 20/33] ftrace: Remove data field from ftrace_func_probe structure

2017-04-21 Thread Steven Rostedt
From: "Steven Rostedt (VMware)" 

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: Steven Rostedt (VMware) 
---
 kernel/trace/ftrace.c  | 11 ---
 kernel/trace/trace.c   |  4 ++--
 kernel/trace/trace.h   |  2 +-
 kernel/trace/trace_events.c|  5 ++---
 kernel/trace/trace_functions.c |  4 ++--
 5 files changed, 11 insertions(+), 15 deletions(-)

diff --git a/kernel/trace/ftrace.c b/kernel/trace/ftrace.c
index 15f910a03822..f7fcab8f3aa1 100644
--- a/kernel/trace/ftrace.c
+++ b/kernel/trace/ftrace.c
@@ -1102,7 +1102,6 @@ struct ftrace_func_probe {
struct hlist_node   node;
struct ftrace_probe_ops *ops;
unsigned long   ip;
-   void*data;
struct list_headfree_list;
 };
 
@@ -3152,7 +3151,7 @@ t_hash_show(struct seq_file *m, struct ftrace_iterator 
*iter)
return -EIO;
 
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);
 
@@ -3735,7 +3734,7 @@ static void function_trace_probe_call(unsigned long ip, 
unsigned long parent_ip,
preempt_disable_notrace();
hlist_for_each_entry_rcu_notrace(entry, hhd, node) {
if (entry->ip == ip)
-   entry->ops->func(ip, parent_ip, entry->ops, 
>data);
+   entry->ops->func(ip, parent_ip, entry->ops, NULL);
}
preempt_enable_notrace();
 }
@@ -3800,7 +3799,7 @@ static bool __disable_ftrace_function_probe(void)
 static void ftrace_free_entry(struct ftrace_func_probe *entry)
 {
if (entry->ops->free)
-   entry->ops->free(entry->ops, entry->ip, >data);
+   entry->ops->free(entry->ops, entry->ip, NULL);
kfree(entry);
 }
 
@@ -4007,15 +4006,13 @@ register_ftrace_function_probe(char *glob, struct 
ftrace_probe_ops *ops,
 
count++;
 
-   entry->data = data;
-
/*
 * The caller might want to do something special
 * for each function we find. We call the callback
 * to give the caller an opportunity to do so.
 */
if (ops->init) {
-   if (ops->init(ops, rec->ip, >data) < 0) {
+   if (ops->init(ops, rec->ip, data) < 0) {
/* caller does not like this func */
kfree(entry);
continue;
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c
index 7febeb823c62..7a4d578d8887 100644
--- a/kernel/trace/trace.c
+++ b/kernel/trace/trace.c
@@ -6786,11 +6786,11 @@ ftrace_snapshot_print(struct seq_file *m, unsigned long 
ip,
 
 static int
 ftrace_snapshot_init(struct ftrace_probe_ops *ops, unsigned long ip,
-void **data)
+void *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
diff --git a/kernel/trace/trace.h b/kernel/trace/trace.h
index 376d5a798489..86aa5aba 100644
--- a/kernel/trace/trace.h
+++ b/kernel/trace/trace.h
@@ -937,7 +937,7 @@ struct ftrace_probe_ops {
struct ftrace_probe_ops *ops,
void **data);
int (*init)(struct ftrace_probe_ops *ops,
-   unsigned long ip, void **data);
+   unsigned long ip, void *data);
void(*free)(struct ftrace_probe_ops *ops,
unsigned long ip, void **data);
int (*print)(struct seq_file *m,
diff --git a/kernel/trace/trace_events.c b/kernel/trace/trace_events.c
index ee308312fe87..37902107c44f 100644
--- a/kernel/trace/trace_events.c
+++ b/kernel/trace/trace_events.c
@@ -2543,11 +2543,10 @@ event_enable_print(struct seq_file *m, unsigned long ip,
 
 static int
 event_enable_init(struct ftrace_probe_ops *ops, unsigned long ip,
- void **_data)
+ void *_data)
 {
struct ftrace_func_mapper *mapper = ops->private_data;
-   struct event_probe_data **pdata = (struct event_probe_data **)_data;
-

[for-next][PATCH 20/33] ftrace: Remove data field from ftrace_func_probe structure

2017-04-21 Thread Steven Rostedt
From: "Steven Rostedt (VMware)" 

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: Steven Rostedt (VMware) 
---
 kernel/trace/ftrace.c  | 11 ---
 kernel/trace/trace.c   |  4 ++--
 kernel/trace/trace.h   |  2 +-
 kernel/trace/trace_events.c|  5 ++---
 kernel/trace/trace_functions.c |  4 ++--
 5 files changed, 11 insertions(+), 15 deletions(-)

diff --git a/kernel/trace/ftrace.c b/kernel/trace/ftrace.c
index 15f910a03822..f7fcab8f3aa1 100644
--- a/kernel/trace/ftrace.c
+++ b/kernel/trace/ftrace.c
@@ -1102,7 +1102,6 @@ struct ftrace_func_probe {
struct hlist_node   node;
struct ftrace_probe_ops *ops;
unsigned long   ip;
-   void*data;
struct list_headfree_list;
 };
 
@@ -3152,7 +3151,7 @@ t_hash_show(struct seq_file *m, struct ftrace_iterator 
*iter)
return -EIO;
 
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);
 
@@ -3735,7 +3734,7 @@ static void function_trace_probe_call(unsigned long ip, 
unsigned long parent_ip,
preempt_disable_notrace();
hlist_for_each_entry_rcu_notrace(entry, hhd, node) {
if (entry->ip == ip)
-   entry->ops->func(ip, parent_ip, entry->ops, 
>data);
+   entry->ops->func(ip, parent_ip, entry->ops, NULL);
}
preempt_enable_notrace();
 }
@@ -3800,7 +3799,7 @@ static bool __disable_ftrace_function_probe(void)
 static void ftrace_free_entry(struct ftrace_func_probe *entry)
 {
if (entry->ops->free)
-   entry->ops->free(entry->ops, entry->ip, >data);
+   entry->ops->free(entry->ops, entry->ip, NULL);
kfree(entry);
 }
 
@@ -4007,15 +4006,13 @@ register_ftrace_function_probe(char *glob, struct 
ftrace_probe_ops *ops,
 
count++;
 
-   entry->data = data;
-
/*
 * The caller might want to do something special
 * for each function we find. We call the callback
 * to give the caller an opportunity to do so.
 */
if (ops->init) {
-   if (ops->init(ops, rec->ip, >data) < 0) {
+   if (ops->init(ops, rec->ip, data) < 0) {
/* caller does not like this func */
kfree(entry);
continue;
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c
index 7febeb823c62..7a4d578d8887 100644
--- a/kernel/trace/trace.c
+++ b/kernel/trace/trace.c
@@ -6786,11 +6786,11 @@ ftrace_snapshot_print(struct seq_file *m, unsigned long 
ip,
 
 static int
 ftrace_snapshot_init(struct ftrace_probe_ops *ops, unsigned long ip,
-void **data)
+void *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
diff --git a/kernel/trace/trace.h b/kernel/trace/trace.h
index 376d5a798489..86aa5aba 100644
--- a/kernel/trace/trace.h
+++ b/kernel/trace/trace.h
@@ -937,7 +937,7 @@ struct ftrace_probe_ops {
struct ftrace_probe_ops *ops,
void **data);
int (*init)(struct ftrace_probe_ops *ops,
-   unsigned long ip, void **data);
+   unsigned long ip, void *data);
void(*free)(struct ftrace_probe_ops *ops,
unsigned long ip, void **data);
int (*print)(struct seq_file *m,
diff --git a/kernel/trace/trace_events.c b/kernel/trace/trace_events.c
index ee308312fe87..37902107c44f 100644
--- a/kernel/trace/trace_events.c
+++ b/kernel/trace/trace_events.c
@@ -2543,11 +2543,10 @@ event_enable_print(struct seq_file *m, unsigned long ip,
 
 static int
 event_enable_init(struct ftrace_probe_ops *ops, unsigned long ip,
- void **_data)
+ void *_data)
 {
struct ftrace_func_mapper *mapper = ops->private_data;
-   struct event_probe_data **pdata = (struct event_probe_data **)_data;
-   struct event_probe_data *data =