diff options
| author | Frederic Weisbecker <fweisbec@gmail.com> | 2013-05-02 17:37:49 +0200 | 
|---|---|---|
| committer | Frederic Weisbecker <fweisbec@gmail.com> | 2013-05-02 17:54:19 +0200 | 
| commit | c032862fba51a3ca504752d3a25186b324c5ce83 (patch) | |
| tree | 955dc2ba4ab3df76ecc2bb780ee84aca04967e8d /tools/perf/util/annotate.h | |
| parent | fda76e074c7737fc57855dd17c762e50ed526052 (diff) | |
| parent | 8700c95adb033843fc163d112b9d21d4fda78018 (diff) | |
| download | olio-linux-3.10-c032862fba51a3ca504752d3a25186b324c5ce83.tar.xz olio-linux-3.10-c032862fba51a3ca504752d3a25186b324c5ce83.zip  | |
Merge commit '8700c95adb03' into timers/nohz
The full dynticks tree needs the latest RCU and sched
upstream updates in order to fix some dependencies.
Merge a common upstream merge point that has these
updates.
Conflicts:
	include/linux/perf_event.h
	kernel/rcutree.h
	kernel/rcutree_plugin.h
Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com>
Diffstat (limited to 'tools/perf/util/annotate.h')
| -rw-r--r-- | tools/perf/util/annotate.h | 51 | 
1 files changed, 31 insertions, 20 deletions
diff --git a/tools/perf/util/annotate.h b/tools/perf/util/annotate.h index c422440fe61..af755156d27 100644 --- a/tools/perf/util/annotate.h +++ b/tools/perf/util/annotate.h @@ -50,6 +50,8 @@ bool ins__is_jump(const struct ins *ins);  bool ins__is_call(const struct ins *ins);  int ins__scnprintf(struct ins *ins, char *bf, size_t size, struct ins_operands *ops); +struct annotation; +  struct disasm_line {  	struct list_head    node;  	s64		    offset; @@ -68,17 +70,24 @@ void disasm_line__free(struct disasm_line *dl);  struct disasm_line *disasm__get_next_ip_line(struct list_head *head, struct disasm_line *pos);  int disasm_line__scnprintf(struct disasm_line *dl, char *bf, size_t size, bool raw);  size_t disasm__fprintf(struct list_head *head, FILE *fp); +double disasm__calc_percent(struct annotation *notes, int evidx, s64 offset, +			    s64 end, const char **path);  struct sym_hist {  	u64		sum;  	u64		addr[0];  }; -struct source_line { -	struct rb_node	node; +struct source_line_percent {  	double		percent;  	double		percent_sum; +}; + +struct source_line { +	struct rb_node	node;  	char		*path; +	int		nr_pcnt; +	struct source_line_percent p[1];  };  /** struct annotated_source - symbols with hits have this attached as in sannotation @@ -130,47 +139,49 @@ void symbol__annotate_zero_histograms(struct symbol *sym);  int symbol__annotate(struct symbol *sym, struct map *map, size_t privsize);  int symbol__annotate_init(struct map *map __maybe_unused, struct symbol *sym); -int symbol__annotate_printf(struct symbol *sym, struct map *map, int evidx, -			    bool full_paths, int min_pcnt, int max_lines, -			    int context); +int symbol__annotate_printf(struct symbol *sym, struct map *map, +			    struct perf_evsel *evsel, bool full_paths, +			    int min_pcnt, int max_lines, int context);  void symbol__annotate_zero_histogram(struct symbol *sym, int evidx);  void symbol__annotate_decay_histogram(struct symbol *sym, int evidx);  void disasm__purge(struct list_head *head); -int symbol__tty_annotate(struct symbol *sym, struct map *map, int evidx, -			 bool print_lines, bool full_paths, int min_pcnt, -			 int max_lines); +int symbol__tty_annotate(struct symbol *sym, struct map *map, +			 struct perf_evsel *evsel, bool print_lines, +			 bool full_paths, int min_pcnt, int max_lines); -#ifdef NEWT_SUPPORT -int symbol__tui_annotate(struct symbol *sym, struct map *map, int evidx, +#ifdef SLANG_SUPPORT +int symbol__tui_annotate(struct symbol *sym, struct map *map, +			 struct perf_evsel *evsel,  			 struct hist_browser_timer *hbt);  #else  static inline int symbol__tui_annotate(struct symbol *sym __maybe_unused, -				       struct map *map __maybe_unused, -				       int evidx __maybe_unused, -				       struct hist_browser_timer *hbt -				       __maybe_unused) +				struct map *map __maybe_unused, +				struct perf_evsel *evsel  __maybe_unused, +				struct hist_browser_timer *hbt +				__maybe_unused)  {  	return 0;  }  #endif  #ifdef GTK2_SUPPORT -int symbol__gtk_annotate(struct symbol *sym, struct map *map, int evidx, +int symbol__gtk_annotate(struct symbol *sym, struct map *map, +			 struct perf_evsel *evsel,  			 struct hist_browser_timer *hbt); -static inline int hist_entry__gtk_annotate(struct hist_entry *he, int evidx, +static inline int hist_entry__gtk_annotate(struct hist_entry *he, +					   struct perf_evsel *evsel,  					   struct hist_browser_timer *hbt)  { -	return symbol__gtk_annotate(he->ms.sym, he->ms.map, evidx, hbt); +	return symbol__gtk_annotate(he->ms.sym, he->ms.map, evsel, hbt);  }  void perf_gtk__show_annotations(void);  #else  static inline int hist_entry__gtk_annotate(struct hist_entry *he __maybe_unused, -					   int evidx __maybe_unused, -					   struct hist_browser_timer *hbt -					   __maybe_unused) +				struct perf_evsel *evsel __maybe_unused, +				struct hist_browser_timer *hbt __maybe_unused)  {  	return 0;  }  |