-/* $Id$ */
-
-/* msg_config.c - support for MSG user configuration */
-
-/* Copyright (c) 2005 Martin Quinson. */
-/* All rights reserved. */
+/* Copyright (c) 2005, 2006, 2007, 2009, 2010. The SimGrid Team.
+ * All rights reserved. */
/* This program is free software; you can redistribute it and/or modify it
* under the terms of the license (GNU LGPL) which comes with this package. */
-#include "private.h"
+#include "msg_private.h"
#include "xbt/sysdep.h"
#include "xbt/log.h"
-
-int _msg_init_status = 0; /* 0: beginning of time;
- 1: pre-inited (cfg_set created);
- 2: inited (running) */
-xbt_cfg_t _msg_cfg_set = NULL;
-
-/* callback of the surf_workstation_model variable */
-static void _msg_cfg_cb__surf_workstation_model(const char *name, int pos) {
- char *val;
-
- xbt_assert0(_msg_init_status<2, "Cannot change the model after the initialization");
-
- val = xbt_cfg_get_string (_msg_cfg_set, name);
-
-#ifdef USE_GTNETS
- xbt_assert1(!strcmp(val, "CLM03") ||
- !strcmp(val, "KCCFLN05") ||
- !strcmp(val, "GTNETS"),
- "Unknown workstation model: %s (either 'CLM03', 'KCCFLN05', or 'GTNETS'",val);
-#else
- xbt_assert1(!strcmp(val, "CLM03") ||
- !strcmp(val, "KCCFLN05"),
- "Unknown workstation model: %s (either 'CLM03' or 'KCCFLN05'",val);
-#endif
-
-}
-
-/* create the config set and register what should be */
-void msg_config_init(void) {
-
- if (_msg_init_status)
- return; /* Already inited, nothing to do */
-
- _msg_init_status = 1;
- _msg_cfg_set = xbt_cfg_new();
-
- xbt_cfg_register (_msg_cfg_set,
- "surf_workstation_model", xbt_cfgelm_string, 1,1,
- &_msg_cfg_cb__surf_workstation_model,NULL);
-
- xbt_cfg_set_string(_msg_cfg_set,"surf_workstation_model", "KCCFLN05");
-}
-
-void msg_config_finalize(void) {
-
- if (!_msg_init_status)
- return; /* Not initialized yet. Nothing to do */
-
- xbt_cfg_free(&_msg_cfg_set);
- _msg_init_status = 0;
-}
+#include "simix/simix.h"
/** \brief set a configuration variable
- *
+ *
* Currently existing configuation variable:
- * - surf_workstation_model (string): Model of workstation to use.
+ * - workstation/model (string): Model of workstation to use.
* Possible values (defaults to "KCCFLN05"):
* - "CLM03": realistic TCP behavior + basic CPU model (see [CML03 at CCGrid03]) + support for parallel tasks
* - "KCCFLN05": realistic TCP behavior + basic CPU model (see [CML03 at CCGrid03]) + failure handling + interference between communications and computations if precised in the platform file.
- *
+ * - "KCCFLN05": realistic TCP behavior + basic CPU model (see [CML03 at CCGrid03]) + failure handling + interference between communications and computations if precised in the platform file. Use maxmin for the network.
+ * - "KCCFLN05_proportional": realistic TCP behavior + basic CPU model (see [CML03 at CCGrid03]) + failure handling + interference between communications and computations if precised in the platform file. Uses the proportional approahc as described in the Corine Touati's PhD Thesis.
+ * - "KCCFLN05_Vegas": realistic TCP behavior + basic CPU model (see [CML03 at CCGrid03]) + failure handling + interference between communications and computations if precised in the platform file. Uses the fairness adapted to the TCP Vegas flow control.
+ * - "KCCFLN05_Reno": realistic TCP behavior + basic CPU model (see [CML03 at CCGrid03]) + failure handling + interference between communications and computations if precised in the platform file. Uses the fairness adapted to the TCP Reno flow control.
+ *
* Example:
- * MSG_config("surf_workstation_model","KCCFLN05");
+ * MSG_config("workstation/model","KCCFLN05");
*/
-void
-MSG_config(const char *name, ...) {
+void MSG_config(const char *name, ...)
+{
va_list pa;
-
- if (!_msg_init_status) {
- msg_config_init();
+
+ if (!msg_global) {
+ fprintf(stderr,
+ "ERROR: Please call MSG_init() before using MSG_config()\n");
+ abort();
}
- /* xbt_cfg_dump("msg_cfg_set","",_msg_cfg_set);*/
- va_start(pa,name);
- xbt_cfg_set_vargs(_msg_cfg_set,name,pa);
+ va_start(pa, name);
+ xbt_cfg_set_vargs(_surf_cfg_set, name, pa);
va_end(pa);
-
+ return;
}