diff options
| author | Thomas Gleixner <tglx@linutronix.de> | 2018-06-22 21:20:35 +0200 | 
|---|---|---|
| committer | Thomas Gleixner <tglx@linutronix.de> | 2018-06-22 21:20:35 +0200 | 
| commit | 7731b8bc94e599c9a79e428f3359ff2c34b7576a (patch) | |
| tree | 879f18ccbe274122f2d4f095b43cbc7f953e0ada /tools/perf/util/util.c | |
| parent | 48e315618dc4dc8904182cd221e3d395d5d97005 (diff) | |
| parent | 9ffc59d57228d74809700be6f7ecb1db10292f05 (diff) | |
Merge branch 'linus' into x86/urgent
Required to queue a dependent fix.
Diffstat (limited to 'tools/perf/util/util.c')
| -rw-r--r-- | tools/perf/util/util.c | 34 | 
1 files changed, 33 insertions, 1 deletions
diff --git a/tools/perf/util/util.c b/tools/perf/util/util.c index 1019bbc5dbd8..eac5b858a371 100644 --- a/tools/perf/util/util.c +++ b/tools/perf/util/util.c @@ -38,11 +38,43 @@ void perf_set_multithreaded(void)  }  unsigned int page_size; -int cacheline_size; + +#ifdef _SC_LEVEL1_DCACHE_LINESIZE +#define cache_line_size(cacheline_sizep) *cacheline_sizep = sysconf(_SC_LEVEL1_DCACHE_LINESIZE) +#else +static void cache_line_size(int *cacheline_sizep) +{ +	if (sysfs__read_int("devices/system/cpu/cpu0/cache/index0/coherency_line_size", cacheline_sizep)) +		pr_debug("cannot determine cache line size"); +} +#endif + +int cacheline_size(void) +{ +	static int size; + +	if (!size) +		cache_line_size(&size); + +	return size; +}  int sysctl_perf_event_max_stack = PERF_MAX_STACK_DEPTH;  int sysctl_perf_event_max_contexts_per_stack = PERF_MAX_CONTEXTS_PER_STACK; +int sysctl__max_stack(void) +{ +	int value; + +	if (sysctl__read_int("kernel/perf_event_max_stack", &value) == 0) +		sysctl_perf_event_max_stack = value; + +	if (sysctl__read_int("kernel/perf_event_max_contexts_per_stack", &value) == 0) +		sysctl_perf_event_max_contexts_per_stack = value; + +	return sysctl_perf_event_max_stack; +} +  bool test_attr__enabled;  bool perf_host  = true;  | 
