map.h 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. #ifndef __PERF_MAP_H
  2. #define __PERF_MAP_H
  3. #include <linux/compiler.h>
  4. #include <linux/list.h>
  5. #include <linux/rbtree.h>
  6. #include <stdio.h>
  7. #include "types.h"
  8. enum map_type {
  9. MAP__FUNCTION = 0,
  10. MAP__VARIABLE,
  11. };
  12. #define MAP__NR_TYPES (MAP__VARIABLE + 1)
  13. extern const char *map_type__name[MAP__NR_TYPES];
  14. struct dso;
  15. struct ref_reloc_sym;
  16. struct map_groups;
  17. struct kernel_info;
  18. struct map {
  19. union {
  20. struct rb_node rb_node;
  21. struct list_head node;
  22. };
  23. u64 start;
  24. u64 end;
  25. enum map_type type;
  26. u64 pgoff;
  27. /* ip -> dso rip */
  28. u64 (*map_ip)(struct map *, u64);
  29. /* dso rip -> ip */
  30. u64 (*unmap_ip)(struct map *, u64);
  31. struct dso *dso;
  32. struct map_groups *groups;
  33. };
  34. struct kmap {
  35. struct ref_reloc_sym *ref_reloc_sym;
  36. struct map_groups *kmaps;
  37. };
  38. struct map_groups {
  39. struct rb_root maps[MAP__NR_TYPES];
  40. struct list_head removed_maps[MAP__NR_TYPES];
  41. struct kernel_info *this_kerninfo;
  42. };
  43. /* Native host kernel uses -1 as pid index in kernel_info */
  44. #define HOST_KERNEL_ID (-1)
  45. #define DEFAULT_GUEST_KERNEL_ID (0)
  46. struct kernel_info {
  47. struct rb_node rb_node;
  48. pid_t pid;
  49. char *root_dir;
  50. struct list_head dsos__user;
  51. struct list_head dsos__kernel;
  52. struct map_groups kmaps;
  53. struct map *vmlinux_maps[MAP__NR_TYPES];
  54. };
  55. static inline struct kmap *map__kmap(struct map *self)
  56. {
  57. return (struct kmap *)(self + 1);
  58. }
  59. static inline u64 map__map_ip(struct map *map, u64 ip)
  60. {
  61. return ip - map->start + map->pgoff;
  62. }
  63. static inline u64 map__unmap_ip(struct map *map, u64 ip)
  64. {
  65. return ip + map->start - map->pgoff;
  66. }
  67. static inline u64 identity__map_ip(struct map *map __used, u64 ip)
  68. {
  69. return ip;
  70. }
  71. /* rip/ip <-> addr suitable for passing to `objdump --start-address=` */
  72. u64 map__rip_2objdump(struct map *map, u64 rip);
  73. u64 map__objdump_2ip(struct map *map, u64 addr);
  74. struct symbol;
  75. typedef int (*symbol_filter_t)(struct map *map, struct symbol *sym);
  76. void map__init(struct map *self, enum map_type type,
  77. u64 start, u64 end, u64 pgoff, struct dso *dso);
  78. struct map *map__new(struct list_head *dsos__list, u64 start, u64 len,
  79. u64 pgoff, u32 pid, char *filename,
  80. enum map_type type, char *cwd, int cwdlen);
  81. void map__delete(struct map *self);
  82. struct map *map__clone(struct map *self);
  83. int map__overlap(struct map *l, struct map *r);
  84. size_t map__fprintf(struct map *self, FILE *fp);
  85. int map__load(struct map *self, symbol_filter_t filter);
  86. struct symbol *map__find_symbol(struct map *self,
  87. u64 addr, symbol_filter_t filter);
  88. struct symbol *map__find_symbol_by_name(struct map *self, const char *name,
  89. symbol_filter_t filter);
  90. void map__fixup_start(struct map *self);
  91. void map__fixup_end(struct map *self);
  92. void map__reloc_vmlinux(struct map *self);
  93. size_t __map_groups__fprintf_maps(struct map_groups *self,
  94. enum map_type type, int verbose, FILE *fp);
  95. void maps__insert(struct rb_root *maps, struct map *map);
  96. struct map *maps__find(struct rb_root *maps, u64 addr);
  97. void map_groups__init(struct map_groups *self);
  98. int map_groups__clone(struct map_groups *self,
  99. struct map_groups *parent, enum map_type type);
  100. size_t map_groups__fprintf(struct map_groups *self, int verbose, FILE *fp);
  101. size_t map_groups__fprintf_maps(struct map_groups *self, int verbose, FILE *fp);
  102. struct kernel_info *add_new_kernel_info(struct rb_root *kerninfo_root,
  103. pid_t pid, const char *root_dir);
  104. struct kernel_info *kerninfo__find(struct rb_root *kerninfo_root, pid_t pid);
  105. struct kernel_info *kerninfo__findnew(struct rb_root *kerninfo_root, pid_t pid);
  106. struct kernel_info *kerninfo__findhost(struct rb_root *kerninfo_root);
  107. char *kern_mmap_name(struct kernel_info *kerninfo, char *buff);
  108. /*
  109. * Default guest kernel is defined by parameter --guestkallsyms
  110. * and --guestmodules
  111. */
  112. static inline int is_default_guest(struct kernel_info *kerninfo)
  113. {
  114. if (!kerninfo)
  115. return 0;
  116. return kerninfo->pid == DEFAULT_GUEST_KERNEL_ID;
  117. }
  118. static inline int is_host_kernel(struct kernel_info *kerninfo)
  119. {
  120. if (!kerninfo)
  121. return 0;
  122. return kerninfo->pid == HOST_KERNEL_ID;
  123. }
  124. typedef void (*process_kernel_info)(struct kernel_info *kerninfo, void *data);
  125. void kerninfo__process_allkernels(struct rb_root *kerninfo_root,
  126. process_kernel_info process,
  127. void *data);
  128. static inline void map_groups__insert(struct map_groups *self, struct map *map)
  129. {
  130. maps__insert(&self->maps[map->type], map);
  131. map->groups = self;
  132. }
  133. static inline struct map *map_groups__find(struct map_groups *self,
  134. enum map_type type, u64 addr)
  135. {
  136. return maps__find(&self->maps[type], addr);
  137. }
  138. struct symbol *map_groups__find_symbol(struct map_groups *self,
  139. enum map_type type, u64 addr,
  140. struct map **mapp,
  141. symbol_filter_t filter);
  142. struct symbol *map_groups__find_symbol_by_name(struct map_groups *self,
  143. enum map_type type,
  144. const char *name,
  145. struct map **mapp,
  146. symbol_filter_t filter);
  147. static inline
  148. struct symbol *map_groups__find_function(struct map_groups *self, u64 addr,
  149. struct map **mapp, symbol_filter_t filter)
  150. {
  151. return map_groups__find_symbol(self, MAP__FUNCTION, addr, mapp, filter);
  152. }
  153. static inline
  154. struct symbol *map_groups__find_function_by_name(struct map_groups *self,
  155. const char *name, struct map **mapp,
  156. symbol_filter_t filter)
  157. {
  158. return map_groups__find_symbol_by_name(self, MAP__FUNCTION, name, mapp, filter);
  159. }
  160. int map_groups__fixup_overlappings(struct map_groups *self, struct map *map,
  161. int verbose, FILE *fp);
  162. struct map *map_groups__find_by_name(struct map_groups *self,
  163. enum map_type type, const char *name);
  164. struct map *map_groups__new_module(struct map_groups *self,
  165. u64 start,
  166. const char *filename,
  167. struct kernel_info *kerninfo);
  168. void map_groups__flush(struct map_groups *self);
  169. #endif /* __PERF_MAP_H */