Commit 834c91f2 authored by bcoudurier's avatar bcoudurier

use correct demux mechanism when audio compression id is -2, dv audio does not...

use correct demux mechanism when audio compression id is -2, dv audio does not matter, demux partially qt_dv_pal_test.mov which does NOT use cid -2

git-svn-id: file:///var/local/repositories/ffmpeg/trunk@11908 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent dfd6eee5
...@@ -108,6 +108,7 @@ typedef struct MOVStreamContext { ...@@ -108,6 +108,7 @@ typedef struct MOVStreamContext {
unsigned int samples_per_frame; unsigned int samples_per_frame;
int dv_audio_container; int dv_audio_container;
int pseudo_stream_id; int pseudo_stream_id;
int16_t audio_cid; ///< stsd audio compression id
} MOVStreamContext; } MOVStreamContext;
typedef struct MOVContext { typedef struct MOVContext {
...@@ -743,7 +744,7 @@ static int mov_read_stsd(MOVContext *c, ByteIOContext *pb, MOV_atom_t atom) ...@@ -743,7 +744,7 @@ static int mov_read_stsd(MOVContext *c, ByteIOContext *pb, MOV_atom_t atom)
/* do we need to force to 16 for AMR ? */ /* do we need to force to 16 for AMR ? */
/* handle specific s8 codec */ /* handle specific s8 codec */
get_be16(pb); /* compression id = 0*/ sc->audio_cid = get_be16(pb);
get_be16(pb); /* packet size = 0 */ get_be16(pb); /* packet size = 0 */
st->codec->sample_rate = ((get_be32(pb) >> 16)); st->codec->sample_rate = ((get_be32(pb) >> 16));
...@@ -1329,7 +1330,8 @@ static void mov_build_index(MOVContext *mov, AVStream *st) ...@@ -1329,7 +1330,8 @@ static void mov_build_index(MOVContext *mov, AVStream *st)
unsigned int stss_index = 0; unsigned int stss_index = 0;
unsigned int i, j, k; unsigned int i, j, k;
if (sc->sample_sizes || st->codec->codec_type == CODEC_TYPE_VIDEO || sc->dv_audio_container) { if (sc->sample_sizes || st->codec->codec_type == CODEC_TYPE_VIDEO ||
sc->audio_cid == -2) {
unsigned int current_sample = 0; unsigned int current_sample = 0;
unsigned int stts_sample = 0; unsigned int stts_sample = 0;
unsigned int keyframe, sample_size; unsigned int keyframe, sample_size;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment