aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat/mov.c
diff options
context:
space:
mode:
authorBaptiste Coudurier <baptiste.coudurier@gmail.com>2008-02-13 10:52:23 +0000
committerBaptiste Coudurier <baptiste.coudurier@gmail.com>2008-02-13 10:52:23 +0000
commit531527652f84df55418f3953c760308eaf576615 (patch)
treef9efe6f1133857e0658ca43713c2770d57ea6d8c /libavformat/mov.c
parent5e53486545726987ab4482321d4dcf7e23e7652f (diff)
downloadffmpeg-531527652f84df55418f3953c760308eaf576615.tar.gz
remove messy and not always correct chunk size workaround, use correct values instead
Originally committed as revision 11921 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat/mov.c')
-rw-r--r--libavformat/mov.c45
1 files changed, 17 insertions, 28 deletions
diff --git a/libavformat/mov.c b/libavformat/mov.c
index c1d5e7c78e..44c71f24bd 100644
--- a/libavformat/mov.c
+++ b/libavformat/mov.c
@@ -760,6 +760,19 @@ static int mov_read_stsd(MOVContext *c, ByteIOContext *pb, MOV_atom_t atom)
else if (st->codec->bits_per_sample == 24)
st->codec->codec_id = CODEC_ID_PCM_S24BE;
break;
+ /* set values for old format before stsd version 1 appeared */
+ case CODEC_ID_MACE3:
+ sc->samples_per_frame = 6;
+ sc->bytes_per_frame = 2*st->codec->channels;
+ break;
+ case CODEC_ID_MACE6:
+ sc->samples_per_frame = 6;
+ sc->bytes_per_frame = 1*st->codec->channels;
+ break;
+ case CODEC_ID_ADPCM_IMA_QT:
+ sc->samples_per_frame = 64;
+ sc->bytes_per_frame = 34*st->codec->channels;
+ break;
default:
break;
}
@@ -1326,7 +1339,7 @@ static void mov_build_index(MOVContext *mov, AVStream *st)
unsigned int stts_index = 0;
unsigned int stsc_index = 0;
unsigned int stss_index = 0;
- unsigned int i, j, k;
+ unsigned int i, j;
if (sc->sample_sizes || st->codec->codec_type == CODEC_TYPE_VIDEO ||
sc->audio_cid == -2) {
@@ -1393,33 +1406,9 @@ static void mov_build_index(MOVContext *mov, AVStream *st)
frames = chunk_samples / sc->samples_per_frame;
chunk_samples = sc->samples_per_frame;
}
- } else { /* workaround to find nearest next chunk offset */
- chunk_size = INT_MAX;
- for (j = 0; j < mov->fc->nb_streams; j++) {
- MOVStreamContext *msc = mov->fc->streams[j]->priv_data;
- for (k = msc->next_chunk; k < msc->chunk_count; k++) {
- if (msc->chunk_offsets[k] > current_offset &&
- msc->chunk_offsets[k] - current_offset < chunk_size) {
- chunk_size = msc->chunk_offsets[k] - current_offset;
- msc->next_chunk = k;
- break;
- }
- }
- }
- /* check for last chunk */
- if (chunk_size == INT_MAX)
- for (j = 0; j < mov->mdat_count; j++) {
- dprintf(mov->fc, "mdat %d, offset %"PRIx64", size %"PRId64", current offset %"PRIx64"\n",
- j, mov->mdat_list[j].offset, mov->mdat_list[j].size, current_offset);
- if (mov->mdat_list[j].offset <= current_offset &&
- mov->mdat_list[j].offset + mov->mdat_list[j].size > current_offset)
- chunk_size = mov->mdat_list[j].offset + mov->mdat_list[j].size - current_offset;
- }
- assert(chunk_size != INT_MAX);
- for (j = 0; j < mov->fc->nb_streams; j++) {
- MOVStreamContext *msc = mov->fc->streams[j]->priv_data;
- msc->next_chunk = 0;
- }
+ } else {
+ av_log(mov->fc, AV_LOG_ERROR, "could not determine chunk size, report problem\n");
+ goto out;
}
for (j = 0; j < frames; j++) {
av_add_index_entry(st, current_offset, current_dts, chunk_size, 0, AVINDEX_KEYFRAME);