Skip to content

Commit 029c75e

Browse files
committed
perf tools: No need to unconditionally read the max_stack sysctls
Let tools that need to have those variables with the sysctl current values use a function that will read them. Cc: Adrian Hunter <[email protected]> Cc: David Ahern <[email protected]> Cc: Jiri Olsa <[email protected]> Cc: Namhyung Kim <[email protected]> Cc: Wang Nan <[email protected]> Link: https://lkml.kernel.org/n/[email protected] Signed-off-by: Arnaldo Carvalho de Melo <[email protected]>
1 parent 9ac94e3 commit 029c75e

File tree

6 files changed

+18
-10
lines changed

6 files changed

+18
-10
lines changed

tools/perf/builtin-top.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1264,7 +1264,7 @@ int cmd_top(int argc, const char **argv)
12641264
.proc_map_timeout = 500,
12651265
.overwrite = 1,
12661266
},
1267-
.max_stack = sysctl_perf_event_max_stack,
1267+
.max_stack = sysctl__max_stack(),
12681268
.sym_pcnt_filter = 5,
12691269
.nr_threads_synthesize = UINT_MAX,
12701270
};

tools/perf/builtin-trace.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -3162,7 +3162,7 @@ int cmd_trace(int argc, const char **argv)
31623162
mmap_pages_user_set = false;
31633163

31643164
if (trace.max_stack == UINT_MAX) {
3165-
trace.max_stack = input_name ? PERF_MAX_STACK_DEPTH : sysctl_perf_event_max_stack;
3165+
trace.max_stack = input_name ? PERF_MAX_STACK_DEPTH : sysctl__max_stack();
31663166
max_stack_user_set = false;
31673167
}
31683168

tools/perf/perf.c

Lines changed: 0 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -426,7 +426,6 @@ int main(int argc, const char **argv)
426426
int err;
427427
const char *cmd;
428428
char sbuf[STRERR_BUFSIZE];
429-
int value;
430429

431430
/* libsubcmd init */
432431
exec_cmd_init("perf", PREFIX, PERF_EXEC_PATH, EXEC_PATH_ENVIRONMENT);
@@ -435,12 +434,6 @@ int main(int argc, const char **argv)
435434
/* The page_size is placed in util object. */
436435
page_size = sysconf(_SC_PAGE_SIZE);
437436

438-
if (sysctl__read_int("kernel/perf_event_max_stack", &value) == 0)
439-
sysctl_perf_event_max_stack = value;
440-
441-
if (sysctl__read_int("kernel/perf_event_max_contexts_per_stack", &value) == 0)
442-
sysctl_perf_event_max_contexts_per_stack = value;
443-
444437
cmd = extract_argv0_path(argv[0]);
445438
if (!cmd)
446439
cmd = "perf-help";

tools/perf/util/evsel.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2862,7 +2862,7 @@ int perf_evsel__open_strerror(struct perf_evsel *evsel, struct target *target,
28622862
return scnprintf(msg, size,
28632863
"Not enough memory to setup event with callchain.\n"
28642864
"Hint: Try tweaking /proc/sys/kernel/perf_event_max_stack\n"
2865-
"Hint: Current value: %d", sysctl_perf_event_max_stack);
2865+
"Hint: Current value: %d", sysctl__max_stack());
28662866
break;
28672867
case ENODEV:
28682868
if (target->cpu_list)

tools/perf/util/util.c

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -62,6 +62,19 @@ int cacheline_size(void)
6262
int sysctl_perf_event_max_stack = PERF_MAX_STACK_DEPTH;
6363
int sysctl_perf_event_max_contexts_per_stack = PERF_MAX_CONTEXTS_PER_STACK;
6464

65+
int sysctl__max_stack(void)
66+
{
67+
int value;
68+
69+
if (sysctl__read_int("kernel/perf_event_max_stack", &value) == 0)
70+
sysctl_perf_event_max_stack = value;
71+
72+
if (sysctl__read_int("kernel/perf_event_max_contexts_per_stack", &value) == 0)
73+
sysctl_perf_event_max_contexts_per_stack = value;
74+
75+
return sysctl_perf_event_max_stack;
76+
}
77+
6578
bool test_attr__enabled;
6679

6780
bool perf_host = true;

tools/perf/util/util.h

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -45,6 +45,8 @@ int hex2u64(const char *ptr, u64 *val);
4545
extern unsigned int page_size;
4646
int __pure cacheline_size(void);
4747

48+
int sysctl__max_stack(void);
49+
4850
int fetch_kernel_version(unsigned int *puint,
4951
char *str, size_t str_sz);
5052
#define KVER_VERSION(x) (((x) >> 16) & 0xff)

0 commit comments

Comments
 (0)