Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Make rngStream management functions in platform more visible
[simgrid.git] / src / include / simgrid / platf_interface.h
index a2ae6f2..3956166 100644 (file)
@@ -24,6 +24,11 @@ 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, const char*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);
@@ -33,13 +38,20 @@ 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 <config>s, if any, and before <AS> or friends such as <cluster>)
  */
 void surf_config_models_setup(void);
 
-
-
+/* RngStream management functions */
+typedef struct RngStream_InfoState *RngStream; //Not to have to include RngStream.h
+void sg_platf_rng_stream_init(unsigned long seed[6]);
+RngStream sg_platf_rng_stream_get(const char* id);
 
 #endif                          /* SG_PLATF_INTERFACE_H */