2 * SPDX-License-Identifier: MIT
4 * Copyright (C) 2016 Philippe Proulx <pproulx@efficios.com>
7 #ifndef CTF_FS_DS_FILE_H
8 #define CTF_FS_DS_FILE_H
13 #include "common/macros.h"
14 #include <babeltrace2/babeltrace.h>
16 #include "../common/msg-iter/msg-iter.hpp"
17 #include "lttng-index.hpp"
19 struct ctf_fs_component;
22 struct ctf_fs_ds_file;
23 struct ctf_fs_ds_file_group;
24 struct ctf_fs_ds_group_medops_data;
26 struct ctf_fs_ds_file_info {
30 /* Guaranteed to be set, as opposed to the index. */
34 struct ctf_fs_metadata;
36 struct ctf_fs_ds_file {
37 bt_logging_level log_level;
40 bt_self_component *self_comp;
43 bt_self_message_iterator *self_msg_iter;
46 struct ctf_fs_metadata *metadata;
49 struct ctf_fs_file *file;
57 * Max length of chunk to mmap() when updating the current mapping.
58 * This value must be page-aligned.
62 /* Length of the current mapping. Never exceeds the file's length. */
65 /* Offset in the file where the current mapping starts. */
66 off_t mmap_offset_in_file;
69 * Offset, in the current mapping, of the address to return on the next
72 off_t request_offset_in_mapping;
76 struct ctf_fs_ds_file *ctf_fs_ds_file_create(
77 struct ctf_fs_trace *ctf_fs_trace,
78 bt_self_message_iterator *self_msg_iter,
79 bt_stream *stream, const char *path,
80 bt_logging_level log_level);
83 void ctf_fs_ds_file_destroy(struct ctf_fs_ds_file *stream);
86 struct ctf_fs_ds_index *ctf_fs_ds_file_build_index(
87 struct ctf_fs_ds_file *ds_file,
88 struct ctf_fs_ds_file_info *ds_file_info,
89 struct ctf_msg_iter *msg_iter);
92 struct ctf_fs_ds_index *ctf_fs_ds_index_create(bt_logging_level log_level,
93 bt_self_component *self_comp);
96 void ctf_fs_ds_index_destroy(struct ctf_fs_ds_index *index);
99 * Medium operations to iterate on a single ctf_fs_ds_file.
101 * The data pointer when using this must be a pointer to the ctf_fs_ds_file.
103 extern struct ctf_msg_iter_medium_ops ctf_fs_ds_file_medops;
106 * Medium operations to iterate on the packet of a ctf_fs_ds_group.
108 * The iteration is done based on the index of the group.
110 * The data pointer when using these medops must be a pointer to a ctf_fs_ds
111 * group_medops_data structure.
114 extern struct ctf_msg_iter_medium_ops ctf_fs_ds_group_medops;
117 enum ctf_msg_iter_medium_status ctf_fs_ds_group_medops_data_create(
118 struct ctf_fs_ds_file_group *ds_file_group,
119 bt_self_message_iterator *self_msg_iter,
120 bt_logging_level log_level,
121 struct ctf_fs_ds_group_medops_data **out);
124 void ctf_fs_ds_group_medops_data_reset(struct ctf_fs_ds_group_medops_data *data);
127 void ctf_fs_ds_group_medops_data_destroy(
128 struct ctf_fs_ds_group_medops_data *data);
130 #endif /* CTF_FS_DS_FILE_H */