X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/3a54b6d1aef3110883b46f912b3a4eeb5c9fb087..74b753c075bcd054409e619771d3b5967cfdb60e:/src/mc/memory_map.c diff --git a/src/mc/memory_map.c b/src/mc/memory_map.c index b4315233c4..b582b326bf 100644 --- a/src/mc/memory_map.c +++ b/src/mc/memory_map.c @@ -9,7 +9,7 @@ XBT_LOG_NEW_DEFAULT_SUBCATEGORY(mc_memory_map, mc, "Logging specific to algorithms for memory_map"); -memory_map_t get_memory_map(void) +memory_map_t MC_get_memory_map(void) { FILE *fp; /* File pointer to process's proc maps file */ char *line = NULL; /* Temporal storage for each line that is readed */ @@ -32,6 +32,8 @@ memory_map_t get_memory_map(void) xbt_assert(fp, "Cannot open /proc/self/maps to investigate the memory map of the process. Please report this bug."); + setbuf(fp, NULL); + ret = xbt_new0(s_memory_map_t, 1); /* Read one line at the time, parse it and add it to the memory map to be returned */ @@ -153,11 +155,12 @@ memory_map_t get_memory_map(void) return ret; } -void free_memory_map(memory_map_t map){ +void MC_free_memory_map(memory_map_t map){ int i; for(i=0; i< map->mapsize; i++){ xbt_free(map->regions[i].pathname); } + xbt_free(map->regions); xbt_free(map); }