Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Add two new tag for routing cluster (only):
[simgrid.git] / src / surf / sg_platf.c
index 65cc84c..df9423d 100644 (file)
@@ -13,6 +13,7 @@
 
 XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(surf_parse);
 xbt_dynar_t sg_platf_host_cb_list = NULL;   // of sg_platf_host_cb_t
+xbt_dynar_t sg_platf_host_link_cb_list = NULL;   // of sg_platf_host_link_cb_t
 xbt_dynar_t sg_platf_link_cb_list = NULL;   // of sg_platf_link_cb_t
 xbt_dynar_t sg_platf_router_cb_list = NULL; // of sg_platf_router_cb_t
 xbt_dynar_t sg_platf_peer_cb_list = NULL; // of sg_platf_peer_cb_t
@@ -34,6 +35,7 @@ static RngStream sg_platf_rng_stream = NULL;
 /** Module management function: creates all internal data structures */
 void sg_platf_init(void) {
   sg_platf_host_cb_list = xbt_dynar_new(sizeof(sg_platf_host_cb_t), NULL);
+  sg_platf_host_link_cb_list = xbt_dynar_new(sizeof(sg_platf_host_link_cb_t), NULL);
   sg_platf_router_cb_list = xbt_dynar_new(sizeof(sg_platf_host_cb_t), NULL);
   sg_platf_link_cb_list = xbt_dynar_new(sizeof(sg_platf_host_cb_t), NULL);
   sg_platf_peer_cb_list = xbt_dynar_new(sizeof(sg_platf_peer_cb_t), NULL);
@@ -50,6 +52,7 @@ void sg_platf_init(void) {
 /** Module management function: frees all internal data structures */
 void sg_platf_exit(void) {
   xbt_dynar_free(&sg_platf_host_cb_list);
+  xbt_dynar_free(&sg_platf_host_link_cb_list);
   xbt_dynar_free(&sg_platf_router_cb_list);
   xbt_dynar_free(&sg_platf_link_cb_list);
   xbt_dynar_free(&sg_platf_postparse_cb_list);
@@ -74,6 +77,13 @@ void sg_platf_new_host(sg_platf_host_cbarg_t h){
     fun(h);
   }
 }
+void sg_platf_new_host_link(sg_platf_host_link_cbarg_t h){
+  unsigned int iterator;
+  sg_platf_host_link_cb_t fun;
+  xbt_dynar_foreach(sg_platf_host_link_cb_list, iterator, fun) {
+    fun(h);
+  }
+}
 void sg_platf_new_router(sg_platf_router_cbarg_t router) {
   unsigned int iterator;
   sg_platf_router_cb_t fun;
@@ -143,7 +153,7 @@ void sg_platf_end() {
 
 static int surf_parse_models_setup_already_called = 0;
 
-void sg_platf_new_AS_begin(const char *id, const char *routing) {
+void sg_platf_new_AS_begin(const char *id, int routing) {
   unsigned int iterator;
   sg_platf_AS_begin_cb_t fun;
 
@@ -181,6 +191,9 @@ void sg_platf_new_AS_end() {
 void sg_platf_host_add_cb(sg_platf_host_cb_t fct) {
   xbt_dynar_push(sg_platf_host_cb_list, &fct);
 }
+void sg_platf_host_link_add_cb(sg_platf_host_link_cb_t fct) {
+  xbt_dynar_push(sg_platf_host_link_cb_list, &fct);
+}
 void sg_platf_link_add_cb(sg_platf_link_cb_t fct) {
   xbt_dynar_push(sg_platf_link_cb_list, &fct);
 }
@@ -224,10 +237,10 @@ void sg_platf_rng_stream_init(unsigned long seed[6]) {
 RngStream sg_platf_rng_stream_get(const char* id) {
   RngStream stream = NULL;
   unsigned int id_hash;
-  
+
   stream = RngStream_CopyStream(sg_platf_rng_stream);
   id_hash = xbt_str_hash(id);
   RngStream_AdvanceState(stream, 0, (long)id_hash);
-  
+
   return stream;
 }