1 /* Copyright (c) 2010. The SimGrid Team.
2 * All rights reserved. */
4 /* This program is free software; you can redistribute it and/or modify it
5 * under the terms of the license (GNU LGPL) which comes with this package. */
7 #include "instr/instr_private.h"
8 #include "surf/surf_private.h"
12 XBT_LOG_NEW_DEFAULT_SUBCATEGORY(instr_surf, instr, "Tracing Surf");
14 static xbt_dict_t resource_variables; /* (host|link)#variable -> value */
16 void TRACE_surf_alloc(void)
18 resource_variables = xbt_dict_new();
20 TRACE_surf_resource_utilization_alloc();
23 void TRACE_surf_release(void)
25 TRACE_surf_resource_utilization_release();
26 instr_destroy_platform();
29 static void TRACE_surf_set_resource_variable(double date,
34 char value_str[INSTR_DEFAULT_STR_SIZE];
35 snprintf(value_str, 100, "%f", value);
36 pajeSetVariable(date, variable, resource, value_str);
39 void TRACE_surf_host_set_power(double date, const char *resource,
42 if (!TRACE_is_active())
45 char *host_type = instr_host_type (resource);
46 char variable_type[INSTR_DEFAULT_STR_SIZE];
47 snprintf (variable_type, INSTR_DEFAULT_STR_SIZE, "power-%s", host_type);
49 TRACE_surf_set_resource_variable(date, variable_type, resource, power);
52 void TRACE_surf_link_set_bandwidth(double date, const char *resource, double bandwidth)
54 if (!TRACE_is_active())
57 char *link_type = instr_link_type (resource);
58 char variable_type[INSTR_DEFAULT_STR_SIZE];
59 snprintf (variable_type, INSTR_DEFAULT_STR_SIZE, "bandwidth-%s", link_type);
61 TRACE_surf_set_resource_variable(date, variable_type, resource, bandwidth);
64 //FIXME: this function is not used (latency availability traces support exists in surf network models?)
65 void TRACE_surf_link_set_latency(double date, const char *resource, double latency)
67 if (!TRACE_is_active())
70 char *link_type = instr_link_type (resource);
71 char variable_type[INSTR_DEFAULT_STR_SIZE];
72 snprintf (variable_type, INSTR_DEFAULT_STR_SIZE, "latency-%s", link_type);
74 TRACE_surf_set_resource_variable(date, variable_type, resource, latency);
78 void TRACE_surf_gtnets_communicate(void *action, int src, int dst)
80 xbt_die ("gtnets tracing is to be udpated");
83 int TRACE_surf_gtnets_get_src(void *action)
85 xbt_die ("gtnets tracing is to be udpated");
88 int TRACE_surf_gtnets_get_dst(void *action)
90 xbt_die ("gtnets tracing is to be udpated");
93 void TRACE_surf_gtnets_destroy(void *action)
95 xbt_die ("gtnets tracing is to be udpated");
98 void TRACE_surf_action(surf_action_t surf_action, const char *category)
100 if (!TRACE_is_active())
102 if (!TRACE_categorized ())
107 surf_action->category = xbt_strdup(category);
109 #endif /* HAVE_TRACING */