summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog7
-rw-r--r--gst/mpegdemux/gstmpegtsdemux.c30
2 files changed, 36 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 301e66c3..e07adaf9 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,12 @@
2008-11-05 Zaheer Abbas Merali <zaheerabbas at merali dot org>
+ patch by: Josep Torra
+
+ * gst/mpegdemux/gstmpegtsdemux.c:
+ Heuristic approach when resyncing.
+
+2008-11-05 Zaheer Abbas Merali <zaheerabbas at merali dot org>
+
patch by: Sebastian Pölsterl
* gst/mpegdemux/gstmpegdesc.c:
diff --git a/gst/mpegdemux/gstmpegtsdemux.c b/gst/mpegdemux/gstmpegtsdemux.c
index 1aa2f387..c00d3b63 100644
--- a/gst/mpegdemux/gstmpegtsdemux.c
+++ b/gst/mpegdemux/gstmpegtsdemux.c
@@ -2458,6 +2458,33 @@ gst_fluts_demux_src_pad_query (GstPad * pad, GstQuery * query)
}
#endif
+
+static FORCE_INLINE gint
+is_mpegts_sync (const guint8 * in_data, const guint8 * end_data,
+ guint packetsize)
+{
+ guint ret = 0;
+ if (G_LIKELY (IS_MPEGTS_SYNC (in_data)))
+ return 100;
+
+ if (in_data + packetsize < end_data - 5) {
+ if (G_LIKELY (IS_MPEGTS_SYNC (in_data + packetsize)))
+ ret += 50;
+ }
+
+ if (in_data[0] == 0x47) {
+ ret += 25;
+
+ if ((in_data[1] & 0x80) == 0x00)
+ ret += 10;
+
+ if ((in_data[3] & 0x10) == 0x10)
+ ret += 5;
+ }
+ return ret;
+}
+
+
static FORCE_INLINE guint
gst_fluts_demux_sync_scan (GstFluTSDemux * demux, const guint8 * in_data,
guint size, guint * flush)
@@ -2468,7 +2495,8 @@ gst_fluts_demux_sync_scan (GstFluTSDemux * demux, const guint8 * in_data,
while (ptr_data <= end_scan && sync_count < LENGHT_SYNC_LUT) {
/* if sync code is found try to store it in the LUT */
- if (G_LIKELY (IS_MPEGTS_SYNC (ptr_data))) {
+ guint chance = is_mpegts_sync (ptr_data, end_scan, demux->packetsize);
+ if (G_LIKELY (chance > 50)) {
/* skip paketsize bytes and try find next */
guint8 *next_sync = ptr_data + demux->packetsize;
if (next_sync < end_scan) {