Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
* Cleanup the DTD by renaming:
[simgrid.git] / src / surf / surf_private.h
index a6b4796..e417d40 100644 (file)
@@ -17,6 +17,8 @@
 #define NO_MAX_DURATION -1.0
 #define SG_TCP_CTE_GAMMA 20000.0
 
+xbt_dict_t current_property_set;
+
 extern const char *surf_action_state_names[6];
 
 typedef enum {
@@ -29,7 +31,7 @@ typedef enum {
   SURF_NETWORK_LINK_FATPIPE = 0
 } e_surf_network_link_sharing_policy_t;
 
-typedef struct surf_resource_private {
+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 */
@@ -39,33 +41,33 @@ typedef struct surf_resource_private {
   void (*update_resource_state) (void *id, tmgr_trace_event_t event_type,
                                 double value);
   void (*finalize) (void);
-} s_surf_resource_private_t;
+} s_surf_model_private_t;
+
+/* #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)))) */
 
-/* #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)))) */
+extern int use_sdp_solver;
+extern int use_lagrange_solver;
 
-XBT_PUBLIC(double) generic_maxmin_share_resources(xbt_swag_t running_actions,
-                                     size_t offset);
-XBT_PUBLIC(double) generic_maxmin_share_resources2(xbt_swag_t running_actions,
+double generic_maxmin_share_resources(xbt_swag_t running_actions,
                                       size_t offset,
-                                      lmm_system_t sys);
-
-/* Generic functions common to all ressources */
-XBT_PUBLIC(e_surf_action_state_t) surf_action_get_state(surf_action_t action);
-XBT_PUBLIC(double) surf_action_get_start_time(surf_action_t action);
-XBT_PUBLIC(double) surf_action_get_finish_time(surf_action_t action);
-XBT_PUBLIC(void) surf_action_free(surf_action_t * action);
-XBT_PUBLIC(void) surf_action_change_state(surf_action_t action,
+                                      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);
-XBT_PUBLIC(void) surf_action_set_data(surf_action_t action,
+void surf_action_set_data(surf_action_t action,
                          void *data);
-XBT_PUBLIC(FILE *) surf_fopen(const char *name, const char *mode);
+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;
 
-
 /*
  * Returns the initial path. On Windows the initial path is
  * the current directory for the current process in the other