diff options
Diffstat (limited to 'kernel/trace/trace.h')
| -rw-r--r-- | kernel/trace/trace.h | 80 |
1 files changed, 62 insertions, 18 deletions
diff --git a/kernel/trace/trace.h b/kernel/trace/trace.h index 405cb850b75d..1d7f4830a80d 100644 --- a/kernel/trace/trace.h +++ b/kernel/trace/trace.h | |||
| @@ -11,6 +11,7 @@ | |||
| 11 | #include <linux/ftrace.h> | 11 | #include <linux/ftrace.h> |
| 12 | #include <trace/boot.h> | 12 | #include <trace/boot.h> |
| 13 | #include <linux/kmemtrace.h> | 13 | #include <linux/kmemtrace.h> |
| 14 | #include <linux/hw_breakpoint.h> | ||
| 14 | 15 | ||
| 15 | #include <linux/trace_seq.h> | 16 | #include <linux/trace_seq.h> |
| 16 | #include <linux/ftrace_event.h> | 17 | #include <linux/ftrace_event.h> |
| @@ -37,6 +38,7 @@ enum trace_type { | |||
| 37 | TRACE_KMEM_ALLOC, | 38 | TRACE_KMEM_ALLOC, |
| 38 | TRACE_KMEM_FREE, | 39 | TRACE_KMEM_FREE, |
| 39 | TRACE_BLK, | 40 | TRACE_BLK, |
| 41 | TRACE_KSYM, | ||
| 40 | 42 | ||
| 41 | __TRACE_LAST_TYPE, | 43 | __TRACE_LAST_TYPE, |
| 42 | }; | 44 | }; |
| @@ -98,9 +100,32 @@ struct syscall_trace_enter { | |||
| 98 | struct syscall_trace_exit { | 100 | struct syscall_trace_exit { |
| 99 | struct trace_entry ent; | 101 | struct trace_entry ent; |
| 100 | int nr; | 102 | int nr; |
| 101 | unsigned long ret; | 103 | long ret; |
| 102 | }; | 104 | }; |
| 103 | 105 | ||
| 106 | struct kprobe_trace_entry { | ||
| 107 | struct trace_entry ent; | ||
| 108 | unsigned long ip; | ||
| 109 | int nargs; | ||
| 110 | unsigned long args[]; | ||
| 111 | }; | ||
| 112 | |||
| 113 | #define SIZEOF_KPROBE_TRACE_ENTRY(n) \ | ||
| 114 | (offsetof(struct kprobe_trace_entry, args) + \ | ||
| 115 | (sizeof(unsigned long) * (n))) | ||
| 116 | |||
| 117 | struct kretprobe_trace_entry { | ||
| 118 | struct trace_entry ent; | ||
| 119 | unsigned long func; | ||
| 120 | unsigned long ret_ip; | ||
| 121 | int nargs; | ||
| 122 | unsigned long args[]; | ||
| 123 | }; | ||
| 124 | |||
| 125 | #define SIZEOF_KRETPROBE_TRACE_ENTRY(n) \ | ||
| 126 | (offsetof(struct kretprobe_trace_entry, args) + \ | ||
| 127 | (sizeof(unsigned long) * (n))) | ||
| 128 | |||
| 104 | /* | 129 | /* |
| 105 | * trace_flag_type is an enumeration that holds different | 130 | * trace_flag_type is an enumeration that holds different |
| 106 | * states when a trace occurs. These are: | 131 | * states when a trace occurs. These are: |
| @@ -209,6 +234,7 @@ extern void __ftrace_bad_type(void); | |||
| 209 | TRACE_KMEM_ALLOC); \ | 234 | TRACE_KMEM_ALLOC); \ |
| 210 | IF_ASSIGN(var, ent, struct kmemtrace_free_entry, \ | 235 | IF_ASSIGN(var, ent, struct kmemtrace_free_entry, \ |
| 211 | TRACE_KMEM_FREE); \ | 236 | TRACE_KMEM_FREE); \ |
| 237 | IF_ASSIGN(var, ent, struct ksym_trace_entry, TRACE_KSYM);\ | ||
| 212 | __ftrace_bad_type(); \ | 238 | __ftrace_bad_type(); \ |
| 213 | } while (0) | 239 | } while (0) |
| 214 | 240 | ||
| @@ -364,6 +390,8 @@ int register_tracer(struct tracer *type); | |||
| 364 | void unregister_tracer(struct tracer *type); | 390 | void unregister_tracer(struct tracer *type); |
| 365 | int is_tracing_stopped(void); | 391 | int is_tracing_stopped(void); |
| 366 | 392 | ||
| 393 | extern int process_new_ksym_entry(char *ksymname, int op, unsigned long addr); | ||
| 394 | |||
| 367 | extern unsigned long nsecs_to_usecs(unsigned long nsecs); | 395 | extern unsigned long nsecs_to_usecs(unsigned long nsecs); |
| 368 | 396 | ||
| 369 | #ifdef CONFIG_TRACER_MAX_TRACE | 397 | #ifdef CONFIG_TRACER_MAX_TRACE |
| @@ -438,6 +466,8 @@ extern int trace_selftest_startup_branch(struct tracer *trace, | |||
| 438 | struct trace_array *tr); | 466 | struct trace_array *tr); |
| 439 | extern int trace_selftest_startup_hw_branches(struct tracer *trace, | 467 | extern int trace_selftest_startup_hw_branches(struct tracer *trace, |
| 440 | struct trace_array *tr); | 468 | struct trace_array *tr); |
| 469 | extern int trace_selftest_startup_ksym(struct tracer *trace, | ||
| 470 | struct trace_array *tr); | ||
| 441 | #endif /* CONFIG_FTRACE_STARTUP_TEST */ | 471 | #endif /* CONFIG_FTRACE_STARTUP_TEST */ |
| 442 | 472 | ||
| 443 | extern void *head_page(struct trace_array_cpu *data); | 473 | extern void *head_page(struct trace_array_cpu *data); |
| @@ -483,10 +513,6 @@ static inline int ftrace_graph_addr(unsigned long addr) | |||
| 483 | return 0; | 513 | return 0; |
| 484 | } | 514 | } |
| 485 | #else | 515 | #else |
| 486 | static inline int ftrace_trace_addr(unsigned long addr) | ||
| 487 | { | ||
| 488 | return 1; | ||
| 489 | } | ||
| 490 | static inline int ftrace_graph_addr(unsigned long addr) | 516 | static inline int ftrace_graph_addr(unsigned long addr) |
| 491 | { | 517 | { |
| 492 | return 1; | 518 | return 1; |
| @@ -500,12 +526,12 @@ print_graph_function(struct trace_iterator *iter) | |||
| 500 | } | 526 | } |
| 501 | #endif /* CONFIG_FUNCTION_GRAPH_TRACER */ | 527 | #endif /* CONFIG_FUNCTION_GRAPH_TRACER */ |
| 502 | 528 | ||
| 503 | extern struct pid *ftrace_pid_trace; | 529 | extern struct list_head ftrace_pids; |
| 504 | 530 | ||
| 505 | #ifdef CONFIG_FUNCTION_TRACER | 531 | #ifdef CONFIG_FUNCTION_TRACER |
| 506 | static inline int ftrace_trace_task(struct task_struct *task) | 532 | static inline int ftrace_trace_task(struct task_struct *task) |
| 507 | { | 533 | { |
| 508 | if (!ftrace_pid_trace) | 534 | if (list_empty(&ftrace_pids)) |
| 509 | return 1; | 535 | return 1; |
| 510 | 536 | ||
| 511 | return test_tsk_trace_trace(task); | 537 | return test_tsk_trace_trace(task); |
| @@ -687,7 +713,6 @@ struct event_filter { | |||
| 687 | int n_preds; | 713 | int n_preds; |
| 688 | struct filter_pred **preds; | 714 | struct filter_pred **preds; |
| 689 | char *filter_string; | 715 | char *filter_string; |
| 690 | bool no_reset; | ||
| 691 | }; | 716 | }; |
| 692 | 717 | ||
| 693 | struct event_subsystem { | 718 | struct event_subsystem { |
| @@ -699,22 +724,40 @@ struct event_subsystem { | |||
| 699 | }; | 724 | }; |
| 700 | 725 | ||
| 701 | struct filter_pred; | 726 | struct filter_pred; |
| 727 | struct regex; | ||
| 702 | 728 | ||
| 703 | typedef int (*filter_pred_fn_t) (struct filter_pred *pred, void *event, | 729 | typedef int (*filter_pred_fn_t) (struct filter_pred *pred, void *event, |
| 704 | int val1, int val2); | 730 | int val1, int val2); |
| 705 | 731 | ||
| 732 | typedef int (*regex_match_func)(char *str, struct regex *r, int len); | ||
| 733 | |||
| 734 | enum regex_type { | ||
| 735 | MATCH_FULL = 0, | ||
| 736 | MATCH_FRONT_ONLY, | ||
| 737 | MATCH_MIDDLE_ONLY, | ||
| 738 | MATCH_END_ONLY, | ||
| 739 | }; | ||
| 740 | |||
| 741 | struct regex { | ||
| 742 | char pattern[MAX_FILTER_STR_VAL]; | ||
| 743 | int len; | ||
| 744 | int field_len; | ||
| 745 | regex_match_func match; | ||
| 746 | }; | ||
| 747 | |||
| 706 | struct filter_pred { | 748 | struct filter_pred { |
| 707 | filter_pred_fn_t fn; | 749 | filter_pred_fn_t fn; |
| 708 | u64 val; | 750 | u64 val; |
| 709 | char str_val[MAX_FILTER_STR_VAL]; | 751 | struct regex regex; |
| 710 | int str_len; | 752 | char *field_name; |
| 711 | char *field_name; | 753 | int offset; |
| 712 | int offset; | 754 | int not; |
| 713 | int not; | 755 | int op; |
| 714 | int op; | 756 | int pop_n; |
| 715 | int pop_n; | ||
| 716 | }; | 757 | }; |
| 717 | 758 | ||
| 759 | extern enum regex_type | ||
| 760 | filter_parse_regex(char *buff, int len, char **search, int *not); | ||
| 718 | extern void print_event_filter(struct ftrace_event_call *call, | 761 | extern void print_event_filter(struct ftrace_event_call *call, |
| 719 | struct trace_seq *s); | 762 | struct trace_seq *s); |
| 720 | extern int apply_event_filter(struct ftrace_event_call *call, | 763 | extern int apply_event_filter(struct ftrace_event_call *call, |
| @@ -730,7 +773,8 @@ filter_check_discard(struct ftrace_event_call *call, void *rec, | |||
| 730 | struct ring_buffer *buffer, | 773 | struct ring_buffer *buffer, |
| 731 | struct ring_buffer_event *event) | 774 | struct ring_buffer_event *event) |
| 732 | { | 775 | { |
| 733 | if (unlikely(call->filter_active) && !filter_match_preds(call, rec)) { | 776 | if (unlikely(call->filter_active) && |
| 777 | !filter_match_preds(call->filter, rec)) { | ||
| 734 | ring_buffer_discard_commit(buffer, event); | 778 | ring_buffer_discard_commit(buffer, event); |
| 735 | return 1; | 779 | return 1; |
| 736 | } | 780 | } |
