Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
I'm so lazy...
[simgrid.git] / src / surf / surf_private.h
index 6452c47..270b889 100644 (file)
 #include "surf/maxmin.h"
 #include "surf/trace_mgr.h"
 #include "xbt/log.h"
-#include "surf/surf_parse.h"
+#include "surf/surfxml_parse_private.h"
 
 #define NO_MAX_DURATION -1.0
+#define SG_TCP_CTE_GAMMA 20000.0
+
+extern const char *surf_action_state_names[6];
+
+typedef enum {
+  SURF_NETWORK_LINK_ON = 1,    /* Ready        */
+  SURF_NETWORK_LINK_OFF = 0    /* Running      */
+} e_surf_network_link_state_t;
+
+typedef enum {
+  SURF_NETWORK_LINK_SHARED = 1,
+  SURF_NETWORK_LINK_FATPIPE = 0
+} e_surf_network_link_sharing_policy_t;
 
 typedef struct surf_resource_private {
   int (*resource_used) (void *resource_id);
@@ -33,6 +46,10 @@ typedef struct surf_resource_private {
 
 double generic_maxmin_share_resources(xbt_swag_t running_actions,
                                      size_t offset);
+double generic_maxmin_share_resources2(xbt_swag_t running_actions,
+                                      size_t offset,
+                                      lmm_system_t sys);
+
 /* Generic functions common to all ressources */
 e_surf_action_state_t surf_action_get_state(surf_action_t action);
 void surf_action_free(surf_action_t * action);
@@ -40,8 +57,15 @@ void surf_action_change_state(surf_action_t action,
                              e_surf_action_state_t state);
 void surf_action_set_data(surf_action_t action,
                          void *data);
+FILE *surf_fopen(const char *name, const char *mode);
 
+static _XBT_INLINE void surf_double_update(double *variable, double value) 
+{
+  *variable -= value;
+  if(*variable< 0.00001) *variable = 0.0;
+}
 extern lmm_system_t maxmin_system;
 extern tmgr_history_t history;
+extern xbt_dynar_t surf_path;
 
 #endif                         /* _SURF_SURF_PRIVATE_H */