[FFmpeg-cvslog] exr: frame multithreading support
Paul B Mahol
git at videolan.org
Fri Jul 13 23:09:29 CEST 2012
ffmpeg | branch: master | Paul B Mahol <onemda at gmail.com> | Thu Jul 12 20:39:55 2012 +0000| [10338073135be8da2e47696636d26fe138248396] | committer: Paul B Mahol
exr: frame multithreading support
Signed-off-by: Paul B Mahol <onemda at gmail.com>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=10338073135be8da2e47696636d26fe138248396
---
libavcodec/exr.c | 7 ++++---
1 file changed, 4 insertions(+), 3 deletions(-)
diff --git a/libavcodec/exr.c b/libavcodec/exr.c
index 905d389..4a43821 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"),
};
More information about the ffmpeg-cvslog
mailing list