X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/939f45165f7ccadb14508dbc6a234a60464b5f57..8fb370cb7b0fe8f6edcec683a27ffe6e58cb3056:/src/include/simgrid/platf_interface.h diff --git a/src/include/simgrid/platf_interface.h b/src/include/simgrid/platf_interface.h index 5df384addf..cd158ea9b6 100644 --- a/src/include/simgrid/platf_interface.h +++ b/src/include/simgrid/platf_interface.h @@ -10,6 +10,7 @@ #define SG_PLATF_INTERFACE_H #include "simgrid/platf.h" /* public interface */ +#include "xbt/RngStream.h" /* Module management functions */ void sg_platf_init(void); @@ -18,22 +19,56 @@ void sg_platf_exit(void); /* Managing the parsing callbacks */ typedef void (*sg_platf_host_cb_t)(sg_platf_host_cbarg_t); +typedef void (*sg_platf_host_link_cb_t)(sg_platf_host_link_cbarg_t); typedef void (*sg_platf_router_cb_t)(sg_platf_router_cbarg_t); typedef void (*sg_platf_link_cb_t)(sg_platf_link_cbarg_t); typedef void (*sg_platf_peer_cb_t)(sg_platf_peer_cbarg_t); typedef void (*sg_platf_cluster_cb_t)(sg_platf_cluster_cbarg_t); +typedef void (*sg_platf_cabinet_cb_t)(sg_platf_cabinet_cbarg_t); +typedef void (*sg_platf_AS_begin_cb_t)(const char*id, int routing); +typedef void (*sg_platf_prop_cb_t)(sg_platf_prop_cbarg_t); + +typedef void (*sg_platf_route_cb_t)(sg_platf_route_cbarg_t); +typedef void (*sg_platf_ASroute_cb_t)(sg_platf_ASroute_cbarg_t); +typedef void (*sg_platf_bypassRoute_cb_t)(sg_platf_bypassRoute_cbarg_t); +typedef void (*sg_platf_bypassASroute_cb_t)(sg_platf_bypassASroute_cbarg_t); + +typedef void (*sg_platf_trace_cb_t)(sg_platf_trace_cbarg_t); +typedef void (*sg_platf_trace_connect_cb_t)(sg_platf_trace_connect_cbarg_t); + typedef void (*sg_platf_storage_cb_t)(sg_platf_storage_cbarg_t); -typedef void (*sg_platf_AS_begin_cb_t)(const char*id, const char*routing); +typedef void (*sg_platf_storage_type_cb_t)(sg_platf_storage_type_cbarg_t); +typedef void (*sg_platf_mount_cb_t)(sg_platf_mount_cbarg_t); +typedef void (*sg_platf_mstorage_cb_t)(sg_platf_mstorage_cbarg_t); + +typedef void (*sg_platf_process_cb_t)(sg_platf_process_cbarg_t); void sg_platf_host_add_cb(sg_platf_host_cb_t); +void sg_platf_host_link_add_cb(sg_platf_host_link_cb_t); void sg_platf_router_add_cb(sg_platf_router_cb_t); void sg_platf_link_add_cb(sg_platf_link_cb_t); void sg_platf_peer_add_cb(sg_platf_peer_cb_t fct); void sg_platf_cluster_add_cb(sg_platf_cluster_cb_t fct); +void sg_platf_cabinet_add_cb(sg_platf_cabinet_cb_t fct); void sg_platf_postparse_add_cb(void_f_void_t fct); void sg_platf_AS_begin_add_cb(sg_platf_AS_begin_cb_t fct); void sg_platf_AS_end_add_cb(void_f_void_t fct); +void sg_platf_prop_add_cb(sg_platf_prop_cb_t fct); + +void sg_platf_route_add_cb(sg_platf_route_cb_t); +void sg_platf_ASroute_add_cb(sg_platf_ASroute_cb_t); +void sg_platf_bypassRoute_add_cb(sg_platf_bypassRoute_cb_t); +void sg_platf_bypassASroute_add_cb(sg_platf_bypassASroute_cb_t); + +void sg_platf_trace_add_cb(sg_platf_trace_cb_t); +void sg_platf_trace_connect_add_cb(sg_platf_trace_connect_cb_t); + void sg_platf_storage_add_cb(sg_platf_storage_cb_t fct); +void sg_platf_mstorage_add_cb(sg_platf_mstorage_cb_t fct); +void sg_platf_storage_type_add_cb(sg_platf_storage_type_cb_t fct); +void sg_platf_mount_add_cb(sg_platf_mount_cb_t fct); + +void sg_platf_process_add_cb(sg_platf_process_cb_t fct); /** \brief Pick the right models for CPU, net and workstation, and call their model_init_preparse * @@ -41,7 +76,8 @@ void sg_platf_storage_add_cb(sg_platf_storage_cb_t fct); */ void surf_config_models_setup(void); - - +/* RngStream management functions */ +void sg_platf_rng_stream_init(unsigned long seed[6]); +RngStream sg_platf_rng_stream_get(const char* id); #endif /* SG_PLATF_INTERFACE_H */