X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/6e7f2fe14eee0c4db1b815d0130dd8888886222c..2c5c14ffd2b2af540f201434bd4d32f9c197507f:/src/include/simgrid/platf_interface.h diff --git a/src/include/simgrid/platf_interface.h b/src/include/simgrid/platf_interface.h index bc84e74d96..683ca3ee2c 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,12 +18,44 @@ void sg_platf_exit(void); /* Managing the parsing callbacks */ -typedef void (*surf_parse_host_fct_t)(surf_parsing_host_arg_t); -typedef void (*surf_parse_router_fct_t)(surf_parsing_router_arg_t); -void surf_parse_host_add_cb(surf_parse_host_fct_t); -void surf_parse_router_add_cb(surf_parse_router_fct_t); - - - +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_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_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_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 */