summaryrefslogtreecommitdiffstats
path: root/sys/v4l2
diff options
context:
space:
mode:
Diffstat (limited to 'sys/v4l2')
-rw-r--r--sys/v4l2/gstv4l2element.h1
-rw-r--r--sys/v4l2/gstv4l2src.c25
-rw-r--r--sys/v4l2/gstv4l2src.h2
-rw-r--r--sys/v4l2/v4l2src_calls.c4
4 files changed, 25 insertions, 7 deletions
diff --git a/sys/v4l2/gstv4l2element.h b/sys/v4l2/gstv4l2element.h
index 61442aff..0fadf068 100644
--- a/sys/v4l2/gstv4l2element.h
+++ b/sys/v4l2/gstv4l2element.h
@@ -38,6 +38,7 @@
#include <sys/types.h>
#include <linux/types.h>
#define _LINUX_TIME_H
+#define __user
#include <linux/videodev2.h>
/*
diff --git a/sys/v4l2/gstv4l2src.c b/sys/v4l2/gstv4l2src.c
index 9d8b0e6e..40bc0dae 100644
--- a/sys/v4l2/gstv4l2src.c
+++ b/sys/v4l2/gstv4l2src.c
@@ -255,6 +255,8 @@ gst_v4l2src_init (GTypeInstance * instance, gpointer g_class)
/* fps */
v4l2src->use_fixed_fps = TRUE;
+
+ v4l2src->is_capturing = FALSE;
}
@@ -384,7 +386,7 @@ gst_v4l2src_v4l2fourcc_to_caps (guint32 fourcc)
switch (fourcc) {
case V4L2_PIX_FMT_MJPEG: /* Motion-JPEG */
case V4L2_PIX_FMT_JPEG: /* JFIF JPEG */
- structure = gst_structure_new ("video/x-jpeg", NULL);
+ structure = gst_structure_new ("image/jpeg", NULL);
break;
case V4L2_PIX_FMT_RGB332:
case V4L2_PIX_FMT_RGB555:
@@ -631,7 +633,7 @@ gst_v4l2_fourcc_from_structure (GstStructure * structure)
}
} else if (strcmp (mimetype, "video/x-dv") == 0) {
fourcc = V4L2_PIX_FMT_DV;
- } else if (strcmp (mimetype, "video/x-jpeg") == 0) {
+ } else if (strcmp (mimetype, "image/jpeg") == 0) {
fourcc = V4L2_PIX_FMT_JPEG;
}
@@ -714,6 +716,7 @@ gst_v4l2src_link (GstPad * pad, const GstCaps * caps)
struct v4l2_fmtdesc *format;
int w, h;
GstStructure *structure;
+ gboolean was_capturing;
v4l2src = GST_V4L2SRC (gst_pad_get_parent (pad));
v4l2element = GST_V4L2ELEMENT (v4l2src);
@@ -722,6 +725,10 @@ gst_v4l2src_link (GstPad * pad, const GstCaps * caps)
/* clean up if we still haven't cleaned up our previous
* capture session */
+ if ((was_capturing = v4l2src->is_capturing)) {
+ if (!gst_v4l2src_capture_stop (v4l2src))
+ return GST_PAD_LINK_REFUSED;
+ }
if (GST_V4L2_IS_ACTIVE (v4l2element)) {
if (!gst_v4l2src_capture_deinit (v4l2src))
return GST_PAD_LINK_REFUSED;
@@ -740,6 +747,10 @@ gst_v4l2src_link (GstPad * pad, const GstCaps * caps)
/* we found the pixelformat! - try it out */
if (gst_v4l2src_set_capture (v4l2src, format, w, h)) {
if (gst_v4l2src_capture_init (v4l2src)) {
+ if (was_capturing || GST_STATE (v4l2src) == GST_STATE_PLAYING)
+ if (!gst_v4l2src_capture_start (v4l2src))
+ return GST_PAD_LINK_REFUSED;
+
return GST_PAD_LINK_OK;
}
}
@@ -759,7 +770,7 @@ gst_v4l2src_getcaps (GstPad * pad)
GstStructure *structure;
if (!GST_V4L2_IS_OPEN (GST_V4L2ELEMENT (v4l2src))) {
- return gst_caps_new_any ();
+ return gst_caps_copy (gst_pad_get_pad_template_caps (pad));
}
/* build our own capslist */
@@ -1022,7 +1033,8 @@ gst_v4l2src_change_state (GstElement * element)
break;
case GST_STATE_PAUSED_TO_PLAYING:
/* queue all buffer, start streaming capture */
- if (!gst_v4l2src_capture_start (v4l2src))
+ if (GST_V4L2ELEMENT (v4l2src)->buffer &&
+ !gst_v4l2src_capture_start (v4l2src))
return GST_STATE_FAILURE;
g_get_current_time (&time);
v4l2src->substract_time = GST_TIMEVAL_TO_TIME (time) -
@@ -1034,12 +1046,13 @@ gst_v4l2src_change_state (GstElement * element)
v4l2src->substract_time = GST_TIMEVAL_TO_TIME (time) -
v4l2src->substract_time;
/* de-queue all queued buffers */
- if (!gst_v4l2src_capture_stop (v4l2src))
+ if (v4l2src->is_capturing && !gst_v4l2src_capture_stop (v4l2src))
return GST_STATE_FAILURE;
break;
case GST_STATE_PAUSED_TO_READY:
/* stop capturing, unmap all buffers */
- if (!gst_v4l2src_capture_deinit (v4l2src))
+ if (GST_V4L2ELEMENT (v4l2src)->buffer &&
+ !gst_v4l2src_capture_deinit (v4l2src))
return GST_STATE_FAILURE;
break;
case GST_STATE_READY_TO_NULL:
diff --git a/sys/v4l2/gstv4l2src.h b/sys/v4l2/gstv4l2src.h
index ca528d1e..cbcfc6ec 100644
--- a/sys/v4l2/gstv4l2src.h
+++ b/sys/v4l2/gstv4l2src.h
@@ -75,7 +75,7 @@ struct _GstV4l2Src {
struct v4l2_format format;
/* True if we want to stop */
- gboolean quit;
+ gboolean quit, is_capturing;
/* A/V sync... frame counter and internal cache */
gulong handled;
diff --git a/sys/v4l2/v4l2src_calls.c b/sys/v4l2/v4l2src_calls.c
index a2db4f2b..3754bbcc 100644
--- a/sys/v4l2/v4l2src_calls.c
+++ b/sys/v4l2/v4l2src_calls.c
@@ -317,6 +317,7 @@ gst_v4l2src_capture_init (GstV4l2Src * v4l2src)
}
GST_V4L2_SET_ACTIVE (GST_V4L2ELEMENT (v4l2src));
+
return TRUE;
}
@@ -349,6 +350,8 @@ gst_v4l2src_capture_start (GstV4l2Src * v4l2src)
return FALSE;
}
+ v4l2src->is_capturing = TRUE;
+
return TRUE;
}
@@ -379,6 +382,7 @@ gst_v4l2src_capture_stop (GstV4l2Src * v4l2src)
/* make an optional pending wait stop */
v4l2src->quit = TRUE;
+ v4l2src->is_capturing = FALSE;
return TRUE;
}