summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSebastian Dröge <sebastian@centricular.com>2017-07-05 00:48:36 +0300
committerSebastian Dröge <sebastian@centricular.com>2017-07-05 00:50:32 +0300
commit6a1b95bfb5d89d1383aee91d375bdee34430cc1d (patch)
tree348f74ef2a71c67d941211433c74ff9b1d9398c1
parentbf16241150cdf133b007994c4962063a51bcd986 (diff)
downloadgstreamer-plugins-bad-6a1b95bfb5d89d1383aee91d375bdee34430cc1d.tar.gz
mxfdemux: Don't include any KLV packets between header metadata and index table segments in calculations
Minor fixup of last commit.
-rw-r--r--gst/mxf/mxfdemux.c31
1 files changed, 21 insertions, 10 deletions
diff --git a/gst/mxf/mxfdemux.c b/gst/mxf/mxfdemux.c
index 5716f949f..d796e807b 100644
--- a/gst/mxf/mxfdemux.c
+++ b/gst/mxf/mxfdemux.c
@@ -2016,23 +2016,34 @@ read_partition_header (GstMXFDemux * demux)
return;
}
- while (demux->offset <
- demux->run_in +
- demux->current_partition->partition.this_partition +
- demux->current_partition->partition.header_byte_count +
- demux->current_partition->partition.index_byte_count) {
- if (mxf_is_index_table_segment (&key)) {
- gst_mxf_demux_handle_index_table_segment (demux, &key, buf,
- demux->offset);
- }
+ while (mxf_is_fill (&key)) {
demux->offset += read;
-
gst_buffer_unref (buf);
if (gst_mxf_demux_pull_klv_packet (demux, demux->offset, &key, &buf, &read)
!= GST_FLOW_OK)
return;
}
+ if (demux->current_partition->partition.index_byte_count
+ && mxf_is_index_table_segment (&key)) {
+ guint64 index_end_offset =
+ demux->offset + demux->current_partition->partition.index_byte_count;
+
+ while (demux->offset < index_end_offset) {
+ if (mxf_is_index_table_segment (&key)) {
+ gst_mxf_demux_handle_index_table_segment (demux, &key, buf,
+ demux->offset);
+ }
+ demux->offset += read;
+
+ gst_buffer_unref (buf);
+ if (gst_mxf_demux_pull_klv_packet (demux, demux->offset, &key, &buf,
+ &read)
+ != GST_FLOW_OK)
+ return;
+ }
+ }
+
while (mxf_is_fill (&key)) {
demux->offset += read;
gst_buffer_unref (buf);