aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPaul B Mahol <onemda@gmail.com>2016-05-20 20:54:10 +0200
committerPaul B Mahol <onemda@gmail.com>2016-05-21 18:10:07 +0200
commit8e069eb525d46b8f89089e37fc7ac81b2d9b1092 (patch)
tree61def1d1071e28757f7db170e603ff72bb31281a
parentc749be9eb3499e82a66617c306d04b8b30e60e0d (diff)
downloadffmpeg-8e069eb525d46b8f89089e37fc7ac81b2d9b1092.tar.gz
avcodec/aic: add frame threading support
Signed-off-by: Paul B Mahol <onemda@gmail.com>
-rw-r--r--libavcodec/aic.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/libavcodec/aic.c b/libavcodec/aic.c
index 5decc78744..ff8e3922be 100644
--- a/libavcodec/aic.c
+++ b/libavcodec/aic.c
@@ -28,6 +28,7 @@
#include "get_bits.h"
#include "golomb.h"
#include "idctdsp.h"
+#include "thread.h"
#include "unary.h"
#define AIC_HDR_SIZE 24
@@ -375,6 +376,7 @@ static int aic_decode_frame(AVCodecContext *avctx, void *data, int *got_frame,
uint32_t off;
int x, y, ret;
int slice_size;
+ ThreadFrame frame = { .f = data };
ctx->frame = data;
ctx->frame->pict_type = AV_PICTURE_TYPE_I;
@@ -393,7 +395,7 @@ static int aic_decode_frame(AVCodecContext *avctx, void *data, int *got_frame,
return ret;
}
- if ((ret = ff_get_buffer(avctx, ctx->frame, 0)) < 0)
+ if ((ret = ff_thread_get_buffer(avctx, &frame, 0)) < 0)
return ret;
bytestream2_init(&gb, buf + AIC_HDR_SIZE,
@@ -488,5 +490,6 @@ AVCodec ff_aic_decoder = {
.init = aic_decode_init,
.close = aic_decode_close,
.decode = aic_decode_frame,
- .capabilities = AV_CODEC_CAP_DR1,
+ .capabilities = AV_CODEC_CAP_DR1 | AV_CODEC_CAP_FRAME_THREADS,
+ .init_thread_copy = ONLY_IF_THREADS_ENABLED(aic_decode_init),
};