1 /* Copyright (c) 2013-2016. The SimGrid Team. All rights reserved. */
3 /* This program is free software; you can redistribute it and/or modify it
4 * under the terms of the license (GNU LGPL) which comes with this package. */
6 #ifndef SURF_ROUTING_CLUSTER_HPP_
7 #define SURF_ROUTING_CLUSTER_HPP_
9 #include "src/surf/AsImpl.hpp"
14 class XBT_PRIVATE AsCluster: public AsImpl {
16 AsCluster(const char*name);
19 virtual void getRouteAndLatency(NetCard *src, NetCard *dst, sg_platf_route_cbarg_t into, double *latency) override;
20 void getGraph(xbt_graph_t graph, xbt_dict_t nodes, xbt_dict_t edges) override;
22 virtual void create_links_for_node(sg_platf_cluster_cbarg_t cluster, int id, int rank, int position);
23 virtual void parse_specific_arguments(sg_platf_cluster_cbarg_t cluster) {}
25 xbt_dynar_t privateLinks_ = xbt_dynar_new(sizeof(s_surf_parsing_link_up_down_t),NULL);
27 Link* backbone_ = nullptr;
28 void *loopback_ = nullptr;
29 NetCard *router_ = nullptr;
30 int has_limiter_ = 0; /* O or 1. must be an int since it's used to shift the considered index */
31 int has_loopback_ = 0; /* O or 1. must be an int since it's used to shift the considered index */
32 int nb_links_per_node_ = 1; /* may be 1 (if only a private link), 2 or 3 (if limiter and loopback) */
39 #endif /* SURF_ROUTING_CLUSTER_HPP_ */