Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751916AbdGRQTx (ORCPT ); Tue, 18 Jul 2017 12:19:53 -0400 Received: from mail-pg0-f48.google.com ([74.125.83.48]:32984 "EHLO mail-pg0-f48.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751406AbdGRQTv (ORCPT ); Tue, 18 Jul 2017 12:19:51 -0400 Date: Wed, 19 Jul 2017 01:18:57 +0900 From: Namhyung Kim To: Taeung Song Cc: Arnaldo Carvalho de Melo , linux-kernel@vger.kernel.org, Milian Wolff , Jiri Olsa , kernel-team@lge.com Subject: Re: [PATCH v2 8/9] perf annotate browser: Support the toggle number of samples with a 'e' hotkey Message-ID: <20170718161857.GB12241@danjae.aot.lge.com> References: <1499967976-15674-1-git-send-email-treeze.taeung@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <1499967976-15674-1-git-send-email-treeze.taeung@gmail.com> User-Agent: Mutt/1.8.2 (2017-04-18) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4068 Lines: 102 On Fri, Jul 14, 2017 at 02:46:16AM +0900, Taeung Song wrote: > Cc: Namhyung Kim > Cc: Milian Wolff > Cc: Jiri Olsa > Signed-off-by: Taeung Song Hmm.. IIUC there're 3 modes of annotation view: percent, period and sample, right? The existing 't' hotkey seems to toggle between percent and period. And you added 'e' for sample and percent, right? I'm not sure percent by sample and percent by period are both needed. If so, I think it's better to add a hotkey to toggle between percent and value (both for period and sample). And existing key should toggle between sample and period. If percent by sample is not meaningful, I'd rather make the hotkey to circulate through percent, period and sample. Thanks, Namhyung > --- > tools/perf/ui/browsers/annotate.c | 18 +++++++++++++++++- > 1 file changed, 17 insertions(+), 1 deletion(-) > > diff --git a/tools/perf/ui/browsers/annotate.c b/tools/perf/ui/browsers/annotate.c > index 34b3189..19173b1 100644 > --- a/tools/perf/ui/browsers/annotate.c > +++ b/tools/perf/ui/browsers/annotate.c > @@ -41,6 +41,7 @@ static struct annotate_browser_opt { > jump_arrows, > show_linenr, > show_nr_jumps, > + show_nr_samples, > show_total_period; > } annotate_browser__opts = { > .use_offset = true, > @@ -156,6 +157,9 @@ static void annotate_browser__write(struct ui_browser *browser, void *entry, int > if (annotate_browser__opts.show_total_period) { > ui_browser__printf(browser, "%10" PRIu64 " ", > bdl->samples[i].sample.period); > + } else if (annotate_browser__opts.show_nr_samples) { > + ui_browser__printf(browser, "%6" PRIu64 " ", > + bdl->samples[i].sample.nr_samples); > } else { > ui_browser__printf(browser, "%6.2f ", > bdl->samples[i].percent); > @@ -169,6 +173,8 @@ static void annotate_browser__write(struct ui_browser *browser, void *entry, int > else { > if (annotate_browser__opts.show_total_period) > ui_browser__printf(browser, "%*s", 11, "Event count"); > + else if (annotate_browser__opts.show_nr_samples) > + ui_browser__printf(browser, "%*s", 7, "Samples"); > else > ui_browser__printf(browser, "%*s", 7, "Percent"); > } > @@ -834,6 +840,7 @@ static int annotate_browser__run(struct annotate_browser *browser, > "o Toggle disassembler output/simplified view\n" > "s Toggle source code view\n" > "t Toggle total period view\n" > + "e Toggle number of samples\n" > "/ Search string\n" > "k Toggle line numbers\n" > "r Run available scripts\n" > @@ -914,6 +921,12 @@ static int annotate_browser__run(struct annotate_browser *browser, > !annotate_browser__opts.show_total_period; > annotate_browser__update_addr_width(browser); > continue; > + case 'e': > + annotate_browser__opts.show_total_period = false; > + annotate_browser__opts.show_nr_samples = > + !annotate_browser__opts.show_nr_samples; > + annotate_browser__update_addr_width(browser); > + continue; > case K_LEFT: > case K_ESC: > case 'q': > @@ -934,9 +947,11 @@ static int annotate_browser__run(struct annotate_browser *browser, > int map_symbol__tui_annotate(struct map_symbol *ms, struct perf_evsel *evsel, > struct hist_browser_timer *hbt) > { > - /* Set default value for show_total_period. */ > + /* Set default value for show_total_period and show_nr_samples */ > annotate_browser__opts.show_total_period = > symbol_conf.show_total_period; > + annotate_browser__opts.show_nr_samples = > + symbol_conf.show_nr_samples; > > return symbol__tui_annotate(ms->sym, ms->map, evsel, hbt); > } > @@ -1187,6 +1202,7 @@ static struct annotate_config { > ANNOTATE_CFG(jump_arrows), > ANNOTATE_CFG(show_linenr), > ANNOTATE_CFG(show_nr_jumps), > + ANNOTATE_CFG(show_nr_samples), > ANNOTATE_CFG(show_total_period), > ANNOTATE_CFG(use_offset), > }; > -- > 2.7.4 >