Commit 6e2ad28c authored by Paul B Mahol's avatar Paul B Mahol Committed by Vittorio Giovara

aic: add frame threading support

Signed-off-by: 's avatarPaul B Mahol <onemda@gmail.com>
parent c3ed259e
...@@ -28,6 +28,7 @@ ...@@ -28,6 +28,7 @@
#include "get_bits.h" #include "get_bits.h"
#include "golomb.h" #include "golomb.h"
#include "idctdsp.h" #include "idctdsp.h"
#include "thread.h"
#include "unary.h" #include "unary.h"
#define AIC_HDR_SIZE 24 #define AIC_HDR_SIZE 24
...@@ -373,6 +374,7 @@ static int aic_decode_frame(AVCodecContext *avctx, void *data, int *got_frame, ...@@ -373,6 +374,7 @@ static int aic_decode_frame(AVCodecContext *avctx, void *data, int *got_frame,
uint32_t off; uint32_t off;
int x, y, ret; int x, y, ret;
int slice_size; int slice_size;
ThreadFrame frame = { .f = data };
ctx->frame = data; ctx->frame = data;
ctx->frame->pict_type = AV_PICTURE_TYPE_I; ctx->frame->pict_type = AV_PICTURE_TYPE_I;
...@@ -391,7 +393,7 @@ static int aic_decode_frame(AVCodecContext *avctx, void *data, int *got_frame, ...@@ -391,7 +393,7 @@ static int aic_decode_frame(AVCodecContext *avctx, void *data, int *got_frame,
return ret; return ret;
} }
if ((ret = ff_get_buffer(avctx, ctx->frame, 0)) < 0) if ((ret = ff_thread_get_buffer(avctx, &frame, 0)) < 0)
return ret; return ret;
bytestream2_init(&gb, buf + AIC_HDR_SIZE, bytestream2_init(&gb, buf + AIC_HDR_SIZE,
...@@ -484,5 +486,6 @@ AVCodec ff_aic_decoder = { ...@@ -484,5 +486,6 @@ AVCodec ff_aic_decoder = {
.init = aic_decode_init, .init = aic_decode_init,
.close = aic_decode_close, .close = aic_decode_close,
.decode = aic_decode_frame, .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),
}; };
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment