diff options
Diffstat (limited to 'tools/perf')
| -rw-r--r-- | tools/perf/builtin-top.c | 38 |
1 files changed, 11 insertions, 27 deletions
diff --git a/tools/perf/builtin-top.c b/tools/perf/builtin-top.c index 6a5de90e9b83..b9a321fd184e 100644 --- a/tools/perf/builtin-top.c +++ b/tools/perf/builtin-top.c | |||
| @@ -451,9 +451,8 @@ static void print_sym_table(void) | |||
| 451 | struct sym_entry *syme, *n; | 451 | struct sym_entry *syme, *n; |
| 452 | struct rb_root tmp = RB_ROOT; | 452 | struct rb_root tmp = RB_ROOT; |
| 453 | struct rb_node *nd; | 453 | struct rb_node *nd; |
| 454 | int sym_width = 0, dso_width = 0; | 454 | int sym_width = 0, dso_width = 0, max_dso_width; |
| 455 | const int win_width = winsize.ws_col - 1; | 455 | const int win_width = winsize.ws_col - 1; |
| 456 | struct dso *unique_dso = NULL, *first_dso = NULL; | ||
| 457 | 456 | ||
| 458 | samples = userspace_samples = 0; | 457 | samples = userspace_samples = 0; |
| 459 | 458 | ||
| @@ -539,11 +538,6 @@ static void print_sym_table(void) | |||
| 539 | (int)syme->snap_count < count_filter) | 538 | (int)syme->snap_count < count_filter) |
| 540 | continue; | 539 | continue; |
| 541 | 540 | ||
| 542 | if (first_dso == NULL) | ||
| 543 | unique_dso = first_dso = syme->map->dso; | ||
| 544 | else if (syme->map->dso != first_dso) | ||
| 545 | unique_dso = NULL; | ||
| 546 | |||
| 547 | if (syme->map->dso->long_name_len > dso_width) | 541 | if (syme->map->dso->long_name_len > dso_width) |
| 548 | dso_width = syme->map->dso->long_name_len; | 542 | dso_width = syme->map->dso->long_name_len; |
| 549 | 543 | ||
| @@ -553,14 +547,10 @@ static void print_sym_table(void) | |||
| 553 | 547 | ||
| 554 | printed = 0; | 548 | printed = 0; |
| 555 | 549 | ||
| 556 | if (unique_dso) | 550 | max_dso_width = winsize.ws_col - sym_width - 29; |
| 557 | printf("DSO: %s\n", unique_dso->long_name); | 551 | if (dso_width > max_dso_width) |
| 558 | else { | 552 | dso_width = max_dso_width; |
| 559 | int max_dso_width = winsize.ws_col - sym_width - 29; | 553 | putchar('\n'); |
| 560 | if (dso_width > max_dso_width) | ||
| 561 | dso_width = max_dso_width; | ||
| 562 | putchar('\n'); | ||
| 563 | } | ||
| 564 | if (nr_counters == 1) | 554 | if (nr_counters == 1) |
| 565 | printf(" samples pcnt"); | 555 | printf(" samples pcnt"); |
| 566 | else | 556 | else |
| @@ -568,17 +558,13 @@ static void print_sym_table(void) | |||
| 568 | 558 | ||
| 569 | if (verbose) | 559 | if (verbose) |
| 570 | printf(" RIP "); | 560 | printf(" RIP "); |
| 571 | printf(" %-*.*s", sym_width, sym_width, "function"); | 561 | printf(" %-*.*s DSO\n", sym_width, sym_width, "function"); |
| 572 | if (!unique_dso) | ||
| 573 | printf(" DSO"); | ||
| 574 | putchar('\n'); | ||
| 575 | printf(" %s _______ _____", | 562 | printf(" %s _______ _____", |
| 576 | nr_counters == 1 ? " " : "______"); | 563 | nr_counters == 1 ? " " : "______"); |
| 577 | if (verbose) | 564 | if (verbose) |
| 578 | printf(" ________________"); | 565 | printf(" ________________"); |
| 579 | printf(" %-*.*s", sym_width, sym_width, graph_line); | 566 | printf(" %-*.*s", sym_width, sym_width, graph_line); |
| 580 | if (!unique_dso) | 567 | printf(" %-*.*s", dso_width, dso_width, graph_line); |
| 581 | printf(" %-*.*s", dso_width, dso_width, graph_line); | ||
| 582 | puts("\n"); | 568 | puts("\n"); |
| 583 | 569 | ||
| 584 | for (nd = rb_first(&tmp); nd; nd = rb_next(nd)) { | 570 | for (nd = rb_first(&tmp); nd; nd = rb_next(nd)) { |
| @@ -603,12 +589,10 @@ static void print_sym_table(void) | |||
| 603 | if (verbose) | 589 | if (verbose) |
| 604 | printf(" %016llx", sym->start); | 590 | printf(" %016llx", sym->start); |
| 605 | printf(" %-*.*s", sym_width, sym_width, sym->name); | 591 | printf(" %-*.*s", sym_width, sym_width, sym->name); |
| 606 | if (!unique_dso) | 592 | printf(" %-*.*s\n", dso_width, dso_width, |
| 607 | printf(" %-*.*s", dso_width, dso_width, | 593 | dso_width >= syme->map->dso->long_name_len ? |
| 608 | dso_width >= syme->map->dso->long_name_len ? | 594 | syme->map->dso->long_name : |
| 609 | syme->map->dso->long_name : | 595 | syme->map->dso->short_name); |
| 610 | syme->map->dso->short_name); | ||
| 611 | printf("\n"); | ||
| 612 | } | 596 | } |
| 613 | } | 597 | } |
| 614 | 598 | ||
