Commit cc5d17e0 authored by Ronald S. Bultje's avatar Ronald S. Bultje Committed by Michael Niedermayer

mimic: use hpeldsp instead of dsputil for half-pel functions.

parent 04a75bb7
...@@ -1749,7 +1749,7 @@ lagarith_decoder_select="dsputil" ...@@ -1749,7 +1749,7 @@ lagarith_decoder_select="dsputil"
ljpeg_encoder_select="aandcttables mpegvideoenc" ljpeg_encoder_select="aandcttables mpegvideoenc"
loco_decoder_select="golomb" loco_decoder_select="golomb"
mdec_decoder_select="dsputil error_resilience mpegvideo" mdec_decoder_select="dsputil error_resilience mpegvideo"
mimic_decoder_select="dsputil" mimic_decoder_select="dsputil hpeldsp"
mjpeg_encoder_select="aandcttables dsputil mpegvideoenc" mjpeg_encoder_select="aandcttables dsputil mpegvideoenc"
mlp_decoder_select="dsputil mlp_parser" mlp_decoder_select="dsputil mlp_parser"
motionpixels_decoder_select="dsputil" motionpixels_decoder_select="dsputil"
......
...@@ -28,6 +28,7 @@ ...@@ -28,6 +28,7 @@
#include "get_bits.h" #include "get_bits.h"
#include "bytestream.h" #include "bytestream.h"
#include "dsputil.h" #include "dsputil.h"
#include "hpeldsp.h"
#include "thread.h" #include "thread.h"
#define MIMIC_HEADER_SIZE 20 #define MIMIC_HEADER_SIZE 20
...@@ -52,6 +53,7 @@ typedef struct { ...@@ -52,6 +53,7 @@ typedef struct {
GetBitContext gb; GetBitContext gb;
ScanTable scantable; ScanTable scantable;
DSPContext dsp; DSPContext dsp;
HpelDSPContext hdsp;
VLC vlc; VLC vlc;
/* Kept in the context so multithreading can have a constant to read from */ /* Kept in the context so multithreading can have a constant to read from */
...@@ -144,6 +146,7 @@ static av_cold int mimic_decode_init(AVCodecContext *avctx) ...@@ -144,6 +146,7 @@ static av_cold int mimic_decode_init(AVCodecContext *avctx)
return ret; return ret;
} }
ff_dsputil_init(&ctx->dsp, avctx); ff_dsputil_init(&ctx->dsp, avctx);
ff_hpeldsp_init(&ctx->hdsp, avctx->flags);
ff_init_scantable(ctx->dsp.idct_permutation, &ctx->scantable, col_zag); ff_init_scantable(ctx->dsp.idct_permutation, &ctx->scantable, col_zag);
for (i = 0; i < FF_ARRAY_ELEMS(ctx->frames); i++) { for (i = 0; i < FF_ARRAY_ELEMS(ctx->frames); i++) {
...@@ -304,7 +307,7 @@ static int decode(MimicContext *ctx, int quality, int num_coeffs, ...@@ -304,7 +307,7 @@ static int decode(MimicContext *ctx, int quality, int num_coeffs,
cur_row, 0); cur_row, 0);
p += src - p += src -
ctx->flipped_ptrs[ctx->prev_index].data[plane]; ctx->flipped_ptrs[ctx->prev_index].data[plane];
ctx->dsp.put_pixels_tab[1][0](dst, p, stride, 8); ctx->hdsp.put_pixels_tab[1][0](dst, p, stride, 8);
} else { } else {
av_log(ctx->avctx, AV_LOG_ERROR, av_log(ctx->avctx, AV_LOG_ERROR,
"No such backreference! Buggy sample.\n"); "No such backreference! Buggy sample.\n");
...@@ -313,7 +316,7 @@ static int decode(MimicContext *ctx, int quality, int num_coeffs, ...@@ -313,7 +316,7 @@ static int decode(MimicContext *ctx, int quality, int num_coeffs,
} else { } else {
ff_thread_await_progress(&ctx->frames[ctx->prev_index], ff_thread_await_progress(&ctx->frames[ctx->prev_index],
cur_row, 0); cur_row, 0);
ctx->dsp.put_pixels_tab[1][0](dst, src, stride, 8); ctx->hdsp.put_pixels_tab[1][0](dst, src, stride, 8);
} }
src += 8; src += 8;
dst += 8; dst += 8;
......
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