@@ -16,6 +16,7 @@ using namespace libcamera;
struct _GstLibcameraPad {
GstPad parent;
StreamRole role;
+ GstLibcameraPool *pool;
};
enum {
@@ -107,3 +108,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 @@
#include <gst/gst.h>
#include <libcamera/stream.h>
+#include "gstlibcamerapool.h"
+
#ifndef __GST_LIBCAMERA_PAD_H__
#define __GST_LIBCAMERA_PAD_H__
@@ -18,4 +20,8 @@ G_DECLARE_FINAL_TYPE(GstLibcameraPad, gst_libcamera_pad,
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__ */