aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2014-05-30 01:23:04 +0200
committerMichael Niedermayer <michaelni@gmx.at>2014-05-30 01:23:04 +0200
commitd35899ccce39e77a3f7fb667bdfc710c605d03a4 (patch)
treea72ecac476a799f37c63fe704758f61044a999e8 /libavcodec
parent40f3a87c10d5773eb66e09f4ed3d8197b1840863 (diff)
parentcb52a17cb62297802b0a77e5af9850d87c3f925b (diff)
downloadffmpeg-d35899ccce39e77a3f7fb667bdfc710c605d03a4.tar.gz
Merge commit 'cb52a17cb62297802b0a77e5af9850d87c3f925b'
* commit 'cb52a17cb62297802b0a77e5af9850d87c3f925b': dsputil: Move Bink-specific add_pixels8 to binkdsp Conflicts: libavcodec/dsputil.c Merged-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec')
-rw-r--r--libavcodec/bink.c4
-rw-r--r--libavcodec/binkdsp.c21
-rw-r--r--libavcodec/binkdsp.h1
-rw-r--r--libavcodec/dsputil.c21
-rw-r--r--libavcodec/dsputil.h1
5 files changed, 24 insertions, 24 deletions
diff --git a/libavcodec/bink.c b/libavcodec/bink.c
index f23542f17e..a28b6f0254 100644
--- a/libavcodec/bink.c
+++ b/libavcodec/bink.c
@@ -889,7 +889,7 @@ static int binkb_decode_plane(BinkContext *c, AVFrame *frame, GetBitContext *gb,
c->dsp.clear_block(block);
v = binkb_get_value(c, BINKB_SRC_INTER_COEFS);
read_residue(gb, block, v);
- c->dsp.add_pixels8(dst, block, stride);
+ c->bdsp.add_pixels8(dst, block, stride);
break;
case 4:
xoff = binkb_get_value(c, BINKB_SRC_X_OFF);
@@ -1126,7 +1126,7 @@ static int bink_decode_plane(BinkContext *c, AVFrame *frame, GetBitContext *gb,
c->dsp.clear_block(block);
v = get_bits(gb, 7);
read_residue(gb, block, v);
- c->dsp.add_pixels8(dst, block, stride);
+ c->bdsp.add_pixels8(dst, block, stride);
break;
case INTRA_BLOCK:
memset(dctblock, 0, sizeof(*dctblock) * 64);
diff --git a/libavcodec/binkdsp.c b/libavcodec/binkdsp.c
index 5b3c26229f..9d70e2326f 100644
--- a/libavcodec/binkdsp.c
+++ b/libavcodec/binkdsp.c
@@ -24,6 +24,7 @@
* Bink DSP routines
*/
+#include "config.h"
#include "libavutil/attributes.h"
#include "binkdsp.h"
@@ -128,9 +129,29 @@ static void scale_block_c(const uint8_t src[64]/*align 8*/, uint8_t *dst/*align
}
}
+static void add_pixels8_c(uint8_t *av_restrict pixels, int16_t *block,
+ int line_size)
+{
+ int i;
+
+ for (i = 0; i < 8; i++) {
+ pixels[0] += block[0];
+ pixels[1] += block[1];
+ pixels[2] += block[2];
+ pixels[3] += block[3];
+ pixels[4] += block[4];
+ pixels[5] += block[5];
+ pixels[6] += block[6];
+ pixels[7] += block[7];
+ pixels += line_size;
+ block += 8;
+ }
+}
+
av_cold void ff_binkdsp_init(BinkDSPContext *c)
{
c->idct_add = bink_idct_add_c;
c->idct_put = bink_idct_put_c;
c->scale_block = scale_block_c;
+ c->add_pixels8 = add_pixels8_c;
}
diff --git a/libavcodec/binkdsp.h b/libavcodec/binkdsp.h
index 6b84e014ab..f319d1ffe5 100644
--- a/libavcodec/binkdsp.h
+++ b/libavcodec/binkdsp.h
@@ -33,6 +33,7 @@ typedef struct BinkDSPContext {
void (*idct_put)(uint8_t *dest/*align 8*/, int line_size, int32_t *block/*align 16*/);
void (*idct_add)(uint8_t *dest/*align 8*/, int line_size, int32_t *block/*align 16*/);
void (*scale_block)(const uint8_t src[64]/*align 8*/, uint8_t *dst/*align 8*/, int linesize);
+ void (*add_pixels8)(uint8_t *pixels, int16_t *block, int line_size);
} BinkDSPContext;
void ff_binkdsp_init(BinkDSPContext *c);
diff --git a/libavcodec/dsputil.c b/libavcodec/dsputil.c
index 44dcf3f92d..6d41dfca71 100644
--- a/libavcodec/dsputil.c
+++ b/libavcodec/dsputil.c
@@ -381,25 +381,6 @@ static void put_signed_pixels_clamped_c(const int16_t *block,
}
}
-static void add_pixels8_c(uint8_t *av_restrict pixels, int16_t *block,
- int line_size)
-{
- int i;
-
- for (i = 0; i < 8; i++) {
- pixels[0] += block[0];
- pixels[1] += block[1];
- pixels[2] += block[2];
- pixels[3] += block[3];
- pixels[4] += block[4];
- pixels[5] += block[5];
- pixels[6] += block[6];
- pixels[7] += block[7];
- pixels += line_size;
- block += 8;
- }
-}
-
static void add_pixels_clamped_c(const int16_t *block, uint8_t *av_restrict pixels,
int line_size)
{
@@ -2486,8 +2467,6 @@ av_cold void ff_dsputil_init(DSPContext *c, AVCodecContext *avctx)
c->shrink[2] = ff_shrink44;
c->shrink[3] = ff_shrink88;
- c->add_pixels8 = add_pixels8_c;
-
c->draw_edges = draw_edges_8_c;
c->clear_block = clear_block_8_c;
diff --git a/libavcodec/dsputil.h b/libavcodec/dsputil.h
index e4998ecda1..f2198698f4 100644
--- a/libavcodec/dsputil.h
+++ b/libavcodec/dsputil.h
@@ -136,7 +136,6 @@ typedef struct DSPContext {
void (*add_pixels_clamped)(const int16_t *block /* align 16 */,
uint8_t *pixels /* align 8 */,
int line_size);
- void (*add_pixels8)(uint8_t *pixels, int16_t *block, int line_size);
int (*sum_abs_dctelem)(int16_t *block /* align 16 */);
/**
* translational global motion compensation.