mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-11-27 01:11:31 +00:00
perf tools: Fallback to reading sysfs to get cacheline size
On systems where sysconf(_SC_LEVEL1_DCACHE_LINESIZE) is not available, such as musl LIBC and Android's bionic libc. Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Chris Phlipot <cphlipot0@gmail.com> Cc: David Ahern <dsahern@gmail.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Wang Nan <wangnan0@huawei.com> Link: http://lkml.kernel.org/n/tip-772obxzby758g7m2wmzcejxz@git.kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
dd7bd10936
commit
9a3dc28bb0
1 changed files with 11 additions and 1 deletions
|
|
@ -497,6 +497,16 @@ void pthread__unblock_sigwinch(void)
|
||||||
pthread_sigmask(SIG_UNBLOCK, &set, NULL);
|
pthread_sigmask(SIG_UNBLOCK, &set, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#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))
|
||||||
|
perror("cannot determine cache line size");
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
int main(int argc, const char **argv)
|
int main(int argc, const char **argv)
|
||||||
{
|
{
|
||||||
const char *cmd;
|
const char *cmd;
|
||||||
|
|
@ -509,7 +519,7 @@ int main(int argc, const char **argv)
|
||||||
|
|
||||||
/* The page_size is placed in util object. */
|
/* The page_size is placed in util object. */
|
||||||
page_size = sysconf(_SC_PAGE_SIZE);
|
page_size = sysconf(_SC_PAGE_SIZE);
|
||||||
cacheline_size = sysconf(_SC_LEVEL1_DCACHE_LINESIZE);
|
cache_line_size(&cacheline_size);
|
||||||
|
|
||||||
if (sysctl__read_int("kernel/perf_event_max_stack", &value) == 0)
|
if (sysctl__read_int("kernel/perf_event_max_stack", &value) == 0)
|
||||||
sysctl_perf_event_max_stack = value;
|
sysctl_perf_event_max_stack = value;
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue