Commit 13999e59 authored by Steven Rostedt's avatar Steven Rostedt Committed by Ingo Molnar

perf tools: Handle the case with and without the "signed" trace field

The trace format files now have a "signed" field. But we should
still be able to handle the kernels that do not have this field.
Signed-off-by: default avatarSteven Rostedt <srostedt@redhat.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
LKML-Reference: <20091014194358.888239553@goodmis.org>
Signed-off-by: default avatarIngo Molnar <mingo@elte.hu>
parent f1d1feec
...@@ -924,23 +924,30 @@ static int event_read_fields(struct event *event, struct format_field **fields) ...@@ -924,23 +924,30 @@ static int event_read_fields(struct event *event, struct format_field **fields)
if (read_expected(EVENT_OP, (char *)";") < 0) if (read_expected(EVENT_OP, (char *)";") < 0)
goto fail_expect; goto fail_expect;
if (read_expected(EVENT_ITEM, (char *)"signed") < 0) type = read_token(&token);
goto fail_expect; if (type != EVENT_NEWLINE) {
/* newer versions of the kernel have a "signed" type */
if (test_type_token(type, token, EVENT_ITEM, (char *)"signed"))
goto fail;
free_token(token);
if (read_expected(EVENT_OP, (char *)":") < 0) if (read_expected(EVENT_OP, (char *)":") < 0)
goto fail_expect; goto fail_expect;
if (read_expect_type(EVENT_ITEM, &token)) if (read_expect_type(EVENT_ITEM, &token))
goto fail; goto fail;
if (strtoul(token, NULL, 0))
field->flags |= FIELD_IS_SIGNED;
free_token(token);
/* add signed type */
free_token(token);
if (read_expected(EVENT_OP, (char *)";") < 0) if (read_expected(EVENT_OP, (char *)";") < 0)
goto fail_expect; goto fail_expect;
if (read_expect_type(EVENT_NEWLINE, &token) < 0) if (read_expect_type(EVENT_NEWLINE, &token))
goto fail; goto fail;
}
free_token(token); free_token(token);
*fields = field; *fields = field;
...@@ -2949,21 +2956,23 @@ static void print_args(struct print_arg *args) ...@@ -2949,21 +2956,23 @@ static void print_args(struct print_arg *args)
} }
} }
static void parse_header_field(char *type, static void parse_header_field(char *field,
int *offset, int *size) int *offset, int *size)
{ {
char *token; char *token;
int type;
if (read_expected(EVENT_ITEM, (char *)"field") < 0) if (read_expected(EVENT_ITEM, (char *)"field") < 0)
return; return;
if (read_expected(EVENT_OP, (char *)":") < 0) if (read_expected(EVENT_OP, (char *)":") < 0)
return; return;
/* type */ /* type */
if (read_expect_type(EVENT_ITEM, &token) < 0) if (read_expect_type(EVENT_ITEM, &token) < 0)
return; goto fail;
free_token(token); free_token(token);
if (read_expected(EVENT_ITEM, type) < 0) if (read_expected(EVENT_ITEM, field) < 0)
return; return;
if (read_expected(EVENT_OP, (char *)";") < 0) if (read_expected(EVENT_OP, (char *)";") < 0)
return; return;
...@@ -2972,7 +2981,7 @@ static void parse_header_field(char *type, ...@@ -2972,7 +2981,7 @@ static void parse_header_field(char *type,
if (read_expected(EVENT_OP, (char *)":") < 0) if (read_expected(EVENT_OP, (char *)":") < 0)
return; return;
if (read_expect_type(EVENT_ITEM, &token) < 0) if (read_expect_type(EVENT_ITEM, &token) < 0)
return; goto fail;
*offset = atoi(token); *offset = atoi(token);
free_token(token); free_token(token);
if (read_expected(EVENT_OP, (char *)";") < 0) if (read_expected(EVENT_OP, (char *)";") < 0)
...@@ -2982,22 +2991,36 @@ static void parse_header_field(char *type, ...@@ -2982,22 +2991,36 @@ static void parse_header_field(char *type,
if (read_expected(EVENT_OP, (char *)":") < 0) if (read_expected(EVENT_OP, (char *)":") < 0)
return; return;
if (read_expect_type(EVENT_ITEM, &token) < 0) if (read_expect_type(EVENT_ITEM, &token) < 0)
return; goto fail;
*size = atoi(token); *size = atoi(token);
free_token(token); free_token(token);
if (read_expected(EVENT_OP, (char *)";") < 0) if (read_expected(EVENT_OP, (char *)";") < 0)
return; return;
if (read_expected(EVENT_ITEM, (char *)"signed") < 0) type = read_token(&token);
return; if (type != EVENT_NEWLINE) {
/* newer versions of the kernel have a "signed" type */
if (type != EVENT_ITEM)
goto fail;
if (strcmp(token, (char *)"signed") != 0)
goto fail;
free_token(token);
if (read_expected(EVENT_OP, (char *)":") < 0) if (read_expected(EVENT_OP, (char *)":") < 0)
return; return;
if (read_expect_type(EVENT_ITEM, &token) < 0)
return; if (read_expect_type(EVENT_ITEM, &token))
goto fail;
free_token(token); free_token(token);
if (read_expected(EVENT_OP, (char *)";") < 0) if (read_expected(EVENT_OP, (char *)";") < 0)
return; return;
if (read_expect_type(EVENT_NEWLINE, &token) < 0)
return; if (read_expect_type(EVENT_NEWLINE, &token))
goto fail;
}
fail:
free_token(token); free_token(token);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment