X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/f8b73381cb02cdf39dd7829afe40df5f218a27f0..7fdb9c9ac44fba9f76a3b45d032561995bec2e0d:/src/include/simgrid/platf_interface.h diff --git a/src/include/simgrid/platf_interface.h b/src/include/simgrid/platf_interface.h index a78eb2f639..1e2ad2cb40 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); @@ -17,11 +18,40 @@ void sg_platf_exit(void); /* Managing the parsing callbacks */ -typedef void (*surf_parse_host_fct_t)(surf_parsing_host_arg_t); -void surf_parse_host_add_cb(surf_parse_host_fct_t); - -void surf_parse_host(surf_parsing_host_arg_t h); - - +typedef void (*sg_platf_host_cb_t)(sg_platf_host_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_AS_begin_cb_t)(const char*id, int routing); + +typedef void (*sg_platf_storage_cb_t)(sg_platf_storage_cbarg_t); +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); + +void sg_platf_host_add_cb(sg_platf_host_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_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_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); + +/** \brief Pick the right models for CPU, net and workstation, and call their model_init_preparse + * + * Must be called within parsing/creating the environment (after the s, if any, and before or friends such as ) + */ +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 */