blob: 4828f7feea8949eb0e9a7d0464fad3997519c170 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Jiri Olsaf5fc14122013-10-15 16:27:32 +02002#ifndef __PERF_DATA_H
3#define __PERF_DATA_H
4
5#include <stdbool.h>
6
7enum perf_data_mode {
8 PERF_DATA_MODE_WRITE,
9 PERF_DATA_MODE_READ,
10};
11
Jiri Olsaeae8ad82017-01-23 22:25:41 +010012struct perf_data_file {
13 const char *path;
14 int fd;
15};
16
Jiri Olsa8ceb41d2017-01-23 22:07:59 +010017struct perf_data {
Jiri Olsaeae8ad82017-01-23 22:25:41 +010018 struct perf_data_file file;
Jiri Olsa6f9a3172013-11-28 11:30:17 +010019 bool is_pipe;
20 bool force;
21 unsigned long size;
22 enum perf_data_mode mode;
Jiri Olsaf5fc14122013-10-15 16:27:32 +020023};
24
Jiri Olsa8ceb41d2017-01-23 22:07:59 +010025static inline bool perf_data__is_read(struct perf_data *data)
Jiri Olsaf5fc14122013-10-15 16:27:32 +020026{
Jiri Olsa8ceb41d2017-01-23 22:07:59 +010027 return data->mode == PERF_DATA_MODE_READ;
Jiri Olsaf5fc14122013-10-15 16:27:32 +020028}
29
Jiri Olsa8ceb41d2017-01-23 22:07:59 +010030static inline bool perf_data__is_write(struct perf_data *data)
Jiri Olsaf5fc14122013-10-15 16:27:32 +020031{
Jiri Olsa8ceb41d2017-01-23 22:07:59 +010032 return data->mode == PERF_DATA_MODE_WRITE;
Jiri Olsaf5fc14122013-10-15 16:27:32 +020033}
34
Jiri Olsa8ceb41d2017-01-23 22:07:59 +010035static inline int perf_data__is_pipe(struct perf_data *data)
Jiri Olsacc9784bd2013-10-15 16:27:34 +020036{
Jiri Olsa8ceb41d2017-01-23 22:07:59 +010037 return data->is_pipe;
Jiri Olsacc9784bd2013-10-15 16:27:34 +020038}
39
Jiri Olsa8ceb41d2017-01-23 22:07:59 +010040static inline int perf_data__fd(struct perf_data *data)
Jiri Olsacc9784bd2013-10-15 16:27:34 +020041{
Jiri Olsaeae8ad82017-01-23 22:25:41 +010042 return data->file.fd;
Jiri Olsacc9784bd2013-10-15 16:27:34 +020043}
44
Jiri Olsa8ceb41d2017-01-23 22:07:59 +010045static inline unsigned long perf_data__size(struct perf_data *data)
Jiri Olsacc9784bd2013-10-15 16:27:34 +020046{
Jiri Olsa8ceb41d2017-01-23 22:07:59 +010047 return data->size;
Jiri Olsacc9784bd2013-10-15 16:27:34 +020048}
49
Jiri Olsa8ceb41d2017-01-23 22:07:59 +010050int perf_data__open(struct perf_data *data);
51void perf_data__close(struct perf_data *data);
52ssize_t perf_data__write(struct perf_data *data,
Jiri Olsa6f9a3172013-11-28 11:30:17 +010053 void *buf, size_t size);
Jiri Olsae2686872017-01-23 22:42:56 +010054ssize_t perf_data_file__write(struct perf_data_file *file,
55 void *buf, size_t size);
Wang Nan040f9912016-04-13 08:21:05 +000056/*
57 * If at_exit is set, only rename current perf.data to
Jiri Olsa8ceb41d2017-01-23 22:07:59 +010058 * perf.data.<postfix>, continue write on original data.
Wang Nan040f9912016-04-13 08:21:05 +000059 * Set at_exit when flushing the last output.
60 *
61 * Return value is fd of new output.
62 */
Jiri Olsa8ceb41d2017-01-23 22:07:59 +010063int perf_data__switch(struct perf_data *data,
Wang Nan040f9912016-04-13 08:21:05 +000064 const char *postfix,
65 size_t pos, bool at_exit);
Jiri Olsaf5fc14122013-10-15 16:27:32 +020066#endif /* __PERF_DATA_H */