]> git.sesse.net Git - nageru/blobdiff - nageru/mjpeg_encoder.h
Fix some overly repetitive code in PBOFrameAllocator.
[nageru] / nageru / mjpeg_encoder.h
index 3630d9f26a6f94048b0c3df0b9a9593955948c1a..8b68294a48d9e01dfd0254b213b2770d57e0330d 100644 (file)
@@ -103,7 +103,7 @@ private:
        void va_receiver_thread_func();
        void encode_jpeg_va(QueuedFrame &&qf);
        std::vector<uint8_t> encode_jpeg_libjpeg(const QueuedFrame &qf);
-       void write_mjpeg_packet(int64_t pts, unsigned card_index, const std::vector<uint8_t> &jpeg);
+       void write_mjpeg_packet(int64_t pts, unsigned card_index, const uint8_t *jpeg, size_t jpeg_size);
        void init_jpeg_422(unsigned width, unsigned height, VectorDestinationManager *dest, jpeg_compress_struct *cinfo);
        std::vector<uint8_t> get_jpeg_header(unsigned width, unsigned height, jpeg_compress_struct *cinfo);
 
@@ -146,6 +146,13 @@ private:
        static std::unique_ptr<VADisplayWithCleanup> try_open_va(const std::string &va_display, std::string *error, VAConfigID *config_id);
 
        uint8_t *tmp_y, *tmp_cbcr, *tmp_cb, *tmp_cr;  // Private to the encoder thread. Used by the libjpeg backend only.
+
+       std::atomic<int64_t> metric_mjpeg_frames_zero_size_dropped{0};
+       std::atomic<int64_t> metric_mjpeg_frames_interlaced_dropped{0};
+       std::atomic<int64_t> metric_mjpeg_frames_unsupported_pixel_format_dropped{0};
+       std::atomic<int64_t> metric_mjpeg_frames_oversized_dropped{0};
+       std::atomic<int64_t> metric_mjpeg_overrun_dropped{0};
+       std::atomic<int64_t> metric_mjpeg_overrun_submitted{0};
 };
 
 #endif  // !defined(_MJPEG_ENCODER_H)