@@ -17,6 +17,7 @@ struct _GstLibcameraPad {
GstPad parent;
StreamRole role;
GstLibcameraPool *pool;
+ GQueue pending_buffers;
};
enum {
@@ -136,3 +137,29 @@ gst_libcamera_pad_get_stream(GstPad *pad)
return nullptr;
}
+
+void
+gst_libcamera_pad_queue_buffer(GstPad *pad, GstBuffer *buffer)
+{
+ auto *self = GST_LIBCAMERA_PAD(pad);
+ GLibLocker lock(GST_OBJECT(self));
+
+ g_queue_push_head(&self->pending_buffers, buffer);
+}
+
+GstFlowReturn
+gst_libcamera_pad_push_pending(GstPad *pad)
+{
+ auto *self = GST_LIBCAMERA_PAD(pad);
+ GstBuffer *buffer;
+
+ {
+ GLibLocker lock(GST_OBJECT(self));
+ buffer = GST_BUFFER(g_queue_pop_tail(&self->pending_buffers));
+ }
+
+ if (!buffer)
+ return GST_FLOW_CUSTOM_SUCCESS;
+
+ return gst_pad_push(pad, buffer);
+}
@@ -26,4 +26,8 @@ void gst_libcamera_pad_set_pool(GstPad *pad, GstLibcameraPool *pool);
libcamera::Stream *gst_libcamera_pad_get_stream(GstPad *pad);
+void gst_libcamera_pad_queue_buffer(GstPad *pad, GstBuffer *buffer);
+
+GstFlowReturn gst_libcamera_pad_push_pending(GstPad *pad);
+
#endif /* __GST_LIBCAMERA_PAD_H__ */