projects
/
lttv.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
mega fix for states : per cpu and _not_ per tracefile state. We have many tracefiles...
[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..c37fb032eb210e04e0a20c9bcafe88202f59050f 100644
(file)
--- a/
ltt/branches/poly/lttv/lttv/state.h
+++ b/
ltt/branches/poly/lttv/lttv/state.h
@@
-189,20
+189,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
+251,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
+285,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.038218 seconds
and
4
git commands to generate.