diff options
-rw-r--r-- | include/linux/ftrace.h | 1 | ||||
-rw-r--r-- | kernel/trace/ftrace.c | 14 |
2 files changed, 8 insertions, 7 deletions
diff --git a/include/linux/ftrace.h b/include/linux/ftrace.h index c146c1021a29..9d598bbf28a6 100644 --- a/include/linux/ftrace.h +++ b/include/linux/ftrace.h | |||
@@ -145,7 +145,6 @@ enum { | |||
145 | }; | 145 | }; |
146 | 146 | ||
147 | struct dyn_ftrace { | 147 | struct dyn_ftrace { |
148 | struct list_head list; | ||
149 | unsigned long ip; /* address of mcount call-site */ | 148 | unsigned long ip; /* address of mcount call-site */ |
150 | unsigned long flags; | 149 | unsigned long flags; |
151 | struct dyn_arch_ftrace arch; | 150 | struct dyn_arch_ftrace arch; |
diff --git a/kernel/trace/ftrace.c b/kernel/trace/ftrace.c index bf78a4c75c67..90d5729afeff 100644 --- a/kernel/trace/ftrace.c +++ b/kernel/trace/ftrace.c | |||
@@ -272,7 +272,7 @@ enum { | |||
272 | 272 | ||
273 | static int ftrace_filtered; | 273 | static int ftrace_filtered; |
274 | 274 | ||
275 | static LIST_HEAD(ftrace_new_addrs); | 275 | static struct dyn_ftrace *ftrace_new_addrs; |
276 | 276 | ||
277 | static DEFINE_MUTEX(ftrace_regex_lock); | 277 | static DEFINE_MUTEX(ftrace_regex_lock); |
278 | 278 | ||
@@ -409,8 +409,8 @@ ftrace_record_ip(unsigned long ip) | |||
409 | return NULL; | 409 | return NULL; |
410 | 410 | ||
411 | rec->ip = ip; | 411 | rec->ip = ip; |
412 | 412 | rec->flags = (unsigned long)ftrace_new_addrs; | |
413 | list_add(&rec->list, &ftrace_new_addrs); | 413 | ftrace_new_addrs = rec; |
414 | 414 | ||
415 | return rec; | 415 | return rec; |
416 | } | 416 | } |
@@ -716,19 +716,21 @@ unsigned long ftrace_update_tot_cnt; | |||
716 | 716 | ||
717 | static int ftrace_update_code(struct module *mod) | 717 | static int ftrace_update_code(struct module *mod) |
718 | { | 718 | { |
719 | struct dyn_ftrace *p, *t; | 719 | struct dyn_ftrace *p; |
720 | cycle_t start, stop; | 720 | cycle_t start, stop; |
721 | 721 | ||
722 | start = ftrace_now(raw_smp_processor_id()); | 722 | start = ftrace_now(raw_smp_processor_id()); |
723 | ftrace_update_cnt = 0; | 723 | ftrace_update_cnt = 0; |
724 | 724 | ||
725 | list_for_each_entry_safe(p, t, &ftrace_new_addrs, list) { | 725 | while (ftrace_new_addrs) { |
726 | 726 | ||
727 | /* If something went wrong, bail without enabling anything */ | 727 | /* If something went wrong, bail without enabling anything */ |
728 | if (unlikely(ftrace_disabled)) | 728 | if (unlikely(ftrace_disabled)) |
729 | return -1; | 729 | return -1; |
730 | 730 | ||
731 | list_del_init(&p->list); | 731 | p = ftrace_new_addrs; |
732 | ftrace_new_addrs = (struct dyn_ftrace *)p->flags; | ||
733 | p->flags = 0L; | ||
732 | 734 | ||
733 | /* convert record (i.e, patch mcount-call with NOP) */ | 735 | /* convert record (i.e, patch mcount-call with NOP) */ |
734 | if (ftrace_code_disable(mod, p)) { | 736 | if (ftrace_code_disable(mod, p)) { |