Commit f6b8436b authored by Namhyung Kim's avatar Namhyung Kim Committed by Arnaldo Carvalho de Melo

perf hists browser: Fix the number of entries for 'e' key

The 'e' key is to toggle expand/collapse the selected entry only.  But
the current code has a bug that it only increases the number of entries
by 1 in the hierarchy mode so users cannot move under the current entry
after the key stroke.  This is due to a wrong assumption in the
hist_entry__set_folding().

The commit b33f9226 ("perf hists browser: Put hist_entry folding
logic into single function") factored out the code, but actually it
should be handled separately.  The hist_browser__set_folding() is to
update fold state for each entry so it needs to traverse all (child)
entries regardless of the current fold state.  So it increases the
number of entries by 1.

But the hist_entry__set_folding() only cares the currently selected
entry and its all children.  So it should count all unfolded child
entries.  This code is implemented in hist_browser__toggle_fold()
already so we can just call it.

Fixes: b33f9226 ("perf hists browser: Put hist_entry folding logic into single function")
Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
Tested-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Ian Rogers <irogers@google.com>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: stable@vger.kernel.org
Link: https://lore.kernel.org/r/20230731094934.1616495-2-namhyung@kernel.orgSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent e2cabf2a
...@@ -407,11 +407,6 @@ static bool hist_browser__selection_has_children(struct hist_browser *browser) ...@@ -407,11 +407,6 @@ static bool hist_browser__selection_has_children(struct hist_browser *browser)
return container_of(ms, struct callchain_list, ms)->has_children; return container_of(ms, struct callchain_list, ms)->has_children;
} }
static bool hist_browser__he_selection_unfolded(struct hist_browser *browser)
{
return browser->he_selection ? browser->he_selection->unfolded : false;
}
static bool hist_browser__selection_unfolded(struct hist_browser *browser) static bool hist_browser__selection_unfolded(struct hist_browser *browser)
{ {
struct hist_entry *he = browser->he_selection; struct hist_entry *he = browser->he_selection;
...@@ -584,8 +579,8 @@ static int hierarchy_set_folding(struct hist_browser *hb, struct hist_entry *he, ...@@ -584,8 +579,8 @@ static int hierarchy_set_folding(struct hist_browser *hb, struct hist_entry *he,
return n; return n;
} }
static void __hist_entry__set_folding(struct hist_entry *he, static void hist_entry__set_folding(struct hist_entry *he,
struct hist_browser *hb, bool unfold) struct hist_browser *hb, bool unfold)
{ {
hist_entry__init_have_children(he); hist_entry__init_have_children(he);
he->unfolded = unfold ? he->has_children : false; he->unfolded = unfold ? he->has_children : false;
...@@ -603,34 +598,12 @@ static void __hist_entry__set_folding(struct hist_entry *he, ...@@ -603,34 +598,12 @@ static void __hist_entry__set_folding(struct hist_entry *he,
he->nr_rows = 0; he->nr_rows = 0;
} }
static void hist_entry__set_folding(struct hist_entry *he,
struct hist_browser *browser, bool unfold)
{
double percent;
percent = hist_entry__get_percent_limit(he);
if (he->filtered || percent < browser->min_pcnt)
return;
__hist_entry__set_folding(he, browser, unfold);
if (!he->depth || unfold)
browser->nr_hierarchy_entries++;
if (he->leaf)
browser->nr_callchain_rows += he->nr_rows;
else if (unfold && !hist_entry__has_hierarchy_children(he, browser->min_pcnt)) {
browser->nr_hierarchy_entries++;
he->has_no_entry = true;
he->nr_rows = 1;
} else
he->has_no_entry = false;
}
static void static void
__hist_browser__set_folding(struct hist_browser *browser, bool unfold) __hist_browser__set_folding(struct hist_browser *browser, bool unfold)
{ {
struct rb_node *nd; struct rb_node *nd;
struct hist_entry *he; struct hist_entry *he;
double percent;
nd = rb_first_cached(&browser->hists->entries); nd = rb_first_cached(&browser->hists->entries);
while (nd) { while (nd) {
...@@ -640,6 +613,21 @@ __hist_browser__set_folding(struct hist_browser *browser, bool unfold) ...@@ -640,6 +613,21 @@ __hist_browser__set_folding(struct hist_browser *browser, bool unfold)
nd = __rb_hierarchy_next(nd, HMD_FORCE_CHILD); nd = __rb_hierarchy_next(nd, HMD_FORCE_CHILD);
hist_entry__set_folding(he, browser, unfold); hist_entry__set_folding(he, browser, unfold);
percent = hist_entry__get_percent_limit(he);
if (he->filtered || percent < browser->min_pcnt)
continue;
if (!he->depth || unfold)
browser->nr_hierarchy_entries++;
if (he->leaf)
browser->nr_callchain_rows += he->nr_rows;
else if (unfold && !hist_entry__has_hierarchy_children(he, browser->min_pcnt)) {
browser->nr_hierarchy_entries++;
he->has_no_entry = true;
he->nr_rows = 1;
} else
he->has_no_entry = false;
} }
} }
...@@ -659,8 +647,10 @@ static void hist_browser__set_folding_selected(struct hist_browser *browser, boo ...@@ -659,8 +647,10 @@ static void hist_browser__set_folding_selected(struct hist_browser *browser, boo
if (!browser->he_selection) if (!browser->he_selection)
return; return;
hist_entry__set_folding(browser->he_selection, browser, unfold); if (unfold == browser->he_selection->unfolded)
browser->b.nr_entries = hist_browser__nr_entries(browser); return;
hist_browser__toggle_fold(browser);
} }
static void ui_browser__warn_lost_events(struct ui_browser *browser) static void ui_browser__warn_lost_events(struct ui_browser *browser)
...@@ -732,8 +722,8 @@ static int hist_browser__handle_hotkey(struct hist_browser *browser, bool warn_l ...@@ -732,8 +722,8 @@ static int hist_browser__handle_hotkey(struct hist_browser *browser, bool warn_l
hist_browser__set_folding(browser, true); hist_browser__set_folding(browser, true);
break; break;
case 'e': case 'e':
/* Expand the selected entry. */ /* Toggle expand/collapse the selected entry. */
hist_browser__set_folding_selected(browser, !hist_browser__he_selection_unfolded(browser)); hist_browser__toggle_fold(browser);
break; break;
case 'H': case 'H':
browser->show_headers = !browser->show_headers; browser->show_headers = !browser->show_headers;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment