#include <ltt/ltt-private.h>
#include <string.h>
+static inline void print_enum_events(LttEvent *e, struct marker_field *f,
+ guint64 value, GString *s, LttvTracefileState *tfs)
+{
+ LttTrace *trace = ltt_tracefile_get_trace(e->tracefile);
+ struct marker_info *info = marker_get_info_from_id(trace, e->event_id);
+ LttvTraceState *ts = (LttvTraceState*)(tfs->parent.t_context);
+
+ //TODO optimize with old quarks.
+ if (info->name == g_quark_from_static_string("kernel_arch_syscall_entry") &&
+ f->name == LTT_FIELD_SYSCALL_ID) {
+ g_string_append_printf(s, " [%s]",
+ g_quark_to_string(ts->syscall_names[value]));
+ }
+}
void lttv_print_field(LttEvent *e, struct marker_field *f, GString *s,
- gboolean field_names)
+ gboolean field_names, LttvTracefileState *tfs)
{
GQuark name;
+ guint64 value;
//int nb, i;
if(name)
g_string_append_printf(s, "%s = ", g_quark_to_string(name));
}
-
- g_string_append_printf(s, "%lld", ltt_event_get_long_int(e,f));
+ value = ltt_event_get_long_int(e,f);
+ g_string_append_printf(s, "%lld", value);
//g_string_append_printf(s, type->fmt, ltt_event_get_long_int(e,f));
+ print_enum_events(e, f, value, s, tfs);
break;
case LTT_TYPE_UNSIGNED_INT:
if(name)
g_string_append_printf(s, "%s = ", g_quark_to_string(name));
}
- g_string_append_printf(s, "%llu", ltt_event_get_long_unsigned(e,f));
+ value = ltt_event_get_long_unsigned(e,f);
+ g_string_append_printf(s, "%llu", value);
+ print_enum_events(e, f, value, s, tfs);
//g_string_append_printf(s, type->fmt, ltt_event_get_long_unsigned(e,f));
break;
field++) {
if(field != marker_get_field(info, 0))
g_string_append_printf(s, ", ");
- lttv_print_field(e, field, s, field_names);
+ lttv_print_field(e, field, s, field_names, tfs);
}
g_string_append_printf(s, " }");
}
#include <ltt/marker-desc.h>
#include <stdio.h>
#include <string.h>
+#include <ltt/ltt-private.h>
/* Comment :
* Mathieu Desnoyers
LTT_FACILITY_LIST,
LTT_FACILITY_FS,
LTT_FACILITY_USER_GENERIC,
- LTT_FACILITY_BLOCK;
+ LTT_FACILITY_BLOCK,
+ LTT_FACILITY_STATEDUMP;
/* Events Quarks */
LTT_EVENT_THREAD_BRAND,
LTT_EVENT_REQUEST_ISSUE,
LTT_EVENT_REQUEST_COMPLETE,
- LTT_EVENT_LIST_INTERRUPT;
+ LTT_EVENT_LIST_INTERRUPT,
+ LTT_EVENT_SYS_CALL_TABLE;
/* Fields Quarks */
LTT_FIELD_MINOR,
LTT_FIELD_MAJOR,
LTT_FIELD_OPERATION,
- LTT_FIELD_ACTION;
+ LTT_FIELD_ACTION,
+ LTT_FIELD_ID,
+ LTT_FIELD_ADDRESS,
+ LTT_FIELD_SYMBOL;
LttvExecutionMode
LTTV_STATE_MODE_UNKNOWN,
return FALSE;
}
+static gboolean dump_syscall(void *hook_data, void *call_data)
+{
+ LttvTracefileState *s = (LttvTracefileState *)call_data;
+ LttvTraceState *ts = (LttvTraceState*)s->parent.t_context;
+ LttEvent *e = ltt_tracefile_get_event(s->parent.tf);
+ LttvTraceHook *th = (LttvTraceHook *)hook_data;
+ guint id;
+ guint64 address;
+ char *symbol;
+
+ id = ltt_event_get_unsigned(e, lttv_trace_get_hook_field(th, 0));
+ address = ltt_event_get_long_unsigned(e, lttv_trace_get_hook_field(th, 1));
+ symbol = ltt_event_get_string(e, lttv_trace_get_hook_field(th, 2));
+
+ if (ts->nb_syscalls < id) {
+ GQuark *old_names = ts->syscall_names;
+ guint new_nb_syscalls = max(id + 1, ts->nb_syscalls * 2);
+ guint i;
+ GString *fe_name = g_string_new("");
+ ts->syscall_names = g_new(GQuark, new_nb_syscalls);
+ memcpy(ts->syscall_names, old_names,
+ ts->nb_syscalls * sizeof(GQuark));
+ for(i = ts->nb_syscalls ; i < new_nb_syscalls ; i++) {
+ g_string_printf(fe_name, "syscall %d", i);
+ ts->syscall_names[i] = g_quark_from_string(fe_name->str);
+ }
+ g_string_free(fe_name, TRUE);
+ ts->nb_syscalls = new_nb_syscalls;
+ }
+ ts->syscall_names[id] = g_quark_from_string(symbol);
+
+ return FALSE;
+}
+
static gboolean schedchange(void *hook_data, void *call_data)
{
LttvTracefileState *s = (LttvTracefileState *)call_data;
FIELD_ARRAY(LTT_FIELD_THIS_FN, LTT_FIELD_CALL_SITE),
function_exit, NULL, &hooks);
+ lttv_trace_find_hook(ts->parent.t,
+ LTT_FACILITY_STATEDUMP,
+ LTT_EVENT_SYS_CALL_TABLE,
+ FIELD_ARRAY(LTT_FIELD_ID, LTT_FIELD_ADDRESS, LTT_FIELD_SYMBOL),
+ dump_syscall, NULL, &hooks);
+
/* Add these hooks to each event_by_id hooks list */
nb_tracefile = ts->parent.tracefiles->len;
LTT_FACILITY_LIST = g_quark_from_string("list");
LTT_FACILITY_USER_GENERIC = g_quark_from_string("user_generic");
LTT_FACILITY_BLOCK = g_quark_from_string("block");
-
-
+ LTT_FACILITY_STATEDUMP = g_quark_from_string("statedump");
+
LTT_EVENT_SYSCALL_ENTRY = g_quark_from_string("syscall_entry");
LTT_EVENT_SYSCALL_EXIT = g_quark_from_string("syscall_exit");
LTT_EVENT_TRAP_ENTRY = g_quark_from_string("trap_entry");
LTT_EVENT_THREAD_BRAND = g_quark_from_string("thread_brand");
LTT_EVENT_REQUEST_ISSUE = g_quark_from_string("_blk_request_issue");
LTT_EVENT_REQUEST_COMPLETE = g_quark_from_string("_blk_request_complete");
- LTT_EVENT_LIST_INTERRUPT = g_quark_from_string("interrupt");;
-
+ LTT_EVENT_LIST_INTERRUPT = g_quark_from_string("interrupt");
+ LTT_EVENT_SYS_CALL_TABLE = g_quark_from_string("sys_call_table");
LTT_FIELD_SYSCALL_ID = g_quark_from_string("syscall_id");
LTT_FIELD_TRAP_ID = g_quark_from_string("trap_id");
LTT_FIELD_MINOR = g_quark_from_string("minor");
LTT_FIELD_OPERATION = g_quark_from_string("direction");
LTT_FIELD_ACTION = g_quark_from_string("action");
+ LTT_FIELD_ID = g_quark_from_string("id");
+ LTT_FIELD_ADDRESS = g_quark_from_string("address");
+ LTT_FIELD_SYMBOL = g_quark_from_string("symbol");
LTTV_CPU_UNKNOWN = g_quark_from_string("unknown");
LTTV_CPU_IDLE = g_quark_from_string("idle");