aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec
diff options
context:
space:
mode:
authorDale Curtis <dalecurtis@chromium.org>2012-04-12 17:12:27 -0700
committerRonald S. Bultje <rsbultje@gmail.com>2012-04-12 21:32:01 -0700
commit97ae370078e5ee8e78269fe4d7b4f457e82bd758 (patch)
tree0bb2ae3c477dbf074780115ab26686d9e999592f /libavcodec
parent27c2fb0f721efb61f65017efa82c32c12de4287b (diff)
downloadffmpeg-97ae370078e5ee8e78269fe4d7b4f457e82bd758.tar.gz
pthread: Fix crash due to fctx->delaying not being cleared.
Reproducible with test case and ffplay -threads 2. Stack trace: http://pastebin.com/PexZ4Uc0 Test case: http://commondatastorage.googleapis.com/dalecurtis-shared/crash.ogm Signed-off-by: Dale Curtis <dalecurtis@chromium.org> Signed-off-by: Ronald S. Bultje <rsbultje@gmail.com>
Diffstat (limited to 'libavcodec')
-rw-r--r--libavcodec/pthread.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/libavcodec/pthread.c b/libavcodec/pthread.c
index ee7bdb5310..dc9220adc4 100644
--- a/libavcodec/pthread.c
+++ b/libavcodec/pthread.c
@@ -603,11 +603,12 @@ int ff_thread_decode_frame(AVCodecContext *avctx,
* If we're still receiving the initial packets, don't return a frame.
*/
- if (fctx->delaying && avpkt->size) {
+ if (fctx->delaying) {
if (fctx->next_decoding >= (avctx->thread_count-1)) fctx->delaying = 0;
*got_picture_ptr=0;
- return avpkt->size;
+ if (avpkt->size)
+ return avpkt->size;
}
/*