dsputil: Split off pixel block routines into their own context
This commit is contained in:
@@ -159,16 +159,16 @@ static inline void dct_get(ASV1Context *a, const AVFrame *frame,
|
||||
uint8_t *ptr_cb = frame->data[1] + (mb_y * 8 * frame->linesize[1]) + mb_x * 8;
|
||||
uint8_t *ptr_cr = frame->data[2] + (mb_y * 8 * frame->linesize[2]) + mb_x * 8;
|
||||
|
||||
a->dsp.get_pixels(block[0], ptr_y , linesize);
|
||||
a->dsp.get_pixels(block[1], ptr_y + 8, linesize);
|
||||
a->dsp.get_pixels(block[2], ptr_y + 8*linesize , linesize);
|
||||
a->dsp.get_pixels(block[3], ptr_y + 8*linesize + 8, linesize);
|
||||
a->pdsp.get_pixels(block[0], ptr_y, linesize);
|
||||
a->pdsp.get_pixels(block[1], ptr_y + 8, linesize);
|
||||
a->pdsp.get_pixels(block[2], ptr_y + 8 * linesize, linesize);
|
||||
a->pdsp.get_pixels(block[3], ptr_y + 8 * linesize + 8, linesize);
|
||||
for(i=0; i<4; i++)
|
||||
a->fdsp.fdct(block[i]);
|
||||
|
||||
if(!(a->avctx->flags&CODEC_FLAG_GRAY)){
|
||||
a->dsp.get_pixels(block[4], ptr_cb, frame->linesize[1]);
|
||||
a->dsp.get_pixels(block[5], ptr_cr, frame->linesize[2]);
|
||||
a->pdsp.get_pixels(block[4], ptr_cb, frame->linesize[1]);
|
||||
a->pdsp.get_pixels(block[5], ptr_cr, frame->linesize[2]);
|
||||
for(i=4; i<6; i++)
|
||||
a->fdsp.fdct(block[i]);
|
||||
}
|
||||
@@ -248,8 +248,8 @@ static av_cold int encode_init(AVCodecContext *avctx){
|
||||
avctx->coded_frame->key_frame = 1;
|
||||
|
||||
ff_asv_common_init(avctx);
|
||||
ff_dsputil_init(&a->dsp, avctx);
|
||||
ff_fdctdsp_init(&a->fdsp, avctx);
|
||||
ff_pixblockdsp_init(&a->pdsp, avctx);
|
||||
|
||||
if(avctx->global_quality == 0) avctx->global_quality= 4*FF_QUALITY_SCALE;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user