diff options
author | Sebastian Dröge <sebastian.droege@collabora.co.uk> | 2009-04-17 15:39:10 +0200 |
---|---|---|
committer | Sebastian Dröge <sebastian.droege@collabora.co.uk> | 2009-05-13 10:34:04 +0200 |
commit | 1419d1cddaab8ee5f58fe0766fa9dd1dcb57b3fa (patch) | |
tree | aad6054f1463603b3981851cecc3c158143270f2 | |
parent | b9659ac68b241d75e34bc4003467742127b65b6a (diff) |
[MOVED FROM BAD 51/56] deinterlace2: Fix timestamps for buffers with RFF flag set
-rw-r--r-- | gst/deinterlace2/gstdeinterlace2.c | 12 |
1 files changed, 5 insertions, 7 deletions
diff --git a/gst/deinterlace2/gstdeinterlace2.c b/gst/deinterlace2/gstdeinterlace2.c index 7bbe2494..3a42d0d5 100644 --- a/gst/deinterlace2/gstdeinterlace2.c +++ b/gst/deinterlace2/gstdeinterlace2.c @@ -734,18 +734,16 @@ gst_deinterlace2_push_history (GstDeinterlace2 * self, GstBuffer * buffer) the timestamp of the buffer equals the first fields timestamp */ timestamp = GST_BUFFER_TIMESTAMP (buffer); - if (repeated) { - GST_BUFFER_TIMESTAMP (field1) = timestamp; - GST_BUFFER_TIMESTAMP (field2) = timestamp + 2 * self->field_duration; - } else { - GST_BUFFER_TIMESTAMP (field1) = timestamp; - GST_BUFFER_TIMESTAMP (field2) = timestamp + self->field_duration; - } + GST_BUFFER_TIMESTAMP (field1) = timestamp; + GST_BUFFER_TIMESTAMP (field2) = timestamp + self->field_duration; + if (repeated) + GST_BUFFER_TIMESTAMP (field2) += self->field_duration; if (repeated) { self->field_history[0].buf = field2; self->field_history[0].flags = field2_flags; self->field_history[1].buf = gst_buffer_ref (field1); + GST_BUFFER_TIMESTAMP (self->field_history[1].buf) += self->field_duration; self->field_history[1].flags = field1_flags; self->field_history[2].buf = field1; self->field_history[2].flags = field1_flags; |