diff options
-rw-r--r-- | kernel/trace/trace.c | 7 |
1 files changed, 2 insertions, 5 deletions
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c index 3ce3c4ccfc94..4ceb2546c7ef 100644 --- a/kernel/trace/trace.c +++ b/kernel/trace/trace.c | |||
@@ -2158,9 +2158,7 @@ __trace_array_vprintk(struct ring_buffer *buffer, | |||
2158 | goto out; | 2158 | goto out; |
2159 | } | 2159 | } |
2160 | 2160 | ||
2161 | len = vsnprintf(tbuffer, TRACE_BUF_SIZE, fmt, args); | 2161 | len = vscnprintf(tbuffer, TRACE_BUF_SIZE, fmt, args); |
2162 | if (len > TRACE_BUF_SIZE) | ||
2163 | goto out; | ||
2164 | 2162 | ||
2165 | local_save_flags(flags); | 2163 | local_save_flags(flags); |
2166 | size = sizeof(*entry) + len + 1; | 2164 | size = sizeof(*entry) + len + 1; |
@@ -2171,8 +2169,7 @@ __trace_array_vprintk(struct ring_buffer *buffer, | |||
2171 | entry = ring_buffer_event_data(event); | 2169 | entry = ring_buffer_event_data(event); |
2172 | entry->ip = ip; | 2170 | entry->ip = ip; |
2173 | 2171 | ||
2174 | memcpy(&entry->buf, tbuffer, len); | 2172 | memcpy(&entry->buf, tbuffer, len + 1); |
2175 | entry->buf[len] = '\0'; | ||
2176 | if (!call_filter_check_discard(call, entry, buffer, event)) { | 2173 | if (!call_filter_check_discard(call, entry, buffer, event)) { |
2177 | __buffer_unlock_commit(buffer, event); | 2174 | __buffer_unlock_commit(buffer, event); |
2178 | ftrace_trace_stack(buffer, flags, 6, pc); | 2175 | ftrace_trace_stack(buffer, flags, 6, pc); |