X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/f440037b8c394baf8a480ba497a22e5768b7e818..afd3a47e007a0f91d206cc2e47b69b4b86970fc2:/src/surf/surf_routing.cpp diff --git a/src/surf/surf_routing.cpp b/src/surf/surf_routing.cpp index 777f4d75db..1bf0d25ee7 100644 --- a/src/surf/surf_routing.cpp +++ b/src/surf/surf_routing.cpp @@ -1,110 +1,7 @@ -/* Copyright (c) 2009-2011, 2013-2016. The SimGrid Team. - * All rights reserved. */ +/* Copyright (c) 2009-2016. 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 +#include "xbt/dict.h" -#include - -#include - -#include "src/surf/surf_routing.hpp" - -#include "simgrid/sg_config.h" -#include "src/surf/storage_interface.hpp" - -#include "src/kernel/routing/AsImpl.hpp" -#include "src/surf/network_interface.hpp" - -XBT_LOG_NEW_DEFAULT_SUBCATEGORY(surf_route, surf, "Routing part of surf"); - -namespace simgrid { -namespace kernel { -namespace routing { - - /* Callbacks */ - simgrid::xbt::signal netcardCreatedCallbacks; - simgrid::xbt::signal asCreatedCallbacks; - -}}} // namespace simgrid::kernel::routing - -/** - * @ingroup SURF_build_api - * @brief A library containing all known hosts - */ - -int MSG_FILE_LEVEL = -1; //Msg file level - -int SIMIX_STORAGE_LEVEL = -1; //Simix storage level -int MSG_STORAGE_LEVEL = -1; //Msg storage level - -xbt_lib_t as_router_lib; -int ROUTING_ASR_LEVEL = -1; //Routing level -int COORD_ASR_LEVEL = -1; //Coordinates level -int NS3_ASR_LEVEL = -1; //host node for ns3 -int ROUTING_PROP_ASR_LEVEL = -1; //Where the properties are stored - -/** @brief Retrieve a netcard from its name - * - * Netcards are the thing that connect host or routers to the network - */ -simgrid::kernel::routing::NetCard *sg_netcard_by_name_or_null(const char *name) -{ - sg_host_t h = sg_host_by_name(name); - simgrid::kernel::routing::NetCard *netcard = h==nullptr ? nullptr: h->pimpl_netcard; - if (!netcard) - netcard = (simgrid::kernel::routing::NetCard*) xbt_lib_get_or_null(as_router_lib, name, ROUTING_ASR_LEVEL); - return netcard; -} - -/* Global vars */ -simgrid::kernel::routing::RoutingPlatf* routing_platf = new simgrid::kernel::routing::RoutingPlatf(); - -void sg_platf_new_trace(sg_platf_trace_cbarg_t trace) -{ - tmgr_trace_t tmgr_trace; - if (trace->file && strcmp(trace->file, "") != 0) { - tmgr_trace = tmgr_trace_new_from_file(trace->file); - } else { - xbt_assert(strcmp(trace->pc_data, ""), - "Trace '%s' must have either a content, or point to a file on disk.",trace->id); - tmgr_trace = tmgr_trace_new_from_string(trace->id, trace->pc_data, trace->periodicity); - } - xbt_dict_set(traces_set_list, trace->id, (void *) tmgr_trace, nullptr); -} - -/* ************************************************************************** */ -/* ************************* GENERIC PARSE FUNCTIONS ************************ */ - -static void check_disk_attachment() -{ - xbt_lib_cursor_t cursor; - char *key; - void **data; - xbt_lib_foreach(storage_lib, cursor, key, data) { - if (xbt_lib_get_level(xbt_lib_get_elm_or_null(storage_lib, key), SURF_STORAGE_LEVEL) != nullptr) { - simgrid::surf::Storage* storage = - static_cast(xbt_lib_get_or_null(storage_lib, key, SURF_STORAGE_LEVEL)); - simgrid::kernel::routing::NetCard* host_elm = sg_netcard_by_name_or_null(storage->attach_); - if (!host_elm) - surf_parse_error("Unable to attach storage %s: host %s doesn't exist.", storage->getName(), storage->attach_); - } - } -} - -void routing_register_callbacks() -{ - simgrid::surf::on_postparse.connect(check_disk_attachment); - - instr_routing_define_callbacks(); -} - -/** \brief Frees all memory allocated by the routing module */ -void routing_exit() { - delete routing_platf; -} - -simgrid::kernel::routing::RoutingPlatf::RoutingPlatf() = default; -simgrid::kernel::routing::RoutingPlatf::~RoutingPlatf() = default;