annotate.h 2.9 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
#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>

struct objdump_line {
	struct list_head node;
	s64		 offset;
	char		 *line;
};

void objdump_line__free(struct objdump_line *self);
struct objdump_line *objdump__get_next_ip_line(struct list_head *head,
					       struct objdump_line *pos);

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

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

31
/** struct annotated_source - symbols with hits have this attached as in sannotation
32 33
 *
 * @histogram: Array of addr hit histograms per event being monitored
34 35
 * @lines: If 'print_lines' is specified, per source code line percentages
 * @source: source parsed from objdump -dS
36
 *
37
 * lines is allocated, percentages calculated and all sorted by percentage
38 39 40 41 42
 * 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.
 */
43 44 45
struct annotated_source {
	struct list_head   source;
	struct source_line *lines;
46
	int    		   nr_histograms;
47
	int    		   sizeof_sym_hist;
48 49 50 51 52 53
	struct sym_hist	   histograms[0];
};

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

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

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

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

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

78 79 80
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,
81 82
			    bool full_paths, int min_pcnt, int max_lines,
			    int context);
83
void symbol__annotate_zero_histogram(struct symbol *sym, int evidx);
84
void symbol__annotate_decay_histogram(struct symbol *sym, int evidx);
85
void objdump_line_list__purge(struct list_head *head);
86

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

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

#endif	/* __PERF_ANNOTATE_H */