aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKostya Shishkov <kostya.shishkov@gmail.com>2012-02-17 09:46:53 +0100
committerKostya Shishkov <kostya.shishkov@gmail.com>2012-02-17 14:11:48 +0100
commit5d9ad5425f1fae4876e30c2c4500bfd0950e0d88 (patch)
treef6171f4e4fae2d046ca6d9bcf6d75b620ca964ef
parent25c42234a981477693dd419932575de0178e6aa5 (diff)
downloadffmpeg-5d9ad5425f1fae4876e30c2c4500bfd0950e0d88.tar.gz
prores: initialise encoder and decoder parts only when needed
-rw-r--r--libavcodec/proresdsp.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/libavcodec/proresdsp.c b/libavcodec/proresdsp.c
index e19eed208b..99adf64838 100644
--- a/libavcodec/proresdsp.c
+++ b/libavcodec/proresdsp.c
@@ -29,6 +29,7 @@
#define CLIP_AND_BIAS(x) (av_clip((x) + BIAS, CLIP_MIN, CLIP_MAX))
+#if CONFIG_PRORES_DECODER
/**
* Add bias value, clamp and output pixels of a slice
*/
@@ -50,7 +51,9 @@ static void prores_idct_put_c(uint16_t *out, int linesize, DCTELEM *block, const
ff_prores_idct(block, qmat);
put_pixels(out, linesize >> 1, block);
}
+#endif
+#if CONFIG_PRORES_ENCODER
static void prores_fdct_c(const uint16_t *src, int linesize, DCTELEM *block)
{
int x, y;
@@ -63,18 +66,23 @@ static void prores_fdct_c(const uint16_t *src, int linesize, DCTELEM *block)
}
ff_jpeg_fdct_islow_10(block);
}
+#endif
void ff_proresdsp_init(ProresDSPContext *dsp)
{
+#if CONFIG_PRORES_DECODER
dsp->idct_put = prores_idct_put_c;
dsp->idct_permutation_type = FF_NO_IDCT_PERM;
- dsp->fdct = prores_fdct_c;
- dsp->dct_permutation_type = FF_NO_IDCT_PERM;
if (HAVE_MMX) ff_proresdsp_x86_init(dsp);
ff_init_scantable_permutation(dsp->idct_permutation,
dsp->idct_permutation_type);
+#endif
+#if CONFIG_PRORES_ENCODER
+ dsp->fdct = prores_fdct_c;
+ dsp->dct_permutation_type = FF_NO_IDCT_PERM;
ff_init_scantable_permutation(dsp->dct_permutation,
dsp->dct_permutation_type);
+#endif
}