}
-typedef struct s_smpi_factor *smpi_factor_t;
-typedef struct s_smpi_factor {
+typedef struct s_smpi_os_factor *smpi_os_factor_t;
+typedef struct s_smpi_os_factor {
long factor;
int nb_values;
double values[4];//arbitrary set to 4
-} s_smpi_factor_t;
+} s_smpi_os_factor_t;
xbt_dynar_t smpi_os_values = NULL;
xbt_dynar_t smpi_or_values = NULL;
xbt_dynar_t smpi_ois_values = NULL;
// Methods used to parse and store the values for timing injections in smpi
// These are taken from surf/network.c and generalized to have more factors
-// These methods should be merged with those in surf/network.c (moved somewhere in xbt ?)
+// FIXME: These methods should be merged with those in surf/network.c (moved somewhere in xbt ?)
static int factor_cmp(const void *pa, const void *pb)
{
- return (((s_smpi_factor_t*)pa)->factor > ((s_smpi_factor_t*)pb)->factor) ? 1 :
- (((s_smpi_factor_t*)pa)->factor < ((s_smpi_factor_t*)pb)->factor) ? -1 : 0;
+ return (((s_smpi_os_factor_t*)pa)->factor > ((s_smpi_os_factor_t*)pb)->factor) ? 1 :
+ (((s_smpi_os_factor_t*)pa)->factor < ((s_smpi_os_factor_t*)pb)->factor) ? -1 : 0;
}
{
char *value = NULL;
unsigned int iter = 0;
- s_smpi_factor_t fact;
+ s_smpi_os_factor_t fact;
fact.nb_values=0;
unsigned int i=0;
xbt_dynar_t smpi_factor, radical_elements, radical_elements2 = NULL;
- smpi_factor = xbt_dynar_new(sizeof(s_smpi_factor_t), NULL);
+ smpi_factor = xbt_dynar_new(sizeof(s_smpi_os_factor_t), NULL);
radical_elements = xbt_str_split(smpi_coef_string, ";");
xbt_dynar_foreach(radical_elements, iter, value) {
- memset(&fact, 0, sizeof(s_smpi_factor_t));
+ memset(&fact, 0, sizeof(s_smpi_os_factor_t));
radical_elements2 = xbt_str_split(value, ":");
if (xbt_dynar_length(radical_elements2) <2 || xbt_dynar_length(radical_elements2) > 5)
xbt_die("Malformed radical for smpi factor!");
}
}
- xbt_dynar_push_as(smpi_factor, s_smpi_factor_t, fact);
+ xbt_dynar_push_as(smpi_factor, s_smpi_os_factor_t, fact);
XBT_DEBUG("smpi_factor:\t%ld : %d values, first: %f", fact.factor, fact.nb_values ,fact.values[0]);
xbt_dynar_free(&radical_elements2);
}
smpi_register_static(smpi_os_values, xbt_dynar_free_voidp);
}
unsigned int iter = 0;
- s_smpi_factor_t fact;
+ s_smpi_os_factor_t fact;
double current=0.0;
// Iterate over all the sections that were specified and find the right
// value. (fact.factor represents the interval sizes; we want to find the
smpi_register_static(smpi_ois_values, xbt_dynar_free_voidp);
}
unsigned int iter = 0;
- s_smpi_factor_t fact;
+ s_smpi_os_factor_t fact;
double current=0.0;
// Iterate over all the sections that were specified and find the right
// value. (fact.factor represents the interval sizes; we want to find the
smpi_register_static(smpi_or_values, xbt_dynar_free_voidp);
}
unsigned int iter = 0;
- s_smpi_factor_t fact;
+ s_smpi_os_factor_t fact;
double current=0.0;
// Iterate over all the sections that were specified and find the right
// value. (fact.factor represents the interval sizes; we want to find the