summaryrefslogtreecommitdiff
path: root/libavcodec
diff options
context:
space:
mode:
authorAnton Khirnov <anton@khirnov.net>2013-08-11 12:14:44 +0200
committerAnton Khirnov <anton@khirnov.net>2013-09-24 17:13:52 +0200
commitcab8c5f8e140c96ba3725ab709d823abfd1e31a5 (patch)
tree1a6907e0bed1ed80cb18ac299be2f16b4ab5a45f /libavcodec
parente880418660c80e2f12a123e131975cdb6b12cd13 (diff)
h264: do not reinitialize the global cabac tables at each slice header
Diffstat (limited to 'libavcodec')
-rw-r--r--libavcodec/cabac.c6
-rw-r--r--libavcodec/h264.c3
2 files changed, 8 insertions, 1 deletions
diff --git a/libavcodec/cabac.c b/libavcodec/cabac.c
index 50f086e6f3..e1cd811b70 100644
--- a/libavcodec/cabac.c
+++ b/libavcodec/cabac.c
@@ -137,6 +137,10 @@ void ff_init_cabac_decoder(CABACContext *c, const uint8_t *buf, int buf_size){
void ff_init_cabac_states(void)
{
int i, j;
+ static int initialized = 0;
+
+ if (initialized)
+ return;
for(i=0; i<64; i++){
for(j=0; j<4; j++){ //FIXME check if this is worth the 1 shift we save
@@ -158,4 +162,6 @@ void ff_init_cabac_states(void)
for(i=0; i< 63; i++){
ff_h264_last_coeff_flag_offset_8x8[i] = last_coeff_flag_offset_8x8[i];
}
+
+ initialized = 1;
}
diff --git a/libavcodec/h264.c b/libavcodec/h264.c
index 274c738c5d..5ff55ceccb 100644
--- a/libavcodec/h264.c
+++ b/libavcodec/h264.c
@@ -1548,6 +1548,8 @@ av_cold int ff_h264_decode_init(AVCodecContext *avctx)
ff_h264_decode_init_vlc();
+ ff_init_cabac_states();
+
h->pixel_shift = 0;
h->sps.bit_depth_luma = avctx->bits_per_raw_sample = 8;
@@ -4244,7 +4246,6 @@ static int decode_slice(struct AVCodecContext *avctx, void *arg)
align_get_bits(&h->gb);
/* init cabac */
- ff_init_cabac_states();
ff_init_cabac_decoder(&h->cabac,
h->gb.buffer + get_bits_count(&h->gb) / 8,
(get_bits_left(&h->gb) + 7) / 8);