All of lore.kernel.org
 help / color / mirror / Atom feed
From: Arnaldo Carvalho de Melo <acme@kernel.org>
To: "liwei (GF)" <liwei391@huawei.com>
Cc: Jiri Olsa <jolsa@redhat.com>, Namhyung Kim <namhyung@kernel.org>,
	Mark Rutland <mark.rutland@arm.com>,
	Alexander Shishkin <alexander.shishkin@linux.intel.com>,
	linux-kernel <linux-kernel@vger.kernel.org>,
	Jin Yao <yao.jin@linux.intel.com>,
	Andi Kleen <ak@linux.intel.com>,
	guohanjun@huawei.com
Subject: Re: [PATCH] perf report TUI: Fix segmentation fault in perf_evsel__hists_browse()
Date: Fri, 3 Jul 2020 08:59:11 -0300	[thread overview]
Message-ID: <20200703115911.GE1320@kernel.org> (raw)
In-Reply-To: <48be67be-9b87-87a1-125a-bb7d0d027a57@huawei.com>

Em Fri, Jul 03, 2020 at 09:03:53AM +0800, liwei (GF) escreveu:
> Ping...

Thanks, applied and tested, added the Acked-by Jiri and Namhyung
provided,

- Arnaldo
 
> On 2020/6/12 23:19, Namhyung Kim wrote:
> > Hello,
> > 
> > On Fri, Jun 12, 2020 at 6:58 PM Wei Li <liwei391@huawei.com> wrote:
> >>
> >> The segmentation fault can be reproduced as following steps:
> >> 1) Executing perf report in tui.
> >> 2) Typing '/xxxxx' to filter the symbol to get nothing matched.
> >> 3) Pressing enter with no entry selected.
> >> Then it will report a segmentation fault.
> >>
> >> It is caused by the lack of check of browser->he_selection when
> >> accessing it's member res_samples in perf_evsel__hists_browse().
> >>
> >> These processes are meaningful for specified samples, so we can
> >> skip these when nothing is selected.
> >>
> >> Fixes: 4968ac8fb7c3 ("perf report: Implement browsing of individual samples")
> >> Signed-off-by: Wei Li <liwei391@huawei.com>
> > 
> > Acked-by: Namhyung Kim <namhyung@kernel.org>
> > 
> > Thanks
> > Namhyung
> > 
> > 
> >> ---
> >>  tools/perf/ui/browsers/hists.c | 17 +++++++++++------
> >>  1 file changed, 11 insertions(+), 6 deletions(-)
> >>
> >> diff --git a/tools/perf/ui/browsers/hists.c b/tools/perf/ui/browsers/hists.c
> >> index 487e54ef56a9..2101b6b770d8 100644
> >> --- a/tools/perf/ui/browsers/hists.c
> >> +++ b/tools/perf/ui/browsers/hists.c
> >> @@ -2288,6 +2288,11 @@ static struct thread *hist_browser__selected_thread(struct hist_browser *browser
> >>         return browser->he_selection->thread;
> >>  }
> >>
> >> +static struct res_sample *hist_browser__selected_res_sample(struct hist_browser *browser)
> >> +{
> >> +       return browser->he_selection ? browser->he_selection->res_samples : NULL;
> >> +}
> >> +
> >>  /* Check whether the browser is for 'top' or 'report' */
> >>  static inline bool is_report_browser(void *timer)
> >>  {
> >> @@ -3357,16 +3362,16 @@ static int perf_evsel__hists_browse(struct evsel *evsel, int nr_events,
> >>                                              &options[nr_options], NULL, NULL, evsel);
> >>                 nr_options += add_res_sample_opt(browser, &actions[nr_options],
> >>                                                  &options[nr_options],
> >> -                                hist_browser__selected_entry(browser)->res_samples,
> >> -                                evsel, A_NORMAL);
> >> +                                                hist_browser__selected_res_sample(browser),
> >> +                                                evsel, A_NORMAL);
> >>                 nr_options += add_res_sample_opt(browser, &actions[nr_options],
> >>                                                  &options[nr_options],
> >> -                                hist_browser__selected_entry(browser)->res_samples,
> >> -                                evsel, A_ASM);
> >> +                                                hist_browser__selected_res_sample(browser),
> >> +                                                evsel, A_ASM);
> >>                 nr_options += add_res_sample_opt(browser, &actions[nr_options],
> >>                                                  &options[nr_options],
> >> -                                hist_browser__selected_entry(browser)->res_samples,
> >> -                                evsel, A_SOURCE);
> >> +                                                hist_browser__selected_res_sample(browser),
> >> +                                                evsel, A_SOURCE);
> >>                 nr_options += add_switch_opt(browser, &actions[nr_options],
> >>                                              &options[nr_options]);
> >>  skip_scripting:
> >> --
> >> 2.17.1
> >>

-- 

- Arnaldo

  reply	other threads:[~2020-07-03 11:59 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-06-12  9:43 [PATCH] perf report TUI: Fix segmentation fault in perf_evsel__hists_browse() Wei Li
2020-06-12 15:19 ` Namhyung Kim
2020-07-03  1:03   ` liwei (GF)
2020-07-03 11:59     ` Arnaldo Carvalho de Melo [this message]
2020-07-03 11:10 ` Jiri Olsa

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20200703115911.GE1320@kernel.org \
    --to=acme@kernel.org \
    --cc=ak@linux.intel.com \
    --cc=alexander.shishkin@linux.intel.com \
    --cc=guohanjun@huawei.com \
    --cc=jolsa@redhat.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=liwei391@huawei.com \
    --cc=mark.rutland@arm.com \
    --cc=namhyung@kernel.org \
    --cc=yao.jin@linux.intel.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.