-struct s_routing_component {
- model_type_t routing;
- e_surf_routing_hierarchy_t hierarchy;
- char *name;
- struct s_routing_component* routing_father;
- xbt_dict_t routing_sons;
- route_extended_t (*get_route)(routing_component_t rc, const char* src, const char* dst);
- route_extended_t (*get_bypass_route)(routing_component_t rc, const char* src, const char* dst);
- void (*finalize)(routing_component_t rc);
- void (*set_processing_unit)(routing_component_t rc, const char* name);
- void (*set_autonomous_system)(routing_component_t rc, const char* name);
- void (*set_route)(routing_component_t rc, const char* src, const char* dst, route_t route);
- void (*set_ASroute)(routing_component_t rc, const char* src, const char* dst, route_extended_t route);
- void (*set_bypassroute)(routing_component_t rc, const char* src, const char* dst, route_extended_t e_route);
-};
-
-struct s_routing_global {
- routing_component_t root;
- xbt_dict_t where_network_elements; /* char* -> s_routing_component* */
- void *loopback;
- size_t size_of_link;
- xbt_dynar_t (*get_route)(const char* src, const char* dst);
- xbt_dict_t (*get_onelink_routes)(void);
- int (*is_router)(const char *name);
- void (*finalize)(void);
- xbt_dynar_t last_route;
-};
-
-XBT_PUBLIC(void) routing_model_create(size_t size_of_link,void *loopback);
+XBT_PUBLIC(void) routing_model_create(void *loopback);
+XBT_PUBLIC(void) routing_exit(void);
+XBT_PUBLIC(void) storage_register_callbacks(void);
+
+XBT_PRIVATE void routing_new_cluster(sg_platf_cluster_cbarg_t cluster);
+
+XBT_PUBLIC(void) routing_register_callbacks(void);
+XBT_PUBLIC(void) generic_free_route(sg_platf_route_cbarg_t route); // FIXME rename to routing_route_free
+ // FIXME: make previous function private to routing again?
+
+
+XBT_PUBLIC(void) routing_get_route_and_latency(sg_netcard_t src, sg_netcard_t dst,
+ xbt_dynar_t * route, double *latency);