[aravis] gst: make num-buffers a property
- From: Emmanuel Pacaud <emmanuel src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [aravis] gst: make num-buffers a property
- Date: Thu, 30 Oct 2014 20:05:45 +0000 (UTC)
commit 24437574b602dd118956baea924105d07f242d35
Author: Patrick Doyle <wpd harvestai com>
Date: Thu Oct 30 15:37:43 2014 -0400
gst: make num-buffers a property
gst-0.10/gstaravis.c | 22 +++++++++++++++++++---
gst-0.10/gstaravis.h | 1 +
gst/gstaravis.c | 23 ++++++++++++++++++++---
gst/gstaravis.h | 1 +
4 files changed, 41 insertions(+), 6 deletions(-)
---
diff --git a/gst-0.10/gstaravis.c b/gst-0.10/gstaravis.c
index 9be6eaf..ff8a990 100644
--- a/gst-0.10/gstaravis.c
+++ b/gst-0.10/gstaravis.c
@@ -38,7 +38,7 @@
#include <time.h>
#include <string.h>
-#define GST_ARAVIS_N_BUFFERS 50
+#define GST_ARAVIS_DEFAULT_N_BUFFERS 50
#define GST_ARAVIS_BUFFER_TIMEOUT_DEFAULT 2000000
GST_DEBUG_CATEGORY_STATIC (aravis_debug);
@@ -57,7 +57,8 @@ enum
PROP_V_BINNING,
PROP_OFFSET_X,
PROP_OFFSET_Y,
- PROP_PACKET_RESEND
+ PROP_PACKET_RESEND,
+ PROP_NUM_BUFFERS
};
GST_BOILERPLATE (GstAravis, gst_aravis, GstPushSrc, GST_TYPE_PUSH_SRC);
@@ -260,7 +261,7 @@ gst_aravis_set_caps (GstBaseSrc *src, GstCaps *caps)
else
g_object_set (gst_aravis->stream, "packet-resend", ARV_GV_STREAM_PACKET_RESEND_NEVER, NULL);
- for (i = 0; i < GST_ARAVIS_N_BUFFERS; i++)
+ for (i = 0; i < gst_aravis->num_buffers; i++)
arv_stream_push_buffer (gst_aravis->stream,
arv_buffer_new (gst_aravis->payload, NULL));
@@ -469,6 +470,7 @@ gst_aravis_init (GstAravis *gst_aravis, GstAravisClass *g_class)
gst_aravis->h_binning = -1;
gst_aravis->v_binning = -1;
gst_aravis->packet_resend = TRUE;
+ gst_aravis->num_buffers = GST_ARAVIS_DEFAULT_N_BUFFERS;
gst_aravis->payload = 0;
gst_aravis->buffer_timeout_us = GST_ARAVIS_BUFFER_TIMEOUT_DEFAULT;
@@ -562,6 +564,9 @@ gst_aravis_set_property (GObject * object, guint prop_id,
case PROP_PACKET_RESEND:
gst_aravis->packet_resend = g_value_get_boolean (value);
break;
+ case PROP_NUM_BUFFERS:
+ gst_aravis->num_buffers = g_value_get_int (value);
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
@@ -608,6 +613,9 @@ gst_aravis_get_property (GObject * object, guint prop_id, GValue * value,
case PROP_PACKET_RESEND:
g_value_set_boolean (value, gst_aravis->packet_resend);
break;
+ case PROP_NUM_BUFFERS:
+ g_value_set_int (value, gst_aravis->num_buffers);
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
@@ -727,6 +735,14 @@ gst_aravis_class_init (GstAravisClass * klass)
"Request dropped packets to be reissued by the camera",
TRUE,
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
+ g_object_class_install_property
+ (gobject_class,
+ PROP_NUM_BUFFERS,
+ g_param_spec_int ("num-buffers",
+ "Number of Buffers",
+ "Number of video buffers to allocate for video frames",
+ 1, G_MAXINT, GST_ARAVIS_DEFAULT_N_BUFFERS,
+ G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
GST_DEBUG_CATEGORY_INIT (aravis_debug, "aravissrc", 0, "Aravis interface");
diff --git a/gst-0.10/gstaravis.h b/gst-0.10/gstaravis.h
index 136442b..737fd7f 100644
--- a/gst-0.10/gstaravis.h
+++ b/gst-0.10/gstaravis.h
@@ -54,6 +54,7 @@ struct _GstAravis {
gint h_binning;
gint v_binning;
gboolean packet_resend;
+ gint num_buffers;
gint payload;
diff --git a/gst/gstaravis.c b/gst/gstaravis.c
index f6f4148..6d51f23 100644
--- a/gst/gstaravis.c
+++ b/gst/gstaravis.c
@@ -38,7 +38,7 @@
#include <time.h>
#include <string.h>
-#define GST_ARAVIS_N_BUFFERS 50
+#define GST_ARAVIS_DEFAULT_N_BUFFERS 50
#define GST_ARAVIS_BUFFER_TIMEOUT_DEFAULT 2000000
GST_DEBUG_CATEGORY_STATIC (aravis_debug);
@@ -57,7 +57,8 @@ enum
PROP_V_BINNING,
PROP_OFFSET_X,
PROP_OFFSET_Y,
- PROP_PACKET_RESEND
+ PROP_PACKET_RESEND,
+ PROP_NUM_BUFFERS
};
G_DEFINE_TYPE (GstAravis, gst_aravis, GST_TYPE_PUSH_SRC);
@@ -248,7 +249,7 @@ gst_aravis_set_caps (GstBaseSrc *src, GstCaps *caps)
else
g_object_set (gst_aravis->stream, "packet-resend", ARV_GV_STREAM_PACKET_RESEND_NEVER, NULL);
- for (i = 0; i < GST_ARAVIS_N_BUFFERS; i++)
+ for (i = 0; i < gst_aravis->num_buffers; i++)
arv_stream_push_buffer (gst_aravis->stream,
arv_buffer_new (gst_aravis->payload, NULL));
@@ -445,6 +446,7 @@ gst_aravis_init (GstAravis *gst_aravis)
gst_aravis->h_binning = -1;
gst_aravis->v_binning = -1;
gst_aravis->packet_resend = TRUE;
+ gst_aravis->num_buffers = GST_ARAVIS_DEFAULT_N_BUFFERS;
gst_aravis->payload = 0;
gst_aravis->buffer_timeout_us = GST_ARAVIS_BUFFER_TIMEOUT_DEFAULT;
@@ -538,6 +540,9 @@ gst_aravis_set_property (GObject * object, guint prop_id,
case PROP_PACKET_RESEND:
gst_aravis->packet_resend = g_value_get_boolean (value);
break;
+ case PROP_NUM_BUFFERS:
+ gst_aravis->num_buffers = g_value_get_int (value);
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
@@ -584,6 +589,9 @@ gst_aravis_get_property (GObject * object, guint prop_id, GValue * value,
case PROP_PACKET_RESEND:
g_value_set_boolean (value, gst_aravis->packet_resend);
break;
+ case PROP_NUM_BUFFERS:
+ g_value_set_int (value, gst_aravis->num_buffers);
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
@@ -692,6 +700,15 @@ gst_aravis_class_init (GstAravisClass * klass)
TRUE,
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
+ g_object_class_install_property
+ (gobject_class,
+ PROP_NUM_BUFFERS,
+ g_param_spec_int ("num-buffers",
+ "Number of Buffers",
+ "Number of video buffers to allocate for video frames",
+ 1, G_MAXINT, GST_ARAVIS_DEFAULT_N_BUFFERS,
+ G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
+
GST_DEBUG_CATEGORY_INIT (aravis_debug, "aravissrc", 0, "Aravis interface");
gst_element_class_set_details_simple (element_class,
diff --git a/gst/gstaravis.h b/gst/gstaravis.h
index a3a4ba1..4de65d7 100644
--- a/gst/gstaravis.h
+++ b/gst/gstaravis.h
@@ -54,6 +54,7 @@ struct _GstAravis {
gint h_binning;
gint v_binning;
gboolean packet_resend;
+ gint num_buffers;
gint payload;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]