diff options
Diffstat (limited to 'tools/perf')
| -rw-r--r-- | tools/perf/MANIFEST | 8 | ||||
| -rw-r--r-- | tools/perf/Makefile.perf | 19 | ||||
| -rw-r--r-- | tools/perf/builtin-stat.c | 4 | ||||
| -rw-r--r-- | tools/perf/config/Makefile | 2 | ||||
| -rw-r--r-- | tools/perf/ui/browsers/hists.c | 2 | ||||
| -rw-r--r-- | tools/perf/util/Build | 4 | ||||
| -rw-r--r-- | tools/perf/util/auxtrace.c | 10 | ||||
| -rw-r--r-- | tools/perf/util/include/linux/rbtree.h | 16 | ||||
| -rw-r--r-- | tools/perf/util/include/linux/rbtree_augmented.h | 2 | ||||
| -rw-r--r-- | tools/perf/util/python-ext-sources | 4 | ||||
| -rw-r--r-- | tools/perf/util/stat-shadow.c | 8 | ||||
| -rw-r--r-- | tools/perf/util/symbol.c | 2 | ||||
| -rw-r--r-- | tools/perf/util/symbol.h | 3 | ||||
| -rw-r--r-- | tools/perf/util/thread_map.c | 3 | ||||
| -rw-r--r-- | tools/perf/util/vdso.c | 8 |
15 files changed, 44 insertions, 51 deletions
diff --git a/tools/perf/MANIFEST b/tools/perf/MANIFEST index fe50a1b34aa0..d01a0aad5a01 100644 --- a/tools/perf/MANIFEST +++ b/tools/perf/MANIFEST | |||
| @@ -18,6 +18,8 @@ tools/arch/x86/include/asm/atomic.h | |||
| 18 | tools/arch/x86/include/asm/rmwcc.h | 18 | tools/arch/x86/include/asm/rmwcc.h |
| 19 | tools/lib/traceevent | 19 | tools/lib/traceevent |
| 20 | tools/lib/api | 20 | tools/lib/api |
| 21 | tools/lib/hweight.c | ||
| 22 | tools/lib/rbtree.c | ||
| 21 | tools/lib/symbol/kallsyms.c | 23 | tools/lib/symbol/kallsyms.c |
| 22 | tools/lib/symbol/kallsyms.h | 24 | tools/lib/symbol/kallsyms.h |
| 23 | tools/lib/util/find_next_bit.c | 25 | tools/lib/util/find_next_bit.c |
| @@ -44,6 +46,8 @@ tools/include/linux/kernel.h | |||
| 44 | tools/include/linux/list.h | 46 | tools/include/linux/list.h |
| 45 | tools/include/linux/log2.h | 47 | tools/include/linux/log2.h |
| 46 | tools/include/linux/poison.h | 48 | tools/include/linux/poison.h |
| 49 | tools/include/linux/rbtree.h | ||
| 50 | tools/include/linux/rbtree_augmented.h | ||
| 47 | tools/include/linux/types.h | 51 | tools/include/linux/types.h |
| 48 | include/asm-generic/bitops/arch_hweight.h | 52 | include/asm-generic/bitops/arch_hweight.h |
| 49 | include/asm-generic/bitops/const_hweight.h | 53 | include/asm-generic/bitops/const_hweight.h |
| @@ -51,12 +55,9 @@ include/asm-generic/bitops/fls64.h | |||
| 51 | include/asm-generic/bitops/__fls.h | 55 | include/asm-generic/bitops/__fls.h |
| 52 | include/asm-generic/bitops/fls.h | 56 | include/asm-generic/bitops/fls.h |
| 53 | include/linux/perf_event.h | 57 | include/linux/perf_event.h |
| 54 | include/linux/rbtree.h | ||
| 55 | include/linux/list.h | 58 | include/linux/list.h |
| 56 | include/linux/hash.h | 59 | include/linux/hash.h |
| 57 | include/linux/stringify.h | 60 | include/linux/stringify.h |
| 58 | lib/hweight.c | ||
| 59 | lib/rbtree.c | ||
| 60 | include/linux/swab.h | 61 | include/linux/swab.h |
| 61 | arch/*/include/asm/unistd*.h | 62 | arch/*/include/asm/unistd*.h |
| 62 | arch/*/include/uapi/asm/unistd*.h | 63 | arch/*/include/uapi/asm/unistd*.h |
| @@ -65,7 +66,6 @@ arch/*/lib/memcpy*.S | |||
| 65 | arch/*/lib/memset*.S | 66 | arch/*/lib/memset*.S |
| 66 | include/linux/poison.h | 67 | include/linux/poison.h |
| 67 | include/linux/hw_breakpoint.h | 68 | include/linux/hw_breakpoint.h |
| 68 | include/linux/rbtree_augmented.h | ||
| 69 | include/uapi/linux/perf_event.h | 69 | include/uapi/linux/perf_event.h |
| 70 | include/uapi/linux/const.h | 70 | include/uapi/linux/const.h |
| 71 | include/uapi/linux/swab.h | 71 | include/uapi/linux/swab.h |
diff --git a/tools/perf/Makefile.perf b/tools/perf/Makefile.perf index 7a4b549214e3..bba34636b733 100644 --- a/tools/perf/Makefile.perf +++ b/tools/perf/Makefile.perf | |||
| @@ -109,9 +109,22 @@ $(OUTPUT)PERF-VERSION-FILE: ../../.git/HEAD | |||
| 109 | $(Q)$(SHELL_PATH) util/PERF-VERSION-GEN $(OUTPUT) | 109 | $(Q)$(SHELL_PATH) util/PERF-VERSION-GEN $(OUTPUT) |
| 110 | $(Q)touch $(OUTPUT)PERF-VERSION-FILE | 110 | $(Q)touch $(OUTPUT)PERF-VERSION-FILE |
| 111 | 111 | ||
| 112 | CC = $(CROSS_COMPILE)gcc | 112 | # Makefiles suck: This macro sets a default value of $(2) for the |
| 113 | LD ?= $(CROSS_COMPILE)ld | 113 | # variable named by $(1), unless the variable has been set by |
| 114 | AR = $(CROSS_COMPILE)ar | 114 | # environment or command line. This is necessary for CC and AR |
| 115 | # because make sets default values, so the simpler ?= approach | ||
| 116 | # won't work as expected. | ||
| 117 | define allow-override | ||
| 118 | $(if $(or $(findstring environment,$(origin $(1))),\ | ||
| 119 | $(findstring command line,$(origin $(1)))),,\ | ||
| 120 | $(eval $(1) = $(2))) | ||
| 121 | endef | ||
| 122 | |||
| 123 | # Allow setting CC and AR and LD, or setting CROSS_COMPILE as a prefix. | ||
| 124 | $(call allow-override,CC,$(CROSS_COMPILE)gcc) | ||
| 125 | $(call allow-override,AR,$(CROSS_COMPILE)ar) | ||
| 126 | $(call allow-override,LD,$(CROSS_COMPILE)ld) | ||
| 127 | |||
| 115 | PKG_CONFIG = $(CROSS_COMPILE)pkg-config | 128 | PKG_CONFIG = $(CROSS_COMPILE)pkg-config |
| 116 | 129 | ||
| 117 | RM = rm -f | 130 | RM = rm -f |
diff --git a/tools/perf/builtin-stat.c b/tools/perf/builtin-stat.c index 37e301a32f43..d99d850e1444 100644 --- a/tools/perf/builtin-stat.c +++ b/tools/perf/builtin-stat.c | |||
| @@ -343,7 +343,7 @@ static int read_counter(struct perf_evsel *counter) | |||
| 343 | return 0; | 343 | return 0; |
| 344 | } | 344 | } |
| 345 | 345 | ||
| 346 | static void read_counters(bool close) | 346 | static void read_counters(bool close_counters) |
| 347 | { | 347 | { |
| 348 | struct perf_evsel *counter; | 348 | struct perf_evsel *counter; |
| 349 | 349 | ||
| @@ -354,7 +354,7 @@ static void read_counters(bool close) | |||
| 354 | if (process_counter(counter)) | 354 | if (process_counter(counter)) |
| 355 | pr_warning("failed to process counter %s\n", counter->name); | 355 | pr_warning("failed to process counter %s\n", counter->name); |
| 356 | 356 | ||
| 357 | if (close) { | 357 | if (close_counters) { |
| 358 | perf_evsel__close_fd(counter, perf_evsel__nr_cpus(counter), | 358 | perf_evsel__close_fd(counter, perf_evsel__nr_cpus(counter), |
| 359 | thread_map__nr(evsel_list->threads)); | 359 | thread_map__nr(evsel_list->threads)); |
| 360 | } | 360 | } |
diff --git a/tools/perf/config/Makefile b/tools/perf/config/Makefile index 094ddaee104c..d31fac19c30b 100644 --- a/tools/perf/config/Makefile +++ b/tools/perf/config/Makefile | |||
| @@ -638,7 +638,7 @@ ifndef DESTDIR | |||
| 638 | prefix ?= $(HOME) | 638 | prefix ?= $(HOME) |
| 639 | endif | 639 | endif |
| 640 | bindir_relative = bin | 640 | bindir_relative = bin |
| 641 | bindir = $(prefix)/$(bindir_relative) | 641 | bindir = $(abspath $(prefix)/$(bindir_relative)) |
| 642 | mandir = share/man | 642 | mandir = share/man |
| 643 | infodir = share/info | 643 | infodir = share/info |
| 644 | perfexecdir = libexec/perf-core | 644 | perfexecdir = libexec/perf-core |
diff --git a/tools/perf/ui/browsers/hists.c b/tools/perf/ui/browsers/hists.c index 7629bef2fd79..fa67613976a8 100644 --- a/tools/perf/ui/browsers/hists.c +++ b/tools/perf/ui/browsers/hists.c | |||
| @@ -48,7 +48,7 @@ static struct rb_node *hists__filter_entries(struct rb_node *nd, | |||
| 48 | 48 | ||
| 49 | static bool hist_browser__has_filter(struct hist_browser *hb) | 49 | static bool hist_browser__has_filter(struct hist_browser *hb) |
| 50 | { | 50 | { |
| 51 | return hists__has_filter(hb->hists) || hb->min_pcnt; | 51 | return hists__has_filter(hb->hists) || hb->min_pcnt || symbol_conf.has_filter; |
| 52 | } | 52 | } |
| 53 | 53 | ||
| 54 | static int hist_browser__get_folding(struct hist_browser *browser) | 54 | static int hist_browser__get_folding(struct hist_browser *browser) |
diff --git a/tools/perf/util/Build b/tools/perf/util/Build index 586a59d46022..d2d318c59b37 100644 --- a/tools/perf/util/Build +++ b/tools/perf/util/Build | |||
| @@ -139,10 +139,10 @@ $(OUTPUT)util/find_next_bit.o: ../lib/util/find_next_bit.c FORCE | |||
| 139 | $(call rule_mkdir) | 139 | $(call rule_mkdir) |
| 140 | $(call if_changed_dep,cc_o_c) | 140 | $(call if_changed_dep,cc_o_c) |
| 141 | 141 | ||
| 142 | $(OUTPUT)util/rbtree.o: ../../lib/rbtree.c FORCE | 142 | $(OUTPUT)util/rbtree.o: ../lib/rbtree.c FORCE |
| 143 | $(call rule_mkdir) | 143 | $(call rule_mkdir) |
| 144 | $(call if_changed_dep,cc_o_c) | 144 | $(call if_changed_dep,cc_o_c) |
| 145 | 145 | ||
| 146 | $(OUTPUT)util/hweight.o: ../../lib/hweight.c FORCE | 146 | $(OUTPUT)util/hweight.o: ../lib/hweight.c FORCE |
| 147 | $(call rule_mkdir) | 147 | $(call rule_mkdir) |
| 148 | $(call if_changed_dep,cc_o_c) | 148 | $(call if_changed_dep,cc_o_c) |
diff --git a/tools/perf/util/auxtrace.c b/tools/perf/util/auxtrace.c index 7e7405c9b936..83d9dd96fe08 100644 --- a/tools/perf/util/auxtrace.c +++ b/tools/perf/util/auxtrace.c | |||
| @@ -53,11 +53,6 @@ int auxtrace_mmap__mmap(struct auxtrace_mmap *mm, | |||
| 53 | { | 53 | { |
| 54 | struct perf_event_mmap_page *pc = userpg; | 54 | struct perf_event_mmap_page *pc = userpg; |
| 55 | 55 | ||
| 56 | #if BITS_PER_LONG != 64 && !defined(HAVE_SYNC_COMPARE_AND_SWAP_SUPPORT) | ||
| 57 | pr_err("Cannot use AUX area tracing mmaps\n"); | ||
| 58 | return -1; | ||
| 59 | #endif | ||
| 60 | |||
| 61 | WARN_ONCE(mm->base, "Uninitialized auxtrace_mmap\n"); | 56 | WARN_ONCE(mm->base, "Uninitialized auxtrace_mmap\n"); |
| 62 | 57 | ||
| 63 | mm->userpg = userpg; | 58 | mm->userpg = userpg; |
| @@ -73,6 +68,11 @@ int auxtrace_mmap__mmap(struct auxtrace_mmap *mm, | |||
| 73 | return 0; | 68 | return 0; |
| 74 | } | 69 | } |
| 75 | 70 | ||
| 71 | #if BITS_PER_LONG != 64 && !defined(HAVE_SYNC_COMPARE_AND_SWAP_SUPPORT) | ||
| 72 | pr_err("Cannot use AUX area tracing mmaps\n"); | ||
| 73 | return -1; | ||
| 74 | #endif | ||
| 75 | |||
| 76 | pc->aux_offset = mp->offset; | 76 | pc->aux_offset = mp->offset; |
| 77 | pc->aux_size = mp->len; | 77 | pc->aux_size = mp->len; |
| 78 | 78 | ||
diff --git a/tools/perf/util/include/linux/rbtree.h b/tools/perf/util/include/linux/rbtree.h deleted file mode 100644 index f06d89f0b867..000000000000 --- a/tools/perf/util/include/linux/rbtree.h +++ /dev/null | |||
| @@ -1,16 +0,0 @@ | |||
| 1 | #ifndef __TOOLS_LINUX_PERF_RBTREE_H | ||
| 2 | #define __TOOLS_LINUX_PERF_RBTREE_H | ||
| 3 | #include <stdbool.h> | ||
| 4 | #include "../../../../include/linux/rbtree.h" | ||
| 5 | |||
| 6 | /* | ||
| 7 | * Handy for checking that we are not deleting an entry that is | ||
| 8 | * already in a list, found in block/{blk-throttle,cfq-iosched}.c, | ||
| 9 | * probably should be moved to lib/rbtree.c... | ||
| 10 | */ | ||
| 11 | static inline void rb_erase_init(struct rb_node *n, struct rb_root *root) | ||
| 12 | { | ||
| 13 | rb_erase(n, root); | ||
| 14 | RB_CLEAR_NODE(n); | ||
| 15 | } | ||
| 16 | #endif /* __TOOLS_LINUX_PERF_RBTREE_H */ | ||
diff --git a/tools/perf/util/include/linux/rbtree_augmented.h b/tools/perf/util/include/linux/rbtree_augmented.h deleted file mode 100644 index 9d6fcdf1788b..000000000000 --- a/tools/perf/util/include/linux/rbtree_augmented.h +++ /dev/null | |||
| @@ -1,2 +0,0 @@ | |||
| 1 | #include <stdbool.h> | ||
| 2 | #include "../../../../include/linux/rbtree_augmented.h" | ||
diff --git a/tools/perf/util/python-ext-sources b/tools/perf/util/python-ext-sources index e23ded40c79e..0766d98c5da5 100644 --- a/tools/perf/util/python-ext-sources +++ b/tools/perf/util/python-ext-sources | |||
| @@ -10,7 +10,7 @@ util/ctype.c | |||
| 10 | util/evlist.c | 10 | util/evlist.c |
| 11 | util/evsel.c | 11 | util/evsel.c |
| 12 | util/cpumap.c | 12 | util/cpumap.c |
| 13 | ../../lib/hweight.c | 13 | ../lib/hweight.c |
| 14 | util/thread_map.c | 14 | util/thread_map.c |
| 15 | util/util.c | 15 | util/util.c |
| 16 | util/xyarray.c | 16 | util/xyarray.c |
| @@ -19,5 +19,5 @@ util/rblist.c | |||
| 19 | util/stat.c | 19 | util/stat.c |
| 20 | util/strlist.c | 20 | util/strlist.c |
| 21 | util/trace-event.c | 21 | util/trace-event.c |
| 22 | ../../lib/rbtree.c | 22 | ../lib/rbtree.c |
| 23 | util/string.c | 23 | util/string.c |
diff --git a/tools/perf/util/stat-shadow.c b/tools/perf/util/stat-shadow.c index 53e8bb7bc852..2a5d8d7698ae 100644 --- a/tools/perf/util/stat-shadow.c +++ b/tools/perf/util/stat-shadow.c | |||
| @@ -85,7 +85,7 @@ void perf_stat__update_shadow_stats(struct perf_evsel *counter, u64 *count, | |||
| 85 | else if (perf_evsel__match(counter, HARDWARE, HW_CPU_CYCLES)) | 85 | else if (perf_evsel__match(counter, HARDWARE, HW_CPU_CYCLES)) |
| 86 | update_stats(&runtime_cycles_stats[ctx][cpu], count[0]); | 86 | update_stats(&runtime_cycles_stats[ctx][cpu], count[0]); |
| 87 | else if (perf_stat_evsel__is(counter, CYCLES_IN_TX)) | 87 | else if (perf_stat_evsel__is(counter, CYCLES_IN_TX)) |
| 88 | update_stats(&runtime_transaction_stats[ctx][cpu], count[0]); | 88 | update_stats(&runtime_cycles_in_tx_stats[ctx][cpu], count[0]); |
| 89 | else if (perf_stat_evsel__is(counter, TRANSACTION_START)) | 89 | else if (perf_stat_evsel__is(counter, TRANSACTION_START)) |
| 90 | update_stats(&runtime_transaction_stats[ctx][cpu], count[0]); | 90 | update_stats(&runtime_transaction_stats[ctx][cpu], count[0]); |
| 91 | else if (perf_stat_evsel__is(counter, ELISION_START)) | 91 | else if (perf_stat_evsel__is(counter, ELISION_START)) |
| @@ -398,20 +398,18 @@ void perf_stat__print_shadow_stats(FILE *out, struct perf_evsel *evsel, | |||
| 398 | " # %5.2f%% aborted cycles ", | 398 | " # %5.2f%% aborted cycles ", |
| 399 | 100.0 * ((total2-avg) / total)); | 399 | 100.0 * ((total2-avg) / total)); |
| 400 | } else if (perf_stat_evsel__is(evsel, TRANSACTION_START) && | 400 | } else if (perf_stat_evsel__is(evsel, TRANSACTION_START) && |
| 401 | avg > 0 && | ||
| 402 | runtime_cycles_in_tx_stats[ctx][cpu].n != 0) { | 401 | runtime_cycles_in_tx_stats[ctx][cpu].n != 0) { |
| 403 | total = avg_stats(&runtime_cycles_in_tx_stats[ctx][cpu]); | 402 | total = avg_stats(&runtime_cycles_in_tx_stats[ctx][cpu]); |
| 404 | 403 | ||
| 405 | if (total) | 404 | if (avg) |
| 406 | ratio = total / avg; | 405 | ratio = total / avg; |
| 407 | 406 | ||
| 408 | fprintf(out, " # %8.0f cycles / transaction ", ratio); | 407 | fprintf(out, " # %8.0f cycles / transaction ", ratio); |
| 409 | } else if (perf_stat_evsel__is(evsel, ELISION_START) && | 408 | } else if (perf_stat_evsel__is(evsel, ELISION_START) && |
| 410 | avg > 0 && | ||
| 411 | runtime_cycles_in_tx_stats[ctx][cpu].n != 0) { | 409 | runtime_cycles_in_tx_stats[ctx][cpu].n != 0) { |
| 412 | total = avg_stats(&runtime_cycles_in_tx_stats[ctx][cpu]); | 410 | total = avg_stats(&runtime_cycles_in_tx_stats[ctx][cpu]); |
| 413 | 411 | ||
| 414 | if (total) | 412 | if (avg) |
| 415 | ratio = total / avg; | 413 | ratio = total / avg; |
| 416 | 414 | ||
| 417 | fprintf(out, " # %8.0f cycles / elision ", ratio); | 415 | fprintf(out, " # %8.0f cycles / elision ", ratio); |
diff --git a/tools/perf/util/symbol.c b/tools/perf/util/symbol.c index 48b588c6951a..60f11414bb5c 100644 --- a/tools/perf/util/symbol.c +++ b/tools/perf/util/symbol.c | |||
| @@ -1911,6 +1911,8 @@ int setup_list(struct strlist **list, const char *list_str, | |||
| 1911 | pr_err("problems parsing %s list\n", list_name); | 1911 | pr_err("problems parsing %s list\n", list_name); |
| 1912 | return -1; | 1912 | return -1; |
| 1913 | } | 1913 | } |
| 1914 | |||
| 1915 | symbol_conf.has_filter = true; | ||
| 1914 | return 0; | 1916 | return 0; |
| 1915 | } | 1917 | } |
| 1916 | 1918 | ||
diff --git a/tools/perf/util/symbol.h b/tools/perf/util/symbol.h index bef47ead1d9b..b98ce51af142 100644 --- a/tools/perf/util/symbol.h +++ b/tools/perf/util/symbol.h | |||
| @@ -105,7 +105,8 @@ struct symbol_conf { | |||
| 105 | demangle_kernel, | 105 | demangle_kernel, |
| 106 | filter_relative, | 106 | filter_relative, |
| 107 | show_hist_headers, | 107 | show_hist_headers, |
| 108 | branch_callstack; | 108 | branch_callstack, |
| 109 | has_filter; | ||
| 109 | const char *vmlinux_name, | 110 | const char *vmlinux_name, |
| 110 | *kallsyms_name, | 111 | *kallsyms_name, |
| 111 | *source_prefix, | 112 | *source_prefix, |
diff --git a/tools/perf/util/thread_map.c b/tools/perf/util/thread_map.c index da7646d767fe..292ae2c90e06 100644 --- a/tools/perf/util/thread_map.c +++ b/tools/perf/util/thread_map.c | |||
| @@ -136,8 +136,7 @@ struct thread_map *thread_map__new_by_uid(uid_t uid) | |||
| 136 | if (grow) { | 136 | if (grow) { |
| 137 | struct thread_map *tmp; | 137 | struct thread_map *tmp; |
| 138 | 138 | ||
| 139 | tmp = realloc(threads, (sizeof(*threads) + | 139 | tmp = thread_map__realloc(threads, max_threads); |
| 140 | max_threads * sizeof(pid_t))); | ||
| 141 | if (tmp == NULL) | 140 | if (tmp == NULL) |
| 142 | goto out_free_namelist; | 141 | goto out_free_namelist; |
| 143 | 142 | ||
diff --git a/tools/perf/util/vdso.c b/tools/perf/util/vdso.c index 4b89118f158d..44d440da15dc 100644 --- a/tools/perf/util/vdso.c +++ b/tools/perf/util/vdso.c | |||
| @@ -236,18 +236,16 @@ static struct dso *__machine__findnew_compat(struct machine *machine, | |||
| 236 | const char *file_name; | 236 | const char *file_name; |
| 237 | struct dso *dso; | 237 | struct dso *dso; |
| 238 | 238 | ||
| 239 | pthread_rwlock_wrlock(&machine->dsos.lock); | ||
| 240 | dso = __dsos__find(&machine->dsos, vdso_file->dso_name, true); | 239 | dso = __dsos__find(&machine->dsos, vdso_file->dso_name, true); |
| 241 | if (dso) | 240 | if (dso) |
| 242 | goto out_unlock; | 241 | goto out; |
| 243 | 242 | ||
| 244 | file_name = vdso__get_compat_file(vdso_file); | 243 | file_name = vdso__get_compat_file(vdso_file); |
| 245 | if (!file_name) | 244 | if (!file_name) |
| 246 | goto out_unlock; | 245 | goto out; |
| 247 | 246 | ||
| 248 | dso = __machine__addnew_vdso(machine, vdso_file->dso_name, file_name); | 247 | dso = __machine__addnew_vdso(machine, vdso_file->dso_name, file_name); |
| 249 | out_unlock: | 248 | out: |
| 250 | pthread_rwlock_unlock(&machine->dsos.lock); | ||
| 251 | return dso; | 249 | return dso; |
| 252 | } | 250 | } |
| 253 | 251 | ||
