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.h"
17 #include "lttng-index.h"
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 */