From cac0a56c555d1234dc1db33c3d4735d22ca8f7b8 Mon Sep 17 00:00:00 2001 From: Roman Shaposhnik Date: Wed, 31 Mar 2004 04:51:14 +0000 Subject: * .mov files with uncompressed audio can't be correctly processed because of the sample_size == 1 and MINOLTA hack relying on the information. So in a way, it's a hack of a hack. btw, if somebody knows why in the world even Apple's software thinks that for PCM 16bit sample_size == 1 please let me know. It clearly isn't documented that way. Originally committed as revision 2941 to svn://svn.ffmpeg.org/ffmpeg/trunk --- libavformat/mov.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 'libavformat/mov.c') diff --git a/libavformat/mov.c b/libavformat/mov.c index e1629be8ed..30378f22f4 100644 --- a/libavformat/mov.c +++ b/libavformat/mov.c @@ -1676,7 +1676,13 @@ again: for(i=0; i<(sc->sample_to_chunk_sz); i++) { if( (sc->sample_to_chunk[i].first)<=(sc->next_chunk) && (sc->sample_size>0) ) { - foundsize=sc->sample_to_chunk[i].count*sc->sample_size; + // I can't figure out why for PCM audio sample_size is always 1 + // (it should actually be channels*bits_per_second/8) but it is. + AVCodecContext* cod = &s->streams[sc->ffindex]->codec; + if (sc->sample_size == 1 && (cod->codec_id == CODEC_ID_PCM_S16BE || cod->codec_id == CODEC_ID_PCM_S16LE)) + foundsize=(sc->sample_to_chunk[i].count*cod->channels*cod->bits_per_sample)/8; + else + foundsize=sc->sample_to_chunk[i].count*sc->sample_size; } #ifdef DEBUG /*printf("sample_to_chunk first=%ld count=%ld, id=%ld\n", sc->sample_to_chunk[i].first, sc->sample_to_chunk[i].count, sc->sample_to_chunk[i].id);*/ -- cgit v1.2.3