From 5f51afd6024015834a993417324c8a44dd0ed744 Mon Sep 17 00:00:00 2001 From: Guillaume Poirier Date: Wed, 17 Dec 2008 09:47:06 +0000 Subject: [PATCH] add AltiVec implementation of int32_to_float_fmul_scalar Originally committed as revision 16186 to svn://svn.ffmpeg.org/ffmpeg/trunk --- libavcodec/ppc/float_altivec.c | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/libavcodec/ppc/float_altivec.c b/libavcodec/ppc/float_altivec.c index 1f39d8f461..e27ac03f24 100644 --- a/libavcodec/ppc/float_altivec.c +++ b/libavcodec/ppc/float_altivec.c @@ -150,6 +150,30 @@ static void vector_fmul_add_add_altivec(float *dst, const float *src0, } +static void int32_to_float_fmul_scalar_altivec(float *dst, const int *src, float mul, int len) +{ + union { + vector float v; + float s[4]; + } mul_u; + int i; + vector float src1, src2, dst1, dst2, mul_v, zero; + + zero = (vector float)vec_splat_u32(0); + mul_u.s[0] = mul; + mul_v = vec_splat(mul_u.v, 0); + + for(i=0; ivector_fmul = vector_fmul_altivec; c->vector_fmul_reverse = vector_fmul_reverse_altivec; c->vector_fmul_add_add = vector_fmul_add_add_altivec; + c->int32_to_float_fmul_scalar = int32_to_float_fmul_scalar_altivec; if(!(avctx->flags & CODEC_FLAG_BITEXACT)) { c->float_to_int16 = float_to_int16_altivec; c->float_to_int16_interleave = float_to_int16_interleave_altivec;