|
|
d11878 |
--- crash-trace-command-2.0/trace.c.orig
|
|
|
d11878 |
+++ crash-trace-command-2.0/trace.c
|
|
|
d11878 |
@@ -34,6 +34,10 @@ static int encapsulated_current_trace;
|
|
|
d11878 |
* trace_buffer is supported
|
|
|
d11878 |
*/
|
|
|
d11878 |
static int trace_buffer_available;
|
|
|
d11878 |
+/*
|
|
|
d11878 |
+ * max_buffer is supported
|
|
|
d11878 |
+ */
|
|
|
d11878 |
+static int max_buffer_available;
|
|
|
d11878 |
|
|
|
d11878 |
#define koffset(struct, member) struct##_##member##_offset
|
|
|
d11878 |
|
|
|
d11878 |
@@ -154,6 +158,7 @@ static int init_offsets(void)
|
|
|
d11878 |
if (koffset(struct, member) < 0) { \
|
|
|
d11878 |
fprintf(fp, "failed to init the offset, struct:"\
|
|
|
d11878 |
#struct ", member:" #member); \
|
|
|
d11878 |
+ fprintf(fp, "\n"); \
|
|
|
d11878 |
return -1; \
|
|
|
d11878 |
} \
|
|
|
d11878 |
} while (0)
|
|
|
d11878 |
@@ -163,8 +168,10 @@ static int init_offsets(void)
|
|
|
d11878 |
|
|
|
d11878 |
if (trace_buffer_available) {
|
|
|
d11878 |
init_offset(trace_array, trace_buffer);
|
|
|
d11878 |
- init_offset(trace_array, max_buffer);
|
|
|
d11878 |
init_offset(trace_buffer, buffer);
|
|
|
d11878 |
+
|
|
|
d11878 |
+ if (max_buffer_available)
|
|
|
d11878 |
+ init_offset(trace_array, max_buffer);
|
|
|
d11878 |
} else {
|
|
|
d11878 |
init_offset(trace_array, buffer);
|
|
|
d11878 |
}
|
|
|
d11878 |
@@ -176,6 +183,9 @@ static int init_offsets(void)
|
|
|
d11878 |
fprintf(fp, "per cpu buffer sizes\n");
|
|
|
d11878 |
}
|
|
|
d11878 |
|
|
|
d11878 |
+ if (kernel_symbol_exists("ring_buffer_read"))
|
|
|
d11878 |
+ gdb_set_crash_scope(symbol_value("ring_buffer_read"), "ring_buffer_read");
|
|
|
d11878 |
+
|
|
|
d11878 |
if (!per_cpu_buffer_sizes)
|
|
|
d11878 |
init_offset(ring_buffer, pages);
|
|
|
d11878 |
init_offset(ring_buffer, flags);
|
|
|
d11878 |
@@ -205,7 +215,12 @@ static int init_offsets(void)
|
|
|
d11878 |
|
|
|
d11878 |
init_offset(list_head, next);
|
|
|
d11878 |
|
|
|
d11878 |
- init_offset(ftrace_event_call, list);
|
|
|
d11878 |
+ koffset(ftrace_event_call, list) = MAX(MEMBER_OFFSET("ftrace_event_call", "list"),
|
|
|
d11878 |
+ MEMBER_OFFSET("trace_event_call", "list"));
|
|
|
d11878 |
+ if (koffset(ftrace_event_call, list) < 0) {
|
|
|
d11878 |
+ fprintf(fp, "failed to init the offset, struct:[f]trace_event_call member:list)\n");
|
|
|
d11878 |
+ return -1; \
|
|
|
d11878 |
+ }
|
|
|
d11878 |
|
|
|
d11878 |
init_offset(ftrace_event_field, link);
|
|
|
d11878 |
init_offset(ftrace_event_field, name);
|
|
|
d11878 |
@@ -448,6 +463,9 @@ out_fail:
|
|
|
d11878 |
static int ftrace_int_max_tr_trace(void)
|
|
|
d11878 |
{
|
|
|
d11878 |
if (trace_buffer_available) {
|
|
|
d11878 |
+ if (!max_buffer_available)
|
|
|
d11878 |
+ return 0;
|
|
|
d11878 |
+
|
|
|
d11878 |
global_max_buffer = global_trace + koffset(trace_array, max_buffer);
|
|
|
d11878 |
read_value(max_tr_ring_buffer, global_max_buffer, trace_buffer, buffer);
|
|
|
d11878 |
} else {
|
|
|
d11878 |
@@ -528,6 +546,9 @@ static int ftrace_init(void)
|
|
|
d11878 |
|
|
|
d11878 |
if (MEMBER_EXISTS("trace_array", "trace_buffer")) {
|
|
|
d11878 |
trace_buffer_available = 1;
|
|
|
d11878 |
+
|
|
|
d11878 |
+ if (MEMBER_EXISTS("trace_array", "max_buffer"))
|
|
|
d11878 |
+ max_buffer_available = 1;
|
|
|
d11878 |
} else {
|
|
|
d11878 |
sym_max_tr_trace = symbol_search("max_tr");
|
|
|
d11878 |
if (sym_max_tr_trace == NULL)
|
|
|
d11878 |
@@ -710,7 +731,8 @@ static int syscall_get_enter_fields(ulon
|
|
|
d11878 |
goto work;
|
|
|
d11878 |
|
|
|
d11878 |
inited = 1;
|
|
|
d11878 |
- data_offset = MEMBER_OFFSET("ftrace_event_call", "data");
|
|
|
d11878 |
+ data_offset = MAX(MEMBER_OFFSET("ftrace_event_call", "data"),
|
|
|
d11878 |
+ MEMBER_OFFSET("trace_event_call", "data"));
|
|
|
d11878 |
if (data_offset < 0)
|
|
|
d11878 |
return -1;
|
|
|
d11878 |
|
|
|
d11878 |
@@ -742,7 +764,8 @@ static int syscall_get_exit_fields_old(u
|
|
|
d11878 |
goto work;
|
|
|
d11878 |
|
|
|
d11878 |
inited = 1;
|
|
|
d11878 |
- data_offset = MEMBER_OFFSET("ftrace_event_call", "data");
|
|
|
d11878 |
+ data_offset = MAX(MEMBER_OFFSET("ftrace_event_call", "data"),
|
|
|
d11878 |
+ MEMBER_OFFSET("trace_event_call", "data"));
|
|
|
d11878 |
if (data_offset < 0)
|
|
|
d11878 |
return -1;
|
|
|
d11878 |
|
|
|
d11878 |
@@ -803,18 +826,22 @@ int ftrace_get_event_type_fields(ulong c
|
|
|
d11878 |
goto work;
|
|
|
d11878 |
|
|
|
d11878 |
inited = 1;
|
|
|
d11878 |
- fields_offset = MEMBER_OFFSET("ftrace_event_call", "fields");
|
|
|
d11878 |
+ fields_offset = MAX(MEMBER_OFFSET("ftrace_event_call", "fields"),
|
|
|
d11878 |
+ MEMBER_OFFSET("trace_event_call", "fields"));
|
|
|
d11878 |
|
|
|
d11878 |
- class_offset = MEMBER_OFFSET("ftrace_event_call", "class");
|
|
|
d11878 |
+ class_offset = MAX(MEMBER_OFFSET("ftrace_event_call", "class"),
|
|
|
d11878 |
+ MEMBER_OFFSET("trace_event_call", "class"));
|
|
|
d11878 |
if (class_offset < 0)
|
|
|
d11878 |
goto work;
|
|
|
d11878 |
|
|
|
d11878 |
inited = 2;
|
|
|
d11878 |
- fields_offset = MEMBER_OFFSET("ftrace_event_class", "fields");
|
|
|
d11878 |
+ fields_offset = MAX(MEMBER_OFFSET("ftrace_event_class", "fields"),
|
|
|
d11878 |
+ MEMBER_OFFSET("trace_event_class", "fields"));
|
|
|
d11878 |
if (fields_offset < 0)
|
|
|
d11878 |
return -1;
|
|
|
d11878 |
|
|
|
d11878 |
- get_fields_offset = MEMBER_OFFSET("ftrace_event_class", "get_fields");
|
|
|
d11878 |
+ get_fields_offset = MAX(MEMBER_OFFSET("ftrace_event_class", "get_fields"),
|
|
|
d11878 |
+ MEMBER_OFFSET("trace_event_class", "get_fields"));
|
|
|
d11878 |
if ((sp = symbol_search("syscall_get_enter_fields")) != NULL)
|
|
|
d11878 |
syscall_get_enter_fields_value = sp->value;
|
|
|
d11878 |
if ((sp = symbol_search("syscall_get_exit_fields")) != NULL)
|
|
|
d11878 |
@@ -988,19 +1015,45 @@ static void ftrace_destroy_event_types(v
|
|
|
d11878 |
free(ftrace_common_fields);
|
|
|
d11878 |
}
|
|
|
d11878 |
|
|
|
d11878 |
+#define TRACE_EVENT_FL_TRACEPOINT 0x40
|
|
|
d11878 |
+
|
|
|
d11878 |
static
|
|
|
d11878 |
int ftrace_get_event_type_name(ulong call, char *name, int len)
|
|
|
d11878 |
{
|
|
|
d11878 |
static int inited;
|
|
|
d11878 |
static int name_offset;
|
|
|
d11878 |
+ static int flags_offset;
|
|
|
d11878 |
+ static int tp_name_offset;
|
|
|
d11878 |
+ uint flags;
|
|
|
d11878 |
|
|
|
d11878 |
ulong name_addr;
|
|
|
d11878 |
|
|
|
d11878 |
- if (!inited) {
|
|
|
d11878 |
- inited = 1;
|
|
|
d11878 |
- name_offset = MEMBER_OFFSET("ftrace_event_call", "name");
|
|
|
d11878 |
- }
|
|
|
d11878 |
+ if (inited)
|
|
|
d11878 |
+ goto work;
|
|
|
d11878 |
|
|
|
d11878 |
+ inited = 1;
|
|
|
d11878 |
+ name_offset = MAX(MEMBER_OFFSET("ftrace_event_call", "name"),
|
|
|
d11878 |
+ MEMBER_OFFSET("trace_event_call", "name"));
|
|
|
d11878 |
+ if (name_offset >= 0)
|
|
|
d11878 |
+ goto work;
|
|
|
d11878 |
+
|
|
|
d11878 |
+ name_offset = MAX(ANON_MEMBER_OFFSET("ftrace_event_call", "name"),
|
|
|
d11878 |
+ ANON_MEMBER_OFFSET("trace_event_call", "name"));
|
|
|
d11878 |
+ if (name_offset < 0)
|
|
|
d11878 |
+ return -1;
|
|
|
d11878 |
+
|
|
|
d11878 |
+ flags_offset = MAX(MEMBER_OFFSET("ftrace_event_call", "flags"),
|
|
|
d11878 |
+ MEMBER_OFFSET("trace_event_call", "flags"));
|
|
|
d11878 |
+ if (flags_offset < 0)
|
|
|
d11878 |
+ return -1;
|
|
|
d11878 |
+
|
|
|
d11878 |
+ tp_name_offset = MEMBER_OFFSET("tracepoint", "name");
|
|
|
d11878 |
+ if (tp_name_offset < 0)
|
|
|
d11878 |
+ return -1;
|
|
|
d11878 |
+
|
|
|
d11878 |
+ inited = 2;
|
|
|
d11878 |
+
|
|
|
d11878 |
+work:
|
|
|
d11878 |
if (name_offset < 0)
|
|
|
d11878 |
return -1;
|
|
|
d11878 |
|
|
|
d11878 |
@@ -1008,6 +1061,21 @@ int ftrace_get_event_type_name(ulong cal
|
|
|
d11878 |
"read ftrace_event_call name_addr", RETURN_ON_ERROR))
|
|
|
d11878 |
return -1;
|
|
|
d11878 |
|
|
|
d11878 |
+ if (inited == 2) {
|
|
|
d11878 |
+ if (!readmem(call + flags_offset, KVADDR, &flags,
|
|
|
d11878 |
+ sizeof(flags), "read ftrace_event_call flags",
|
|
|
d11878 |
+ RETURN_ON_ERROR))
|
|
|
d11878 |
+ return -1;
|
|
|
d11878 |
+
|
|
|
d11878 |
+ if (flags & TRACE_EVENT_FL_TRACEPOINT) {
|
|
|
d11878 |
+ if (!readmem(name_addr + tp_name_offset, KVADDR,
|
|
|
d11878 |
+ &name_addr, sizeof(name_addr),
|
|
|
d11878 |
+ "read tracepoint name", RETURN_ON_ERROR))
|
|
|
d11878 |
+ return -1;
|
|
|
d11878 |
+ }
|
|
|
d11878 |
+
|
|
|
d11878 |
+ }
|
|
|
d11878 |
+
|
|
|
d11878 |
if (!read_string(name_addr, name, len))
|
|
|
d11878 |
return -1;
|
|
|
d11878 |
|
|
|
d11878 |
@@ -1028,16 +1096,19 @@ int ftrace_get_event_type_system(ulong c
|
|
|
d11878 |
goto work;
|
|
|
d11878 |
|
|
|
d11878 |
inited = 1;
|
|
|
d11878 |
- sys_offset = MEMBER_OFFSET("ftrace_event_call", "system");
|
|
|
d11878 |
+ sys_offset = MAX(MEMBER_OFFSET("ftrace_event_call", "system"),
|
|
|
d11878 |
+ MEMBER_OFFSET("trace_event_call", "system"));
|
|
|
d11878 |
|
|
|
d11878 |
if (sys_offset >= 0)
|
|
|
d11878 |
goto work;
|
|
|
d11878 |
|
|
|
d11878 |
- class_offset = MEMBER_OFFSET("ftrace_event_call", "class");
|
|
|
d11878 |
+ class_offset = MAX(MEMBER_OFFSET("ftrace_event_call", "class"),
|
|
|
d11878 |
+ MEMBER_OFFSET("trace_event_call", "class"));
|
|
|
d11878 |
if (class_offset < 0)
|
|
|
d11878 |
return -1;
|
|
|
d11878 |
|
|
|
d11878 |
- sys_offset = MEMBER_OFFSET("ftrace_event_class", "system");
|
|
|
d11878 |
+ sys_offset = MAX(MEMBER_OFFSET("ftrace_event_class", "system"),
|
|
|
d11878 |
+ MEMBER_OFFSET("trace_event_class", "system"));
|
|
|
d11878 |
inited = 2;
|
|
|
d11878 |
|
|
|
d11878 |
work:
|
|
|
d11878 |
@@ -1109,7 +1180,8 @@ int ftrace_get_event_type_print_fmt(ulon
|
|
|
d11878 |
|
|
|
d11878 |
if (!inited) {
|
|
|
d11878 |
inited = 1;
|
|
|
d11878 |
- fmt_offset = MEMBER_OFFSET("ftrace_event_call", "print_fmt");
|
|
|
d11878 |
+ fmt_offset = MAX(MEMBER_OFFSET("ftrace_event_call", "print_fmt"),
|
|
|
d11878 |
+ MEMBER_OFFSET("trace_event_call", "print_fmt"));
|
|
|
d11878 |
}
|
|
|
d11878 |
|
|
|
d11878 |
if (fmt_offset < 0) {
|
|
|
d11878 |
@@ -1132,11 +1204,13 @@ int ftrace_get_event_type_id(ulong call,
|
|
|
d11878 |
|
|
|
d11878 |
if (!inited) {
|
|
|
d11878 |
inited = 1;
|
|
|
d11878 |
- id_offset = MEMBER_OFFSET("ftrace_event_call", "id");
|
|
|
d11878 |
+ id_offset = MAX(MEMBER_OFFSET("ftrace_event_call", "id"),
|
|
|
d11878 |
+ MEMBER_OFFSET("trace_event_call", "id"));
|
|
|
d11878 |
|
|
|
d11878 |
if (id_offset < 0) {
|
|
|
d11878 |
/* id = call->event.type */
|
|
|
d11878 |
- int f1 = MEMBER_OFFSET("ftrace_event_call", "event");
|
|
|
d11878 |
+ int f1 = MAX(MEMBER_OFFSET("ftrace_event_call", "event"),
|
|
|
d11878 |
+ MEMBER_OFFSET("trace_event_call", "event"));
|
|
|
d11878 |
int f2 = MEMBER_OFFSET("trace_event", "type");
|
|
|
d11878 |
|
|
|
d11878 |
if (f1 >= 0 && f2 >= 0)
|
|
|
d11878 |
@@ -1495,7 +1569,6 @@ static void ftrace_show(int argc, char *
|
|
|
d11878 |
FILE *file;
|
|
|
d11878 |
size_t ret;
|
|
|
d11878 |
size_t nitems __attribute__ ((__unused__));
|
|
|
d11878 |
- char *unused __attribute__ ((__unused__));
|
|
|
d11878 |
|
|
|
d11878 |
/* check trace-cmd */
|
|
|
d11878 |
if (env_trace_cmd)
|
|
|
d11878 |
@@ -1519,8 +1592,9 @@ static void ftrace_show(int argc, char *
|
|
|
d11878 |
}
|
|
|
d11878 |
|
|
|
d11878 |
/* dump trace.dat to the temp file */
|
|
|
d11878 |
- unused = mktemp(tmp);
|
|
|
d11878 |
- fd = open(tmp, O_WRONLY | O_CREAT | O_TRUNC, 0644);
|
|
|
d11878 |
+ fd = mkstemp(tmp);
|
|
|
d11878 |
+ if (fd < 0)
|
|
|
d11878 |
+ return;
|
|
|
d11878 |
if (trace_cmd_data_output(fd) < 0)
|
|
|
d11878 |
goto out;
|
|
|
d11878 |
|