* \param ip Instruction pointer
* \return true if the variable is valid
* */
-static bool mc_valid_variable(dw_variable_t var, dw_frame_t frame, const void* ip) {
+static bool mc_valid_variable(dw_variable_t var, dw_frame_t scope, const void* ip) {
// The variable is not yet valid:
- if((const void*)((const char*) frame->low_pc + var->start_scope) > ip)
+ if((const void*)((const char*) scope->low_pc + var->start_scope) > ip)
return false;
else
return true;
dw_variable_t current_variable;
xbt_dynar_foreach(scope->variables, cursor, current_variable){
- if(!mc_valid_variable(current_variable, stack_frame->frame, (void*) stack_frame->ip))
+ if(!mc_valid_variable(current_variable, scope, (void*) stack_frame->ip))
continue;
int region_type;
new_var->type = current_variable->type;
new_var->region= region_type;
- /* if(current_variable->address!=NULL) {
+ if(current_variable->address!=NULL) {
new_var->address = current_variable->address;
- } else */
+ } else
if(current_variable->locations.size != 0){
new_var->address = (void*) mc_dwarf_resolve_locations(¤t_variable->locations,
current_variable->object_info,
&(stack_frame->unw_cursor), (void*)stack_frame->frame_base, NULL);
+ } else {
+ xbt_die("No address");
}
xbt_dynar_push(result, &new_var);
if (finished && comm->task_received != NULL) {
/* I am the receiver */
- simdata_task_t simdata = (*comm->task_received)->simdata;
- if (msg_global->debug_multiple_use && simdata->isused!=0)
- xbt_ex_free(*(xbt_ex_t*)simdata->isused);
- simdata->isused = 0;
+ if (msg_global->debug_multiple_use && (*comm->task_received)->simdata->isused!=0)
+ xbt_ex_free(*(xbt_ex_t*)(*comm->task_received)->simdata->isused);
+ (*comm->task_received)->simdata->isused = 0;
}
}
CATCH(e) {
if (status == MSG_OK && comm->task_received != NULL) {
/* I am the receiver */
- simdata_task_t simdata = (*comm->task_received)->simdata;
- if (msg_global->debug_multiple_use && simdata->isused!=0)
- xbt_ex_free(*(xbt_ex_t*)simdata->isused);
- simdata->isused = 0;
+ if (msg_global->debug_multiple_use && (*comm->task_received)->simdata->isused!=0)
+ xbt_ex_free(*(xbt_ex_t*)(*comm->task_received)->simdata->isused);
+ (*comm->task_received)->simdata->isused = 0;
}
}
if (comm->task_received != NULL) {
/* I am the receiver */
- simdata_task_t simdata = (*comm->task_received)->simdata;
- if (msg_global->debug_multiple_use && simdata->isused!=0)
- xbt_ex_free(*(xbt_ex_t*)simdata->isused);
- simdata->isused = 0;
+ if (msg_global->debug_multiple_use && (*comm->task_received)->simdata->isused!=0)
+ xbt_ex_free(*(xbt_ex_t*)(*comm->task_received)->simdata->isused);
+ (*comm->task_received)->simdata->isused = 0;
}
/* FIXME: these functions are not traceable */
if (comm->task_received != NULL) {
/* I am the receiver */
- simdata_task_t simdata = (*comm->task_received)->simdata;
- if (msg_global->debug_multiple_use && simdata->isused!=0)
- xbt_ex_free(*(xbt_ex_t*)simdata->isused);
- simdata->isused = 0;
+ if (msg_global->debug_multiple_use && (*comm->task_received)->simdata->isused!=0)
+ xbt_ex_free(*(xbt_ex_t*)(*comm->task_received)->simdata->isused);
+ (*comm->task_received)->simdata->isused = 0;
}
return finished_index;
TRY {
simcall_comm_recv(mailbox, task, NULL, NULL, NULL, timeout, rate);
XBT_DEBUG("Got task %s from %p",(*task)->name,mailbox);
- simdata_task_t simdata = (*task)->simdata;
- if (msg_global->debug_multiple_use && simdata->isused!=0)
- xbt_ex_free(*(xbt_ex_t*)simdata->isused);
- simdata->isused = 0;
+ if (msg_global->debug_multiple_use && (*task)->simdata->isused!=0)
+ xbt_ex_free(*(xbt_ex_t*)(*task)->simdata->isused);
+ (*task)->simdata->isused = 0;
}
CATCH(e) {
switch (e.category) {