perf data: Support single perf.data file directory

Support directory output that contains a regular perf.data file, named
"data". By default the directory is named perf.data i.e.
	perf.data
	└── data

Most of the infrastructure to support a directory is already there. This
patch makes the changes needed to support the format above.

Presently there is no 'perf record' option to output a directory.

This is preparation for adding support for putting a copy of /proc/kcore in
the directory.

Signed-off-by: Adrian Hunter <adrian.hunter@intel.com>
Reviewed-by: Jiri Olsa <jolsa@kernel.org>
Link: http://lore.kernel.org/lkml/20191004083121.12182-5-adrian.hunter@intel.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
Adrian Hunter 2019-10-04 11:31:20 +03:00 committed by Arnaldo Carvalho de Melo
parent 01e97a59ea
commit 46e201efa1
4 changed files with 43 additions and 2 deletions

View File

@ -0,0 +1,28 @@
perf.data directory format
DISCLAIMER This is not ABI yet and is subject to possible change
in following versions of perf. We will remove this
disclaimer once the directory format soaks in.
This document describes the on-disk perf.data directory format.
The layout is described by HEADER_DIR_FORMAT feature.
Currently it holds only version number (0):
HEADER_DIR_FORMAT = 24
struct {
uint64_t version;
}
The current only version value 0 means that:
- there is a single perf.data file named 'data' within the directory.
e.g.
$ tree -ps perf.data
perf.data
└── [-rw------- 25912] data
Future versions are expected to describe different data files
layout according to special needs.

View File

@ -537,7 +537,7 @@ static int record__process_auxtrace(struct perf_tool *tool,
size_t padding; size_t padding;
u8 pad[8] = {0}; u8 pad[8] = {0};
if (!perf_data__is_pipe(data) && !perf_data__is_dir(data)) { if (!perf_data__is_pipe(data) && perf_data__is_single_file(data)) {
off_t file_offset; off_t file_offset;
int fd = perf_data__fd(data); int fd = perf_data__fd(data);
int err; int err;

View File

@ -76,6 +76,13 @@ int perf_data__open_dir(struct perf_data *data)
DIR *dir; DIR *dir;
int nr = 0; int nr = 0;
/*
* Directory containing a single regular perf data file which is already
* open, means there is nothing more to do here.
*/
if (perf_data__is_single_file(data))
return 0;
if (WARN_ON(!data->is_dir)) if (WARN_ON(!data->is_dir))
return -EINVAL; return -EINVAL;
@ -406,7 +413,7 @@ unsigned long perf_data__size(struct perf_data *data)
u64 size = data->file.size; u64 size = data->file.size;
int i; int i;
if (!data->is_dir) if (perf_data__is_single_file(data))
return size; return size;
for (i = 0; i < data->dir.nr; i++) { for (i = 0; i < data->dir.nr; i++) {

View File

@ -10,6 +10,7 @@ enum perf_data_mode {
}; };
enum perf_dir_version { enum perf_dir_version {
PERF_DIR_SINGLE_FILE = 0,
PERF_DIR_VERSION = 1, PERF_DIR_VERSION = 1,
}; };
@ -54,6 +55,11 @@ static inline bool perf_data__is_dir(struct perf_data *data)
return data->is_dir; return data->is_dir;
} }
static inline bool perf_data__is_single_file(struct perf_data *data)
{
return data->dir.version == PERF_DIR_SINGLE_FILE;
}
static inline int perf_data__fd(struct perf_data *data) static inline int perf_data__fd(struct perf_data *data)
{ {
return data->file.fd; return data->file.fd;