Steven Rostedt | f0868d1 | 2008-12-23 23:24:12 -0500 | [diff] [blame] | 1 | #ifndef __TRACE_EVENTS_H |
| 2 | #define __TRACE_EVENTS_H |
| 3 | |
| 4 | #include "trace.h" |
| 5 | |
Arnaldo Carvalho de Melo | 2c9b238 | 2009-02-02 20:30:12 -0200 | [diff] [blame] | 6 | typedef int (*trace_print_func)(struct trace_iterator *iter, int flags); |
Steven Rostedt | f0868d1 | 2008-12-23 23:24:12 -0500 | [diff] [blame] | 7 | |
| 8 | struct trace_event { |
| 9 | struct hlist_node node; |
| 10 | int type; |
| 11 | trace_print_func trace; |
| 12 | trace_print_func latency_trace; |
| 13 | trace_print_func raw; |
| 14 | trace_print_func hex; |
| 15 | trace_print_func binary; |
| 16 | }; |
| 17 | |
Steven Rostedt | c37abc5 | 2009-01-15 20:50:54 -0500 | [diff] [blame] | 18 | extern int trace_seq_printf(struct trace_seq *s, const char *fmt, ...) |
| 19 | __attribute__ ((format (printf, 2, 3))); |
Steven Rostedt | f0868d1 | 2008-12-23 23:24:12 -0500 | [diff] [blame] | 20 | extern int |
| 21 | seq_print_ip_sym(struct trace_seq *s, unsigned long ip, |
| 22 | unsigned long sym_flags); |
| 23 | extern ssize_t trace_seq_to_user(struct trace_seq *s, char __user *ubuf, |
| 24 | size_t cnt); |
| 25 | int trace_seq_puts(struct trace_seq *s, const char *str); |
| 26 | int trace_seq_putc(struct trace_seq *s, unsigned char c); |
| 27 | int trace_seq_putmem(struct trace_seq *s, void *mem, size_t len); |
| 28 | int trace_seq_putmem_hex(struct trace_seq *s, void *mem, size_t len); |
| 29 | int trace_seq_path(struct trace_seq *s, struct path *path); |
| 30 | int seq_print_userip_objs(const struct userstack_entry *entry, |
| 31 | struct trace_seq *s, unsigned long sym_flags); |
| 32 | int seq_print_user_ip(struct trace_seq *s, struct mm_struct *mm, |
| 33 | unsigned long ip, unsigned long sym_flags); |
| 34 | |
Frederic Weisbecker | c4a8e8b | 2009-02-02 20:29:21 -0200 | [diff] [blame] | 35 | int trace_print_context(struct trace_iterator *iter); |
| 36 | int trace_print_lat_context(struct trace_iterator *iter); |
| 37 | |
Steven Rostedt | f0868d1 | 2008-12-23 23:24:12 -0500 | [diff] [blame] | 38 | struct trace_event *ftrace_find_event(int type); |
| 39 | int register_ftrace_event(struct trace_event *event); |
| 40 | int unregister_ftrace_event(struct trace_event *event); |
| 41 | |
Arnaldo Carvalho de Melo | 2c9b238 | 2009-02-02 20:30:12 -0200 | [diff] [blame] | 42 | int trace_nop_print(struct trace_iterator *iter, int flags); |
Steven Rostedt | f633cef | 2008-12-23 23:24:13 -0500 | [diff] [blame] | 43 | |
Steven Rostedt | f0868d1 | 2008-12-23 23:24:12 -0500 | [diff] [blame] | 44 | #define MAX_MEMHEX_BYTES 8 |
| 45 | #define HEX_CHARS (MAX_MEMHEX_BYTES*2 + 1) |
| 46 | |
Steven Rostedt | f633cef | 2008-12-23 23:24:13 -0500 | [diff] [blame] | 47 | #define SEQ_PUT_FIELD_RET(s, x) \ |
| 48 | do { \ |
| 49 | if (!trace_seq_putmem(s, &(x), sizeof(x))) \ |
Lai Jiangshan | 6c1a99a | 2009-01-15 18:05:40 +0800 | [diff] [blame] | 50 | return TRACE_TYPE_PARTIAL_LINE; \ |
Steven Rostedt | f633cef | 2008-12-23 23:24:13 -0500 | [diff] [blame] | 51 | } while (0) |
| 52 | |
| 53 | #define SEQ_PUT_HEX_FIELD_RET(s, x) \ |
| 54 | do { \ |
| 55 | BUILD_BUG_ON(sizeof(x) > MAX_MEMHEX_BYTES); \ |
| 56 | if (!trace_seq_putmem_hex(s, &(x), sizeof(x))) \ |
Lai Jiangshan | 6c1a99a | 2009-01-15 18:05:40 +0800 | [diff] [blame] | 57 | return TRACE_TYPE_PARTIAL_LINE; \ |
Steven Rostedt | f633cef | 2008-12-23 23:24:13 -0500 | [diff] [blame] | 58 | } while (0) |
| 59 | |
Steven Rostedt | f0868d1 | 2008-12-23 23:24:12 -0500 | [diff] [blame] | 60 | #endif |
| 61 | |