Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
[trace] tracing no longer needs src and dst for every network surf action
[simgrid.git] / src / surf / network_private.h
index cba58fb..000acc7 100644 (file)
@@ -1,6 +1,4 @@
-/*     $Id$     */
-
-/* Copyright (c) 2004 Arnaud Legrand. All rights reserved.                  */
+/* Copyright (c) 2004-2012. The SimGrid Team. All rights reserved.          */
 
 /* This program is free software; you can redistribute it and/or modify it
  * under the terms of the license (GNU LGPL) which comes with this package. */
 
 #include "surf_private.h"
 #include "xbt/dict.h"
+#include "xbt/fifo.h"
 
 typedef struct network_link_CM02 {
-  surf_model_t model;  /* Any such object, added in a trace
-                                  should start by this field!!! */
-  xbt_dict_t properties;
+  s_surf_resource_lmm_t lmm_resource;   /* must remain first to be added to a trace */
+
   /* Using this object with the public part of
      model does not make sense */
-  char *name;
-  double bw_current;
-  tmgr_trace_event_t bw_event;
   double lat_current;
   tmgr_trace_event_t lat_event;
-  e_surf_link_state_t state_current;
-  tmgr_trace_event_t state_event;
-  lmm_constraint_t constraint;
 } s_link_CM02_t, *link_CM02_t;
 
-
-typedef struct network_card_CM02 {
-  char *name;
-  int id;
-} s_network_card_CM02_t, *network_card_CM02_t;
-
 typedef struct surf_action_network_CM02 {
-  s_surf_action_t generic_action;
+  s_surf_action_lmm_t generic_lmm_action;
   double latency;
   double lat_current;
-  lmm_variable_t variable;
+  double weight;
   double rate;
-  int suspended;
-  network_card_CM02_t src;
-  network_card_CM02_t dst;
+  struct {
+     const char* link_name;
+     double gap;
+     double size;
+     xbt_fifo_item_t fifo_item;
+  } sender;
+#ifdef HAVE_LATENCY_BOUND_TRACKING
+  int latency_limited;
+#endif
 } s_surf_action_network_CM02_t, *surf_action_network_CM02_t;
 
-extern xbt_dict_t network_card_set;
-
-
-extern int card_number;
-extern link_CM02_t **routing_table;
-extern int *routing_table_size;
-
-#define ROUTE(i,j) routing_table[(i)+(j)*card_number]
-#define ROUTE_SIZE(i,j) routing_table_size[(i)+(j)*card_number]
-
-#endif                         /* _SURF_NETWORK_PRIVATE_H */
+#endif                          /* _SURF_NETWORK_PRIVATE_H */