summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSebastian Dröge <slomo@circular-chaos.org>2008-01-19 15:53:38 +0000
committerSebastian Dröge <slomo@circular-chaos.org>2008-01-19 15:53:38 +0000
commita0283af747eb72ba84298d2a264f957fc4fb8ea3 (patch)
treeea40b9dfce35c0d6440f98025404c04dbb8eac73
parentc7fcd9d5ae4f4ef2ea1a50542fa7ca93673cde8a (diff)
downloadgst-plugins-bad-a0283af747eb72ba84298d2a264f957fc4fb8ea3.tar.gz
gst-plugins-bad-a0283af747eb72ba84298d2a264f957fc4fb8ea3.tar.bz2
gst-plugins-bad-a0283af747eb72ba84298d2a264f957fc4fb8ea3.zip
gst/rawparse/gstrawparse.c: Improve handling of unknown or too small upstream sizes in pull mode.
Original commit message from CVS: * gst/rawparse/gstrawparse.c: (gst_raw_parse_loop): Improve handling of unknown or too small upstream sizes in pull mode.
-rw-r--r--ChangeLog6
-rw-r--r--gst/rawparse/gstrawparse.c11
2 files changed, 12 insertions, 5 deletions
diff --git a/ChangeLog b/ChangeLog
index dc3c321a..318a6d32 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,11 @@
2008-01-19 Sebastian Dröge <slomo@circular-chaos.org>
+ * gst/rawparse/gstrawparse.c: (gst_raw_parse_loop):
+ Improve handling of unknown or too small upstream sizes in
+ pull mode.
+
+2008-01-19 Sebastian Dröge <slomo@circular-chaos.org>
+
* gst/rawparse/gstrawparse.c: (gst_raw_parse_loop),
(gst_raw_parse_handle_seek_push):
Improve debugging a bit and for handling multiple frames per buffer
diff --git a/gst/rawparse/gstrawparse.c b/gst/rawparse/gstrawparse.c
index 16a6b9f7..be7549b0 100644
--- a/gst/rawparse/gstrawparse.c
+++ b/gst/rawparse/gstrawparse.c
@@ -304,13 +304,14 @@ gst_raw_parse_loop (GstElement * element)
if (rp->offset + size > rp->upstream_length) {
GstFormat fmt = GST_FORMAT_BYTES;
- if (!gst_pad_query_peer_duration (rp->sinkpad, &fmt, &rp->upstream_length)
- || rp->upstream_length < rp->offset + rp->framesize) {
+ if (!gst_pad_query_peer_duration (rp->sinkpad, &fmt, &rp->upstream_length)) {
+ GST_WARNING_OBJECT (rp,
+ "Could not get upstream duration, trying to pull frame by frame");
+ size = rp->framesize;
+ } else if (rp->upstream_length < rp->offset + rp->framesize) {
ret = GST_FLOW_UNEXPECTED;
goto pause;
- }
-
- if (rp->offset + size > rp->upstream_length) {
+ } else if (rp->offset + size > rp->upstream_length) {
size = rp->upstream_length - rp->offset;
size -= size % rp->framesize;
}