static void* storage_create_resource(const char* id, const char* type,
const char* content, xbt_dict_t storage_properties)
{
- xbt_assert(!surf_storage_resource_by_name(id),
- "Storage '%s' declared several times in the platform file",
- id);
- XBT_DEBUG("Storage_create_resource '%s' at level SURF_STORAGE_LEVEL",id);
- surf_storage_t storage = NULL;
- storage = (surf_storage_t) surf_resource_new(sizeof(s_surf_storage_t),
- surf_storage_model, id, storage_properties);
- storage->type = type;
- storage->content = content;
- xbt_lib_set(storage_lib, id, SURF_STORAGE_LEVEL, storage);
-
- return storage;
+ return NULL;
}
static void storage_finalize(void)
static void parse_storage_init(sg_platf_storage_cbarg_t storage)
{
- XBT_INFO("parse_storage_init");
+ XBT_DEBUG("parse_storage_init");
}
static void parse_mstorage_init(sg_platf_mstorage_cbarg_t mstorage)
{
- XBT_INFO("parse_mstorage_init");
+ XBT_DEBUG("parse_mstorage_init");
}
static void parse_storage_type_init(sg_platf_storage_type_cbarg_t storagetype_)
{
- XBT_INFO("parse_storage_type_init");
+ XBT_DEBUG("parse_storage_type_init");
}
static void parse_mount_init(sg_platf_mount_cbarg_t mount)
{
- XBT_INFO("parse_mount_init");
+ XBT_DEBUG("parse_mount_init");
}
static void storage_define_callbacks()
{
sg_platf_storage_add_cb(parse_storage_init);
- sg_platf_mstorage_add_cb(parse_mstorage_init);
sg_platf_storage_type_add_cb(parse_storage_type_init);
+ sg_platf_mstorage_add_cb(parse_mstorage_init);
sg_platf_mount_add_cb(parse_mount_init);
}
XBT_DEBUG("ADD ROUTING LEVEL");
ROUTING_HOST_LEVEL = xbt_lib_add_level(host_lib,xbt_free);
ROUTING_ASR_LEVEL = xbt_lib_add_level(as_router_lib,xbt_free);
- // FOR NOW UNUSED
-// ROUTING_STORAGE_LEVEL = xbt_lib_add_level(storage_lib,NULL);
+ ROUTING_STORAGE_LEVEL = xbt_lib_add_level(storage_lib,xbt_free);
+ ROUTING_STORAGE_TYPE_LEVEL = xbt_lib_add_level(storage_lib,routing_storage_type_free);
+ ROUTING_STORAGE_HOST_LEVEL = xbt_lib_add_level(storage_lib,routing_storage_host_free);
XBT_DEBUG("ADD SURF LEVELS");
SURF_CPU_LEVEL = xbt_lib_add_level(host_lib,surf_resource_free);
SURF_WKS_LEVEL = xbt_lib_add_level(host_lib,surf_resource_free);
SURF_LINK_LEVEL = xbt_lib_add_level(link_lib,surf_resource_free);
- SURF_STORAGE_LEVEL = xbt_lib_add_level(storage_lib,surf_resource_free);
/* Connect our log channels: that must be done manually under windows */
XBT_LOG_CONNECT(surf_cpu, surf);
static xbt_dict_t random_value = NULL;
xbt_lib_t storage_lib;
-int ROUTING_STORAGE_LEVEL; //Routing level
-int SURF_STORAGE_LEVEL; //Surf level
+int ROUTING_STORAGE_LEVEL; //Routing for storagelevel
+int ROUTING_STORAGE_TYPE_LEVEL; //Routing for storage_type level
+int ROUTING_STORAGE_HOST_LEVEL;
/* Global vars */
routing_global_t global_routing = NULL;
/* global parse functions */
xbt_dynar_t parsed_link_list = NULL; /* temporary store of current list link of a route */
+xbt_dynar_t mount_list = NULL; /* temporary store of current mount storage */
static const char *src = NULL; /* temporary store the source name of a route */
static const char *dst = NULL; /* temporary store the destination name of a route */
static char *gw_src = NULL; /* temporary store the gateway source name of a route */
info->rc_component = current_routing;
info->rc_type = SURF_NETWORK_ELEMENT_HOST;
xbt_lib_set(host_lib, host->id, ROUTING_HOST_LEVEL, (void *) info);
+
+ if(mount_list){
+ xbt_lib_set(storage_lib, host->id, ROUTING_STORAGE_HOST_LEVEL, (void *) mount_list);
+ mount_list = NULL;
+ }
+
if (host->coord && strcmp(host->coord, "")) {
unsigned int cursor;
char*str;
static void routing_parse_storage(sg_platf_storage_cbarg_t storage)
{
+ xbt_assert(!xbt_lib_get_or_null(storage_lib, storage->id,ROUTING_STORAGE_LEVEL),
+ "Reading a storage, processing unit \"%s\" already exists", storage->id);
+
+ // Verification of an existing type_id
+ void* storage_type = xbt_lib_get_or_null(storage_lib, storage->type_id,ROUTING_STORAGE_TYPE_LEVEL);
+ xbt_assert(storage_type,"Reading a storage, type id \"%s\" does not exists", storage->type_id);
+
XBT_INFO("ROUTING Create a storage name '%s' with type_id '%s'",storage->id,storage->type_id);
-}
-static void routing_parse_mstorage(sg_platf_mstorage_cbarg_t mstorage)
-{
- XBT_INFO("ROUTING Mount a storage name '%s' with type_id '%s'",mstorage->name, mstorage->type_id);
+
+ xbt_lib_set(storage_lib,storage->id,ROUTING_STORAGE_LEVEL,(void *) xbt_strdup(storage->type_id));
}
static void routing_parse_storage_type(sg_platf_storage_type_cbarg_t storage_type)
{
+ xbt_assert(!xbt_lib_get_or_null(storage_lib, storage_type->id,ROUTING_STORAGE_TYPE_LEVEL),
+ "Reading a storage type, processing unit \"%s\" already exists", storage_type->id);
+
XBT_INFO("ROUTING Create a storage type_id '%s' with model '%s'",storage_type->id,storage_type->model);
+ storage_type_t stype = xbt_new0(s_storage_type_t, 1);
+ stype->model = xbt_strdup(storage_type->model);
+ stype->properties = storage_type->properties;
+ stype->content = xbt_strdup(storage_type->content);
+ stype->type_id = xbt_strdup(storage_type->id);
+
+ xbt_lib_set(storage_lib,storage_type->id,ROUTING_STORAGE_TYPE_LEVEL,(void *) stype);
+}
+static void routing_parse_mstorage(sg_platf_mstorage_cbarg_t mstorage)
+{
+ mount_t mnt = xbt_new0(s_mount_t, 1);
+ mnt->type_id = xbt_strdup(mstorage->type_id);
+ mnt->name = xbt_strdup(mstorage->name);
+
+ if(!mount_list){
+ XBT_INFO("Creata a Mount list for %s",A_surfxml_host_id);
+ mount_list = xbt_dynar_new(sizeof(char *), NULL);
+ }
+ xbt_dynar_push(mount_list,(void *) mnt);
+ free(mnt->type_id);
+ free(mnt->name);
+ xbt_free(mnt);
+ XBT_INFO("ROUTING Mount a storage name '%s' with type_id '%s'",mstorage->name, mstorage->type_id);
}
static void routing_parse_mount(sg_platf_mount_cbarg_t mount)
{
- XBT_INFO("ROUTING Mount '%s' on '%s'",mount->id, mount->name);
+
+ // Verification of an existing storage
+ void* storage = xbt_lib_get_or_null(storage_lib, mount->id,ROUTING_STORAGE_LEVEL);
+ xbt_assert(storage,"Disk id \"%s\" does not exists", mount->id);
+
+ XBT_DEBUG("ROUTING Mount '%s' on '%s'",mount->id, mount->name);
+ sg_platf_mstorage_cbarg_t mstorage = xbt_new0(s_sg_platf_mstorage_cbarg_t, 1);
+ mstorage->name = xbt_strdup(mount->name);
+ mstorage->type_id = xbt_strdup((const char*)storage);
+
+ routing_parse_mstorage(mstorage);
+ free(mstorage->name);
+ free(mstorage->type_id);
+ xbt_free(mstorage);
}
static void routing_parse_cluster(sg_platf_cluster_cbarg_t cluster)