Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Taking latencies into account (but not for the bandwidth limitation yet).
[simgrid.git] / src / surf / network_private.h
index 0f58113..203c3cd 100644 (file)
@@ -8,16 +8,38 @@
 
 #include "surf_private.h"
 
-typedef struct surf_action_network {
-  s_surf_action_t generic_action;
-  lmm_variable_t variable;
-} s_surf_action_network_t, *surf_action_network_t;
+typedef enum {
+  SURF_NETWORK_LINK_ON = 1,            /* Ready        */
+  SURF_NETWORK_LINK_OFF = 0            /* Running      */
+} e_surf_network_link_state_t;
 
-typedef struct network {
+typedef struct network_link {
   surf_resource_t resource;   /* Any such object, added in a trace
                                 should start by this field!!! */
+                              /* Using this object with the public part of
+                                resource does not make sense */
   const char *name;
-} s_network_t, *network_t;
+  xbt_maxmin_float_t bw_current;
+  tmgr_trace_event_t bw_event;
+  xbt_maxmin_float_t lat_current;
+  tmgr_trace_event_t lat_event;
+  e_surf_network_link_state_t state_current;
+  tmgr_trace_event_t state_event;
+  lmm_constraint_t constraint;
+} s_network_link_t, *network_link_t;
+
 
+typedef struct network_card {
+  const char *name;
+  int id;
+} s_network_card_t, *network_card_t;
+
+typedef struct surf_action_network {
+  s_surf_action_t generic_action;
+  xbt_heap_float_t latency;
+  lmm_variable_t variable;
+  network_card_t src;
+  network_card_t dst;
+} s_surf_action_network_t, *surf_action_network_t;
 
 #endif                         /* _SURF_NETWORK_PRIVATE_H */