Browse Source

h261: Move encoder/decoder shared table init to common code

tags/n2.0
Diego Biurrun 12 years ago
parent
commit
20429ba96e
4 changed files with 14 additions and 7 deletions
  1. +11
    -0
      libavcodec/h261.c
  2. +1
    -0
      libavcodec/h261.h
  3. +1
    -1
      libavcodec/h261dec.c
  4. +1
    -6
      libavcodec/h261enc.c

+ 11
- 0
libavcodec/h261.c View File

@@ -79,3 +79,14 @@ void ff_h261_loop_filter(MpegEncContext *s)
h261_loop_filter(dest_cb, uvlinesize); h261_loop_filter(dest_cb, uvlinesize);
h261_loop_filter(dest_cr, uvlinesize); h261_loop_filter(dest_cr, uvlinesize);
} }

av_cold void ff_h261_common_init(void)
{
static int done = 0;

if (done)
return;

ff_init_rl(&ff_h261_rl_tcoeff, ff_h261_rl_table_store);
done = 1;
}

+ 1
- 0
libavcodec/h261.h View File

@@ -61,6 +61,7 @@ extern const uint8_t ff_h261_cbp_tab[63][2];
extern RLTable ff_h261_rl_tcoeff; extern RLTable ff_h261_rl_tcoeff;


void ff_h261_loop_filter(MpegEncContext *s); void ff_h261_loop_filter(MpegEncContext *s);
void ff_h261_common_init(void);


int ff_h261_get_picture_format(int width, int height); int ff_h261_get_picture_format(int width, int height);
void ff_h261_reorder_mb_index(MpegEncContext *s); void ff_h261_reorder_mb_index(MpegEncContext *s);


+ 1
- 1
libavcodec/h261dec.c View File

@@ -61,7 +61,6 @@ static av_cold void h261_decode_init_vlc(H261Context *h)
INIT_VLC_STATIC(&h261_cbp_vlc, H261_CBP_VLC_BITS, 63, INIT_VLC_STATIC(&h261_cbp_vlc, H261_CBP_VLC_BITS, 63,
&ff_h261_cbp_tab[0][1], 2, 1, &ff_h261_cbp_tab[0][1], 2, 1,
&ff_h261_cbp_tab[0][0], 2, 1, 512); &ff_h261_cbp_tab[0][0], 2, 1, 512);
ff_init_rl(&ff_h261_rl_tcoeff, ff_h261_rl_table_store);
INIT_VLC_RL(ff_h261_rl_tcoeff, 552); INIT_VLC_RL(ff_h261_rl_tcoeff, 552);
} }
} }
@@ -82,6 +81,7 @@ static av_cold int h261_decode_init(AVCodecContext *avctx)
avctx->pix_fmt = AV_PIX_FMT_YUV420P; avctx->pix_fmt = AV_PIX_FMT_YUV420P;
s->codec_id = avctx->codec->id; s->codec_id = avctx->codec->id;


ff_h261_common_init();
h261_decode_init_vlc(h); h261_decode_init_vlc(h);


h->gob_start_code_skipped = 0; h->gob_start_code_skipped = 0;


+ 1
- 6
libavcodec/h261enc.c View File

@@ -313,12 +313,7 @@ void ff_h261_encode_mb(MpegEncContext *s, int16_t block[6][64],


void ff_h261_encode_init(MpegEncContext *s) void ff_h261_encode_init(MpegEncContext *s)
{ {
static int done = 0;

if (!done) {
done = 1;
ff_init_rl(&ff_h261_rl_tcoeff, ff_h261_rl_table_store);
}
ff_h261_common_init();


s->min_qcoeff = -127; s->min_qcoeff = -127;
s->max_qcoeff = 127; s->max_qcoeff = 127;


Loading…
Cancel
Save