X-Git-Url: https://git.sesse.net/?p=nageru;a=blobdiff_plain;f=pbo_frame_allocator.h;h=eead7f4a32f979c8203a184f535862c6f1dab0e2;hp=1fb6a072a1ecfc112c99d1c0a4fc8d9aa10f61e9;hb=4e3c52ba57c4552a969e71ccdefd9941ce8d6290;hpb=5bc2d4de98e960f40a11cd2991a25ea7d1d5a143 diff --git a/pbo_frame_allocator.h b/pbo_frame_allocator.h index 1fb6a07..eead7f4 100644 --- a/pbo_frame_allocator.h +++ b/pbo_frame_allocator.h @@ -2,21 +2,27 @@ #define _PBO_FRAME_ALLOCATOR 1 #include +#include +#include +#include #include #include +#include + #include "bmusb/bmusb.h" // An allocator that allocates straight into OpenGL pinned memory. // Meant for video frames only. We use a queue rather than a stack, // since we want to maximize pipelineability. -class PBOFrameAllocator : public FrameAllocator { +class PBOFrameAllocator : public bmusb::FrameAllocator { public: // Note: You need to have an OpenGL context when calling // the constructor. - PBOFrameAllocator(size_t frame_size, + PBOFrameAllocator(bmusb::PixelFormat pixel_format, + size_t frame_size, GLuint width, GLuint height, - size_t num_queued_frames = 16, // FIXME: should be 6 + size_t num_queued_frames = 16, GLenum buffer = GL_PIXEL_UNPACK_BUFFER_ARB, GLenum permissions = GL_MAP_WRITE_BIT, GLenum map_bits = GL_MAP_FLUSH_EXPLICIT_BIT); @@ -26,12 +32,33 @@ public: struct Userdata { GLuint pbo; - GLuint tex_y, tex_cbcr; + + // NOTE: These frames typically go into LiveInputWrapper, which is + // configured to accept one type of frame only. In other words, + // the existence of a format field doesn't mean you can set it + // freely at runtime. + bmusb::PixelFormat pixel_format; + + // Used only for PixelFormat_8BitYCbCrPlanar. + movit::YCbCrFormat ycbcr_format; + + // The second set is only used for the second field of interlaced inputs. + GLuint tex_y[2], tex_cbcr[2]; // For PixelFormat_8BitYCbCr. + GLuint tex_cb[2], tex_cr[2]; // For PixelFormat_8BitYCbCrPlanar (which also uses tex_y). + GLuint tex_v210[2], tex_444[2]; // For PixelFormat_10BitYCbCr. + GLuint tex_rgba[2]; // For PixelFormat_8BitBGRA. + GLuint last_width[2], last_height[2]; + GLuint last_cbcr_width[2], last_cbcr_height[2]; + GLuint last_v210_width[2]; // PixelFormat_10BitYCbCr. + bool last_interlaced, last_has_signal, last_is_connected; + unsigned last_frame_rate_nom, last_frame_rate_den; }; private: - size_t frame_size; + void init_frame(size_t frame_idx, size_t frame_size, GLuint width, GLuint height, GLenum permissions, GLenum map_bits); + void destroy_frame(Frame *frame); + bmusb::PixelFormat pixel_format; std::mutex freelist_mutex; std::queue freelist; GLenum buffer;