1 /* platf_private.h - Interface to the SimGrid platforms which visibility should be limited to this directory */
3 /* Copyright (c) 2004-2015. The SimGrid Team.
4 * All rights reserved. */
6 /* This program is free software; you can redistribute it and/or modify it
7 * under the terms of the license (GNU LGPL) which comes with this package. */
12 #include "simgrid/host.h"
13 #include "src/surf/xml/platf.hpp"
18 #include "src/surf/xml/simgrid_dtd.h"
20 #ifndef YY_TYPEDEF_YY_SIZE_T
21 #define YY_TYPEDEF_YY_SIZE_T
22 typedef size_t yy_size_t;
26 SURF_CLUSTER_DRAGONFLY=3,
27 SURF_CLUSTER_FAT_TREE=2,
28 SURF_CLUSTER_FLAT = 1,
29 SURF_CLUSTER_TORUS = 0
30 } e_surf_cluster_topology_t;
32 /* ***************************************** */
34 * Platform creation functions. Instead of passing 123 arguments to the creation functions
35 * (one for each possible XML attribute), we pass structures containing them all. It removes the
36 * chances of switching arguments by error, and reduce the burden when we add a new attribute:
37 * old models can just continue to ignore it without having to update their headers.
39 * It shouldn't be too costly at runtime, provided that structures living on the stack are
40 * used, instead of malloced structures.
45 std::vector<double> speed_per_pstate;
48 tmgr_trace_t speed_trace;
49 tmgr_trace_t state_trace;
51 xbt_dict_t properties;
52 } s_sg_platf_host_cbarg_t, *sg_platf_host_cbarg_t;
57 const char* link_down;
58 } s_sg_platf_host_link_cbarg_t, *sg_platf_host_link_cbarg_t;
60 class LinkCreationArgs {
64 tmgr_trace_t bandwidth_trace = nullptr;
66 tmgr_trace_t latency_trace = nullptr;
67 tmgr_trace_t state_trace = nullptr;
68 e_surf_link_sharing_policy_t policy = SURF_LINK_FATPIPE;
69 xbt_dict_t properties = nullptr;
72 typedef struct s_sg_platf_peer_cbarg *sg_platf_peer_cbarg_t;
73 typedef struct s_sg_platf_peer_cbarg {
79 tmgr_trace_t speed_trace;
80 tmgr_trace_t state_trace;
81 } s_sg_platf_peer_cbarg_t;
83 typedef struct s_sg_platf_route_cbarg *sg_platf_route_cbarg_t;
84 typedef struct s_sg_platf_route_cbarg {
90 std::vector<simgrid::surf::LinkImpl*>* link_list;
91 } s_sg_platf_route_cbarg_t;
93 typedef struct s_sg_platf_cluster_cbarg *sg_platf_cluster_cbarg_t;
94 typedef struct s_sg_platf_cluster_cbarg {
98 std::vector<int>* radicals;
99 std::vector<double> speeds;
108 e_surf_cluster_topology_t topology;
109 const char* topo_parameters;
110 xbt_dict_t properties;
111 const char* router_id;
112 e_surf_link_sharing_policy_t sharing_policy;
113 e_surf_link_sharing_policy_t bb_sharing_policy;
114 } s_sg_platf_cluster_cbarg_t;
116 typedef struct s_sg_platf_cabinet_cbarg *sg_platf_cabinet_cbarg_t;
117 typedef struct s_sg_platf_cabinet_cbarg {
121 std::vector<int>* radicals;
125 } s_sg_platf_cabinet_cbarg_t;
131 const char* content_type;
132 xbt_dict_t properties;
134 } s_sg_platf_storage_cbarg_t, *sg_platf_storage_cbarg_t;
140 const char* content_type;
141 xbt_dict_t properties;
142 xbt_dict_t model_properties;
144 } s_sg_platf_storage_type_cbarg_t, *sg_platf_storage_type_cbarg_t;
147 const char* storageId;
149 } s_sg_platf_mount_cbarg_t, *sg_platf_mount_cbarg_t;
151 typedef struct s_sg_platf_prop_cbarg *sg_platf_prop_cbarg_t;
152 typedef struct s_sg_platf_prop_cbarg {
155 } s_sg_platf_prop_cbarg_t;
157 typedef struct s_sg_platf_trace_cbarg *sg_platf_trace_cbarg_t;
158 typedef struct s_sg_platf_trace_cbarg {
163 } s_sg_platf_trace_cbarg_t;
165 typedef struct s_sg_platf_trace_connect_cbarg *sg_platf_trace_connect_cbarg_t;
166 typedef struct s_sg_platf_trace_connect_cbarg {
167 e_surf_trace_connect_kind_t kind;
170 } s_sg_platf_trace_connect_cbarg_t;
172 typedef struct s_sg_platf_process_cbarg *sg_platf_process_cbarg_t;
173 typedef struct s_sg_platf_process_cbarg {
176 xbt_dict_t properties;
178 const char *function;
181 e_surf_process_on_failure_t on_failure;
182 } s_sg_platf_process_cbarg_t;
184 typedef struct s_sg_platf_AS_cbarg *sg_platf_AS_cbarg_t;
185 typedef struct s_sg_platf_AS_cbarg {
188 } s_sg_platf_AS_cbarg_t;
190 #define SG_PLATF_AS_INITIALIZER {nullptr,0}
192 /********** Routing **********/
193 void routing_cluster_add_backbone(simgrid::surf::LinkImpl* bb);
194 /*** END of the parsing cruft ***/
196 XBT_PUBLIC(void) sg_platf_begin(); // Start a new platform
197 XBT_PUBLIC(void) sg_platf_end(); // Finish the creation of the platform
199 XBT_PUBLIC(simgrid::s4u::NetZone*) sg_platf_new_AS_begin(sg_platf_AS_cbarg_t AS); // Begin description of new AS
200 XBT_PUBLIC(void) sg_platf_new_AS_seal(); // That AS is fully described
202 XBT_PUBLIC(void) sg_platf_new_host (sg_platf_host_cbarg_t host); // Add an host to the currently described AS
203 XBT_PUBLIC(void) sg_platf_new_hostlink(sg_platf_host_link_cbarg_t h); // Add an host_link to the currently described AS
204 XBT_PUBLIC(simgrid::kernel::routing::NetPoint*)
205 sg_platf_new_router(const char* name, const char* coords); // Add a router to the currently described AS
206 XBT_PUBLIC(void) sg_platf_new_link(LinkCreationArgs* link); // Add a link to the currently described AS
207 XBT_PUBLIC(void) sg_platf_new_peer (sg_platf_peer_cbarg_t peer); // Add a peer to the currently described AS
208 XBT_PUBLIC(void) sg_platf_new_cluster(sg_platf_cluster_cbarg_t clust); // Add a cluster to the currently described AS
209 XBT_PUBLIC(void) sg_platf_new_cabinet(sg_platf_cabinet_cbarg_t cabinet); // Add a cabinet to the currently described AS
211 XBT_PUBLIC(void) sg_platf_new_route (sg_platf_route_cbarg_t route); // Add a route
212 XBT_PUBLIC(void) sg_platf_new_bypassRoute (sg_platf_route_cbarg_t bypassroute); // Add a bypassRoute
214 XBT_PUBLIC(void) sg_platf_new_trace(sg_platf_trace_cbarg_t trace);
216 XBT_PUBLIC(void) sg_platf_new_storage(sg_platf_storage_cbarg_t storage); // Add a storage to the currently described AS
217 XBT_PUBLIC(void) sg_platf_new_storage_type(sg_platf_storage_type_cbarg_t storage_type);
218 XBT_PUBLIC(void) sg_platf_new_mount(sg_platf_mount_cbarg_t mount);
220 XBT_PUBLIC(void) sg_platf_new_process(sg_platf_process_cbarg_t process);
221 XBT_PRIVATE void sg_platf_trace_connect(sg_platf_trace_connect_cbarg_t trace_connect);
223 /* Prototypes of the functions offered by flex */
224 XBT_PUBLIC(int) surf_parse_lex();
225 XBT_PUBLIC(int) surf_parse_get_lineno();
226 XBT_PUBLIC(FILE *) surf_parse_get_in();
227 XBT_PUBLIC(FILE *) surf_parse_get_out();
228 XBT_PUBLIC(int) surf_parse_get_leng();
229 XBT_PUBLIC(char *) surf_parse_get_text();
230 XBT_PUBLIC(void) surf_parse_set_lineno(int line_number);
231 XBT_PUBLIC(void) surf_parse_set_in(FILE * in_str);
232 XBT_PUBLIC(void) surf_parse_set_out(FILE * out_str);
233 XBT_PUBLIC(int) surf_parse_get_debug();
234 XBT_PUBLIC(void) surf_parse_set_debug(int bdebug);
235 XBT_PUBLIC(int) surf_parse_lex_destroy();
237 /* To include files (?) */
238 XBT_PRIVATE void surfxml_bufferstack_push(int _new);
239 XBT_PRIVATE void surfxml_bufferstack_pop(int _new);
240 XBT_PUBLIC_DATA(int) surfxml_bufferstack_size;
242 XBT_PUBLIC(void) routing_route_free(sg_platf_route_cbarg_t route);
243 /********** Instr. **********/
244 XBT_PRIVATE void sg_instr_AS_begin(sg_platf_AS_cbarg_t AS);
245 XBT_PRIVATE void sg_instr_new_router(const char* name);
246 XBT_PRIVATE void sg_instr_new_host(simgrid::s4u::Host& host);
247 XBT_PRIVATE void sg_instr_AS_end();
254 extern XBT_PRIVATE simgrid::xbt::signal<void(sg_platf_cluster_cbarg_t)> on_cluster;
259 #endif /* SG_PLATF_H */