X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/841d7ae6385610f340ae3c0be8273bdd9ec80cd5..6c7b494f8d1203fb34e01e349b339a70a68daa7a:/include/simgrid/actor.h diff --git a/include/simgrid/actor.h b/include/simgrid/actor.h index b5de5fdeb5..5885acca42 100644 --- a/include/simgrid/actor.h +++ b/include/simgrid/actor.h @@ -20,13 +20,20 @@ SG_BEGIN_DECL You should not access directly to the fields of the pointed structure, but always use the provided API to interact with actors. */ +XBT_PUBLIC size_t sg_actor_count(); +XBT_PUBLIC sg_actor_t* sg_actor_list(); + +XBT_PUBLIC sg_actor_t sg_actor_create(const char* name, sg_host_t host, xbt_main_func_t code, int argc, + const char* const* argv); XBT_PUBLIC sg_actor_t sg_actor_init(const char* name, sg_host_t host); /** Start the previously initialized actor. * * Note that argv is copied over, so you should free your own copy once the actor is started. */ XBT_PUBLIC void sg_actor_start(sg_actor_t actor, xbt_main_func_t code, int argc, const char* const* argv); +XBT_PUBLIC void sg_actor_set_stacksize(sg_actor_t actor, unsigned size); + XBT_PUBLIC void sg_actor_exit(); -XBT_PUBLIC void sg_actor_on_exit(int_f_int_pvoid_t fun, void* data); +XBT_PUBLIC void sg_actor_on_exit(void_f_int_pvoid_t fun, void* data); XBT_PUBLIC aid_t sg_actor_get_PID(const_sg_actor_t actor); XBT_PUBLIC aid_t sg_actor_get_PPID(const_sg_actor_t actor); @@ -64,13 +71,18 @@ XBT_PUBLIC aid_t sg_actor_self_get_ppid(); XBT_PUBLIC const char* sg_actor_self_get_name(); XBT_PUBLIC void* sg_actor_self_data(); XBT_PUBLIC void sg_actor_self_data_set(void* data); -XBT_PUBLIC void sg_actor_self_execute(double flops); +XBT_ATTRIB_DEPRECATED_v330("Please use sg_actor_execute() instead") XBT_PUBLIC void sg_actor_self_execute(double flops); +XBT_PUBLIC void sg_actor_execute(double flops); +XBT_PUBLIC void sg_actor_execute_with_priority(double flops, double priority); +void sg_actor_parallel_execute(int host_nb, sg_host_t* host_list, double* flops_amount, double* bytes_amount); XBT_PUBLIC void sg_actor_ref(const_sg_actor_t actor); XBT_PUBLIC void sg_actor_unref(const_sg_actor_t actor); XBT_PUBLIC void* sg_actor_data(const_sg_actor_t actor); XBT_PUBLIC void sg_actor_data_set(sg_actor_t actor, void* userdata); XBT_PUBLIC sg_exec_t sg_actor_exec_init(double computation_amount); +XBT_PUBLIC sg_exec_t sg_actor_parallel_exec_init(int host_nb, const sg_host_t* host_list, double* flops_amount, + double* bytes_amount); XBT_PUBLIC sg_exec_t sg_actor_exec_async(double computation_amount); SG_END_DECL