[FFmpeg-devel] [PATCH 04/10] diracdec: decode HQ profile slices in rows
Rostislav Pehlivanov
rpehlivanov at ob-encoder.com
Thu Jun 23 19:06:58 CEST 2016
Siginificantly improves the performance.
Signed-off-by: Rostislav Pehlivanov <rpehlivanov at obe.tv>
---
libavcodec/diracdec.c | 13 +++++++++++--
1 file changed, 11 insertions(+), 2 deletions(-)
diff --git a/libavcodec/diracdec.c b/libavcodec/diracdec.c
index b2008c5..c8ab2df 100644
--- a/libavcodec/diracdec.c
+++ b/libavcodec/diracdec.c
@@ -806,6 +806,16 @@ static int decode_hq_slice(AVCodecContext *avctx, void *arg)
return 0;
}
+static int decode_hq_slice_row(AVCodecContext *avctx, void *arg, int jobnr, int threadnr)
+{
+ int i;
+ DiracContext *s = avctx->priv_data;
+ DiracSlice *slices = ((DiracSlice *)arg) + s->num_x*jobnr;
+ for (i = 0; i < s->num_x; i++)
+ decode_hq_slice(avctx, &slices[i]);
+ return 0;
+}
+
/**
* Dirac Specification ->
* 13.5.1 low_delay_transform_data()
@@ -857,8 +867,7 @@ static int decode_lowdelay(DiracContext *s)
bufsize = 0;
}
}
- avctx->execute(avctx, decode_hq_slice, slices, NULL, slice_num,
- sizeof(DiracSlice));
+ avctx->execute2(avctx, decode_hq_slice_row, slices, NULL, s->num_y);
} else {
for (slice_y = 0; bufsize > 0 && slice_y < s->num_y; slice_y++) {
for (slice_x = 0; bufsize > 0 && slice_x < s->num_x; slice_x++) {
--
2.8.1.369.geae769a
More information about the ffmpeg-devel
mailing list