From 1fc84c8b3106ef7273a8016ec0505e2fa25470d3 Mon Sep 17 00:00:00 2001 From: Moritz Bunkus Date: Fri, 23 Mar 2007 11:53:18 +0000 Subject: [PATCH] Do not skip the first three bytes for normal AC3 tracks in MPEG program streams. --- ChangeLog | 5 +++++ src/input/r_mpeg.cpp | 4 ++-- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/ChangeLog b/ChangeLog index 6774200c9..42e976a9b 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +2007-03-23 Moritz Bunkus + + * mkvmerge: bug fix: Fixed a problem reading normal AC3 tracks + from MPEG program streams. + 2007-03-22 Moritz Bunkus * mkvmerge: bug fix: Fixed an issue with negative/huge timecodes diff --git a/src/input/r_mpeg.cpp b/src/input/r_mpeg.cpp index f48bec51a..d1a23eddf 100644 --- a/src/input/r_mpeg.cpp +++ b/src/input/r_mpeg.cpp @@ -890,12 +890,10 @@ mpeg_ps_reader_c::found_new_stream(int id) { track->type = '?'; if (id > 0xff) { track->type = 'a'; - track->skip_bytes = 3; if ((aid >= 0x20) && (aid <= 0x3f)) { track->type = 's'; track->fourcc = FOURCC('V', 'S', 'U', 'B'); - track->skip_bytes = 0; } else if (((aid >= 0x80) && (aid <= 0x87)) || ((aid >= 0xc0) && (aid <= 0xc7))) @@ -1100,6 +1098,8 @@ mpeg_ps_reader_c::create_packetizer(int64_t id) { ti.fname.c_str(), id); } else if (track->fourcc == FOURCC('A', 'C', '3', ' ')) { + if (16 == track->a_bsid) + track->skip_bytes = 3; track->ptzr = add_packetizer(new ac3_packetizer_c(this, track->a_sample_rate, track->a_channels,