aboutsummaryrefslogtreecommitdiffstats
path: root/tools/perf/util/newt.c
diff options
context:
space:
mode:
Diffstat (limited to 'tools/perf/util/newt.c')
-rw-r--r--tools/perf/util/newt.c96
1 files changed, 68 insertions, 28 deletions
diff --git a/tools/perf/util/newt.c b/tools/perf/util/newt.c
index 6d6e022d7708..c0e71aacfc1b 100644
--- a/tools/perf/util/newt.c
+++ b/tools/perf/util/newt.c
@@ -411,7 +411,7 @@ static void hist_browser__delete(struct hist_browser *self)
411} 411}
412 412
413static int hist_browser__populate(struct hist_browser *self, struct rb_root *hists, 413static int hist_browser__populate(struct hist_browser *self, struct rb_root *hists,
414 u64 nr_hists, u64 session_total) 414 u64 nr_hists, u64 session_total, const char *title)
415{ 415{
416 int max_len = 0, idx, cols, rows; 416 int max_len = 0, idx, cols, rows;
417 struct ui_progress *progress; 417 struct ui_progress *progress;
@@ -476,7 +476,7 @@ static int hist_browser__populate(struct hist_browser *self, struct rb_root *his
476 newtListboxSetWidth(self->tree, max_len); 476 newtListboxSetWidth(self->tree, max_len);
477 477
478 newtCenteredWindow(max_len + (symbol_conf.use_callchain ? 5 : 0), 478 newtCenteredWindow(max_len + (symbol_conf.use_callchain ? 5 : 0),
479 rows - 5, "Report"); 479 rows - 5, title);
480 self->form = newt_form__new(); 480 self->form = newt_form__new();
481 if (self->form == NULL) 481 if (self->form == NULL)
482 return -1; 482 return -1;
@@ -495,7 +495,7 @@ enum hist_filter {
495 HIST_FILTER__THREAD, 495 HIST_FILTER__THREAD,
496}; 496};
497 497
498static u64 hists__filter_by_dso(struct rb_root *hists, struct dso *dso, 498static u64 hists__filter_by_dso(struct rb_root *hists, const struct dso *dso,
499 u64 *session_total) 499 u64 *session_total)
500{ 500{
501 struct rb_node *nd; 501 struct rb_node *nd;
@@ -560,25 +560,47 @@ out:
560 return *(struct thread **)(self->selection + 1); 560 return *(struct thread **)(self->selection + 1);
561} 561}
562 562
563static int hist_browser__title(char *bf, size_t size, const char *input_name,
564 const struct dso *dso, const struct thread *thread)
565{
566 int printed = 0;
567
568 if (thread)
569 printed += snprintf(bf + printed, size - printed,
570 "Thread: %s(%d)",
571 (thread->comm_set ? thread->comm : ""),
572 thread->pid);
573 if (dso)
574 printed += snprintf(bf + printed, size - printed,
575 "%sDSO: %s", thread ? " " : "",
576 dso->short_name);
577 return printed ?: snprintf(bf, size, "Report: %s", input_name);
578}
579
563int perf_session__browse_hists(struct rb_root *hists, u64 nr_hists, 580int perf_session__browse_hists(struct rb_root *hists, u64 nr_hists,
564 u64 session_total, const char *helpline, 581 u64 session_total, const char *helpline,
565 const char *input_name) 582 const char *input_name)
566{ 583{
584 struct hist_browser *browser = hist_browser__new();
585 const struct thread *thread_filter = NULL;
586 const struct dso *dso_filter = NULL;
567 struct newtExitStruct es; 587 struct newtExitStruct es;
568 bool dso_filtered = false, thread_filtered = false; 588 char msg[160];
569 int err = -1; 589 int err = -1;
570 struct hist_browser *browser = hist_browser__new();
571 590
572 if (browser == NULL) 591 if (browser == NULL)
573 return -1; 592 return -1;
574 593
575 newtPushHelpLine(helpline); 594 newtPushHelpLine(helpline);
576 595
577 if (hist_browser__populate(browser, hists, nr_hists, session_total) < 0) 596 hist_browser__title(msg, sizeof(msg), input_name,
597 dso_filter, thread_filter);
598 if (hist_browser__populate(browser, hists, nr_hists, session_total, msg) < 0)
578 goto out; 599 goto out;
579 600
580 while (1) { 601 while (1) {
581 const struct thread *thread; 602 const struct thread *thread;
603 const struct dso *dso;
582 char *options[16]; 604 char *options[16];
583 int nr_options = 0, choice = 0, i, 605 int nr_options = 0, choice = 0, i,
584 annotate = -2, zoom_dso = -2, zoom_thread = -2; 606 annotate = -2, zoom_dso = -2, zoom_thread = -2;
@@ -602,20 +624,21 @@ int perf_session__browse_hists(struct rb_root *hists, u64 nr_hists,
602 browser->selection->sym->name) > 0) 624 browser->selection->sym->name) > 0)
603 annotate = nr_options++; 625 annotate = nr_options++;
604 626
605 if (browser->selection->map != NULL &&
606 asprintf(&options[nr_options], "Zoom %s %s DSO",
607 dso_filtered ? "out of" : "into",
608 (browser->selection->map->dso->kernel ? "the Kernel" :
609 browser->selection->map->dso->short_name)) > 0)
610 zoom_dso = nr_options++;
611
612 thread = hist_browser__selected_thread(browser); 627 thread = hist_browser__selected_thread(browser);
613 if (thread != NULL && 628 if (thread != NULL &&
614 asprintf(&options[nr_options], "Zoom %s %s(%d) thread", 629 asprintf(&options[nr_options], "Zoom %s %s(%d) thread",
615 (thread_filtered ? "out of" : "into"), 630 (thread_filter ? "out of" : "into"),
616 (thread->comm_set ? thread->comm : ""), thread->pid) > 0) 631 (thread->comm_set ? thread->comm : ""),
632 thread->pid) > 0)
617 zoom_thread = nr_options++; 633 zoom_thread = nr_options++;
618 634
635 dso = browser->selection->map ? browser->selection->map->dso : NULL;
636 if (dso != NULL &&
637 asprintf(&options[nr_options], "Zoom %s %s DSO",
638 (dso_filter ? "out of" : "into"),
639 (dso->kernel ? "the Kernel" : dso->short_name)) > 0)
640 zoom_dso = nr_options++;
641
619 options[nr_options++] = (char *)"Exit"; 642 options[nr_options++] = (char *)"Exit";
620 643
621 choice = popup_menu(nr_options, options); 644 choice = popup_menu(nr_options, options);
@@ -637,22 +660,39 @@ do_annotate:
637 "kallsyms file"); 660 "kallsyms file");
638 continue; 661 continue;
639 } 662 }
640 map_symbol__annotate_browser(browser->selection, 663 map_symbol__annotate_browser(browser->selection, input_name);
641 input_name);
642 } else if (choice == zoom_dso) { 664 } else if (choice == zoom_dso) {
643 nr_hists = hists__filter_by_dso(hists, 665 if (dso_filter) {
644 (dso_filtered ? NULL : 666 newtPopHelpLine();
645 browser->selection->map->dso), 667 dso_filter = NULL;
646 &session_total); 668 } else {
647 dso_filtered = !dso_filtered; 669 snprintf(msg, sizeof(msg),
648 if (hist_browser__populate(browser, hists, nr_hists, session_total) < 0) 670 "To zoom out press -> + \"Zoom out of %s DSO\"",
671 dso->kernel ? "the Kernel" : dso->short_name);
672 newtPushHelpLine(msg);
673 dso_filter = dso;
674 }
675 nr_hists = hists__filter_by_dso(hists, dso_filter, &session_total);
676 hist_browser__title(msg, sizeof(msg), input_name,
677 dso_filter, thread_filter);
678 if (hist_browser__populate(browser, hists, nr_hists, session_total, msg) < 0)
649 goto out; 679 goto out;
650 } else if (choice == zoom_thread) { 680 } else if (choice == zoom_thread) {
651 nr_hists = hists__filter_by_thread(hists, 681 if (thread_filter) {
652 (thread_filtered ? NULL : thread), 682 newtPopHelpLine();
653 &session_total); 683 thread_filter = NULL;
654 thread_filtered = !thread_filtered; 684 } else {
655 if (hist_browser__populate(browser, hists, nr_hists, session_total) < 0) 685 snprintf(msg, sizeof(msg),
686 "To zoom out press -> + \"Zoom out of %s(%d) thread\"",
687 (thread->comm_set ? thread->comm : ""),
688 thread->pid);
689 newtPushHelpLine(msg);
690 thread_filter = thread;
691 }
692 nr_hists = hists__filter_by_thread(hists, thread_filter, &session_total);
693 hist_browser__title(msg, sizeof(msg), input_name,
694 dso_filter, thread_filter);
695 if (hist_browser__populate(browser, hists, nr_hists, session_total, msg) < 0)
656 goto out; 696 goto out;
657 } 697 }
658 } 698 }