X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/b40c2e9bf3cf6e8b2fad15594852ce186bf99574..31a999f9a0f6420f98301e553cb0e5f0c8b2a1c8:/src/mc/mc_member.c diff --git a/src/mc/mc_member.c b/src/mc/mc_member.c index bc2436a260..ff7667d8a7 100644 --- a/src/mc/mc_member.c +++ b/src/mc/mc_member.c @@ -15,7 +15,7 @@ * @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_snapshot_t snapshot) + mc_snapshot_t snapshot, int process_index) { if (!member->location.size) { return ((char *) base) + member->offset; @@ -28,6 +28,7 @@ void *mc_member_resolve(const void *base, dw_type_t type, dw_type_t member, state.snapshot = snapshot; state.stack_size = 1; state.stack[0] = (uintptr_t) base; + state.process_index = process_index; if (mc_dwarf_execute_expression (member->location.size, member->location.ops, &state)) @@ -38,26 +39,3 @@ void *mc_member_resolve(const void *base, dw_type_t type, dw_type_t member, return (void *) state.stack[state.stack_size - 1]; } -/** Resolve snapshot in the snapshot address space - * - * @param object Snapshot address of the struct/class - * @param type Type of the struct/class - * @param member Member description - * @param snapshot Snapshot (or NULL) - * @return Snapshot address of the given member of the 'object' struct/class - */ -void *mc_member_snapshot_resolve(const void *object, dw_type_t type, - dw_type_t member, mc_snapshot_t snapshot) -{ - if (!member->location.size) { - return (char *) object + member->offset; - } else { - // Translate the problem in the process address space: - void *real_area = - (void *) mc_untranslate_address((void *) object, snapshot); - // Resolve the member in the process address space: - void *real_member = mc_member_resolve(real_area, type, member, snapshot); - // Translate back in the snapshot address space: - return mc_translate_address((uintptr_t) real_member, snapshot); - } -}