summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaul B Mahol <onemda@gmail.com>2012-07-12 20:39:55 +0000
committerPaul B Mahol <onemda@gmail.com>2012-07-13 21:08:37 +0000
commit10338073135be8da2e47696636d26fe138248396 (patch)
tree163f705d4f93f43840d972b477614c914af64400
parent674216991d409316155695baeb6b69c22c758815 (diff)
exr: frame multithreading support
Signed-off-by: Paul B Mahol <onemda@gmail.com>
-rw-r--r--libavcodec/exr.c7
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"),
};