X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/749cf0c1157c66ccb0dda53d41b082994722d487..e709643ef0c5b61c6c878016c418bffa2b1b20cd:/include/simgrid/actor.h diff --git a/include/simgrid/actor.h b/include/simgrid/actor.h index 9145a7af41..3640e2631b 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); @@ -37,10 +44,11 @@ XBT_PUBLIC const char* sg_actor_get_property_value(const_sg_actor_t actor, const XBT_PUBLIC xbt_dict_t sg_actor_get_properties(const_sg_actor_t actor); XBT_PUBLIC void sg_actor_suspend(sg_actor_t actor); XBT_PUBLIC void sg_actor_resume(sg_actor_t actor); -XBT_PUBLIC int sg_actor_is_suspended(sg_actor_t actor); +XBT_PUBLIC int sg_actor_is_suspended(const_sg_actor_t actor); XBT_PUBLIC sg_actor_t sg_actor_restart(sg_actor_t actor); -void sg_actor_set_auto_restart(sg_actor_t actor, int auto_restart); +XBT_PUBLIC void sg_actor_set_auto_restart(sg_actor_t actor, int auto_restart); XBT_PUBLIC void sg_actor_daemonize(sg_actor_t actor); +XBT_PUBLIC int sg_actor_is_daemon(const_sg_actor_t actor); #ifndef DOXYGEN XBT_ATTRIB_DEPRECATED_v329("Please use sg_actor_set_host() instead") XBT_PUBLIC @@ -63,12 +71,19 @@ 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 #endif /* INCLUDE_SIMGRID_ACTOR_H_ */