3 /* Copyright (c) 2007 Arnaud Legrand, Bruno Donnassolo.
4 All rights reserved. */
6 /* This program is free software; you can redistribute it and/or modify it
7 * under the terms of the license (GNU LGPL) which comes with this package. */
12 XBT_LOG_NEW_DEFAULT_SUBCATEGORY(simix_action, simix,
13 "Logging specific to SIMIX (action)");
15 /************************************* Actions *********************************/
17 smx_action_t SIMIX_communicate(smx_host_t sender,smx_host_t receiver,char * name, double size, double rate)
20 /* alloc structures */
21 smx_action_t act = xbt_new0(s_smx_action_t,1);
22 act->simdata = xbt_new0(s_simdata_action_t,1);
23 simdata_action_t simdata = act->simdata;
24 simdata->cond_list = xbt_fifo_new();
27 act->name = xbt_strdup(name);
28 simdata->action_block=0;
29 simdata->cond_process=NULL;
30 simdata->timeout_cond = NULL;
33 simdata->surf_action = surf_workstation_resource->extension_public->
34 communicate(sender->simdata->host,
35 receiver->simdata->host, size, rate);
36 surf_workstation_resource->common_public->action_set_data(simdata->surf_action,act);
41 smx_action_t SIMIX_execute(smx_host_t host, char * name, double amount)
44 /* alloc structures */
45 smx_action_t act = xbt_new0(s_smx_action_t,1);
46 act->simdata = xbt_new0(s_simdata_action_t,1);
47 simdata_action_t simdata = act->simdata;
48 simdata->cond_list = xbt_fifo_new();
51 simdata->source = host;
52 act-> name = xbt_strdup(name);
53 simdata->action_block=0;
54 simdata->cond_process=NULL;
55 simdata->timeout_cond = NULL;
57 /* set communication */
58 simdata->surf_action = surf_workstation_resource->extension_public->
59 execute(host->simdata->host, amount);
61 surf_workstation_resource->common_public->action_set_data(simdata->surf_action,act);
66 void SIMIX_action_cancel(smx_action_t action)
68 xbt_assert0((action != NULL), "Invalid parameter");
70 if(action->simdata->surf_action) {
71 surf_workstation_resource->common_public->action_cancel(action->simdata->surf_action);
76 void SIMIX_action_set_priority(smx_action_t action, double priority)
78 xbt_assert0( (action != NULL) && (action->simdata != NULL), "Invalid parameter" );
80 surf_workstation_resource->common_public->
81 set_priority(action->simdata->surf_action, priority);
85 void SIMIX_action_destroy(smx_action_t action)
88 xbt_assert0((action != NULL), "Invalid parameter");
90 xbt_assert1((xbt_fifo_size(action->simdata->cond_list)==0),
91 "Conditional list not empty %d. There is a problem. Cannot destroy it now!", xbt_fifo_size(action->simdata->cond_list));
93 if(action->name) free(action->name);
95 xbt_fifo_free(action->simdata->cond_list);
97 if(action->simdata->surf_action)
98 action->simdata->surf_action->resource_type->common_public->action_free(action->simdata->surf_action);
103 void SIMIX_register_action_to_condition(smx_action_t action, smx_cond_t cond)
105 xbt_assert0( (action != NULL) && (cond != NULL), "Invalid parameters");
107 xbt_fifo_push(cond->actions,action);
110 void __SIMIX_wait_for_action(smx_process_t process, smx_action_t action)
112 e_surf_action_state_t state = SURF_ACTION_NOT_IN_THE_SYSTEM;
113 simdata_action_t simdata = action->simdata;
115 xbt_assert0(((process != NULL) && (action != NULL) && (action->simdata != NULL)), "Invalid parameters");
117 /* change context while the action is running */
120 state=surf_workstation_resource->common_public->action_get_state(simdata->surf_action);
121 } while (state==SURF_ACTION_RUNNING);
123 /* action finished, we can continue */
125 if(state == SURF_ACTION_DONE) {
126 if(surf_workstation_resource->common_public->action_free(simdata->surf_action))
127 simdata->surf_action = NULL;
128 } else if(surf_workstation_resource->extension_public->
129 get_state(SIMIX_process_get_host(process)->simdata->host)
131 if(surf_workstation_resource->common_public->action_free(simdata->surf_action))
132 simdata->surf_action = NULL;
134 if(surf_workstation_resource->common_public->action_free(simdata->surf_action))
135 simdata->surf_action = NULL;