diff options
Diffstat (limited to 'tools/perf/ui/browsers/hists.c')
| -rw-r--r-- | tools/perf/ui/browsers/hists.c | 68 | 
1 files changed, 42 insertions, 26 deletions
| diff --git a/tools/perf/ui/browsers/hists.c b/tools/perf/ui/browsers/hists.c index a440e03cd8c2..b720b92eba6e 100644 --- a/tools/perf/ui/browsers/hists.c +++ b/tools/perf/ui/browsers/hists.c @@ -1267,10 +1267,8 @@ static inline void free_popup_options(char **options, int n)  {  	int i; -	for (i = 0; i < n; ++i) { -		free(options[i]); -		options[i] = NULL; -	} +	for (i = 0; i < n; ++i) +		zfree(&options[i]);  }  /* Check whether the browser is for 'top' or 'report' */ @@ -1329,7 +1327,7 @@ static int switch_data_file(void)  			abs_path[nr_options] = strdup(path);  			if (!abs_path[nr_options]) { -				free(options[nr_options]); +				zfree(&options[nr_options]);  				ui__warning("Can't search all data files due to memory shortage.\n");  				fclose(file);  				break; @@ -1400,6 +1398,36 @@ static int perf_evsel__hists_browse(struct perf_evsel *evsel, int nr_events,  	char script_opt[64];  	int delay_secs = hbt ? hbt->refresh : 0; +#define HIST_BROWSER_HELP_COMMON					\ +	"h/?/F1        Show this window\n"				\ +	"UP/DOWN/PGUP\n"						\ +	"PGDN/SPACE    Navigate\n"					\ +	"q/ESC/CTRL+C  Exit browser\n\n"				\ +	"For multiple event sessions:\n\n"				\ +	"TAB/UNTAB     Switch events\n\n"				\ +	"For symbolic views (--sort has sym):\n\n"			\ +	"->            Zoom into DSO/Threads & Annotate current symbol\n" \ +	"<-            Zoom out\n"					\ +	"a             Annotate current symbol\n"			\ +	"C             Collapse all callchains\n"			\ +	"d             Zoom into current DSO\n"				\ +	"E             Expand all callchains\n"				\ + +	/* help messages are sorted by lexical order of the hotkey */ +	const char report_help[] = HIST_BROWSER_HELP_COMMON +	"i             Show header information\n" +	"P             Print histograms to perf.hist.N\n" +	"r             Run available scripts\n" +	"s             Switch to another data file in PWD\n" +	"t             Zoom into current Thread\n" +	"V             Verbose (DSO names in callchains, etc)\n" +	"/             Filter symbol by name"; +	const char top_help[] = HIST_BROWSER_HELP_COMMON +	"P             Print histograms to perf.hist.N\n" +	"t             Zoom into current Thread\n" +	"V             Verbose (DSO names in callchains, etc)\n" +	"/             Filter symbol by name"; +  	if (browser == NULL)  		return -1; @@ -1484,29 +1512,16 @@ static int perf_evsel__hists_browse(struct perf_evsel *evsel, int nr_events,  			if (is_report_browser(hbt))  				goto do_data_switch;  			continue; +		case 'i': +			/* env->arch is NULL for live-mode (i.e. perf top) */ +			if (env->arch) +				tui__header_window(env); +			continue;  		case K_F1:  		case 'h':  		case '?':  			ui_browser__help_window(&browser->b, -					"h/?/F1        Show this window\n" -					"UP/DOWN/PGUP\n" -					"PGDN/SPACE    Navigate\n" -					"q/ESC/CTRL+C  Exit browser\n\n" -					"For multiple event sessions:\n\n" -					"TAB/UNTAB Switch events\n\n" -					"For symbolic views (--sort has sym):\n\n" -					"->            Zoom into DSO/Threads & Annotate current symbol\n" -					"<-            Zoom out\n" -					"a             Annotate current symbol\n" -					"C             Collapse all callchains\n" -					"E             Expand all callchains\n" -					"d             Zoom into current DSO\n" -					"t             Zoom into current Thread\n" -					"r             Run available scripts('perf report' only)\n" -					"s             Switch to another data file in PWD ('perf report' only)\n" -					"P             Print histograms to perf.hist.N\n" -					"V             Verbose (DSO names in callchains, etc)\n" -					"/             Filter symbol by name"); +				is_report_browser(hbt) ? report_help : top_help);  			continue;  		case K_ENTER:  		case K_RIGHT: @@ -1923,7 +1938,7 @@ static int __perf_evlist__tui_browse_hists(struct perf_evlist *evlist,  	ui_helpline__push("Press ESC to exit"); -	list_for_each_entry(pos, &evlist->entries, node) { +	evlist__for_each(evlist, pos) {  		const char *ev_name = perf_evsel__name(pos);  		size_t line_len = strlen(ev_name) + 7; @@ -1955,9 +1970,10 @@ single_entry:  		struct perf_evsel *pos;  		nr_entries = 0; -		list_for_each_entry(pos, &evlist->entries, node) +		evlist__for_each(evlist, pos) {  			if (perf_evsel__is_group_leader(pos))  				nr_entries++; +		}  		if (nr_entries == 1)  			goto single_entry; |