|
@@ -437,7 +437,7 @@ fill_node(struct callchain_node *node, struct callchain_cursor *cursor)
|
|
}
|
|
}
|
|
call->ip = cursor_node->ip;
|
|
call->ip = cursor_node->ip;
|
|
call->ms.sym = cursor_node->sym;
|
|
call->ms.sym = cursor_node->sym;
|
|
- call->ms.map = cursor_node->map;
|
|
|
|
|
|
+ call->ms.map = map__get(cursor_node->map);
|
|
|
|
|
|
if (cursor_node->branch) {
|
|
if (cursor_node->branch) {
|
|
call->branch_count = 1;
|
|
call->branch_count = 1;
|
|
@@ -477,6 +477,7 @@ add_child(struct callchain_node *parent,
|
|
|
|
|
|
list_for_each_entry_safe(call, tmp, &new->val, list) {
|
|
list_for_each_entry_safe(call, tmp, &new->val, list) {
|
|
list_del(&call->list);
|
|
list_del(&call->list);
|
|
|
|
+ map__zput(call->ms.map);
|
|
free(call);
|
|
free(call);
|
|
}
|
|
}
|
|
free(new);
|
|
free(new);
|
|
@@ -761,6 +762,7 @@ merge_chain_branch(struct callchain_cursor *cursor,
|
|
list->ms.map, list->ms.sym,
|
|
list->ms.map, list->ms.sym,
|
|
false, NULL, 0, 0);
|
|
false, NULL, 0, 0);
|
|
list_del(&list->list);
|
|
list_del(&list->list);
|
|
|
|
+ map__zput(list->ms.map);
|
|
free(list);
|
|
free(list);
|
|
}
|
|
}
|
|
|
|
|
|
@@ -811,7 +813,8 @@ int callchain_cursor_append(struct callchain_cursor *cursor,
|
|
}
|
|
}
|
|
|
|
|
|
node->ip = ip;
|
|
node->ip = ip;
|
|
- node->map = map;
|
|
|
|
|
|
+ map__zput(node->map);
|
|
|
|
+ node->map = map__get(map);
|
|
node->sym = sym;
|
|
node->sym = sym;
|
|
node->branch = branch;
|
|
node->branch = branch;
|
|
node->nr_loop_iter = nr_loop_iter;
|
|
node->nr_loop_iter = nr_loop_iter;
|
|
@@ -1142,11 +1145,13 @@ static void free_callchain_node(struct callchain_node *node)
|
|
|
|
|
|
list_for_each_entry_safe(list, tmp, &node->parent_val, list) {
|
|
list_for_each_entry_safe(list, tmp, &node->parent_val, list) {
|
|
list_del(&list->list);
|
|
list_del(&list->list);
|
|
|
|
+ map__zput(list->ms.map);
|
|
free(list);
|
|
free(list);
|
|
}
|
|
}
|
|
|
|
|
|
list_for_each_entry_safe(list, tmp, &node->val, list) {
|
|
list_for_each_entry_safe(list, tmp, &node->val, list) {
|
|
list_del(&list->list);
|
|
list_del(&list->list);
|
|
|
|
+ map__zput(list->ms.map);
|
|
free(list);
|
|
free(list);
|
|
}
|
|
}
|
|
|
|
|
|
@@ -1210,6 +1215,7 @@ int callchain_node__make_parent_list(struct callchain_node *node)
|
|
goto out;
|
|
goto out;
|
|
*new = *chain;
|
|
*new = *chain;
|
|
new->has_children = false;
|
|
new->has_children = false;
|
|
|
|
+ map__get(new->ms.map);
|
|
list_add_tail(&new->list, &head);
|
|
list_add_tail(&new->list, &head);
|
|
}
|
|
}
|
|
parent = parent->parent;
|
|
parent = parent->parent;
|
|
@@ -1230,6 +1236,7 @@ int callchain_node__make_parent_list(struct callchain_node *node)
|
|
out:
|
|
out:
|
|
list_for_each_entry_safe(chain, new, &head, list) {
|
|
list_for_each_entry_safe(chain, new, &head, list) {
|
|
list_del(&chain->list);
|
|
list_del(&chain->list);
|
|
|
|
+ map__zput(chain->ms.map);
|
|
free(chain);
|
|
free(chain);
|
|
}
|
|
}
|
|
return -ENOMEM;
|
|
return -ENOMEM;
|