X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/e4997b8647e1c6c6c5328854a355ad3ef342e614..afb806d0615c22ac119575596b71691f4e2bc9d1:/src/mc/mc_member.cpp diff --git a/src/mc/mc_member.cpp b/src/mc/mc_member.cpp index c69ef5159a..0a5040bf61 100644 --- a/src/mc/mc_member.cpp +++ b/src/mc/mc_member.cpp @@ -6,9 +6,9 @@ #include -#include "mc_object_info.h" -#include "mc_private.h" -#include "mc/Type.hpp" +#include "src/mc/mc_object_info.h" +#include "src/mc/mc_private.h" +#include "src/mc/Type.hpp" namespace simgrid { namespace dwarf { @@ -29,22 +29,16 @@ void *resolve_member( if (!member->has_offset_location()) return ((char *) base) + member->offset(); - s_mc_expression_state_t state; - memset(&state, 0, sizeof(s_mc_expression_state_t)); + ExpressionContext state; state.frame_base = NULL; state.cursor = NULL; state.address_space = address_space; - state.stack_size = 1; - state.stack[0] = (uintptr_t) base; state.process_index = process_index; - if (simgrid::mc::execute( - member->location_expression, &state)) - xbt_die("Error evaluating DWARF expression"); - if (state.stack_size == 0) - xbt_die("No value on the stack"); - else - return (void *) state.stack[state.stack_size - 1]; + ExpressionStack stack; + stack.push((ExpressionStack::value_type) base); + simgrid::dwarf::execute(member->location_expression, state, stack); + return (void*) stack.top(); } }