Commit eca857ab authored by Wang Nan's avatar Wang Nan Committed by Arnaldo Carvalho de Melo

perf record: Force enable --timestamp-filename when --switch-output is provided

Without this patch, the last output doesn't have timestamp appended if
--timestamp-filename is not explicitly provided. For example:

  # perf record -a --switch-output &
  [1] 11224
  # kill -s SIGUSR2 11224
  [ perf record: dump data: Woken up 1 times ]
  # [ perf record: Dump perf.data.2015122622372823 ]

  # fg
  perf record -a --switch-output
  ^C[ perf record: Woken up 1 times to write data ]
  [ perf record: Captured and wrote 0.027 MB perf.data (540 samples) ]

  # ls -l
  total 836
  -rw------- 1 root root  33256 Dec 26 22:37 perf.data   <---- *Odd*
  -rw------- 1 root root 817156 Dec 26 22:37 perf.data.2015122622372823
Signed-off-by: default avatarWang Nan <wangnan0@huawei.com>
Tested-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Masami Hiramatsu <mhiramat@kernel.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Zefan Li <lizefan@huawei.com>
Cc: pi3orama@163.com
Link: http://lkml.kernel.org/r/1461178794-40467-5-git-send-email-wangnan0@huawei.comSigned-off-by: default avatarHe Kuang <hekuang@huawei.com>
[ Updated man page, that also got an entry for --timestamp-filename ]
Signed-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 3c1cb7e3
...@@ -347,6 +347,9 @@ Configure all used events to run in kernel space. ...@@ -347,6 +347,9 @@ Configure all used events to run in kernel space.
--all-user:: --all-user::
Configure all used events to run in user space. Configure all used events to run in user space.
--timestamp-filename
Append timestamp to output file name.
--switch-output:: --switch-output::
Generate multiple perf.data files, timestamp prefixed, switching to a new one Generate multiple perf.data files, timestamp prefixed, switching to a new one
when receiving a SIGUSR2. when receiving a SIGUSR2.
...@@ -355,6 +358,8 @@ A possible use case is to, given an external event, slice the perf.data file ...@@ -355,6 +358,8 @@ A possible use case is to, given an external event, slice the perf.data file
that gets then processed, possibly via a perf script, to decide if that that gets then processed, possibly via a perf script, to decide if that
particular perf.data snapshot should be kept or not. particular perf.data snapshot should be kept or not.
Implies --timestamp-filename.
SEE ALSO SEE ALSO
-------- --------
linkperf:perf-stat[1], linkperf:perf-list[1] linkperf:perf-stat[1], linkperf:perf-list[1]
...@@ -1351,6 +1351,9 @@ int cmd_record(int argc, const char **argv, const char *prefix __maybe_unused) ...@@ -1351,6 +1351,9 @@ int cmd_record(int argc, const char **argv, const char *prefix __maybe_unused)
return -EINVAL; return -EINVAL;
} }
if (rec->switch_output)
rec->timestamp_filename = true;
if (!rec->itr) { if (!rec->itr) {
rec->itr = auxtrace_record__init(rec->evlist, &err); rec->itr = auxtrace_record__init(rec->evlist, &err);
if (err) if (err)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment