diff options
Diffstat (limited to 'kernel/trace/ftrace.c')
-rw-r--r-- | kernel/trace/ftrace.c | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/kernel/trace/ftrace.c b/kernel/trace/ftrace.c index 1796e018fbff..369fb78bd4ab 100644 --- a/kernel/trace/ftrace.c +++ b/kernel/trace/ftrace.c | |||
@@ -773,6 +773,7 @@ enum { | |||
773 | FTRACE_ITER_CONT = (1 << 1), | 773 | FTRACE_ITER_CONT = (1 << 1), |
774 | FTRACE_ITER_NOTRACE = (1 << 2), | 774 | FTRACE_ITER_NOTRACE = (1 << 2), |
775 | FTRACE_ITER_FAILURES = (1 << 3), | 775 | FTRACE_ITER_FAILURES = (1 << 3), |
776 | FTRACE_ITER_PRINTALL = (1 << 4), | ||
776 | }; | 777 | }; |
777 | 778 | ||
778 | #define FTRACE_BUFF_MAX (KSYM_SYMBOL_LEN+4) /* room for wildcards */ | 779 | #define FTRACE_BUFF_MAX (KSYM_SYMBOL_LEN+4) /* room for wildcards */ |
@@ -794,6 +795,9 @@ t_next(struct seq_file *m, void *v, loff_t *pos) | |||
794 | 795 | ||
795 | (*pos)++; | 796 | (*pos)++; |
796 | 797 | ||
798 | if (iter->flags & FTRACE_ITER_PRINTALL) | ||
799 | return NULL; | ||
800 | |||
797 | /* should not be called from interrupt context */ | 801 | /* should not be called from interrupt context */ |
798 | spin_lock(&ftrace_lock); | 802 | spin_lock(&ftrace_lock); |
799 | retry: | 803 | retry: |
@@ -834,6 +838,19 @@ static void *t_start(struct seq_file *m, loff_t *pos) | |||
834 | struct ftrace_iterator *iter = m->private; | 838 | struct ftrace_iterator *iter = m->private; |
835 | void *p = NULL; | 839 | void *p = NULL; |
836 | 840 | ||
841 | /* | ||
842 | * For set_ftrace_filter reading, if we have the filter | ||
843 | * off, we can short cut and just print out that all | ||
844 | * functions are enabled. | ||
845 | */ | ||
846 | if (iter->flags & FTRACE_ITER_FILTER && !ftrace_filtered) { | ||
847 | if (*pos > 0) | ||
848 | return NULL; | ||
849 | iter->flags |= FTRACE_ITER_PRINTALL; | ||
850 | (*pos)++; | ||
851 | return iter; | ||
852 | } | ||
853 | |||
837 | if (*pos > 0) { | 854 | if (*pos > 0) { |
838 | if (iter->idx < 0) | 855 | if (iter->idx < 0) |
839 | return p; | 856 | return p; |
@@ -852,9 +869,15 @@ static void t_stop(struct seq_file *m, void *p) | |||
852 | 869 | ||
853 | static int t_show(struct seq_file *m, void *v) | 870 | static int t_show(struct seq_file *m, void *v) |
854 | { | 871 | { |
872 | struct ftrace_iterator *iter = m->private; | ||
855 | struct dyn_ftrace *rec = v; | 873 | struct dyn_ftrace *rec = v; |
856 | char str[KSYM_SYMBOL_LEN]; | 874 | char str[KSYM_SYMBOL_LEN]; |
857 | 875 | ||
876 | if (iter->flags & FTRACE_ITER_PRINTALL) { | ||
877 | seq_printf(m, "#### all functions enabled ####\n"); | ||
878 | return 0; | ||
879 | } | ||
880 | |||
858 | if (!rec) | 881 | if (!rec) |
859 | return 0; | 882 | return 0; |
860 | 883 | ||