2 * SPDX-License-Identifier: MIT
4 * Copyright 2016 Philippe Proulx <pproulx@efficios.com>
5 * Copyright 2010-2011 EfficiOS Inc. and Linux Foundation
12 #include <babeltrace2/babeltrace.h>
14 #define BT_COMP_LOG_SELF_COMP self_comp
15 #define BT_LOG_OUTPUT_LEVEL log_level
16 #define BT_LOG_TAG "PLUGIN/SRC.CTF.FS/META"
17 #include "logging/comp-logging.h"
19 #include "common/assert.h"
21 #include "../common/src/metadata/tsdl/decoder.hpp"
24 #include "metadata.hpp"
26 FILE *ctf_fs_metadata_open_file(const char *trace_path
, bt_logging_level log_level
,
27 bt_self_component_class
*comp_class
)
29 GString
*metadata_path
;
32 metadata_path
= g_string_new(trace_path
);
37 g_string_append(metadata_path
, G_DIR_SEPARATOR_S CTF_FS_METADATA_FILENAME
);
38 fp
= fopen(metadata_path
->str
, "rb");
40 BT_COMP_CLASS_LOGE_APPEND_CAUSE_ERRNO(comp_class
, "Failed to open metadata file",
41 ": path=\"%s\"", metadata_path
->str
);
44 g_string_free(metadata_path
, TRUE
);
50 static struct ctf_fs_file
*get_file(const char *trace_path
, bt_logging_level log_level
,
51 bt_self_component
*self_comp
)
53 struct ctf_fs_file
*file
= ctf_fs_file_create(log_level
, self_comp
);
59 g_string_append(file
->path
, trace_path
);
60 g_string_append(file
->path
, G_DIR_SEPARATOR_S CTF_FS_METADATA_FILENAME
);
62 if (ctf_fs_file_open(file
, "rb")) {
70 ctf_fs_file_destroy(file
);
78 int ctf_fs_metadata_set_trace_class(bt_self_component
*self_comp
, struct ctf_fs_trace
*ctf_fs_trace
,
79 struct ctf_fs_metadata_config
*config
)
82 struct ctf_fs_file
*file
= NULL
;
83 bt_logging_level log_level
= ctf_fs_trace
->log_level
;
85 ctf_metadata_decoder_config decoder_config
{};
86 decoder_config
.log_level
= ctf_fs_trace
->log_level
, decoder_config
.self_comp
= self_comp
,
87 decoder_config
.clock_class_offset_s
= config
? config
->clock_class_offset_s
: 0,
88 decoder_config
.clock_class_offset_ns
= config
? config
->clock_class_offset_ns
: 0,
89 decoder_config
.force_clock_class_origin_unix_epoch
=
90 config
? config
->force_clock_class_origin_unix_epoch
: false,
91 decoder_config
.create_trace_class
= true,
93 file
= get_file(ctf_fs_trace
->path
->str
, log_level
, self_comp
);
95 BT_COMP_LOGE("Cannot create metadata file object.");
100 ctf_fs_trace
->metadata
->decoder
= ctf_metadata_decoder_create(&decoder_config
);
101 if (!ctf_fs_trace
->metadata
->decoder
) {
102 BT_COMP_LOGE("Cannot create metadata decoder object.");
107 ret
= ctf_metadata_decoder_append_content(ctf_fs_trace
->metadata
->decoder
, file
->fp
);
109 BT_COMP_LOGE("Cannot update metadata decoder's content.");
113 ctf_fs_trace
->metadata
->trace_class
=
114 ctf_metadata_decoder_get_ir_trace_class(ctf_fs_trace
->metadata
->decoder
);
115 BT_ASSERT(!self_comp
|| ctf_fs_trace
->metadata
->trace_class
);
116 ctf_fs_trace
->metadata
->tc
=
117 ctf_metadata_decoder_borrow_ctf_trace_class(ctf_fs_trace
->metadata
->decoder
);
118 BT_ASSERT(ctf_fs_trace
->metadata
->tc
);
121 ctf_fs_file_destroy(file
);
125 int ctf_fs_metadata_init(struct ctf_fs_metadata
*)
127 /* Nothing to initialize for the moment. */
131 void ctf_fs_metadata_fini(struct ctf_fs_metadata
*metadata
)
133 free(metadata
->text
);
135 if (metadata
->trace_class
) {
136 BT_TRACE_CLASS_PUT_REF_AND_RESET(metadata
->trace_class
);
139 if (metadata
->decoder
) {
140 ctf_metadata_decoder_destroy(metadata
->decoder
);