]> git.kernelconcepts.de Git - karo-tx-linux.git/blobdiff - tools/perf/util/map.c
Merge tag 'mmc-v4.3' of git://git.linaro.org/people/ulf.hansson/mmc
[karo-tx-linux.git] / tools / perf / util / map.c
index ce37e95bc51347cf2e3d0f650a64ca4b405c8d2e..b1c475d9b240393e73614bc249e9e4b3dc2eedfc 100644 (file)
@@ -348,9 +348,18 @@ struct symbol *map__find_symbol_by_name(struct map *map, const char *name,
        return dso__find_symbol_by_name(map->dso, map->type, name);
 }
 
-struct map *map__clone(struct map *map)
+struct map *map__clone(struct map *from)
 {
-       return memdup(map, sizeof(*map));
+       struct map *map = memdup(from, sizeof(*map));
+
+       if (map != NULL) {
+               atomic_set(&map->refcnt, 1);
+               RB_CLEAR_NODE(&map->rb_node);
+               dso__get(map->dso);
+               map->groups = NULL;
+       }
+
+       return map;
 }
 
 int map__overlap(struct map *l, struct map *r)