projects
/
lttv.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
lib list
[lttv.git]
/
ltt
/
branches
/
poly
/
lttv
/
lttv
/
state.h
diff --git
a/ltt/branches/poly/lttv/lttv/state.h
b/ltt/branches/poly/lttv/lttv/state.h
index 720506861484f6b17de9956e21bdd7197af84f3e..69f35edf1867f8cfcfa4c67099d46475332094a4 100644
(file)
--- a/
ltt/branches/poly/lttv/lttv/state.h
+++ b/
ltt/branches/poly/lttv/lttv/state.h
@@
-57,7
+57,8
@@
extern GQuark
LTT_FACILITY_KERNEL,
extern GQuark
LTT_FACILITY_KERNEL,
- LTT_FACILITY_PROCESS;
+ LTT_FACILITY_PROCESS,
+ LTT_FACILITY_FS;
/* Events Quarks */
/* Events Quarks */
@@
-71,7
+72,8
@@
extern GQuark
LTT_EVENT_SCHEDCHANGE,
LTT_EVENT_FORK,
LTT_EVENT_EXIT,
LTT_EVENT_SCHEDCHANGE,
LTT_EVENT_FORK,
LTT_EVENT_EXIT,
- LTT_EVENT_FREE;
+ LTT_EVENT_FREE,
+ LTT_EVENT_EXEC;
/* Fields Quarks */
/* Fields Quarks */
@@
-84,7
+86,8
@@
extern GQuark
LTT_FIELD_OUT_STATE,
LTT_FIELD_PARENT_PID,
LTT_FIELD_CHILD_PID,
LTT_FIELD_OUT_STATE,
LTT_FIELD_PARENT_PID,
LTT_FIELD_CHILD_PID,
- LTT_FIELD_PID;
+ LTT_FIELD_PID,
+ LTT_FIELD_NAME;
extern GQuark LTT_EVENT_SYSCALL_ENTRY;
extern GQuark LTT_EVENT_SYSCALL_ENTRY;
@@
-165,7
+168,8
@@
extern LttvProcessStatus
LTTV_STATE_EXIT,
LTTV_STATE_ZOMBIE,
LTTV_STATE_WAIT,
LTTV_STATE_EXIT,
LTTV_STATE_ZOMBIE,
LTTV_STATE_WAIT,
- LTTV_STATE_RUN;
+ LTTV_STATE_RUN,
+ LTTV_STATE_DEAD;
typedef struct _LttvExecutionState {
typedef struct _LttvExecutionState {
@@
-189,20
+193,25
@@
typedef struct _LttvProcessState {
/* WARNING : each time the execution_stack size is modified, the state
* must be reget : g_array_set_size can have to move the array.
* (Mathieu) */
/* WARNING : each time the execution_stack size is modified, the state
* must be reget : g_array_set_size can have to move the array.
* (Mathieu) */
- GQuark last_cpu; /* Last CPU where process was scheduled */
- guint last_cpu_index; /* index in the trace for cpu tracefile */
+ guint cpu; /* CPU where process is scheduled (being either in
+ the active or inactive runqueue)*/
+// guint last_tracefile_index; /* index in the trace for cpu tracefile */
/* opened file descriptors, address map?... */
} LttvProcessState;
/* opened file descriptors, address map?... */
} LttvProcessState;
+#define ANY_CPU 0 /* For clarity sake : a call to lttv_state_find_process for
+ a PID != 0 will search on any cpu automatically. */
+
LttvProcessState *
LttvProcessState *
-lttv_state_find_process(LttvTrace
fileState *tfs
, guint pid);
+lttv_state_find_process(LttvTrace
State *ts, guint cpu
, guint pid);
LttvProcessState *
LttvProcessState *
-lttv_state_find_process_or_create(LttvTracefileState *tfs, guint pid);
+lttv_state_find_process_or_create(LttvTraceState *ts, guint cpu, guint pid,
+ LttTime *timestamp);
LttvProcessState *
LttvProcessState *
-lttv_state_create_process(LttvTrace
fileState *tf
s, LttvProcessState *parent,
- guint
pid
);
+lttv_state_create_process(LttvTrace
State *t
s, LttvProcessState *parent,
+ guint
cpu, guint pid, const LttTime *timestamp
);
void lttv_state_write(LttvTraceState *self, LttTime t, FILE *fp);
void lttv_state_write(LttvTraceState *self, LttTime t, FILE *fp);
@@
-246,6
+255,10
@@
struct _LttvTraceState {
GQuark *trap_names;
GQuark *irq_names;
LttTime *max_time_state_recomputed_in_seek;
GQuark *trap_names;
GQuark *irq_names;
LttTime *max_time_state_recomputed_in_seek;
+
+ /* Array of per cpu running process */
+ LttvProcessState **running_process;
+
};
struct _LttvTraceStateClass {
};
struct _LttvTraceStateClass {
@@
-276,8
+289,8
@@
void lttv_state_state_saved_free(LttvTraceState *self,
struct _LttvTracefileState {
LttvTracefileContext parent;
struct _LttvTracefileState {
LttvTracefileContext parent;
- LttvProcessState *process;
- GQuark
cpu
_name;
+
//
LttvProcessState *process;
+ GQuark
tracefile
_name;
// guint saved_position;
};
// guint saved_position;
};
This page took
0.02404 seconds
and
4
git commands to generate.