79406cd789
Configurable via symbol_conf.sort_by_name, so that the cost of an extra rb_node on all 'struct symbol' instances is not paid by tools that only want to decode addresses. How to use it: symbol_conf.sort_by_name = true; symbol_init(&symbol_conf); struct map *map = map_groups__find_by_name(kmaps, MAP__VARIABLE, "[kernel.kallsyms]"); if (map == NULL) { pr_err("couldn't find map!\n"); kernel_maps__fprintf(stdout); } else { struct symbol *sym = map__find_symbol_by_name(map, sym_filter, NULL); if (sym == NULL) pr_err("couldn't find symbol %s!\n", sym_filter); else pr_info("symbol %s: %#Lx-%#Lx \n", sym_filter, sym->start, sym->end); } Looking over the vmlinux/kallsyms is common enough that I'll add a variable to the upcoming struct perf_session to avoid the need to use map_groups__find_by_name to get the main vmlinux/kallsyms map. The above example looks on the 'variable' symtab, but it is just like that for the functions one. Also the sort operation is done when we first use map__find_symbol_by_name, in a lazy way. Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com> Cc: Frédéric Weisbecker <fweisbec@gmail.com> Cc: Masami Hiramatsu <mhiramat@redhat.com> Cc: Mike Galbraith <efault@gmx.de> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Paul Mackerras <paulus@samba.org> LKML-Reference: <1260564622-12392-1-git-send-email-acme@infradead.org> Signed-off-by: Ingo Molnar <mingo@elte.hu>
70 lines
2 KiB
C
70 lines
2 KiB
C
#ifndef __PERF_THREAD_H
|
|
#define __PERF_THREAD_H
|
|
|
|
#include <linux/rbtree.h>
|
|
#include <unistd.h>
|
|
#include "symbol.h"
|
|
|
|
struct map_groups {
|
|
struct rb_root maps[MAP__NR_TYPES];
|
|
struct list_head removed_maps[MAP__NR_TYPES];
|
|
bool use_modules;
|
|
};
|
|
|
|
struct thread {
|
|
struct rb_node rb_node;
|
|
struct map_groups mg;
|
|
pid_t pid;
|
|
char shortname[3];
|
|
char *comm;
|
|
int comm_len;
|
|
};
|
|
|
|
void map_groups__init(struct map_groups *self);
|
|
int thread__set_comm(struct thread *self, const char *comm);
|
|
int thread__comm_len(struct thread *self);
|
|
struct thread *threads__findnew(pid_t pid);
|
|
struct thread *register_idle_thread(void);
|
|
void thread__insert_map(struct thread *self, struct map *map);
|
|
int thread__fork(struct thread *self, struct thread *parent);
|
|
size_t map_groups__fprintf_maps(struct map_groups *self, FILE *fp);
|
|
size_t threads__fprintf(FILE *fp);
|
|
|
|
void maps__insert(struct rb_root *maps, struct map *map);
|
|
struct map *maps__find(struct rb_root *maps, u64 addr);
|
|
|
|
static inline void map_groups__insert(struct map_groups *self, struct map *map)
|
|
{
|
|
maps__insert(&self->maps[map->type], map);
|
|
}
|
|
|
|
static inline struct map *map_groups__find(struct map_groups *self,
|
|
enum map_type type, u64 addr)
|
|
{
|
|
return maps__find(&self->maps[type], addr);
|
|
}
|
|
|
|
static inline struct map *thread__find_map(struct thread *self,
|
|
enum map_type type, u64 addr)
|
|
{
|
|
return self ? map_groups__find(&self->mg, type, addr) : NULL;
|
|
}
|
|
|
|
void thread__find_addr_location(struct thread *self, u8 cpumode,
|
|
enum map_type type, u64 addr,
|
|
struct addr_location *al,
|
|
symbol_filter_t filter);
|
|
struct symbol *map_groups__find_symbol(struct map_groups *self,
|
|
enum map_type type, u64 addr,
|
|
symbol_filter_t filter);
|
|
|
|
static inline struct symbol *
|
|
map_groups__find_function(struct map_groups *self, u64 addr,
|
|
symbol_filter_t filter)
|
|
{
|
|
return map_groups__find_symbol(self, MAP__FUNCTION, addr, filter);
|
|
}
|
|
|
|
struct map *map_groups__find_by_name(struct map_groups *self,
|
|
enum map_type type, const char *name);
|
|
#endif /* __PERF_THREAD_H */
|