mirror of
https://github.com/Fishwaldo/linux-bl808.git
synced 2025-06-17 20:25:19 +00:00
perf symbols: Use cached rbtrees
At the cost of an extra pointer, we can avoid the O(logN) cost of finding the first element in the tree (smallest node). Signed-off-by: Davidlohr Bueso <dbueso@suse.de> Tested-by: Arnaldo Carvalho de Melo <acme@redhat.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: Namhyung Kim <namhyung@kernel.org> Link: http://lkml.kernel.org/r/20181206191819.30182-6-dave@stgolabs.net Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
ca2270292e
commit
7137ff50b6
8 changed files with 67 additions and 58 deletions
|
@ -227,7 +227,7 @@ static int perf_evsel__add_sample(struct perf_evsel *evsel,
|
||||||
* the DSO?
|
* the DSO?
|
||||||
*/
|
*/
|
||||||
if (al->sym != NULL) {
|
if (al->sym != NULL) {
|
||||||
rb_erase(&al->sym->rb_node,
|
rb_erase_cached(&al->sym->rb_node,
|
||||||
&al->map->dso->symbols);
|
&al->map->dso->symbols);
|
||||||
symbol__delete(al->sym);
|
symbol__delete(al->sym);
|
||||||
dso__reset_find_symbol_cache(al->map->dso);
|
dso__reset_find_symbol_cache(al->map->dso);
|
||||||
|
|
|
@ -1197,7 +1197,7 @@ struct dso *dso__new(const char *name)
|
||||||
strcpy(dso->name, name);
|
strcpy(dso->name, name);
|
||||||
dso__set_long_name(dso, dso->name, false);
|
dso__set_long_name(dso, dso->name, false);
|
||||||
dso__set_short_name(dso, dso->name, false);
|
dso__set_short_name(dso, dso->name, false);
|
||||||
dso->symbols = dso->symbol_names = RB_ROOT;
|
dso->symbols = dso->symbol_names = RB_ROOT_CACHED;
|
||||||
dso->data.cache = RB_ROOT;
|
dso->data.cache = RB_ROOT;
|
||||||
dso->inlined_nodes = RB_ROOT_CACHED;
|
dso->inlined_nodes = RB_ROOT_CACHED;
|
||||||
dso->srclines = RB_ROOT_CACHED;
|
dso->srclines = RB_ROOT_CACHED;
|
||||||
|
@ -1469,7 +1469,7 @@ size_t dso__fprintf(struct dso *dso, FILE *fp)
|
||||||
ret += fprintf(fp, "%sloaded, ", dso__loaded(dso) ? "" : "NOT ");
|
ret += fprintf(fp, "%sloaded, ", dso__loaded(dso) ? "" : "NOT ");
|
||||||
ret += dso__fprintf_buildid(dso, fp);
|
ret += dso__fprintf_buildid(dso, fp);
|
||||||
ret += fprintf(fp, ")\n");
|
ret += fprintf(fp, ")\n");
|
||||||
for (nd = rb_first(&dso->symbols); nd; nd = rb_next(nd)) {
|
for (nd = rb_first_cached(&dso->symbols); nd; nd = rb_next(nd)) {
|
||||||
struct symbol *pos = rb_entry(nd, struct symbol, rb_node);
|
struct symbol *pos = rb_entry(nd, struct symbol, rb_node);
|
||||||
ret += symbol__fprintf(pos, fp);
|
ret += symbol__fprintf(pos, fp);
|
||||||
}
|
}
|
||||||
|
|
|
@ -141,8 +141,8 @@ struct dso {
|
||||||
struct list_head node;
|
struct list_head node;
|
||||||
struct rb_node rb_node; /* rbtree node sorted by long name */
|
struct rb_node rb_node; /* rbtree node sorted by long name */
|
||||||
struct rb_root *root; /* root of rbtree that rb_node is in */
|
struct rb_root *root; /* root of rbtree that rb_node is in */
|
||||||
struct rb_root symbols;
|
struct rb_root_cached symbols;
|
||||||
struct rb_root symbol_names;
|
struct rb_root_cached symbol_names;
|
||||||
struct rb_root_cached inlined_nodes;
|
struct rb_root_cached inlined_nodes;
|
||||||
struct rb_root_cached srclines;
|
struct rb_root_cached srclines;
|
||||||
struct {
|
struct {
|
||||||
|
@ -236,7 +236,7 @@ bool dso__loaded(const struct dso *dso);
|
||||||
|
|
||||||
static inline bool dso__has_symbols(const struct dso *dso)
|
static inline bool dso__has_symbols(const struct dso *dso)
|
||||||
{
|
{
|
||||||
return !RB_EMPTY_ROOT(&dso->symbols);
|
return !RB_EMPTY_ROOT(&dso->symbols.rb_root);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool dso__sorted_by_name(const struct dso *dso);
|
bool dso__sorted_by_name(const struct dso *dso);
|
||||||
|
|
|
@ -286,8 +286,8 @@ void map__put(struct map *map)
|
||||||
|
|
||||||
void map__fixup_start(struct map *map)
|
void map__fixup_start(struct map *map)
|
||||||
{
|
{
|
||||||
struct rb_root *symbols = &map->dso->symbols;
|
struct rb_root_cached *symbols = &map->dso->symbols;
|
||||||
struct rb_node *nd = rb_first(symbols);
|
struct rb_node *nd = rb_first_cached(symbols);
|
||||||
if (nd != NULL) {
|
if (nd != NULL) {
|
||||||
struct symbol *sym = rb_entry(nd, struct symbol, rb_node);
|
struct symbol *sym = rb_entry(nd, struct symbol, rb_node);
|
||||||
map->start = sym->start;
|
map->start = sym->start;
|
||||||
|
@ -296,8 +296,8 @@ void map__fixup_start(struct map *map)
|
||||||
|
|
||||||
void map__fixup_end(struct map *map)
|
void map__fixup_end(struct map *map)
|
||||||
{
|
{
|
||||||
struct rb_root *symbols = &map->dso->symbols;
|
struct rb_root_cached *symbols = &map->dso->symbols;
|
||||||
struct rb_node *nd = rb_last(symbols);
|
struct rb_node *nd = rb_last(&symbols->rb_root);
|
||||||
if (nd != NULL) {
|
if (nd != NULL) {
|
||||||
struct symbol *sym = rb_entry(nd, struct symbol, rb_node);
|
struct symbol *sym = rb_entry(nd, struct symbol, rb_node);
|
||||||
map->end = sym->end;
|
map->end = sym->end;
|
||||||
|
|
|
@ -3529,7 +3529,8 @@ int show_available_funcs(const char *target, struct nsinfo *nsi,
|
||||||
/* Show all (filtered) symbols */
|
/* Show all (filtered) symbols */
|
||||||
setup_pager();
|
setup_pager();
|
||||||
|
|
||||||
for (nd = rb_first(&map->dso->symbol_names); nd; nd = rb_next(nd)) {
|
for (nd = rb_first_cached(&map->dso->symbol_names); nd;
|
||||||
|
nd = rb_next(nd)) {
|
||||||
struct symbol_name_rb_node *pos = rb_entry(nd, struct symbol_name_rb_node, rb_node);
|
struct symbol_name_rb_node *pos = rb_entry(nd, struct symbol_name_rb_node, rb_node);
|
||||||
|
|
||||||
if (strfilter__compare(_filter, pos->sym.name))
|
if (strfilter__compare(_filter, pos->sym.name))
|
||||||
|
|
|
@ -163,7 +163,7 @@ static int choose_best_symbol(struct symbol *syma, struct symbol *symb)
|
||||||
return arch__choose_best_symbol(syma, symb);
|
return arch__choose_best_symbol(syma, symb);
|
||||||
}
|
}
|
||||||
|
|
||||||
void symbols__fixup_duplicate(struct rb_root *symbols)
|
void symbols__fixup_duplicate(struct rb_root_cached *symbols)
|
||||||
{
|
{
|
||||||
struct rb_node *nd;
|
struct rb_node *nd;
|
||||||
struct symbol *curr, *next;
|
struct symbol *curr, *next;
|
||||||
|
@ -171,7 +171,7 @@ void symbols__fixup_duplicate(struct rb_root *symbols)
|
||||||
if (symbol_conf.allow_aliases)
|
if (symbol_conf.allow_aliases)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
nd = rb_first(symbols);
|
nd = rb_first_cached(symbols);
|
||||||
|
|
||||||
while (nd) {
|
while (nd) {
|
||||||
curr = rb_entry(nd, struct symbol, rb_node);
|
curr = rb_entry(nd, struct symbol, rb_node);
|
||||||
|
@ -186,20 +186,20 @@ again:
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (choose_best_symbol(curr, next) == SYMBOL_A) {
|
if (choose_best_symbol(curr, next) == SYMBOL_A) {
|
||||||
rb_erase(&next->rb_node, symbols);
|
rb_erase_cached(&next->rb_node, symbols);
|
||||||
symbol__delete(next);
|
symbol__delete(next);
|
||||||
goto again;
|
goto again;
|
||||||
} else {
|
} else {
|
||||||
nd = rb_next(&curr->rb_node);
|
nd = rb_next(&curr->rb_node);
|
||||||
rb_erase(&curr->rb_node, symbols);
|
rb_erase_cached(&curr->rb_node, symbols);
|
||||||
symbol__delete(curr);
|
symbol__delete(curr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void symbols__fixup_end(struct rb_root *symbols)
|
void symbols__fixup_end(struct rb_root_cached *symbols)
|
||||||
{
|
{
|
||||||
struct rb_node *nd, *prevnd = rb_first(symbols);
|
struct rb_node *nd, *prevnd = rb_first_cached(symbols);
|
||||||
struct symbol *curr, *prev;
|
struct symbol *curr, *prev;
|
||||||
|
|
||||||
if (prevnd == NULL)
|
if (prevnd == NULL)
|
||||||
|
@ -282,25 +282,27 @@ void symbol__delete(struct symbol *sym)
|
||||||
free(((void *)sym) - symbol_conf.priv_size);
|
free(((void *)sym) - symbol_conf.priv_size);
|
||||||
}
|
}
|
||||||
|
|
||||||
void symbols__delete(struct rb_root *symbols)
|
void symbols__delete(struct rb_root_cached *symbols)
|
||||||
{
|
{
|
||||||
struct symbol *pos;
|
struct symbol *pos;
|
||||||
struct rb_node *next = rb_first(symbols);
|
struct rb_node *next = rb_first_cached(symbols);
|
||||||
|
|
||||||
while (next) {
|
while (next) {
|
||||||
pos = rb_entry(next, struct symbol, rb_node);
|
pos = rb_entry(next, struct symbol, rb_node);
|
||||||
next = rb_next(&pos->rb_node);
|
next = rb_next(&pos->rb_node);
|
||||||
rb_erase(&pos->rb_node, symbols);
|
rb_erase_cached(&pos->rb_node, symbols);
|
||||||
symbol__delete(pos);
|
symbol__delete(pos);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void __symbols__insert(struct rb_root *symbols, struct symbol *sym, bool kernel)
|
void __symbols__insert(struct rb_root_cached *symbols,
|
||||||
|
struct symbol *sym, bool kernel)
|
||||||
{
|
{
|
||||||
struct rb_node **p = &symbols->rb_node;
|
struct rb_node **p = &symbols->rb_root.rb_node;
|
||||||
struct rb_node *parent = NULL;
|
struct rb_node *parent = NULL;
|
||||||
const u64 ip = sym->start;
|
const u64 ip = sym->start;
|
||||||
struct symbol *s;
|
struct symbol *s;
|
||||||
|
bool leftmost = true;
|
||||||
|
|
||||||
if (kernel) {
|
if (kernel) {
|
||||||
const char *name = sym->name;
|
const char *name = sym->name;
|
||||||
|
@ -318,26 +320,28 @@ void __symbols__insert(struct rb_root *symbols, struct symbol *sym, bool kernel)
|
||||||
s = rb_entry(parent, struct symbol, rb_node);
|
s = rb_entry(parent, struct symbol, rb_node);
|
||||||
if (ip < s->start)
|
if (ip < s->start)
|
||||||
p = &(*p)->rb_left;
|
p = &(*p)->rb_left;
|
||||||
else
|
else {
|
||||||
p = &(*p)->rb_right;
|
p = &(*p)->rb_right;
|
||||||
|
leftmost = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
rb_link_node(&sym->rb_node, parent, p);
|
rb_link_node(&sym->rb_node, parent, p);
|
||||||
rb_insert_color(&sym->rb_node, symbols);
|
rb_insert_color_cached(&sym->rb_node, symbols, leftmost);
|
||||||
}
|
}
|
||||||
|
|
||||||
void symbols__insert(struct rb_root *symbols, struct symbol *sym)
|
void symbols__insert(struct rb_root_cached *symbols, struct symbol *sym)
|
||||||
{
|
{
|
||||||
__symbols__insert(symbols, sym, false);
|
__symbols__insert(symbols, sym, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct symbol *symbols__find(struct rb_root *symbols, u64 ip)
|
static struct symbol *symbols__find(struct rb_root_cached *symbols, u64 ip)
|
||||||
{
|
{
|
||||||
struct rb_node *n;
|
struct rb_node *n;
|
||||||
|
|
||||||
if (symbols == NULL)
|
if (symbols == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
n = symbols->rb_node;
|
n = symbols->rb_root.rb_node;
|
||||||
|
|
||||||
while (n) {
|
while (n) {
|
||||||
struct symbol *s = rb_entry(n, struct symbol, rb_node);
|
struct symbol *s = rb_entry(n, struct symbol, rb_node);
|
||||||
|
@ -353,9 +357,9 @@ static struct symbol *symbols__find(struct rb_root *symbols, u64 ip)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct symbol *symbols__first(struct rb_root *symbols)
|
static struct symbol *symbols__first(struct rb_root_cached *symbols)
|
||||||
{
|
{
|
||||||
struct rb_node *n = rb_first(symbols);
|
struct rb_node *n = rb_first_cached(symbols);
|
||||||
|
|
||||||
if (n)
|
if (n)
|
||||||
return rb_entry(n, struct symbol, rb_node);
|
return rb_entry(n, struct symbol, rb_node);
|
||||||
|
@ -363,9 +367,9 @@ static struct symbol *symbols__first(struct rb_root *symbols)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct symbol *symbols__last(struct rb_root *symbols)
|
static struct symbol *symbols__last(struct rb_root_cached *symbols)
|
||||||
{
|
{
|
||||||
struct rb_node *n = rb_last(symbols);
|
struct rb_node *n = rb_last(&symbols->rb_root);
|
||||||
|
|
||||||
if (n)
|
if (n)
|
||||||
return rb_entry(n, struct symbol, rb_node);
|
return rb_entry(n, struct symbol, rb_node);
|
||||||
|
@ -383,11 +387,12 @@ static struct symbol *symbols__next(struct symbol *sym)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void symbols__insert_by_name(struct rb_root *symbols, struct symbol *sym)
|
static void symbols__insert_by_name(struct rb_root_cached *symbols, struct symbol *sym)
|
||||||
{
|
{
|
||||||
struct rb_node **p = &symbols->rb_node;
|
struct rb_node **p = &symbols->rb_root.rb_node;
|
||||||
struct rb_node *parent = NULL;
|
struct rb_node *parent = NULL;
|
||||||
struct symbol_name_rb_node *symn, *s;
|
struct symbol_name_rb_node *symn, *s;
|
||||||
|
bool leftmost = true;
|
||||||
|
|
||||||
symn = container_of(sym, struct symbol_name_rb_node, sym);
|
symn = container_of(sym, struct symbol_name_rb_node, sym);
|
||||||
|
|
||||||
|
@ -396,19 +401,21 @@ static void symbols__insert_by_name(struct rb_root *symbols, struct symbol *sym)
|
||||||
s = rb_entry(parent, struct symbol_name_rb_node, rb_node);
|
s = rb_entry(parent, struct symbol_name_rb_node, rb_node);
|
||||||
if (strcmp(sym->name, s->sym.name) < 0)
|
if (strcmp(sym->name, s->sym.name) < 0)
|
||||||
p = &(*p)->rb_left;
|
p = &(*p)->rb_left;
|
||||||
else
|
else {
|
||||||
p = &(*p)->rb_right;
|
p = &(*p)->rb_right;
|
||||||
|
leftmost = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
rb_link_node(&symn->rb_node, parent, p);
|
rb_link_node(&symn->rb_node, parent, p);
|
||||||
rb_insert_color(&symn->rb_node, symbols);
|
rb_insert_color_cached(&symn->rb_node, symbols, leftmost);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void symbols__sort_by_name(struct rb_root *symbols,
|
static void symbols__sort_by_name(struct rb_root_cached *symbols,
|
||||||
struct rb_root *source)
|
struct rb_root_cached *source)
|
||||||
{
|
{
|
||||||
struct rb_node *nd;
|
struct rb_node *nd;
|
||||||
|
|
||||||
for (nd = rb_first(source); nd; nd = rb_next(nd)) {
|
for (nd = rb_first_cached(source); nd; nd = rb_next(nd)) {
|
||||||
struct symbol *pos = rb_entry(nd, struct symbol, rb_node);
|
struct symbol *pos = rb_entry(nd, struct symbol, rb_node);
|
||||||
symbols__insert_by_name(symbols, pos);
|
symbols__insert_by_name(symbols, pos);
|
||||||
}
|
}
|
||||||
|
@ -431,7 +438,7 @@ int symbol__match_symbol_name(const char *name, const char *str,
|
||||||
return arch__compare_symbol_names(name, str);
|
return arch__compare_symbol_names(name, str);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct symbol *symbols__find_by_name(struct rb_root *symbols,
|
static struct symbol *symbols__find_by_name(struct rb_root_cached *symbols,
|
||||||
const char *name,
|
const char *name,
|
||||||
enum symbol_tag_include includes)
|
enum symbol_tag_include includes)
|
||||||
{
|
{
|
||||||
|
@ -441,7 +448,7 @@ static struct symbol *symbols__find_by_name(struct rb_root *symbols,
|
||||||
if (symbols == NULL)
|
if (symbols == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
n = symbols->rb_node;
|
n = symbols->rb_root.rb_node;
|
||||||
|
|
||||||
while (n) {
|
while (n) {
|
||||||
int cmp;
|
int cmp;
|
||||||
|
@ -644,7 +651,7 @@ static int map__process_kallsym_symbol(void *arg, const char *name,
|
||||||
{
|
{
|
||||||
struct symbol *sym;
|
struct symbol *sym;
|
||||||
struct dso *dso = arg;
|
struct dso *dso = arg;
|
||||||
struct rb_root *root = &dso->symbols;
|
struct rb_root_cached *root = &dso->symbols;
|
||||||
|
|
||||||
if (!symbol_type__filter(type))
|
if (!symbol_type__filter(type))
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -681,14 +688,14 @@ static int map_groups__split_kallsyms_for_kcore(struct map_groups *kmaps, struct
|
||||||
struct map *curr_map;
|
struct map *curr_map;
|
||||||
struct symbol *pos;
|
struct symbol *pos;
|
||||||
int count = 0;
|
int count = 0;
|
||||||
struct rb_root old_root = dso->symbols;
|
struct rb_root_cached old_root = dso->symbols;
|
||||||
struct rb_root *root = &dso->symbols;
|
struct rb_root_cached *root = &dso->symbols;
|
||||||
struct rb_node *next = rb_first(root);
|
struct rb_node *next = rb_first_cached(root);
|
||||||
|
|
||||||
if (!kmaps)
|
if (!kmaps)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
*root = RB_ROOT;
|
*root = RB_ROOT_CACHED;
|
||||||
|
|
||||||
while (next) {
|
while (next) {
|
||||||
char *module;
|
char *module;
|
||||||
|
@ -696,8 +703,8 @@ static int map_groups__split_kallsyms_for_kcore(struct map_groups *kmaps, struct
|
||||||
pos = rb_entry(next, struct symbol, rb_node);
|
pos = rb_entry(next, struct symbol, rb_node);
|
||||||
next = rb_next(&pos->rb_node);
|
next = rb_next(&pos->rb_node);
|
||||||
|
|
||||||
rb_erase_init(&pos->rb_node, &old_root);
|
rb_erase_cached(&pos->rb_node, &old_root);
|
||||||
|
RB_CLEAR_NODE(&pos->rb_node);
|
||||||
module = strchr(pos->name, '\t');
|
module = strchr(pos->name, '\t');
|
||||||
if (module)
|
if (module)
|
||||||
*module = '\0';
|
*module = '\0';
|
||||||
|
@ -734,8 +741,8 @@ static int map_groups__split_kallsyms(struct map_groups *kmaps, struct dso *dso,
|
||||||
struct map *curr_map = initial_map;
|
struct map *curr_map = initial_map;
|
||||||
struct symbol *pos;
|
struct symbol *pos;
|
||||||
int count = 0, moved = 0;
|
int count = 0, moved = 0;
|
||||||
struct rb_root *root = &dso->symbols;
|
struct rb_root_cached *root = &dso->symbols;
|
||||||
struct rb_node *next = rb_first(root);
|
struct rb_node *next = rb_first_cached(root);
|
||||||
int kernel_range = 0;
|
int kernel_range = 0;
|
||||||
bool x86_64;
|
bool x86_64;
|
||||||
|
|
||||||
|
@ -849,7 +856,7 @@ static int map_groups__split_kallsyms(struct map_groups *kmaps, struct dso *dso,
|
||||||
}
|
}
|
||||||
add_symbol:
|
add_symbol:
|
||||||
if (curr_map != initial_map) {
|
if (curr_map != initial_map) {
|
||||||
rb_erase(&pos->rb_node, root);
|
rb_erase_cached(&pos->rb_node, root);
|
||||||
symbols__insert(&curr_map->dso->symbols, pos);
|
symbols__insert(&curr_map->dso->symbols, pos);
|
||||||
++moved;
|
++moved;
|
||||||
} else
|
} else
|
||||||
|
@ -857,7 +864,7 @@ add_symbol:
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
discard_symbol:
|
discard_symbol:
|
||||||
rb_erase(&pos->rb_node, root);
|
rb_erase_cached(&pos->rb_node, root);
|
||||||
symbol__delete(pos);
|
symbol__delete(pos);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -68,7 +68,7 @@ struct symbol {
|
||||||
};
|
};
|
||||||
|
|
||||||
void symbol__delete(struct symbol *sym);
|
void symbol__delete(struct symbol *sym);
|
||||||
void symbols__delete(struct rb_root *symbols);
|
void symbols__delete(struct rb_root_cached *symbols);
|
||||||
|
|
||||||
/* symbols__for_each_entry - iterate over symbols (rb_root)
|
/* symbols__for_each_entry - iterate over symbols (rb_root)
|
||||||
*
|
*
|
||||||
|
@ -77,7 +77,7 @@ void symbols__delete(struct rb_root *symbols);
|
||||||
* @nd: the 'struct rb_node *' to use as a temporary storage
|
* @nd: the 'struct rb_node *' to use as a temporary storage
|
||||||
*/
|
*/
|
||||||
#define symbols__for_each_entry(symbols, pos, nd) \
|
#define symbols__for_each_entry(symbols, pos, nd) \
|
||||||
for (nd = rb_first(symbols); \
|
for (nd = rb_first_cached(symbols); \
|
||||||
nd && (pos = rb_entry(nd, struct symbol, rb_node)); \
|
nd && (pos = rb_entry(nd, struct symbol, rb_node)); \
|
||||||
nd = rb_next(nd))
|
nd = rb_next(nd))
|
||||||
|
|
||||||
|
@ -247,10 +247,11 @@ int dso__synthesize_plt_symbols(struct dso *dso, struct symsrc *ss);
|
||||||
|
|
||||||
char *dso__demangle_sym(struct dso *dso, int kmodule, const char *elf_name);
|
char *dso__demangle_sym(struct dso *dso, int kmodule, const char *elf_name);
|
||||||
|
|
||||||
void __symbols__insert(struct rb_root *symbols, struct symbol *sym, bool kernel);
|
void __symbols__insert(struct rb_root_cached *symbols, struct symbol *sym,
|
||||||
void symbols__insert(struct rb_root *symbols, struct symbol *sym);
|
bool kernel);
|
||||||
void symbols__fixup_duplicate(struct rb_root *symbols);
|
void symbols__insert(struct rb_root_cached *symbols, struct symbol *sym);
|
||||||
void symbols__fixup_end(struct rb_root *symbols);
|
void symbols__fixup_duplicate(struct rb_root_cached *symbols);
|
||||||
|
void symbols__fixup_end(struct rb_root_cached *symbols);
|
||||||
void map_groups__fixup_end(struct map_groups *mg);
|
void map_groups__fixup_end(struct map_groups *mg);
|
||||||
|
|
||||||
typedef int (*mapfn_t)(u64 start, u64 len, u64 pgoff, void *data);
|
typedef int (*mapfn_t)(u64 start, u64 len, u64 pgoff, void *data);
|
||||||
|
|
|
@ -65,7 +65,7 @@ size_t dso__fprintf_symbols_by_name(struct dso *dso,
|
||||||
struct rb_node *nd;
|
struct rb_node *nd;
|
||||||
struct symbol_name_rb_node *pos;
|
struct symbol_name_rb_node *pos;
|
||||||
|
|
||||||
for (nd = rb_first(&dso->symbol_names); nd; nd = rb_next(nd)) {
|
for (nd = rb_first_cached(&dso->symbol_names); nd; nd = rb_next(nd)) {
|
||||||
pos = rb_entry(nd, struct symbol_name_rb_node, rb_node);
|
pos = rb_entry(nd, struct symbol_name_rb_node, rb_node);
|
||||||
fprintf(fp, "%s\n", pos->sym.name);
|
fprintf(fp, "%s\n", pos->sym.name);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue