提交 ef65b2a0 编写于 作者: M Mike Galbraith 提交者: Ingo Molnar

perf record: Fix the profiling of existing pid or whole box

Perf record bails if no command argument is provided, so you can't use
naked -a or -p to profile a running task or the whole box.

Allow foreground profiling of an existing pid or the entire system.

[ Impact: fix command option handling bug ]
Signed-off-by: NMike Galbraith <efault@gmx.de>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com>
Cc: Marcelo Tosatti <mtosatti@redhat.com>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: John Kacur <jkacur@redhat.com>
LKML-Reference: <new-submission>
Signed-off-by: NIngo Molnar <mingo@elte.hu>
上级 a930d2c0
...@@ -354,7 +354,7 @@ static int __cmd_record(int argc, const char **argv) ...@@ -354,7 +354,7 @@ static int __cmd_record(int argc, const char **argv)
signal(SIGCHLD, sig_handler); signal(SIGCHLD, sig_handler);
signal(SIGINT, sig_handler); signal(SIGINT, sig_handler);
if (target_pid == -1) { if (target_pid == -1 && argc) {
pid = fork(); pid = fork();
if (pid < 0) if (pid < 0)
perror("failed to fork"); perror("failed to fork");
...@@ -430,7 +430,7 @@ int cmd_record(int argc, const char **argv, const char *prefix) ...@@ -430,7 +430,7 @@ int cmd_record(int argc, const char **argv, const char *prefix)
create_events_help(events_help_msg); create_events_help(events_help_msg);
argc = parse_options(argc, argv, options, record_usage, 0); argc = parse_options(argc, argv, options, record_usage, 0);
if (!argc) if (!argc && target_pid == -1 && !system_wide)
usage_with_options(record_usage, options); usage_with_options(record_usage, options);
if (!nr_counters) { if (!nr_counters) {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册