diff options
author | Paul B Mahol <onemda@gmail.com> | 2012-07-12 20:39:55 +0000 |
---|---|---|
committer | Paul B Mahol <onemda@gmail.com> | 2012-07-13 21:08:37 +0000 |
commit | 10338073135be8da2e47696636d26fe138248396 (patch) | |
tree | 163f705d4f93f43840d972b477614c914af64400 /libavcodec/exr.c | |
parent | 674216991d409316155695baeb6b69c22c758815 (diff) | |
download | ffmpeg-10338073135be8da2e47696636d26fe138248396.tar.gz |
exr: frame multithreading support
Signed-off-by: Paul B Mahol <onemda@gmail.com>
Diffstat (limited to 'libavcodec/exr.c')
-rw-r--r-- | libavcodec/exr.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/libavcodec/exr.c b/libavcodec/exr.c index 905d389d03..4a438214cf 100644 --- a/libavcodec/exr.c +++ b/libavcodec/exr.c @@ -35,6 +35,7 @@ #include "avcodec.h" #include "bytestream.h" #include "mathops.h" +#include "thread.h" #include "libavutil/imgutils.h" enum ExrCompr { @@ -478,7 +479,7 @@ static int decode_frame(AVCodecContext *avctx, } if (s->picture.data[0]) - avctx->release_buffer(avctx, &s->picture); + ff_thread_release_buffer(avctx, &s->picture); if (av_image_check_size(w, h, 0, avctx)) return AVERROR_INVALIDDATA; @@ -505,7 +506,7 @@ static int decode_frame(AVCodecContext *avctx, return AVERROR(ENOMEM); } - if ((ret = avctx->get_buffer(avctx, p)) < 0) { + if ((ret = ff_thread_get_buffer(avctx, p)) < 0) { av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n"); return ret; } @@ -660,6 +661,6 @@ AVCodec ff_exr_decoder = { .init = decode_init, .close = decode_end, .decode = decode_frame, - .capabilities = CODEC_CAP_DR1, + .capabilities = CODEC_CAP_DR1 | CODEC_CAP_FRAME_THREADS, .long_name = NULL_IF_CONFIG_SMALL("OpenEXR image"), }; |