annotate.h 3.1 KB
Newer Older
1 2 3 4 5 6 7 8 9
#ifndef __PERF_ANNOTATE_H
#define __PERF_ANNOTATE_H

#include <stdbool.h>
#include "types.h"
#include "symbol.h"
#include <linux/list.h>
#include <linux/rbtree.h>

10
struct disasm_line {
11 12 13 14 15
	struct list_head node;
	s64		 offset;
	char		 *line;
};

16 17
void disasm_line__free(struct disasm_line *dl);
struct disasm_line *disasm__get_next_ip_line(struct list_head *head, struct disasm_line *pos);
18 19 20 21 22 23 24 25 26 27 28 29

struct sym_hist {
	u64		sum;
	u64		addr[0];
};

struct source_line {
	struct rb_node	node;
	double		percent;
	char		*path;
};

30
/** struct annotated_source - symbols with hits have this attached as in sannotation
31 32
 *
 * @histogram: Array of addr hit histograms per event being monitored
33
 * @lines: If 'print_lines' is specified, per source code line percentages
34
 * @source: source parsed from a disassembler like objdump -dS
35
 *
36
 * lines is allocated, percentages calculated and all sorted by percentage
37 38 39 40 41
 * when the annotation is about to be presented, so the percentages are for
 * one of the entries in the histogram array, i.e. for the event/counter being
 * presented. It is deallocated right after symbol__{tui,tty,etc}_annotate
 * returns.
 */
42 43 44
struct annotated_source {
	struct list_head   source;
	struct source_line *lines;
45
	int    		   nr_histograms;
46
	int    		   sizeof_sym_hist;
47 48 49 50 51 52
	struct sym_hist	   histograms[0];
};

struct annotation {
	pthread_mutex_t		lock;
	struct annotated_source *src;
53 54 55 56 57 58 59
};

struct sannotation {
	struct annotation annotation;
	struct symbol	  symbol;
};

60 61
static inline struct sym_hist *annotation__histogram(struct annotation *notes, int idx)
{
62 63
	return (((void *)&notes->src->histograms) +
	 	(notes->src->sizeof_sym_hist * idx));
64 65
}

66 67 68 69 70 71
static inline struct annotation *symbol__annotation(struct symbol *sym)
{
	struct sannotation *a = container_of(sym, struct sannotation, symbol);
	return &a->annotation;
}

72 73
int symbol__inc_addr_samples(struct symbol *sym, struct map *map,
			     int evidx, u64 addr);
74
int symbol__alloc_hist(struct symbol *sym);
75
void symbol__annotate_zero_histograms(struct symbol *sym);
76

77 78 79
int symbol__annotate(struct symbol *sym, struct map *map, size_t privsize);
int symbol__annotate_init(struct map *map __used, struct symbol *sym);
int symbol__annotate_printf(struct symbol *sym, struct map *map, int evidx,
80 81
			    bool full_paths, int min_pcnt, int max_lines,
			    int context);
82
void symbol__annotate_zero_histogram(struct symbol *sym, int evidx);
83
void symbol__annotate_decay_histogram(struct symbol *sym, int evidx);
84
void disasm__purge(struct list_head *head);
85

86
int symbol__tty_annotate(struct symbol *sym, struct map *map, int evidx,
87 88
			 bool print_lines, bool full_paths, int min_pcnt,
			 int max_lines);
89 90

#ifdef NO_NEWT_SUPPORT
B
Borislav Petkov 已提交
91
static inline int symbol__tui_annotate(struct symbol *sym __used,
92
				       struct map *map __used,
93 94 95
				       int evidx __used,
				       void(*timer)(void *arg) __used,
				       void *arg __used, int delay_secs __used)
96 97 98 99
{
	return 0;
}
#else
100
int symbol__tui_annotate(struct symbol *sym, struct map *map, int evidx,
101
			 void(*timer)(void *arg), void *arg, int delay_secs);
102 103
#endif

104 105
extern const char	*disassembler_style;

106
#endif	/* __PERF_ANNOTATE_H */