diff options
author | Namhyung Kim <namhyung.kim@lge.com> | 2012-09-07 11:49:46 +0900 |
---|---|---|
committer | Steven Rostedt <rostedt@goodmis.org> | 2012-10-01 13:59:49 -0400 |
commit | f6ecd3f4c81f5efe6c5921af9955415fb48cb3f4 (patch) | |
tree | 68d97d7ba0d9560dee45ae3fcd6620ae2bc9b614 /event-parse.c | |
parent | 6fbaf82df7feeff8e57188300086eed9272f0b0b (diff) | |
download | trace-cmd-f6ecd3f4c81f5efe6c5921af9955415fb48cb3f4.tar.gz |
tools lib traceevent: Get rid of die() from pevent_register_event_handler
If memory allocation for handler fails, return gracefully instead of
calling die(). Note that casts to void * are needed because gcc
complained about discarding 'const' qualifier during implicit argument
cast.
Signed-off-by: Namhyung Kim <namhyung@kernel.org>
Acked-by: Steven Rostedt <rostedt@goodmis.org>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/r/1346986187-5170-2-git-send-email-namhyung@kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
Diffstat (limited to 'event-parse.c')
-rw-r--r-- | event-parse.c | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/event-parse.c b/event-parse.c index 89aa2fce..ecc3cbd0 100644 --- a/event-parse.c +++ b/event-parse.c @@ -5182,7 +5182,12 @@ int pevent_register_event_handler(struct pevent *pevent, not_found: /* Save for later use. */ - handle = malloc_or_die(sizeof(*handle)); + handle = malloc(sizeof(*handle)); + if (!handle) { + do_warning("Failed to allocate event handler"); + return PEVENT_ERRNO__MEM_ALLOC_FAILED; + } + memset(handle, 0, sizeof(*handle)); handle->id = id; if (event_name) @@ -5192,7 +5197,11 @@ int pevent_register_event_handler(struct pevent *pevent, if ((event_name && !handle->event_name) || (sys_name && !handle->sys_name)) { - die("Failed to allocate event/sys name"); + do_warning("Failed to allocate event/sys name"); + free((void *)handle->event_name); + free((void *)handle->sys_name); + free(handle); + return PEVENT_ERRNO__MEM_ALLOC_FAILED; } handle->func = func; |