aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/trace
diff options
context:
space:
mode:
authorDan Carpenter <dan.carpenter@oracle.com>2014-11-27 10:57:52 -0500
committerSteven Rostedt <rostedt@goodmis.org>2014-12-03 17:10:14 -0500
commit3558a5ac50dbb2419cc649d5e154af161d661037 (patch)
tree748ba84148b99c750900206d90e5969e505726b6 /kernel/trace
parent8e1e1df29d837c589c8b4d7b49864481ff7795b8 (diff)
tracing: Truncated output is better than nothing
The initial reason for this patch is that I noticed that: if (len > TRACE_BUF_SIZE) is off by one. In this code, if len == TRACE_BUF_SIZE, then it means we have truncated the last character off the output string. If we truncate two or more characters then we exit without printing. After some discussion, we decided that printing truncated data is better than not printing at all so we should just use vscnprintf() and remove the test entirely. Also I have updated memcpy() to copy the NUL char instead of setting the NUL in a separate step. Link: http://lkml.kernel.org/r/20141127155752.GA21914@mwanda Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
Diffstat (limited to 'kernel/trace')
-rw-r--r--kernel/trace/trace.c7
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);