X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/ea9cce21b6d3f37823143217f1ca183bb2f0c9ac..ba5400c9278f4f61cf8319210a5edda78e0c5bd8:/src/mc/mc_member.cpp?ds=sidebyside diff --git a/src/mc/mc_member.cpp b/src/mc/mc_member.cpp index a75a9afdb5..29fe1f5193 100644 --- a/src/mc/mc_member.cpp +++ b/src/mc/mc_member.cpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2014. The SimGrid Team. +/* Copyright (c) 2014-2015. The SimGrid Team. * All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it @@ -8,8 +8,7 @@ #include "mc_object_info.h" #include "mc_private.h" - -extern "C" { +#include "mc/Type.hpp" /** Resolve snapshot in the process address space * @@ -19,12 +18,12 @@ extern "C" { * @param snapshot Snapshot (or NULL) * @return Process address of the given member of the 'object' struct/class */ -void *mc_member_resolve(const void *base, dw_type_t type, dw_type_t member, - mc_address_space_t address_space, int process_index) +void *mc_member_resolve(const void *base, simgrid::mc::Type* type, simgrid::mc::Type* member, + simgrid::mc::AddressSpace* address_space, int process_index) { - if (!member->location.size) { - return ((char *) base) + member->offset; - } + // TODO, get rid of this? + 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)); @@ -35,13 +34,11 @@ void *mc_member_resolve(const void *base, dw_type_t type, dw_type_t member, state.stack[0] = (uintptr_t) base; state.process_index = process_index; - if (mc_dwarf_execute_expression - (member->location.size, member->location.ops, &state)) + 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]; } - -}