aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorUoti Urpala <uoti.urpala@pp1.inet.fi>2006-04-20 19:23:57 +0000
committerRoberto Togni <r_togni@tiscali.it>2006-04-20 19:23:57 +0000
commit4f26258f848e2a607f5f26288012492977c2930e (patch)
tree34b558d748013b83dd75d4c8640476f1999267d0
parentc3f11d199c2aa0590fb1b76ad994c1369dd02cde (diff)
downloadffmpeg-4f26258f848e2a607f5f26288012492977c2930e.tar.gz
dtsdec.c copies one input packet at a time to a (static) buffer of size
4096 bytes while the packet can be up to 18726 bytes. The code also keeps decoding until all input data has been used up, not respecting AVCODEC_MAX_AUDIO_FRAME_SIZE. The patch increases the buffer size and return after decoding one frame. Also fixes dts_decode_init to return -1, not 1, on failure. Patch by Uoti Urpala ||| uoti : urpala |!| pp1 : inet : fi ||| Originally committed as revision 5307 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r--libavcodec/dtsdec.c22
1 files changed, 11 insertions, 11 deletions
diff --git a/libavcodec/dtsdec.c b/libavcodec/dtsdec.c
index 261c98d4db..dd3268217e 100644
--- a/libavcodec/dtsdec.c
+++ b/libavcodec/dtsdec.c
@@ -33,8 +33,7 @@
#include <malloc.h>
#endif
-#define INBUF_SIZE 4096
-#define BUFFER_SIZE 4096
+#define BUFFER_SIZE 18726
#define HEADER_SIZE 14
#ifdef LIBDTS_FIXED
@@ -231,9 +230,11 @@ dts_decode_frame (AVCodecContext *avctx, void *data, int *data_size,
memcpy (bufptr, start, len);
bufptr += len;
start += len;
- if (bufptr == bufpos)
- {
- if (bufpos == buf + HEADER_SIZE)
+ if (bufptr != bufpos)
+ return start - buff;
+ if (bufpos != buf + HEADER_SIZE)
+ break;
+
{
int length;
@@ -248,7 +249,8 @@ dts_decode_frame (AVCodecContext *avctx, void *data, int *data_size,
}
bufpos = buf + length;
}
- else
+ }
+
{
level_t level;
sample_t bias;
@@ -280,16 +282,14 @@ dts_decode_frame (AVCodecContext *avctx, void *data, int *data_size,
}
bufptr = buf;
bufpos = buf + HEADER_SIZE;
- continue;
+ return start-buff;
error:
av_log (NULL, AV_LOG_ERROR, "error\n");
bufptr = buf;
bufpos = buf + HEADER_SIZE;
}
- }
- }
- return buff_size;
+ return start-buff;
}
static int
@@ -297,7 +297,7 @@ dts_decode_init (AVCodecContext *avctx)
{
avctx->priv_data = dts_init (0);
if (avctx->priv_data == NULL)
- return 1;
+ return -1;
return 0;
}