aboutsummaryrefslogtreecommitdiffstats
path: root/tools/lib/traceevent/event-parse.c
diff options
context:
space:
mode:
authorJiri Olsa <jolsa@kernel.org>2015-04-18 11:50:18 -0400
committerArnaldo Carvalho de Melo <acme@redhat.com>2015-04-29 09:37:45 -0400
commitd3542436c9a8d114bf81c0742e67ff8ce8be9324 (patch)
treee278e8fdee5dab07141bbe4c6fb7ac777527dc4a /tools/lib/traceevent/event-parse.c
parentc21410554ee1a8e12fbc99f578d720b641cd1c74 (diff)
tools lib traceevent: Add alias field to struct format_field
Introduce an 'alias' field to 'struct format_field' to be able to use alternative name for the field. It is initialized with same string pointer as 'name' field. The free logic checks the 'alias' pointer being reset by user and frees it. This will be handy when converting data into CTF, where each field within event needs to have a unique name (while this is not required for tracepoint). Converter can easily assign unique name into the format_field struct. Suggested-by: Steven Rostedt <rostedt@goodmis.org> Signed-off-by: Jiri Olsa <jolsa@kernel.org> Acked-by: Steven Rostedt <rostedt@goodmis.org> Cc: David Ahern <dsahern@gmail.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: He Kuang <hekuang@huawei.com> Cc: Jeremie Galarneau <jgalar@efficios.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Paul Mackerras <paulus@samba.org> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Sebastian Andrzej Siewior <bigeasy@linutronix.de> Cc: Tom Zanussi <tzanussi@gmail.com> Cc: Wang Nan <wangnan0@huawei.com> Link: http://lkml.kernel.org/n/tip-qwyq8blnfkg6s5vlbrvn1en3@git.kernel.org Link: http://lkml.kernel.org/r/1429372220-6406-6-git-send-email-jolsa@kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/lib/traceevent/event-parse.c')
-rw-r--r--tools/lib/traceevent/event-parse.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/tools/lib/traceevent/event-parse.c b/tools/lib/traceevent/event-parse.c
index 12a7e2a40c89..1ec56b459bc0 100644
--- a/tools/lib/traceevent/event-parse.c
+++ b/tools/lib/traceevent/event-parse.c
@@ -1387,7 +1387,7 @@ static int event_read_fields(struct event_format *event, struct format_field **f
1387 do_warning_event(event, "%s: no type found", __func__); 1387 do_warning_event(event, "%s: no type found", __func__);
1388 goto fail; 1388 goto fail;
1389 } 1389 }
1390 field->name = last_token; 1390 field->name = field->alias = last_token;
1391 1391
1392 if (test_type(type, EVENT_OP)) 1392 if (test_type(type, EVENT_OP))
1393 goto fail; 1393 goto fail;
@@ -1469,7 +1469,7 @@ static int event_read_fields(struct event_format *event, struct format_field **f
1469 size_dynamic = type_size(field->name); 1469 size_dynamic = type_size(field->name);
1470 free_token(field->name); 1470 free_token(field->name);
1471 strcat(field->type, brackets); 1471 strcat(field->type, brackets);
1472 field->name = token; 1472 field->name = field->alias = token;
1473 type = read_token(&token); 1473 type = read_token(&token);
1474 } else { 1474 } else {
1475 char *new_type; 1475 char *new_type;
@@ -6444,6 +6444,8 @@ void pevent_ref(struct pevent *pevent)
6444void pevent_free_format_field(struct format_field *field) 6444void pevent_free_format_field(struct format_field *field)
6445{ 6445{
6446 free(field->type); 6446 free(field->type);
6447 if (field->alias != field->name)
6448 free(field->alias);
6447 free(field->name); 6449 free(field->name);
6448 free(field); 6450 free(field);
6449} 6451}