X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/ab2a2facb2712c4f2eb91f9ab992dad388f78b74..110275bdfe31a33027e51860ed41f199da963cef:/src/include/surf/surf.h diff --git a/src/include/surf/surf.h b/src/include/surf/surf.h index 66e7041eec..4a7ebcf6f6 100644 --- a/src/include/surf/surf.h +++ b/src/include/surf/surf.h @@ -10,6 +10,7 @@ #include "xbt/swag.h" #include "xbt/dynar.h" +#include "xbt/dict.h" /* Actions and resources are higly connected structures... */ typedef struct surf_action *surf_action_t; @@ -38,13 +39,13 @@ typedef struct surf_action_state { typedef struct surf_action { s_xbt_swag_hookup_t state_hookup; xbt_swag_t state_set; - xbt_maxmin_float_t cost; /* cost */ - xbt_maxmin_float_t max_duration; /* max_duration (may fluctuate until - the task is completed) */ - xbt_maxmin_float_t remains; /* How much of that cost remains to + double cost; /* cost */ + double max_duration; /* max_duration (may fluctuate until + the task is completed) */ + double remains; /* How much of that cost remains to * be done in the currently running task */ - xbt_heap_float_t start; /* start time */ - xbt_heap_float_t finish; /* finish time : this is modified during the run + double start; /* start time */ + double finish; /* finish time : this is modified during the run * and fluctuates until the task is completed */ void *callback; /* for your convenience */ surf_resource_t resource_type; @@ -90,10 +91,11 @@ typedef enum { typedef struct surf_cpu_resource_extension_private *surf_cpu_resource_extension_private_t; typedef struct surf_cpu_resource_extension_public { - surf_action_t(*execute) (void *cpu, xbt_maxmin_float_t size); - surf_action_t(*sleep) (void *cpu, xbt_maxmin_float_t duration); + surf_action_t(*execute) (void *cpu, double size); + surf_action_t(*sleep) (void *cpu, double duration); void (*suspend) (surf_action_t action); void (*resume) (surf_action_t action); + int (*is_suspended) (surf_action_t action); e_surf_cpu_state_t(*get_state) (void *cpu); } s_surf_cpu_resource_extension_public_t, *surf_cpu_resource_extension_public_t; @@ -110,8 +112,7 @@ void surf_cpu_resource_init(const char *filename); typedef struct surf_network_resource_extension_private *surf_network_resource_extension_private_t; typedef struct surf_network_resource_extension_public { - surf_action_t(*communicate) (void *src, void *dst, - xbt_maxmin_float_t size); + surf_action_t(*communicate) (void *src, void *dst, double size); } s_surf_network_resource_extension_public_t, *surf_network_resource_extension_public_t; @@ -128,14 +129,14 @@ void surf_network_resource_init(const char *filename); typedef struct surf_workstation_resource_extension_private *surf_workstation_resource_extension_private_t; typedef struct surf_workstation_resource_extension_public { - surf_action_t(*execute) (void *workstation, xbt_maxmin_float_t size); - surf_action_t(*sleep) (void *workstation, xbt_maxmin_float_t duration); + surf_action_t(*execute) (void *workstation, double size); + surf_action_t(*sleep) (void *workstation, double duration); void (*suspend) (surf_action_t action); void (*resume) (surf_action_t action); + int (*is_suspended) (surf_action_t action); e_surf_cpu_state_t(*get_state) (void *workstation); surf_action_t(*communicate) (void *workstation_src, - void *workstation_dst, - xbt_maxmin_float_t size); + void *workstation_dst, double size); } s_surf_workstation_resource_extension_public_t, *surf_workstation_resource_extension_public_t; @@ -147,6 +148,7 @@ typedef struct surf_workstation_resource { extern surf_workstation_resource_t surf_workstation_resource; void surf_workstation_resource_init(const char *filename); +extern xbt_dict_t workstation_set; /*******************************************/ /*** SURF Globals **************************/ @@ -156,10 +158,10 @@ void surf_init(int *argc, char **argv); /* initialize common structures */ extern xbt_dynar_t resource_list; /* list of initialized resources */ -xbt_heap_float_t surf_solve(void); /* update all states and returns - the time elapsed since last - event */ -xbt_heap_float_t surf_get_clock(void); +double surf_solve(void); /* update all states and returns + the time elapsed since last + event */ +double surf_get_clock(void); void surf_finalize(void); /* clean everything */ #endif /* _SURF_SURF_H */