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/ui/gtk/annotate.c | |
| 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/ui/gtk/annotate.c')
| -rw-r--r-- | tools/perf/ui/gtk/annotate.c | 26 | 
1 files changed, 21 insertions, 5 deletions
diff --git a/tools/perf/ui/gtk/annotate.c b/tools/perf/ui/gtk/annotate.c index 7d8dc581a54..f538794615d 100644 --- a/tools/perf/ui/gtk/annotate.c +++ b/tools/perf/ui/gtk/annotate.c @@ -1,6 +1,7 @@  #include "gtk.h"  #include "util/debug.h"  #include "util/annotate.h" +#include "util/evsel.h"  #include "ui/helpline.h" @@ -32,7 +33,7 @@ static int perf_gtk__get_percent(char *buf, size_t size, struct symbol *sym,  		return 0;  	symhist = annotation__histogram(symbol__annotation(sym), evidx); -	if (!symhist->addr[dl->offset]) +	if (!symbol_conf.event_group && !symhist->addr[dl->offset])  		return 0;  	percent = 100.0 * symhist->addr[dl->offset] / symhist->sum; @@ -85,7 +86,7 @@ static int perf_gtk__get_line(char *buf, size_t size, struct disasm_line *dl)  }  static int perf_gtk__annotate_symbol(GtkWidget *window, struct symbol *sym, -				struct map *map, int evidx, +				struct map *map, struct perf_evsel *evsel,  				struct hist_browser_timer *hbt __maybe_unused)  {  	struct disasm_line *pos, *n; @@ -118,10 +119,24 @@ static int perf_gtk__annotate_symbol(GtkWidget *window, struct symbol *sym,  	list_for_each_entry(pos, ¬es->src->source, node) {  		GtkTreeIter iter; +		int ret = 0;  		gtk_list_store_append(store, &iter); -		if (perf_gtk__get_percent(s, sizeof(s), sym, pos, evidx)) +		if (perf_evsel__is_group_event(evsel)) { +			for (i = 0; i < evsel->nr_members; i++) { +				ret += perf_gtk__get_percent(s + ret, +							     sizeof(s) - ret, +							     sym, pos, +							     evsel->idx + i); +				ret += scnprintf(s + ret, sizeof(s) - ret, " "); +			} +		} else { +			ret = perf_gtk__get_percent(s, sizeof(s), sym, pos, +						    evsel->idx); +		} + +		if (ret)  			gtk_list_store_set(store, &iter, ANN_COL__PERCENT, s, -1);  		if (perf_gtk__get_offset(s, sizeof(s), sym, map, pos))  			gtk_list_store_set(store, &iter, ANN_COL__OFFSET, s, -1); @@ -139,7 +154,8 @@ static int perf_gtk__annotate_symbol(GtkWidget *window, struct symbol *sym,  	return 0;  } -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)  {  	GtkWidget *window; @@ -206,7 +222,7 @@ int symbol__gtk_annotate(struct symbol *sym, struct map *map, int evidx,  	gtk_notebook_append_page(GTK_NOTEBOOK(notebook), scrolled_window,  				 tab_label); -	perf_gtk__annotate_symbol(scrolled_window, sym, map, evidx, hbt); +	perf_gtk__annotate_symbol(scrolled_window, sym, map, evsel, hbt);  	return 0;  }  |