summaryrefslogtreecommitdiff
path: root/libavcodec/vc1dsp.c
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2014-01-13 14:04:48 +0100
committerMichael Niedermayer <michaelni@gmx.at>2014-01-13 14:04:58 +0100
commit1df53ff22de2732596571ea98b8bad1c6dd42543 (patch)
treebf6589b1361676d804d010146453dec18f3be591 /libavcodec/vc1dsp.c
parent22bfb4be284c12f33b9dac010713fe3ca6d974bf (diff)
parentc798a6fedc3dd9ed3ac1fb2d95819af58705a87e (diff)
Merge commit 'c798a6fedc3dd9ed3ac1fb2d95819af58705a87e'
* commit 'c798a6fedc3dd9ed3ac1fb2d95819af58705a87e': vc1: Factorize out chroma MC Merged-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec/vc1dsp.c')
-rw-r--r--libavcodec/vc1dsp.c71
1 files changed, 23 insertions, 48 deletions
diff --git a/libavcodec/vc1dsp.c b/libavcodec/vc1dsp.c
index 5c1c977b0e..960db5602f 100644
--- a/libavcodec/vc1dsp.c
+++ b/libavcodec/vc1dsp.c
@@ -694,6 +694,9 @@ PUT_VC1_MSPEL(1, 3)
PUT_VC1_MSPEL(2, 3)
PUT_VC1_MSPEL(3, 3)
+#define chroma_mc(a) \
+ ((A * src[a] + B * src[a + 1] + \
+ C * src[stride + a] + D * src[stride + a + 1] + 32 - 4) >> 6)
static void put_no_rnd_vc1_chroma_mc8_c(uint8_t *dst /* align 8 */,
uint8_t *src /* align 1 */,
int stride, int h, int x, int y)
@@ -707,22 +710,14 @@ static void put_no_rnd_vc1_chroma_mc8_c(uint8_t *dst /* align 8 */,
av_assert2(x < 8 && y < 8 && x >= 0 && y >= 0);
for (i = 0; i < h; i++) {
- dst[0] = (A * src[0] + B * src[1] +
- C * src[stride + 0] + D * src[stride + 1] + 32 - 4) >> 6;
- dst[1] = (A * src[1] + B * src[2] +
- C * src[stride + 1] + D * src[stride + 2] + 32 - 4) >> 6;
- dst[2] = (A * src[2] + B * src[3] +
- C * src[stride + 2] + D * src[stride + 3] + 32 - 4) >> 6;
- dst[3] = (A * src[3] + B * src[4] +
- C * src[stride + 3] + D * src[stride + 4] + 32 - 4) >> 6;
- dst[4] = (A * src[4] + B * src[5] +
- C * src[stride + 4] + D * src[stride + 5] + 32 - 4) >> 6;
- dst[5] = (A * src[5] + B * src[6] +
- C * src[stride + 5] + D * src[stride + 6] + 32 - 4) >> 6;
- dst[6] = (A * src[6] + B * src[7] +
- C * src[stride + 6] + D * src[stride + 7] + 32 - 4) >> 6;
- dst[7] = (A * src[7] + B * src[8] +
- C * src[stride + 7] + D * src[stride + 8] + 32 - 4) >> 6;
+ dst[0] = chroma_mc(0);
+ dst[1] = chroma_mc(1);
+ dst[2] = chroma_mc(2);
+ dst[3] = chroma_mc(3);
+ dst[4] = chroma_mc(4);
+ dst[5] = chroma_mc(5);
+ dst[6] = chroma_mc(6);
+ dst[7] = chroma_mc(7);
dst += stride;
src += stride;
}
@@ -740,14 +735,10 @@ static void put_no_rnd_vc1_chroma_mc4_c(uint8_t *dst, uint8_t *src,
av_assert2(x < 8 && y < 8 && x >= 0 && y >= 0);
for (i = 0; i < h; i++) {
- dst[0] = (A * src[0] + B * src[1] +
- C * src[stride + 0] + D * src[stride + 1] + 32 - 4) >> 6;
- dst[1] = (A * src[1] + B * src[2] +
- C * src[stride + 1] + D * src[stride + 2] + 32 - 4) >> 6;
- dst[2] = (A * src[2] + B * src[3] +
- C * src[stride + 2] + D * src[stride + 3] + 32 - 4) >> 6;
- dst[3] = (A * src[3] + B * src[4] +
- C * src[stride + 3] + D * src[stride + 4] + 32 - 4) >> 6;
+ dst[0] = chroma_mc(0);
+ dst[1] = chroma_mc(1);
+ dst[2] = chroma_mc(2);
+ dst[3] = chroma_mc(3);
dst += stride;
src += stride;
}
@@ -767,30 +758,14 @@ static void avg_no_rnd_vc1_chroma_mc8_c(uint8_t *dst /* align 8 */,
av_assert2(x < 8 && y < 8 && x >= 0 && y >= 0);
for (i = 0; i < h; i++) {
- dst[0] = avg2(dst[0], ((A * src[0] + B * src[1] +
- C * src[stride + 0] + D * src[stride + 1] +
- 32 - 4) >> 6));
- dst[1] = avg2(dst[1], ((A * src[1] + B * src[2] +
- C * src[stride + 1] + D * src[stride + 2] +
- 32 - 4) >> 6));
- dst[2] = avg2(dst[2], ((A * src[2] + B * src[3] +
- C * src[stride + 2] + D * src[stride + 3] +
- 32 - 4) >> 6));
- dst[3] = avg2(dst[3], ((A * src[3] + B * src[4] +
- C * src[stride + 3] + D * src[stride + 4] +
- 32 - 4) >> 6));
- dst[4] = avg2(dst[4], ((A * src[4] + B * src[5] +
- C * src[stride + 4] + D * src[stride + 5] +
- 32 - 4) >> 6));
- dst[5] = avg2(dst[5], ((A * src[5] + B * src[6] +
- C * src[stride + 5] + D * src[stride + 6] +
- 32 - 4) >> 6));
- dst[6] = avg2(dst[6], ((A * src[6] + B * src[7] +
- C * src[stride + 6] + D * src[stride + 7] +
- 32 - 4) >> 6));
- dst[7] = avg2(dst[7], ((A * src[7] + B * src[8] +
- C * src[stride + 7] + D * src[stride + 8] +
- 32 - 4) >> 6));
+ dst[0] = avg2(dst[0], chroma_mc(0));
+ dst[1] = avg2(dst[1], chroma_mc(1));
+ dst[2] = avg2(dst[2], chroma_mc(2));
+ dst[3] = avg2(dst[3], chroma_mc(3));
+ dst[4] = avg2(dst[4], chroma_mc(4));
+ dst[5] = avg2(dst[5], chroma_mc(5));
+ dst[6] = avg2(dst[6], chroma_mc(6));
+ dst[7] = avg2(dst[7], chroma_mc(7));
dst += stride;
src += stride;
}