diff options
| author | André Fabian Silva Delgado <emulatorman@parabola.nu> | 2016-10-20 00:10:27 -0300 | 
|---|---|---|
| committer | André Fabian Silva Delgado <emulatorman@parabola.nu> | 2016-10-20 00:10:27 -0300 | 
| commit | d0b2f91bede3bd5e3d24dd6803e56eee959c1797 (patch) | |
| tree | 7fee4ab0509879c373c4f2cbd5b8a5be5b4041ee /tools/perf/arch/x86/util | |
| parent | e914f8eb445e8f74b00303c19c2ffceaedd16a05 (diff) | |
Linux-libre 4.8.2-gnupck-4.8.2-gnu
Diffstat (limited to 'tools/perf/arch/x86/util')
| -rw-r--r-- | tools/perf/arch/x86/util/Build | 3 | ||||
| -rw-r--r-- | tools/perf/arch/x86/util/auxtrace.c | 2 | ||||
| -rw-r--r-- | tools/perf/arch/x86/util/group.c | 27 | ||||
| -rw-r--r-- | tools/perf/arch/x86/util/intel-bts.c | 8 | ||||
| -rw-r--r-- | tools/perf/arch/x86/util/intel-pt.c | 10 | ||||
| -rw-r--r-- | tools/perf/arch/x86/util/tsc.c | 2 | ||||
| -rw-r--r-- | tools/perf/arch/x86/util/unwind-libunwind.c | 6 | 
7 files changed, 45 insertions, 13 deletions
| diff --git a/tools/perf/arch/x86/util/Build b/tools/perf/arch/x86/util/Build index 465970370..f95e6f46e 100644 --- a/tools/perf/arch/x86/util/Build +++ b/tools/perf/arch/x86/util/Build @@ -3,11 +3,12 @@ libperf-y += tsc.o  libperf-y += pmu.o  libperf-y += kvm-stat.o  libperf-y += perf_regs.o +libperf-y += group.o  libperf-$(CONFIG_DWARF) += dwarf-regs.o  libperf-$(CONFIG_BPF_PROLOGUE) += dwarf-regs.o -libperf-$(CONFIG_LIBUNWIND)          += unwind-libunwind.o +libperf-$(CONFIG_LOCAL_LIBUNWIND)    += unwind-libunwind.o  libperf-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o  libperf-$(CONFIG_AUXTRACE) += auxtrace.o diff --git a/tools/perf/arch/x86/util/auxtrace.c b/tools/perf/arch/x86/util/auxtrace.c index 7a7805583..cc1d865e3 100644 --- a/tools/perf/arch/x86/util/auxtrace.c +++ b/tools/perf/arch/x86/util/auxtrace.c @@ -37,7 +37,7 @@ struct auxtrace_record *auxtrace_record__init_intel(struct perf_evlist *evlist,  	intel_bts_pmu = perf_pmu__find(INTEL_BTS_PMU_NAME);  	if (evlist) { -		evlist__for_each(evlist, evsel) { +		evlist__for_each_entry(evlist, evsel) {  			if (intel_pt_pmu &&  			    evsel->attr.type == intel_pt_pmu->type)  				found_pt = true; diff --git a/tools/perf/arch/x86/util/group.c b/tools/perf/arch/x86/util/group.c new file mode 100644 index 000000000..37f92aa39 --- /dev/null +++ b/tools/perf/arch/x86/util/group.c @@ -0,0 +1,27 @@ +#include <stdio.h> +#include "api/fs/fs.h" +#include "util/group.h" + +/* + * Check whether we can use a group for top down. + * Without a group may get bad results due to multiplexing. + */ +bool arch_topdown_check_group(bool *warn) +{ +	int n; + +	if (sysctl__read_int("kernel/nmi_watchdog", &n) < 0) +		return false; +	if (n > 0) { +		*warn = true; +		return false; +	} +	return true; +} + +void arch_topdown_group_warn(void) +{ +	fprintf(stderr, +		"nmi_watchdog enabled with topdown. May give wrong results.\n" +		"Disable with echo 0 > /proc/sys/kernel/nmi_watchdog\n"); +} diff --git a/tools/perf/arch/x86/util/intel-bts.c b/tools/perf/arch/x86/util/intel-bts.c index 7dc30637c..5132775a0 100644 --- a/tools/perf/arch/x86/util/intel-bts.c +++ b/tools/perf/arch/x86/util/intel-bts.c @@ -124,7 +124,7 @@ static int intel_bts_recording_options(struct auxtrace_record *itr,  	btsr->evlist = evlist;  	btsr->snapshot_mode = opts->auxtrace_snapshot_mode; -	evlist__for_each(evlist, evsel) { +	evlist__for_each_entry(evlist, evsel) {  		if (evsel->attr.type == intel_bts_pmu->type) {  			if (intel_bts_evsel) {  				pr_err("There may be only one " INTEL_BTS_PMU_NAME " event\n"); @@ -327,7 +327,7 @@ static int intel_bts_snapshot_start(struct auxtrace_record *itr)  			container_of(itr, struct intel_bts_recording, itr);  	struct perf_evsel *evsel; -	evlist__for_each(btsr->evlist, evsel) { +	evlist__for_each_entry(btsr->evlist, evsel) {  		if (evsel->attr.type == btsr->intel_bts_pmu->type)  			return perf_evsel__disable(evsel);  	} @@ -340,7 +340,7 @@ static int intel_bts_snapshot_finish(struct auxtrace_record *itr)  			container_of(itr, struct intel_bts_recording, itr);  	struct perf_evsel *evsel; -	evlist__for_each(btsr->evlist, evsel) { +	evlist__for_each_entry(btsr->evlist, evsel) {  		if (evsel->attr.type == btsr->intel_bts_pmu->type)  			return perf_evsel__enable(evsel);  	} @@ -422,7 +422,7 @@ static int intel_bts_read_finish(struct auxtrace_record *itr, int idx)  			container_of(itr, struct intel_bts_recording, itr);  	struct perf_evsel *evsel; -	evlist__for_each(btsr->evlist, evsel) { +	evlist__for_each_entry(btsr->evlist, evsel) {  		if (evsel->attr.type == btsr->intel_bts_pmu->type)  			return perf_evlist__enable_event_idx(btsr->evlist,  							     evsel, idx); diff --git a/tools/perf/arch/x86/util/intel-pt.c b/tools/perf/arch/x86/util/intel-pt.c index 853b26d85..a2412e9d8 100644 --- a/tools/perf/arch/x86/util/intel-pt.c +++ b/tools/perf/arch/x86/util/intel-pt.c @@ -131,7 +131,7 @@ static int intel_pt_read_config(struct perf_pmu *intel_pt_pmu, const char *str,  	if (!mask)  		return -EINVAL; -	evlist__for_each(evlist, evsel) { +	evlist__for_each_entry(evlist, evsel) {  		if (evsel->attr.type == intel_pt_pmu->type) {  			*res = intel_pt_masked_bits(mask, evsel->attr.config);  			return 0; @@ -511,7 +511,7 @@ static int intel_pt_recording_options(struct auxtrace_record *itr,  	ptr->evlist = evlist;  	ptr->snapshot_mode = opts->auxtrace_snapshot_mode; -	evlist__for_each(evlist, evsel) { +	evlist__for_each_entry(evlist, evsel) {  		if (evsel->attr.type == intel_pt_pmu->type) {  			if (intel_pt_evsel) {  				pr_err("There may be only one " INTEL_PT_PMU_NAME " event\n"); @@ -729,7 +729,7 @@ static int intel_pt_snapshot_start(struct auxtrace_record *itr)  			container_of(itr, struct intel_pt_recording, itr);  	struct perf_evsel *evsel; -	evlist__for_each(ptr->evlist, evsel) { +	evlist__for_each_entry(ptr->evlist, evsel) {  		if (evsel->attr.type == ptr->intel_pt_pmu->type)  			return perf_evsel__disable(evsel);  	} @@ -742,7 +742,7 @@ static int intel_pt_snapshot_finish(struct auxtrace_record *itr)  			container_of(itr, struct intel_pt_recording, itr);  	struct perf_evsel *evsel; -	evlist__for_each(ptr->evlist, evsel) { +	evlist__for_each_entry(ptr->evlist, evsel) {  		if (evsel->attr.type == ptr->intel_pt_pmu->type)  			return perf_evsel__enable(evsel);  	} @@ -1015,7 +1015,7 @@ static int intel_pt_read_finish(struct auxtrace_record *itr, int idx)  			container_of(itr, struct intel_pt_recording, itr);  	struct perf_evsel *evsel; -	evlist__for_each(ptr->evlist, evsel) { +	evlist__for_each_entry(ptr->evlist, evsel) {  		if (evsel->attr.type == ptr->intel_pt_pmu->type)  			return perf_evlist__enable_event_idx(ptr->evlist, evsel,  							     idx); diff --git a/tools/perf/arch/x86/util/tsc.c b/tools/perf/arch/x86/util/tsc.c index 357f1b13b..2e5567c94 100644 --- a/tools/perf/arch/x86/util/tsc.c +++ b/tools/perf/arch/x86/util/tsc.c @@ -62,6 +62,8 @@ int perf_event__synth_time_conv(const struct perf_event_mmap_page *pc,  	struct perf_tsc_conversion tc;  	int err; +	if (!pc) +		return 0;  	err = perf_read_tsc_conversion(pc, &tc);  	if (err == -EOPNOTSUPP)  		return 0; diff --git a/tools/perf/arch/x86/util/unwind-libunwind.c b/tools/perf/arch/x86/util/unwind-libunwind.c index db25e93d9..4f16661cb 100644 --- a/tools/perf/arch/x86/util/unwind-libunwind.c +++ b/tools/perf/arch/x86/util/unwind-libunwind.c @@ -1,12 +1,14 @@ +#ifndef REMOTE_UNWIND_LIBUNWIND  #include <errno.h>  #include <libunwind.h>  #include "perf_regs.h"  #include "../../util/unwind.h"  #include "../../util/debug.h" +#endif  #ifdef HAVE_ARCH_X86_64_SUPPORT -int libunwind__arch_reg_id(int regnum) +int LIBUNWIND__ARCH_REG_ID(int regnum)  {  	int id; @@ -70,7 +72,7 @@ int libunwind__arch_reg_id(int regnum)  	return id;  }  #else -int libunwind__arch_reg_id(int regnum) +int LIBUNWIND__ARCH_REG_ID(int regnum)  {  	int id; | 
