mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-08 13:22:53 +02:00
bfin: Separate VP3 initialization code
This commit is contained in:
parent
f550583c00
commit
438ea561ad
@ -2,7 +2,7 @@ OBJS += bfin/dsputil_bfin.o \
|
|||||||
bfin/fdct_bfin.o \
|
bfin/fdct_bfin.o \
|
||||||
bfin/idct_bfin.o \
|
bfin/idct_bfin.o \
|
||||||
bfin/pixels_bfin.o \
|
bfin/pixels_bfin.o \
|
||||||
bfin/vp3_bfin.o \
|
|
||||||
bfin/vp3_idct_bfin.o \
|
|
||||||
|
|
||||||
OBJS-$(CONFIG_MPEGVIDEOENC) += bfin/mpegvideo_bfin.o
|
OBJS-$(CONFIG_MPEGVIDEOENC) += bfin/mpegvideo_bfin.o
|
||||||
|
OBJS-$(CONFIG_VP3DSP) += bfin/vp3_bfin.o \
|
||||||
|
bfin/vp3_idct_bfin.o
|
||||||
|
@ -257,13 +257,7 @@ void ff_dsputil_init_bfin( DSPContext* c, AVCodecContext *avctx )
|
|||||||
if (avctx->dct_algo == FF_DCT_AUTO)
|
if (avctx->dct_algo == FF_DCT_AUTO)
|
||||||
c->fdct = ff_bfin_fdct;
|
c->fdct = ff_bfin_fdct;
|
||||||
|
|
||||||
// FIXME convert to VP3DSPContext
|
if (avctx->idct_algo == FF_IDCT_AUTO) {
|
||||||
if (0) { // avctx->idct_algo == FF_IDCT_VP3) {
|
|
||||||
c->idct_permutation_type = FF_NO_IDCT_PERM;
|
|
||||||
c->idct = ff_bfin_vp3_idct;
|
|
||||||
c->idct_add = ff_bfin_vp3_idct_add;
|
|
||||||
c->idct_put = ff_bfin_vp3_idct_put;
|
|
||||||
} else if (avctx->idct_algo == FF_IDCT_AUTO) {
|
|
||||||
c->idct_permutation_type = FF_NO_IDCT_PERM;
|
c->idct_permutation_type = FF_NO_IDCT_PERM;
|
||||||
c->idct = ff_bfin_idct;
|
c->idct = ff_bfin_idct;
|
||||||
c->idct_add = bfin_idct_add;
|
c->idct_add = bfin_idct_add;
|
||||||
|
@ -38,9 +38,6 @@
|
|||||||
|
|
||||||
void ff_bfin_idct (int16_t *block) attribute_l1_text;
|
void ff_bfin_idct (int16_t *block) attribute_l1_text;
|
||||||
void ff_bfin_fdct (int16_t *block) attribute_l1_text;
|
void ff_bfin_fdct (int16_t *block) attribute_l1_text;
|
||||||
void ff_bfin_vp3_idct (int16_t *block);
|
|
||||||
void ff_bfin_vp3_idct_put (uint8_t *dest, int line_size, int16_t *block);
|
|
||||||
void ff_bfin_vp3_idct_add (uint8_t *dest, int line_size, int16_t *block);
|
|
||||||
void ff_bfin_add_pixels_clamped (const int16_t *block, uint8_t *dest, int line_size) attribute_l1_text;
|
void ff_bfin_add_pixels_clamped (const int16_t *block, uint8_t *dest, int line_size) attribute_l1_text;
|
||||||
void ff_bfin_put_pixels_clamped (const int16_t *block, uint8_t *dest, int line_size) attribute_l1_text;
|
void ff_bfin_put_pixels_clamped (const int16_t *block, uint8_t *dest, int line_size) attribute_l1_text;
|
||||||
void ff_bfin_diff_pixels (int16_t *block, const uint8_t *s1, const uint8_t *s2, int stride) attribute_l1_text;
|
void ff_bfin_diff_pixels (int16_t *block, const uint8_t *s1, const uint8_t *s2, int stride) attribute_l1_text;
|
||||||
|
@ -21,8 +21,9 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "libavcodec/avcodec.h"
|
#include "libavcodec/avcodec.h"
|
||||||
#include "libavcodec/dsputil.h"
|
#include "libavcodec/vp3dsp.h"
|
||||||
#include "dsputil_bfin.h"
|
#include "dsputil_bfin.h"
|
||||||
|
#include "vp3_bfin.h"
|
||||||
|
|
||||||
/* Intra iDCT offset 128 */
|
/* Intra iDCT offset 128 */
|
||||||
void ff_bfin_vp3_idct_put (uint8_t *dest, int line_size, int16_t *block)
|
void ff_bfin_vp3_idct_put (uint8_t *dest, int line_size, int16_t *block)
|
||||||
@ -47,3 +48,9 @@ void ff_bfin_vp3_idct_add (uint8_t *dest, int line_size, int16_t *block)
|
|||||||
|
|
||||||
memset(block, 0, 128);
|
memset(block, 0, 128);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ff_vp3dsp_init_bfin(VP3DSPContext *c, int flags)
|
||||||
|
{
|
||||||
|
c->idct_add = ff_bfin_vp3_idct_add;
|
||||||
|
c->idct_put = ff_bfin_vp3_idct_put;
|
||||||
|
}
|
||||||
|
@ -310,6 +310,8 @@ av_cold void ff_vp3dsp_init(VP3DSPContext *c, int flags)
|
|||||||
|
|
||||||
if (ARCH_ARM)
|
if (ARCH_ARM)
|
||||||
ff_vp3dsp_init_arm(c, flags);
|
ff_vp3dsp_init_arm(c, flags);
|
||||||
|
if (ARCH_BFIN)
|
||||||
|
ff_vp3dsp_init_bfin(c, flags);
|
||||||
if (ARCH_PPC)
|
if (ARCH_PPC)
|
||||||
ff_vp3dsp_init_ppc(c, flags);
|
ff_vp3dsp_init_ppc(c, flags);
|
||||||
if (ARCH_X86)
|
if (ARCH_X86)
|
||||||
|
@ -49,6 +49,7 @@ typedef struct VP3DSPContext {
|
|||||||
|
|
||||||
void ff_vp3dsp_init(VP3DSPContext *c, int flags);
|
void ff_vp3dsp_init(VP3DSPContext *c, int flags);
|
||||||
void ff_vp3dsp_init_arm(VP3DSPContext *c, int flags);
|
void ff_vp3dsp_init_arm(VP3DSPContext *c, int flags);
|
||||||
|
void ff_vp3dsp_init_bfin(VP3DSPContext *c, int flags);
|
||||||
void ff_vp3dsp_init_ppc(VP3DSPContext *c, int flags);
|
void ff_vp3dsp_init_ppc(VP3DSPContext *c, int flags);
|
||||||
void ff_vp3dsp_init_x86(VP3DSPContext *c, int flags);
|
void ff_vp3dsp_init_x86(VP3DSPContext *c, int flags);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user