mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-16 10:11:38 -04:00
perf maps: Fix copy_from that can break sorted by name order
When an parent is copied into a child the name array is populated in
address not name order. Make sure the name array isn't flagged as sorted.
Fixes: 659ad3492b ("perf maps: Switch from rbtree to lazily sorted array for addresses")
Signed-off-by: Ian Rogers <irogers@google.com>
Signed-off-by: Namhyung Kim <namhyung@kernel.org>
This commit is contained in:
@@ -1081,16 +1081,9 @@ int maps__copy_from(struct maps *dest, struct maps *parent)
|
||||
map__put(new);
|
||||
}
|
||||
maps__set_maps_by_address_sorted(dest, maps__maps_by_address_sorted(parent));
|
||||
if (!err) {
|
||||
RC_CHK_ACCESS(dest)->last_search_by_name_idx =
|
||||
RC_CHK_ACCESS(parent)->last_search_by_name_idx;
|
||||
maps__set_maps_by_name_sorted(dest,
|
||||
dest_maps_by_name &&
|
||||
maps__maps_by_name_sorted(parent));
|
||||
} else {
|
||||
RC_CHK_ACCESS(dest)->last_search_by_name_idx = 0;
|
||||
maps__set_maps_by_name_sorted(dest, false);
|
||||
}
|
||||
RC_CHK_ACCESS(dest)->last_search_by_name_idx = 0;
|
||||
/* Values were copied into the name array in address order. */
|
||||
maps__set_maps_by_name_sorted(dest, false);
|
||||
} else {
|
||||
/* Unexpected copying to a maps containing entries. */
|
||||
for (unsigned int i = 0; !err && i < n; i++) {
|
||||
|
||||
Reference in New Issue
Block a user