Skip to content
Snippets Groups Projects
Commit 3bb10888 authored by Michael Niedermayer's avatar Michael Niedermayer
Browse files

libmpeg2 style bitstream reader 17 vs 16 bit bugfix

Originally committed as revision 1881 to svn://svn.ffmpeg.org/ffmpeg/trunk
parent 41fda91d
No related branches found
No related tags found
No related merge requests found
...@@ -162,7 +162,7 @@ void init_get_bits(GetBitContext *s, ...@@ -162,7 +162,7 @@ void init_get_bits(GetBitContext *s,
{ {
OPEN_READER(re, s) OPEN_READER(re, s)
UPDATE_CACHE(re, s) UPDATE_CACHE(re, s)
// UPDATE_CACHE(re, s) UPDATE_CACHE(re, s)
CLOSE_READER(re, s) CLOSE_READER(re, s)
} }
#ifdef A32_BITSTREAM_READER #ifdef A32_BITSTREAM_READER
......
...@@ -546,7 +546,7 @@ static inline int get_bits_count(GetBitContext *s){ ...@@ -546,7 +546,7 @@ static inline int get_bits_count(GetBitContext *s){
#elif defined LIBMPEG2_BITSTREAM_READER #elif defined LIBMPEG2_BITSTREAM_READER
//libmpeg2 like reader //libmpeg2 like reader
# define MIN_CACHE_BITS 16 # define MIN_CACHE_BITS 17
# define OPEN_READER(name, gb)\ # define OPEN_READER(name, gb)\
int name##_bit_count=(gb)->bit_count;\ int name##_bit_count=(gb)->bit_count;\
...@@ -570,7 +570,7 @@ static inline int get_bits_count(GetBitContext *s){ ...@@ -570,7 +570,7 @@ static inline int get_bits_count(GetBitContext *s){
#else #else
# define UPDATE_CACHE(name, gb)\ # define UPDATE_CACHE(name, gb)\
if(name##_bit_count > 0){\ if(name##_bit_count >= 0){\
name##_cache+= ((name##_buffer_ptr[0]<<8) + name##_buffer_ptr[1]) << name##_bit_count;\ name##_cache+= ((name##_buffer_ptr[0]<<8) + name##_buffer_ptr[1]) << name##_bit_count;\
name##_buffer_ptr+=2;\ name##_buffer_ptr+=2;\
name##_bit_count-= 16;\ name##_bit_count-= 16;\
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment