| From de04f8657de9d3351a2d5880f1f7080b23b798cf Mon Sep 17 00:00:00 2001 |
| From: Steven Rostedt <rostedt@goodmis.org> |
| Date: Tue, 22 Apr 2014 19:23:30 -0400 |
| Subject: tools lib traceevent: Fix memory leak in pretty_print() |
| |
| From: Steven Rostedt <rostedt@goodmis.org> |
| |
| commit de04f8657de9d3351a2d5880f1f7080b23b798cf upstream. |
| |
| Commit 12e55569a244 "tools lib traceevent: Use helper trace-seq in print |
| functions like kernel does" added a extra trace_seq helper to process |
| string arguments like the kernel does it. But the difference between the |
| kernel and the userspace library is that the kernel's trace_seq structure |
| has a static allocated buffer. The userspace one has a dynamically |
| allocated one. It requires a trace_seq_destroy(), otherwise it produces |
| a nasty memory leak. |
| |
| Signed-off-by: Steven Rostedt <rostedt@goodmis.org> |
| Link: http://lkml.kernel.org/r/20140422192330.6bb09bf8@gandalf.local.home |
| Signed-off-by: Jiri Olsa <jolsa@redhat.com> |
| Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> |
| |
| --- |
| tools/lib/traceevent/event-parse.c | 1 + |
| 1 file changed, 1 insertion(+) |
| |
| --- a/tools/lib/traceevent/event-parse.c |
| +++ b/tools/lib/traceevent/event-parse.c |
| @@ -4321,6 +4321,7 @@ static void pretty_print(struct trace_se |
| format, len_arg, arg); |
| trace_seq_terminate(&p); |
| trace_seq_puts(s, p.buffer); |
| + trace_seq_destroy(&p); |
| arg = arg->next; |
| break; |
| default: |