Re: [PATCH 2/2] perf top: Handle 'z' key for toggle zeroing samples in TUI

From: Stephane Eranian
Date: Wed Aug 13 2014 - 16:48:00 EST


On Wed, Aug 13, 2014 at 10:37 PM, Arnaldo Carvalho de Melo
<acme@xxxxxxxxxx> wrote:
>
> Em Wed, Aug 13, 2014 at 01:07:30AM +0200, Stephane Eranian escreveu:
> > On Tue, Aug 12, 2014 at 10:16 AM, Namhyung Kim <namhyung@xxxxxxxxxx> wrote:
> > > The perf top TUI lacks 'z' key support to toggle sample zeroing.
> > > Add it.
> > >
> > Works for me.
> > Tested-by: Stephane Eranian <eranian@xxxxxxxxxx>
>
> One thing that can be improved: Make it trigger a refresh in the right
> after 'z' is pressed.
>
> Also, this toggles the zeroing before each sample, it would be nice to
> have a visual cue that this is in effect, probably in the first line in
> the screen, perhaps on the far right, something like [z] when this is in
> effect and nothing when not.
>
I agree. Had to run a test on the side to verify that it was actually doing
the right thing.

>
> Right now the way to figure this out is to observe the number of
> samples, if it increases monotonically, zeroing before refresh is not in
> effect, if it goes from a high number to a smaller or vice versa,
> zeroing is in effect :-)
>
> Anyway, applied, people wanting this feature can figure this out, what I
> suggested is just polishing.
>
We need to visual cue.

>
> Thanks!
>
> - Arnaldo
>
> > > Reported-by: Stephane Eranian <eranian@xxxxxxxxxx>
> > > Signed-off-by: Namhyung Kim <namhyung@xxxxxxxxxx>
> > > ---
> > > tools/perf/ui/browsers/hists.c | 9 +++++++++
> > > 1 file changed, 9 insertions(+)
> > >
> > > diff --git a/tools/perf/ui/browsers/hists.c b/tools/perf/ui/browsers/hists.c
> > > index 045c1e16ac59..381c085a41b8 100644
> > > --- a/tools/perf/ui/browsers/hists.c
> > > +++ b/tools/perf/ui/browsers/hists.c
> > > @@ -10,6 +10,7 @@
> > > #include "../../util/pstack.h"
> > > #include "../../util/sort.h"
> > > #include "../../util/util.h"
> > > +#include "../../util/top.h"
> > > #include "../../arch/common.h"
> > >
> > > #include "../browser.h"
> > > @@ -1530,6 +1531,7 @@ static int perf_evsel__hists_browse(struct perf_evsel *evsel, int nr_events,
> > > "P Print histograms to perf.hist.N\n"
> > > "t Zoom into current Thread\n"
> > > "V Verbose (DSO names in callchains, etc)\n"
> > > + "z Toggle zeroing of samples\n"
> > > "/ Filter symbol by name";
> > >
> > > if (browser == NULL)
> > > @@ -1630,6 +1632,13 @@ static int perf_evsel__hists_browse(struct perf_evsel *evsel, int nr_events,
> > > case 'F':
> > > symbol_conf.filter_relative ^= 1;
> > > continue;
> > > + case 'z':
> > > + if (!is_report_browser(hbt)) {
> > > + struct perf_top *top = hbt->arg;
> > > +
> > > + top->zero = !top->zero;
> > > + }
> > > + continue;
> > > case K_F1:
> > > case 'h':
> > > case '?':
> > > --
> > > 2.0.0
> > >
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/