return NULL;
}
-static void linkContainers (const char *a1, const char *a2)
+static void linkContainers (const char *a1, const char *a2, xbt_dict_t filter)
{
//ignore loopback
if (strcmp (a1, "__loopback__") == 0 || strcmp (a2, "__loopback__") == 0)
return;
+ //check if we already register this pair (we only need one direction)
+ char aux1[INSTR_DEFAULT_STR_SIZE], aux2[INSTR_DEFAULT_STR_SIZE];
+ snprintf (aux1, INSTR_DEFAULT_STR_SIZE, "%s%s", a1, a2);
+ snprintf (aux2, INSTR_DEFAULT_STR_SIZE, "%s%s", a2, a1);
+ if (xbt_dict_get_or_null (filter, aux1)) return;
+ if (xbt_dict_get_or_null (filter, aux2)) return;
+
+ //ok, not found, register it
+ xbt_dict_set (filter, aux1, xbt_strdup ("1"), xbt_free);
+ xbt_dict_set (filter, aux2, xbt_strdup ("1"), xbt_free);
+
container_t a1_container = getContainerByName (a1);
type_t a1_type = a1_container->type;
new_pajeEndLink(SIMIX_get_clock(), container, link_type, a2_container, "G", key);
}
-static void recursiveGraphExtraction (container_t container)
+static void recursiveGraphExtraction (container_t container, xbt_dict_t filter)
{
if (xbt_dict_length(container->children)){
xbt_dict_cursor_t cursor = NULL;
char *child_name;
//bottom-up recursion
xbt_dict_foreach(container->children, cursor, child_name, child) {
- recursiveGraphExtraction (child);
+ recursiveGraphExtraction (child, filter);
}
//let's get routes
container_t child1, child2;
const char *child_name1, *child_name2;
- xbt_dict_t filter = xbt_dict_new ();
-
xbt_dict_foreach(container->children, cursor1, child_name1, child1) {
xbt_dict_foreach(container->children, cursor2, child_name2, child2) {
- //check if we already register this pair (we only need one direction)
- char aux1[INSTR_DEFAULT_STR_SIZE], aux2[INSTR_DEFAULT_STR_SIZE];
- snprintf (aux1, INSTR_DEFAULT_STR_SIZE, "%s%s", child_name1, child_name2);
- snprintf (aux2, INSTR_DEFAULT_STR_SIZE, "%s%s", child_name2, child_name1);
- if (xbt_dict_get_or_null (filter, aux1)) continue;
- if (xbt_dict_get_or_null (filter, aux2)) continue;
-
- //ok, not found, register it
- xbt_dict_set (filter, aux1, xbt_strdup ("1"), xbt_free);
- xbt_dict_set (filter, aux2, xbt_strdup ("1"), xbt_free);
-
if ((child1->kind == INSTR_HOST || child1->kind == INSTR_ROUTER) &&
(child2->kind == INSTR_HOST || child2->kind == INSTR_ROUTER)){
char *previous_entity_name = (char*)child_name1;
xbt_dynar_foreach (route, cpt, link) {
char *link_name = ((link_CM02_t)link)->lmm_resource.generic_resource.name;
- linkContainers (previous_entity_name, link_name);
+ linkContainers (previous_entity_name, link_name, filter);
previous_entity_name = link_name;
}
- linkContainers (previous_entity_name, child_name2);
+ linkContainers (previous_entity_name, child_name2, filter);
}else if (child1->kind == INSTR_AS &&
child2->kind == INSTR_AS &&
strcmp(child_name1, child_name2) != 0){
char *previous_entity_name = route->src_gateway;
xbt_dynar_foreach (route->generic_route.link_list, cpt, link) {
char *link_name = ((link_CM02_t)link)->lmm_resource.generic_resource.name;
- linkContainers (previous_entity_name, link_name);
+ linkContainers (previous_entity_name, link_name, filter);
previous_entity_name = link_name;
}
- linkContainers (previous_entity_name, route->dst_gateway);
+ linkContainers (previous_entity_name, route->dst_gateway, filter);
}
}
}
- xbt_dict_free(&filter);
}
}
if (TRACE_msg_process_is_enabled()) {
type_t msg_process = getContainerType("MSG_PROCESS", new->type);
- getStateType ("MSG_PROCESS_STATE", msg_process);
+ type_t state = getStateType ("MSG_PROCESS_STATE", msg_process);
+ getValue ("executing", "0 1 0", state);
+ getValue ("suspend", "1 0 1", state);
+ getValue ("sleep", "1 1 0", state);
+ getValue ("receive", "1 0 0", state);
+ getValue ("send", "0 0 1", state);
+ getValue ("task_execute", "0 1 1", state);
getLinkType ("MSG_PROCESS_LINK", getRootType(), msg_process, msg_process);
+ getLinkType ("MSG_PROCESS_TASK_LINK", getRootType(), msg_process, msg_process);
}
if (TRACE_msg_task_is_enabled()) {
type_t msg_task = getContainerType ("MSG_TASK", new->type);
- getStateType ("MSG_TASK_STATE", msg_task);
+ type_t state = getStateType ("MSG_TASK_STATE", msg_task);
+ getValue ("MSG_task_execute", "0 1 0", state);
+ getValue ("created", "1 1 0", state);
getLinkType ("MSG_TASK_LINK", getRootType(), msg_task, msg_task);
}
}
{
xbt_dynar_free(¤tContainer);
currentContainer = NULL;
- recursiveGraphExtraction (getRootContainer());
+ xbt_dict_t filter = xbt_dict_new ();
+ recursiveGraphExtraction (getRootContainer(), filter);
+ xbt_dict_free(&filter);
platform_created = 1;
+ TRACE_paje_dump_buffer(1);
}
void instr_routing_define_callbacks ()