#include <movit/resource_pool.h> // Must be above the Xlib includes.
#include <pthread.h>
+#include <mutex>
+
#include <epoxy/egl.h>
#include "chroma_subsampler.h"
namespace {
// This class can be deleted during regular use, so make all the metrics static.
-bool metrics_inited = false;
+once_flag decklink_metrics_inited;
LatencyHistogram latency_histogram;
atomic<int64_t> metric_decklink_output_width_pixels{-1};
atomic<int64_t> metric_decklink_output_height_pixels{-1};
{
chroma_subsampler.reset(new ChromaSubsampler(resource_pool));
- if (!metrics_inited) {
+ call_once(decklink_metrics_inited, [](){
latency_histogram.init("decklink_output");
global_metrics.add("decklink_output_width_pixels", &metric_decklink_output_width_pixels, Metrics::TYPE_GAUGE);
global_metrics.add("decklink_output_height_pixels", &metric_decklink_output_height_pixels, Metrics::TYPE_GAUGE);
global_metrics.add("decklink_output_completed_frames", {{ "status", "unknown" }}, &metric_decklink_output_completed_frames_unknown);
global_metrics.add("decklink_output_scheduled_samples", &metric_decklink_output_scheduled_samples);
-
- metrics_inited = true;
- }
+ });
}
void DeckLinkOutput::set_device(IDeckLink *decklink)
// These need to survive several QuickSyncEncoderImpl instances,
// so they are outside.
-bool quick_sync_metrics_inited = false;
+once_flag quick_sync_metrics_inited;
LatencyHistogram mixer_latency_histogram, qs_latency_histogram;
MuxMetrics current_file_mux_metrics, total_mux_metrics;
std::atomic<double> metric_current_file_start_time_seconds{0.0 / 0.0};
memset(&slice_param, 0, sizeof(slice_param));
}
- if (!quick_sync_metrics_inited) {
+ call_once(quick_sync_metrics_inited, [](){
mixer_latency_histogram.init("mixer");
qs_latency_histogram.init("quick_sync");
current_file_mux_metrics.init({{ "destination", "current_file" }});
total_mux_metrics.init({{ "destination", "files_total" }});
global_metrics.add("current_file_start_time_seconds", &metric_current_file_start_time_seconds, Metrics::TYPE_GAUGE);
global_metrics.add("quick_sync_stalled_frames", &metric_quick_sync_stalled_frames);
- quick_sync_metrics_inited = true;
- }
+ });
storage_thread = thread(&QuickSyncEncoderImpl::storage_task_thread, this);
: wants_global_headers(oformat->flags & AVFMT_GLOBALHEADER),
dyn(load_x264_for_bit_depth(global_flags.x264_bit_depth))
{
- call_once(x264_metrics_inited, [&](){
+ call_once(x264_metrics_inited, [](){
global_metrics.add("x264_queued_frames", &metric_x264_queued_frames, Metrics::TYPE_GAUGE);
global_metrics.add("x264_max_queued_frames", &metric_x264_max_queued_frames, Metrics::TYPE_GAUGE);
global_metrics.add("x264_dropped_frames", &metric_x264_dropped_frames);