git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/simgrid/simgrid/trunk@7638
48e7efb5-ca39-0410-a469-
dd3cf9ba447f
process_containers = xbt_dict_new();
}
process_containers = xbt_dict_new();
}
-//return 1 if presence must be updated
-int __TRACE_msg_process_location (m_process_t process)
+void __TRACE_msg_process_location (m_process_t process)
+ if (!IS_TRACING_PROCESSES) return;
+
char name[200], alias[200];
m_host_t host = MSG_process_get_host (process);
TRACE_process_container (process, name, 200);
char name[200], alias[200];
m_host_t host = MSG_process_get_host (process);
TRACE_process_container (process, name, 200);
//check if process_alias container is already created
if (!xbt_dict_get_or_null (process_containers, alias)){
//check if process_alias container is already created
if (!xbt_dict_get_or_null (process_containers, alias)){
- if (IS_TRACING_PROCESSES) pajeCreateContainer (MSG_get_clock(), alias, "PROCESS", MSG_host_get_name(host), name);
- if (IS_TRACING_PROCESSES) pajePushState (MSG_get_clock(), "presence", alias, "presence");
- if (IS_TRACING_PROCESSES) pajeSetState (MSG_get_clock(), "category", alias, process->category);
+ pajeCreateContainer (MSG_get_clock(), alias, "PROCESS", MSG_host_get_name(host), name);
+ pajeSetState (MSG_get_clock(), "category", alias, process->category);
xbt_dict_set (process_containers, xbt_strdup(alias), xbt_strdup("1"), xbt_free);
xbt_dict_set (process_containers, xbt_strdup(alias), xbt_strdup("1"), xbt_free);
- return 0;
- }else{
- return 1;
+void __TRACE_msg_process_present (m_process_t process)
+{
+ if (!IS_TRACING_PROCESSES) return;
+
+ //updating presence state of this process location
+ char alias[200];
+ m_host_t host = MSG_process_get_host (process);
+ TRACE_process_alias_container (process, host, alias, 200);
+ pajePushState (MSG_get_clock(), "presence", alias, "presence");
+}
+
/*
* TRACE_msg_set_process_category: tracing interface function
*/
/*
* TRACE_msg_set_process_category: tracing interface function
*/
//create container of type "PROCESS" to indicate location
__TRACE_msg_process_location (process);
//create container of type "PROCESS" to indicate location
__TRACE_msg_process_location (process);
+ __TRACE_msg_process_present (process);
//create container of type "process" to indicate behavior
char name[200];
//create container of type "process" to indicate behavior
char name[200];
{
if (!IS_TRACING_PROCESSES || !IS_TRACED(process)) return;
{
if (!IS_TRACING_PROCESSES || !IS_TRACED(process)) return;
+ //disabling presence in old_host (__TRACE_msg_process_not_present)
char alias[200];
TRACE_process_alias_container (process, old_host, alias, 200);
if (IS_TRACING_PROCESSES) pajePopState (MSG_get_clock(), "presence", alias);
char alias[200];
TRACE_process_alias_container (process, old_host, alias, 200);
if (IS_TRACING_PROCESSES) pajePopState (MSG_get_clock(), "presence", alias);
- if (__TRACE_msg_process_location (process)) {
- TRACE_process_alias_container (process, new_host, alias, 200);
- if (IS_TRACING_PROCESSES) pajePushState (MSG_get_clock(), "presence", alias, "presence");
- }
+ __TRACE_msg_process_location (process);
+ __TRACE_msg_process_present (process);
}
void TRACE_msg_process_kill (m_process_t process)
}
void TRACE_msg_process_kill (m_process_t process)
/* declaration of instrumentation functions from msg_process_instr.c */
void __TRACE_msg_process_init (void);
/* declaration of instrumentation functions from msg_process_instr.c */
void __TRACE_msg_process_init (void);
-int __TRACE_msg_process_location (m_process_t process);
+void __TRACE_msg_process_location (m_process_t process);
+void __TRACE_msg_process_present (m_process_t process);
void TRACE_msg_process_change_host (m_process_t process, m_host_t old_host, m_host_t new_host);
void TRACE_msg_process_kill (m_process_t process);
void TRACE_msg_process_suspend (m_process_t process);
void TRACE_msg_process_change_host (m_process_t process, m_host_t old_host, m_host_t new_host);
void TRACE_msg_process_kill (m_process_t process);
void TRACE_msg_process_suspend (m_process_t process);