X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=mixer.h;h=07a31e959fe5a21e2b268ed7f4aad11e0ac2e90a;hb=05b0c5b2b693ba809b8334a892463ae34febb6c3;hp=76aec682c5d71773c7d3909de60ed2d9a58a76a8;hpb=5c8dc09f89df0f25434bcefc9102438d2b491df2;p=nageru diff --git a/mixer.h b/mixer.h index 76aec68..07a31e9 100644 --- a/mixer.h +++ b/mixer.h @@ -170,6 +170,16 @@ public: void reset_meters(); + struct BufferedFrame { + RefCountedFrame frame; + unsigned field_number; + }; + + BufferedFrame get_buffered_frame(int card, int history_pos) + { + return buffered_frames[card][history_pos]; + } + private: void bm_frame(unsigned card_index, uint16_t timecode, FrameAllocator::Frame video_frame, size_t video_offset, uint16_t video_format, @@ -210,7 +220,8 @@ private: bool should_quit = false; RefCountedFrame new_frame; int64_t new_frame_length; // In TIMEBASE units. - unsigned new_frame_field; // Which field (0 or 1) of the frame to use. + bool new_frame_interlaced; + unsigned new_frame_field; // Which field (0 or 1) of the frame to use. Always 0 for progressive. GLsync new_data_ready_fence; // Whether new_frame is ready for rendering. std::condition_variable new_data_ready_changed; // Set whenever new_data_ready is changed. unsigned dropped_frames = 0; // Before new_frame. @@ -226,7 +237,12 @@ private: }; CaptureCard cards[MAX_CARDS]; // protected by - RefCountedFrame bmusb_current_rendering_frame[MAX_CARDS]; + // For each card, the last three frames (or fields), with 0 being the + // most recent one. Note that we only need the actual history if we have + // interlaced output (for deinterlacing), so if we detect progressive input, + // we immediately clear out all history and all entries will point to the same + // frame. + BufferedFrame buffered_frames[MAX_CARDS][FRAME_HISTORY_LENGTH]; class OutputChannel { public: @@ -252,7 +268,8 @@ private: std::atomic should_quit{false}; audio_level_callback_t audio_level_callback = nullptr; - Ebu_r128_proc r128; + std::mutex r128_mutex; + Ebu_r128_proc r128; // Under r128_mutex. Resampler peak_resampler; std::atomic peak{0.0f};