@@ -17,6 +17,7 @@ using namespace libcamera;
struct _GstLibcameraPad {
GstPad parent;
StreamRole role;
+ GstLibcameraPool *pool;
};
enum {
@@ -108,3 +109,20 @@ gst_libcamera_pad_get_role(GstPad *pad)
GLibLocker lock(GST_OBJECT(self));
return self->role;
}
+
+GstLibcameraPool *
+gst_libcamera_pad_get_pool(GstPad *pad)
+{
+ auto *self = GST_LIBCAMERA_PAD(pad);
+ return self->pool;
+}
+
+void
+gst_libcamera_pad_set_pool(GstPad *pad, GstLibcameraPool *pool)
+{
+ auto *self = GST_LIBCAMERA_PAD(pad);
+
+ if (self->pool)
+ g_object_unref(self->pool);
+ self->pool = pool;
+}
@@ -9,6 +9,8 @@
#ifndef __GST_LIBCAMERA_PAD_H__
#define __GST_LIBCAMERA_PAD_H__
+#include "gstlibcamerapool.h"
+
#include <gst/gst.h>
#include <libcamera/stream.h>
@@ -18,4 +20,8 @@ G_DECLARE_FINAL_TYPE(GstLibcameraPad, gst_libcamera_pad, GST_LIBCAMERA, PAD, Gst
libcamera::StreamRole gst_libcamera_pad_get_role(GstPad *pad);
+GstLibcameraPool *gst_libcamera_pad_get_pool(GstPad *pad);
+
+void gst_libcamera_pad_set_pool(GstPad *pad, GstLibcameraPool *pool);
+
#endif /* __GST_LIBCAMERA_PAD_H__ */