perf tools: Ditch record_opts.callgraph_set

We have callchain_param.enabled for that.

Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: David Ahern <dsahern@gmail.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Milian Wolff <milian.wolff@kdab.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Wang Nan <wangnan0@huawei.com>
Link: http://lkml.kernel.org/n/tip-silwqjc2t25ls42dsvg28pp5@git.kernel.orgSigned-off-by: NArnaldo Carvalho de Melo <acme@redhat.com>
上级 1cc83815
...@@ -946,7 +946,6 @@ int record_opts__parse_callchain(struct record_opts *record, ...@@ -946,7 +946,6 @@ int record_opts__parse_callchain(struct record_opts *record,
const char *arg, bool unset) const char *arg, bool unset)
{ {
int ret; int ret;
record->callgraph_set = true;
callchain->enabled = !unset; callchain->enabled = !unset;
/* --no-call-graph */ /* --no-call-graph */
...@@ -978,15 +977,14 @@ int record_callchain_opt(const struct option *opt, ...@@ -978,15 +977,14 @@ int record_callchain_opt(const struct option *opt,
const char *arg __maybe_unused, const char *arg __maybe_unused,
int unset __maybe_unused) int unset __maybe_unused)
{ {
struct record_opts *record = (struct record_opts *)opt->value; struct callchain_param *callchain = opt->value;
record->callgraph_set = true; callchain->enabled = true;
callchain_param.enabled = true;
if (callchain_param.record_mode == CALLCHAIN_NONE) if (callchain->record_mode == CALLCHAIN_NONE)
callchain_param.record_mode = CALLCHAIN_FP; callchain->record_mode = CALLCHAIN_FP;
callchain_debug(&callchain_param); callchain_debug(callchain);
return 0; return 0;
} }
...@@ -1224,7 +1222,7 @@ struct option __record_options[] = { ...@@ -1224,7 +1222,7 @@ struct option __record_options[] = {
record__parse_mmap_pages), record__parse_mmap_pages),
OPT_BOOLEAN(0, "group", &record.opts.group, OPT_BOOLEAN(0, "group", &record.opts.group,
"put the counters into a counter group"), "put the counters into a counter group"),
OPT_CALLBACK_NOOPT('g', NULL, &record.opts, OPT_CALLBACK_NOOPT('g', NULL, &callchain_param,
NULL, "enables call-graph recording" , NULL, "enables call-graph recording" ,
&record_callchain_opt), &record_callchain_opt),
OPT_CALLBACK(0, "call-graph", &record.opts, OPT_CALLBACK(0, "call-graph", &record.opts,
......
...@@ -1045,18 +1045,17 @@ callchain_opt(const struct option *opt, const char *arg, int unset) ...@@ -1045,18 +1045,17 @@ callchain_opt(const struct option *opt, const char *arg, int unset)
static int static int
parse_callchain_opt(const struct option *opt, const char *arg, int unset) parse_callchain_opt(const struct option *opt, const char *arg, int unset)
{ {
struct record_opts *record = (struct record_opts *)opt->value; struct callchain_param *callchain = opt->value;
record->callgraph_set = true; callchain->enabled = !unset;
callchain_param.enabled = !unset; callchain->record_mode = CALLCHAIN_FP;
callchain_param.record_mode = CALLCHAIN_FP;
/* /*
* --no-call-graph * --no-call-graph
*/ */
if (unset) { if (unset) {
symbol_conf.use_callchain = false; symbol_conf.use_callchain = false;
callchain_param.record_mode = CALLCHAIN_NONE; callchain->record_mode = CALLCHAIN_NONE;
return 0; return 0;
} }
...@@ -1162,10 +1161,10 @@ int cmd_top(int argc, const char **argv, const char *prefix __maybe_unused) ...@@ -1162,10 +1161,10 @@ int cmd_top(int argc, const char **argv, const char *prefix __maybe_unused)
"output field(s): overhead, period, sample plus all of sort keys"), "output field(s): overhead, period, sample plus all of sort keys"),
OPT_BOOLEAN('n', "show-nr-samples", &symbol_conf.show_nr_samples, OPT_BOOLEAN('n', "show-nr-samples", &symbol_conf.show_nr_samples,
"Show a column with the number of samples"), "Show a column with the number of samples"),
OPT_CALLBACK_NOOPT('g', NULL, &top.record_opts, OPT_CALLBACK_NOOPT('g', NULL, &callchain_param,
NULL, "enables call-graph recording and display", NULL, "enables call-graph recording and display",
&callchain_opt), &callchain_opt),
OPT_CALLBACK(0, "call-graph", &top.record_opts, OPT_CALLBACK(0, "call-graph", &callchain_param,
"record_mode[,record_size],print_type,threshold[,print_limit],order,sort_key[,branch]", "record_mode[,record_size],print_type,threshold[,print_limit],order,sort_key[,branch]",
top_callchain_help, &parse_callchain_opt), top_callchain_help, &parse_callchain_opt),
OPT_BOOLEAN(0, "children", &symbol_conf.cumulate_callchain, OPT_BOOLEAN(0, "children", &symbol_conf.cumulate_callchain,
......
...@@ -2457,7 +2457,7 @@ static int trace__add_syscall_newtp(struct trace *trace) ...@@ -2457,7 +2457,7 @@ static int trace__add_syscall_newtp(struct trace *trace)
perf_evlist__add(evlist, sys_enter); perf_evlist__add(evlist, sys_enter);
perf_evlist__add(evlist, sys_exit); perf_evlist__add(evlist, sys_exit);
if (trace->opts.callgraph_set && !trace->kernel_syscallchains) { if (callchain_param.enabled && !trace->kernel_syscallchains) {
/* /*
* We're interested only in the user space callchain * We're interested only in the user space callchain
* leading to the syscall, allow overriding that for * leading to the syscall, allow overriding that for
...@@ -2546,7 +2546,7 @@ static int trace__run(struct trace *trace, int argc, const char **argv) ...@@ -2546,7 +2546,7 @@ static int trace__run(struct trace *trace, int argc, const char **argv)
perf_evlist__config(evlist, &trace->opts, NULL); perf_evlist__config(evlist, &trace->opts, NULL);
if (trace->opts.callgraph_set && trace->syscalls.events.sys_exit) { if (callchain_param.enabled && trace->syscalls.events.sys_exit) {
perf_evsel__config_callchain(trace->syscalls.events.sys_exit, perf_evsel__config_callchain(trace->syscalls.events.sys_exit,
&trace->opts, &callchain_param); &trace->opts, &callchain_param);
/* /*
...@@ -3153,11 +3153,11 @@ int cmd_trace(int argc, const char **argv, const char *prefix __maybe_unused) ...@@ -3153,11 +3153,11 @@ int cmd_trace(int argc, const char **argv, const char *prefix __maybe_unused)
} }
#ifdef HAVE_DWARF_UNWIND_SUPPORT #ifdef HAVE_DWARF_UNWIND_SUPPORT
if ((trace.min_stack || max_stack_user_set) && !trace.opts.callgraph_set) if ((trace.min_stack || max_stack_user_set) && !callchain_param.enabled)
record_opts__parse_callchain(&trace.opts, &callchain_param, "dwarf", false); record_opts__parse_callchain(&trace.opts, &callchain_param, "dwarf", false);
#endif #endif
if (trace.opts.callgraph_set) { if (callchain_param.enabled) {
if (!mmap_pages_user_set && geteuid() == 0) if (!mmap_pages_user_set && geteuid() == 0)
trace.opts.mmap_pages = perf_event_mlock_kb_in_pages() * 4; trace.opts.mmap_pages = perf_event_mlock_kb_in_pages() * 4;
......
...@@ -52,7 +52,6 @@ struct record_opts { ...@@ -52,7 +52,6 @@ struct record_opts {
bool sample_weight; bool sample_weight;
bool sample_time; bool sample_time;
bool sample_time_set; bool sample_time_set;
bool callgraph_set;
bool period; bool period;
bool running_time; bool running_time;
bool full_auxtrace; bool full_auxtrace;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册