watchdog: Make the kthreads NUMA affine
[deliverable/linux.git] / tools / perf / util / symbol.h
CommitLineData
8b40f521
JK
1#ifndef __PERF_SYMBOL
2#define __PERF_SYMBOL 1
a2928c42
ACM
3
4#include <linux/types.h>
e4204992 5#include <stdbool.h>
5aab621b
ACM
6#include <stdint.h>
7#include "map.h"
5da50258 8#include <linux/list.h>
43cbcd8a 9#include <linux/rbtree.h>
5aab621b 10#include <stdio.h>
a2928c42 11
247648e3
ACM
12#ifdef HAVE_CPLUS_DEMANGLE
13extern char *cplus_demangle(const char *, int);
14
15static inline char *bfd_demangle(void __used *v, const char *c, int i)
16{
17 return cplus_demangle(c, i);
18}
19#else
20#ifdef NO_DEMANGLE
21static inline char *bfd_demangle(void __used *v, const char __used *c,
22 int __used i)
23{
24 return NULL;
25}
26#else
27#include <bfd.h>
28#endif
29#endif
30
5aab621b
ACM
31int hex2u64(const char *ptr, u64 *val);
32char *strxfrchar(char *s, char from, char to);
33
84087126
MR
34/*
35 * libelf 0.8.x and earlier do not support ELF_C_READ_MMAP;
36 * for newer versions we can use mmap to reduce memory usage:
37 */
38#ifdef LIBELF_NO_MMAP
39# define PERF_ELF_C_READ_MMAP ELF_C_READ
40#else
41# define PERF_ELF_C_READ_MMAP ELF_C_READ_MMAP
42#endif
43
247648e3
ACM
44#ifndef DMGL_PARAMS
45#define DMGL_PARAMS (1 << 0) /* Include function args */
46#define DMGL_ANSI (1 << 1) /* Include const, volatile, etc */
47#endif
48
5aab621b
ACM
49#define BUILD_ID_SIZE 20
50
171b3be9
ACM
51/** struct symbol - symtab entry
52 *
53 * @ignore - resolvable but tools ignore it (e.g. idle routines)
54 */
a2928c42
ACM
55struct symbol {
56 struct rb_node rb_node;
9cffa8d5
PM
57 u64 start;
58 u64 end;
fefb0b94 59 u16 namelen;
c408fedf 60 u8 binding;
171b3be9 61 bool ignore;
a2928c42
ACM
62 char name[0];
63};
64
aeafcbaf 65void symbol__delete(struct symbol *sym);
628ada0c 66
655000e7
ACM
67struct strlist;
68
b32d133a
ACM
69struct symbol_conf {
70 unsigned short priv_size;
71 bool try_vmlinux_path,
79406cd7 72 use_modules,
d599db3f
ACM
73 sort_by_name,
74 show_nr_samples,
75 use_callchain,
f7d87444 76 exclude_other,
85e00b55 77 show_cpu_utilization,
ec80fde7
ACM
78 initialized,
79 kptr_restrict;
c410a338 80 const char *vmlinux_name,
b226a5a7 81 *kallsyms_name,
9ed7e1b8 82 *source_prefix,
c410a338 83 *field_sep;
a1645ce1
ZY
84 const char *default_guest_vmlinux_name,
85 *default_guest_kallsyms,
86 *default_guest_modules;
87 const char *guestmount;
edb7c60e 88 const char *dso_list_str,
655000e7
ACM
89 *comm_list_str,
90 *sym_list_str,
91 *col_width_list_str;
92 struct strlist *dso_list,
93 *comm_list,
94 *sym_list;
ec5761ea 95 const char *symfs;
b32d133a
ACM
96};
97
75be6cf4 98extern struct symbol_conf symbol_conf;
00a192b3 99
aeafcbaf 100static inline void *symbol__priv(struct symbol *sym)
00a192b3 101{
aeafcbaf 102 return ((void *)sym) - symbol_conf.priv_size;
00a192b3
ACM
103}
104
9de89fe7
ACM
105struct ref_reloc_sym {
106 const char *name;
107 u64 addr;
108 u64 unrelocated_addr;
109};
110
59fd5306
ACM
111struct map_symbol {
112 struct map *map;
113 struct symbol *sym;
0f0cbf7a
ACM
114 bool unfolded;
115 bool has_children;
59fd5306
ACM
116};
117
1ed091c4
ACM
118struct addr_location {
119 struct thread *thread;
120 struct map *map;
121 struct symbol *sym;
122 u64 addr;
123 char level;
c410a338 124 bool filtered;
f60f3593
AS
125 u8 cpumode;
126 s32 cpu;
a1645ce1
ZY
127};
128
129enum dso_kernel_type {
130 DSO_TYPE_USER = 0,
131 DSO_TYPE_KERNEL,
132 DSO_TYPE_GUEST_KERNEL
1ed091c4
ACM
133};
134
a2928c42
ACM
135struct dso {
136 struct list_head node;
6a4694a4 137 struct rb_root symbols[MAP__NR_TYPES];
79406cd7 138 struct rb_root symbol_names[MAP__NR_TYPES];
6e406257 139 enum dso_kernel_type kernel;
8d06367f 140 u8 adjust_symbols:1;
8d06367f 141 u8 has_build_id:1;
88d3d9b7 142 u8 hit:1;
d06d92b7 143 u8 annotate_warned:1;
6e406257
ACM
144 u8 sname_alloc:1;
145 u8 lname_alloc:1;
878b439d 146 unsigned char symtab_type;
79406cd7 147 u8 sorted_by_name;
3610583c 148 u8 loaded;
8d06367f 149 u8 build_id[BUILD_ID_SIZE];
439d473b
ACM
150 const char *short_name;
151 char *long_name;
b63be8d7
ACM
152 u16 long_name_len;
153 u16 short_name_len;
a2928c42
ACM
154 char name[0];
155};
156
00a192b3 157struct dso *dso__new(const char *name);
aeafcbaf 158void dso__delete(struct dso *dso);
a2928c42 159
aeafcbaf 160int dso__name_len(const struct dso *dso);
8a6c5b26 161
aeafcbaf
ACM
162bool dso__loaded(const struct dso *dso, enum map_type type);
163bool dso__sorted_by_name(const struct dso *dso, enum map_type type);
79406cd7 164
aeafcbaf 165static inline void dso__set_loaded(struct dso *dso, enum map_type type)
8d92c02a 166{
aeafcbaf 167 dso->loaded |= (1 << type);
8d92c02a
ACM
168}
169
aeafcbaf 170void dso__sort_by_name(struct dso *dso, enum map_type type);
3610583c 171
a89e5abe
ACM
172struct dso *__dsos__findnew(struct list_head *head, const char *name);
173
aeafcbaf
ACM
174int dso__load(struct dso *dso, struct map *map, symbol_filter_t filter);
175int dso__load_vmlinux(struct dso *dso, struct map *map,
fd930ff9 176 const char *vmlinux, symbol_filter_t filter);
aeafcbaf 177int dso__load_vmlinux_path(struct dso *dso, struct map *map,
9de89fe7 178 symbol_filter_t filter);
aeafcbaf 179int dso__load_kallsyms(struct dso *dso, const char *filename, struct map *map,
9de89fe7 180 symbol_filter_t filter);
aeafcbaf 181int machine__load_kallsyms(struct machine *machine, const char *filename,
5c0541d5 182 enum map_type type, symbol_filter_t filter);
aeafcbaf 183int machine__load_vmlinux_path(struct machine *machine, enum map_type type,
5c0541d5
ACM
184 symbol_filter_t filter);
185
1f626bc3
ACM
186size_t __dsos__fprintf(struct list_head *head, FILE *fp);
187
aeafcbaf
ACM
188size_t machine__fprintf_dsos_buildid(struct machine *machine,
189 FILE *fp, bool with_hits);
190size_t machines__fprintf_dsos(struct rb_root *machines, FILE *fp);
191size_t machines__fprintf_dsos_buildid(struct rb_root *machines,
192 FILE *fp, bool with_hits);
193size_t dso__fprintf_buildid(struct dso *dso, FILE *fp);
194size_t dso__fprintf_symbols_by_name(struct dso *dso,
195 enum map_type type, FILE *fp);
196size_t dso__fprintf(struct dso *dso, enum map_type type, FILE *fp);
b0a9ab62 197
878b439d
ACM
198enum symtab_type {
199 SYMTAB__KALLSYMS = 0,
200 SYMTAB__GUEST_KALLSYMS,
201 SYMTAB__JAVA_JIT,
202 SYMTAB__BUILD_ID_CACHE,
203 SYMTAB__FEDORA_DEBUGINFO,
204 SYMTAB__UBUNTU_DEBUGINFO,
205 SYMTAB__BUILDID_DEBUGINFO,
206 SYMTAB__SYSTEM_PATH_DSO,
207 SYMTAB__GUEST_KMODULE,
208 SYMTAB__SYSTEM_PATH_KMODULE,
209 SYMTAB__NOT_FOUND,
b0a9ab62
ACM
210};
211
aeafcbaf
ACM
212char dso__symtab_origin(const struct dso *dso);
213void dso__set_long_name(struct dso *dso, char *name);
214void dso__set_build_id(struct dso *dso, void *build_id);
215void dso__read_running_kernel_build_id(struct dso *dso,
216 struct machine *machine);
217struct symbol *dso__find_symbol(struct dso *dso, enum map_type type,
218 u64 addr);
219struct symbol *dso__find_symbol_by_name(struct dso *dso, enum map_type type,
79406cd7 220 const char *name);
a2928c42 221
2643ce11 222int filename__read_build_id(const char *filename, void *bf, size_t size);
f1617b40 223int sysfs__read_build_id(const char *filename, void *bf, size_t size);
a1645ce1 224bool __dsos__read_build_ids(struct list_head *head, bool with_hits);
aeafcbaf 225int build_id__sprintf(const u8 *build_id, int len, char *bf);
9e201442
ACM
226int kallsyms__parse(const char *filename, void *arg,
227 int (*process_symbol)(void *arg, const char *name,
3b01a413 228 char type, u64 start, u64 end));
2643ce11 229
aeafcbaf
ACM
230void machine__destroy_kernel_maps(struct machine *machine);
231int __machine__create_kernel_maps(struct machine *machine, struct dso *kernel);
232int machine__create_kernel_maps(struct machine *machine);
5c0541d5 233
aeafcbaf
ACM
234int machines__create_kernel_maps(struct rb_root *machines, pid_t pid);
235int machines__create_guest_kernel_maps(struct rb_root *machines);
236void machines__destroy_guest_kernel_maps(struct rb_root *machines);
a1645ce1 237
75be6cf4 238int symbol__init(void);
d65a458b 239void symbol__exit(void);
36a3e646
ACM
240bool symbol_type__is_a(char symbol_type, enum map_type map_type);
241
aeafcbaf 242size_t machine__fprintf_vmlinux_path(struct machine *machine, FILE *fp);
b0a9ab62 243
8b40f521 244#endif /* __PERF_SYMBOL */
This page took 0.112601 seconds and 5 git commands to generate.