Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Yet another missing 'extern' making the mac linker crazy
[simgrid.git] / src / surf / surf_private.h
index ff76645..2c53b22 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"
+#include "surf/random_mgr.h"
 
 #define NO_MAX_DURATION -1.0
+extern double sg_tcp_gamma;
 
-typedef struct surf_resource_private {
+extern const char *surf_action_state_names[6];
+
+typedef enum {
+  SURF_LINK_ON = 1,             /* Ready        */
+  SURF_LINK_OFF = 0             /* Running      */
+} e_surf_link_state_t;
+
+typedef enum {
+  SURF_LINK_SHARED = 1,
+  SURF_LINK_FATPIPE = 0
+} e_surf_link_sharing_policy_t;
+
+typedef struct surf_model_private {
   int (*resource_used) (void *resource_id);
   /* Share the resources to the actions and return in hom much time
      the next action may terminate */
@@ -24,22 +38,51 @@ typedef struct surf_resource_private {
   /* Update the actions' state */
   void (*update_actions_state) (double now, double delta);
   void (*update_resource_state) (void *id, tmgr_trace_event_t event_type,
-                                double value);
+                                 double value, double time);
   void (*finalize) (void);
-} s_surf_resource_private_t;
+} s_surf_model_private_t;
 
-/* #define pub2priv(r) ((surf_resource_private_t) ((char *)(r) -(sizeof(struct surf_resource_private_part)))) */
-/* #define priv2pub(r) ((void *) ((char *)(r) +(sizeof(struct surf_resource_private_part)))) */
+/* #define pub2priv(r) ((surf_model_private_t) ((char *)(r) -(sizeof(struct surf_model_private_part)))) */
+/* #define priv2pub(r) ((void *) ((char *)(r) +(sizeof(struct surf_model_private_part)))) */
+
+extern int use_sdp_solver;
+extern int use_lagrange_solver;
 
 double generic_maxmin_share_resources(xbt_swag_t running_actions,
-                                     size_t offset);
-/* Generic functions common to all ressources */
+                                      size_t offset,
+                                      lmm_system_t sys,
+                                      void (*solve) (lmm_system_t));
+
+/* Generic functions common to all modelss */
 e_surf_action_state_t surf_action_get_state(surf_action_t action);
+double surf_action_get_start_time(surf_action_t action);
+double surf_action_get_finish_time(surf_action_t action);
 void surf_action_free(surf_action_t * action);
 void surf_action_change_state(surf_action_t action,
-                             e_surf_action_state_t state);
+                              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);
 
-extern lmm_system_t maxmin_system;
 extern tmgr_history_t history;
+extern xbt_dynar_t surf_path;
+
+void surf_config_init(int *argc,char **argv);
+void surf_config_finalize(void);
+void surf_config(const char *name, va_list pa);
+
+
+/*
+ * Returns the initial path. On Windows the initial path is
+ * the current directory for the current process in the other
+ * case the function returns "./" that represents the current
+ * directory on Unix/Linux platforms.
+ */
+const char *__surf_get_initial_path(void);
+
+/* The __surf_is_absolute_file_path() returns 1 if
+ * file_path is a absolute file path, in the other
+ * case the function returns 0.
+ */
+int __surf_is_absolute_file_path(const char *file_path);
 
-#endif                         /* _SURF_SURF_PRIVATE_H */
+#endif /* _SURF_SURF_PRIVATE_H */