* commit 'ed16c2dbf47cdd7c48825b4da6e7036698e5dde1': h261: Remove H.261 loop filter from dsputil Merged-by: Michael Niedermayer <michaelni@gmx.at>tags/n2.0
@@ -1587,33 +1587,6 @@ static void h263_h_loop_filter_c(uint8_t *src, int stride, int qscale){ | |||||
} | } | ||||
} | } | ||||
static void h261_loop_filter_c(uint8_t *src, int stride){ | |||||
int x,y,xy,yz; | |||||
int temp[64]; | |||||
for(x=0; x<8; x++){ | |||||
temp[x ] = 4*src[x ]; | |||||
temp[x + 7*8] = 4*src[x + 7*stride]; | |||||
} | |||||
for(y=1; y<7; y++){ | |||||
for(x=0; x<8; x++){ | |||||
xy = y * stride + x; | |||||
yz = y * 8 + x; | |||||
temp[yz] = src[xy - stride] + 2*src[xy] + src[xy + stride]; | |||||
} | |||||
} | |||||
for(y=0; y<8; y++){ | |||||
src[ y*stride] = (temp[ y*8] + 2)>>2; | |||||
src[7+y*stride] = (temp[7+y*8] + 2)>>2; | |||||
for(x=1; x<7; x++){ | |||||
xy = y * stride + x; | |||||
yz = y * 8 + x; | |||||
src[xy] = (temp[yz-1] + 2*temp[yz] + temp[yz+1] + 8)>>4; | |||||
} | |||||
} | |||||
} | |||||
static inline int pix_abs16_c(void *v, uint8_t *pix1, uint8_t *pix2, int line_size, int h) | static inline int pix_abs16_c(void *v, uint8_t *pix1, uint8_t *pix2, int line_size, int h) | ||||
{ | { | ||||
int s, i; | int s, i; | ||||
@@ -2896,8 +2869,6 @@ av_cold void ff_dsputil_init(DSPContext* c, AVCodecContext *avctx) | |||||
c->h263_v_loop_filter= h263_v_loop_filter_c; | c->h263_v_loop_filter= h263_v_loop_filter_c; | ||||
} | } | ||||
c->h261_loop_filter= h261_loop_filter_c; | |||||
c->try_8x8basis= try_8x8basis_c; | c->try_8x8basis= try_8x8basis_c; | ||||
c->add_8x8basis= add_8x8basis_c; | c->add_8x8basis= add_8x8basis_c; | ||||
@@ -211,8 +211,6 @@ typedef struct DSPContext { | |||||
void (*h263_v_loop_filter)(uint8_t *src, int stride, int qscale); | void (*h263_v_loop_filter)(uint8_t *src, int stride, int qscale); | ||||
void (*h263_h_loop_filter)(uint8_t *src, int stride, int qscale); | void (*h263_h_loop_filter)(uint8_t *src, int stride, int qscale); | ||||
void (*h261_loop_filter)(uint8_t *src, int stride); | |||||
/* assume len is a multiple of 8, and arrays are 16-byte aligned */ | /* assume len is a multiple of 8, and arrays are 16-byte aligned */ | ||||
void (*vector_clipf)(float *dst /* align 16 */, const float *src /* align 16 */, float min, float max, int len /* align 16 */); | void (*vector_clipf)(float *dst /* align 16 */, const float *src /* align 16 */, float min, float max, int len /* align 16 */); | ||||
@@ -32,6 +32,34 @@ | |||||
uint8_t ff_h261_rl_table_store[2][2*MAX_RUN + MAX_LEVEL + 3]; | uint8_t ff_h261_rl_table_store[2][2*MAX_RUN + MAX_LEVEL + 3]; | ||||
static void h261_loop_filter(uint8_t *src, int stride) | |||||
{ | |||||
int x,y,xy,yz; | |||||
int temp[64]; | |||||
for(x=0; x<8; x++){ | |||||
temp[x ] = 4*src[x ]; | |||||
temp[x + 7*8] = 4*src[x + 7*stride]; | |||||
} | |||||
for(y=1; y<7; y++){ | |||||
for(x=0; x<8; x++){ | |||||
xy = y * stride + x; | |||||
yz = y * 8 + x; | |||||
temp[yz] = src[xy - stride] + 2*src[xy] + src[xy + stride]; | |||||
} | |||||
} | |||||
for(y=0; y<8; y++){ | |||||
src[ y*stride] = (temp[ y*8] + 2)>>2; | |||||
src[7+y*stride] = (temp[7+y*8] + 2)>>2; | |||||
for(x=1; x<7; x++){ | |||||
xy = y * stride + x; | |||||
yz = y * 8 + x; | |||||
src[xy] = (temp[yz-1] + 2*temp[yz] + temp[yz+1] + 8)>>4; | |||||
} | |||||
} | |||||
} | |||||
void ff_h261_loop_filter(MpegEncContext *s){ | void ff_h261_loop_filter(MpegEncContext *s){ | ||||
H261Context * h= (H261Context*)s; | H261Context * h= (H261Context*)s; | ||||
const int linesize = s->linesize; | const int linesize = s->linesize; | ||||
@@ -43,10 +71,10 @@ void ff_h261_loop_filter(MpegEncContext *s){ | |||||
if(!(IS_FIL (h->mtype))) | if(!(IS_FIL (h->mtype))) | ||||
return; | return; | ||||
s->dsp.h261_loop_filter(dest_y , linesize); | |||||
s->dsp.h261_loop_filter(dest_y + 8, linesize); | |||||
s->dsp.h261_loop_filter(dest_y + 8 * linesize , linesize); | |||||
s->dsp.h261_loop_filter(dest_y + 8 * linesize + 8, linesize); | |||||
s->dsp.h261_loop_filter(dest_cb, uvlinesize); | |||||
s->dsp.h261_loop_filter(dest_cr, uvlinesize); | |||||
h261_loop_filter(dest_y, linesize); | |||||
h261_loop_filter(dest_y + 8, linesize); | |||||
h261_loop_filter(dest_y + 8 * linesize, linesize); | |||||
h261_loop_filter(dest_y + 8 * linesize + 8, linesize); | |||||
h261_loop_filter(dest_cb, uvlinesize); | |||||
h261_loop_filter(dest_cr, uvlinesize); | |||||
} | } |