diff options
Diffstat (limited to 'kernel/trace/trace_syscalls.c')
-rw-r--r-- | kernel/trace/trace_syscalls.c | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/kernel/trace/trace_syscalls.c b/kernel/trace/trace_syscalls.c index f4eaec3d559a..9ee6386cf842 100644 --- a/kernel/trace/trace_syscalls.c +++ b/kernel/trace/trace_syscalls.c | |||
@@ -105,6 +105,52 @@ print_syscall_exit(struct trace_iterator *iter, int flags) | |||
105 | return TRACE_TYPE_HANDLED; | 105 | return TRACE_TYPE_HANDLED; |
106 | } | 106 | } |
107 | 107 | ||
108 | int ftrace_format_syscall(struct ftrace_event_call *call, struct trace_seq *s) | ||
109 | { | ||
110 | int i; | ||
111 | int nr; | ||
112 | int ret = 0; | ||
113 | struct syscall_metadata *entry; | ||
114 | int offset = sizeof(struct trace_entry); | ||
115 | |||
116 | nr = syscall_name_to_nr((char *)call->data); | ||
117 | entry = syscall_nr_to_meta(nr); | ||
118 | |||
119 | if (!entry) | ||
120 | return ret; | ||
121 | |||
122 | for (i = 0; i < entry->nb_args; i++) { | ||
123 | ret = trace_seq_printf(s, "\tfield:%s %s;", entry->types[i], | ||
124 | entry->args[i]); | ||
125 | if (!ret) | ||
126 | return 0; | ||
127 | ret = trace_seq_printf(s, "\toffset:%d;\tsize:%lu;\n", offset, | ||
128 | sizeof(unsigned long)); | ||
129 | if (!ret) | ||
130 | return 0; | ||
131 | offset += sizeof(unsigned long); | ||
132 | } | ||
133 | |||
134 | trace_seq_printf(s, "\nprint fmt: \""); | ||
135 | for (i = 0; i < entry->nb_args; i++) { | ||
136 | ret = trace_seq_printf(s, "%s: 0x%%0%lulx%s", entry->args[i], | ||
137 | sizeof(unsigned long), | ||
138 | i == entry->nb_args - 1 ? "\", " : ", "); | ||
139 | if (!ret) | ||
140 | return 0; | ||
141 | } | ||
142 | |||
143 | for (i = 0; i < entry->nb_args; i++) { | ||
144 | ret = trace_seq_printf(s, "((unsigned long)(REC->%s))%s", | ||
145 | entry->args[i], | ||
146 | i == entry->nb_args - 1 ? "\n" : ", "); | ||
147 | if (!ret) | ||
148 | return 0; | ||
149 | } | ||
150 | |||
151 | return ret; | ||
152 | } | ||
153 | |||
108 | void ftrace_syscall_enter(struct pt_regs *regs, long id) | 154 | void ftrace_syscall_enter(struct pt_regs *regs, long id) |
109 | { | 155 | { |
110 | struct syscall_trace_enter *entry; | 156 | struct syscall_trace_enter *entry; |