Commit 84b4de89 authored by michael's avatar michael

various fixes related to the non alt_bitstream_reader


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@4136 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 681feee9
...@@ -429,7 +429,7 @@ static inline int get_bits_count(GetBitContext *s){ ...@@ -429,7 +429,7 @@ static inline int get_bits_count(GetBitContext *s){
# define UPDATE_CACHE(name, gb)\ # define UPDATE_CACHE(name, gb)\
if(name##_bit_count >= 0){\ if(name##_bit_count >= 0){\
name##_cache+= (int)be2me_16(*(uint16_t*)name##_buffer_ptr) << name##_bit_count;\ name##_cache+= (int)be2me_16(*(uint16_t*)name##_buffer_ptr) << name##_bit_count;\
((uint16_t*)name##_buffer_ptr)++;\ name##_buffer_ptr += 2;\
name##_bit_count-= 16;\ name##_bit_count-= 16;\
}\ }\
......
...@@ -263,6 +263,7 @@ static const int mb_area_start[5] = { 1, 6, 21, 43, 64 }; ...@@ -263,6 +263,7 @@ static const int mb_area_start[5] = { 1, 6, 21, 43, 64 };
#ifndef ALT_BITSTREAM_READER #ifndef ALT_BITSTREAM_READER
#warning only works with ALT_BITSTREAM_READER #warning only works with ALT_BITSTREAM_READER
static int re_index; //Hack to make it compile
#endif #endif
static inline int get_bits_left(GetBitContext *s) static inline int get_bits_left(GetBitContext *s)
......
...@@ -720,7 +720,7 @@ static int svq3_decode_slice_header (H264Context *h) { ...@@ -720,7 +720,7 @@ static int svq3_decode_slice_header (H264Context *h) {
} else { } else {
int length = (header >> 5) & 3; int length = (header >> 5) & 3;
h->next_slice_index = s->gb.index + 8*show_bits (&s->gb, 8*length) + 8*length; h->next_slice_index = get_bits_count(&s->gb) + 8*show_bits (&s->gb, 8*length) + 8*length;
if (h->next_slice_index > s->gb.size_in_bits){ if (h->next_slice_index > s->gb.size_in_bits){
av_log(h->s.avctx, AV_LOG_ERROR, "slice after bitstream end\n"); av_log(h->s.avctx, AV_LOG_ERROR, "slice after bitstream end\n");
...@@ -728,10 +728,10 @@ static int svq3_decode_slice_header (H264Context *h) { ...@@ -728,10 +728,10 @@ static int svq3_decode_slice_header (H264Context *h) {
} }
s->gb.size_in_bits = h->next_slice_index - 8*(length - 1); s->gb.size_in_bits = h->next_slice_index - 8*(length - 1);
s->gb.index += 8; skip_bits(&s->gb, 8);
if (length > 0) { if (length > 0) {
memcpy ((uint8_t *) &s->gb.buffer[s->gb.index >> 3], memcpy ((uint8_t *) &s->gb.buffer[get_bits_count(&s->gb) >> 3],
&s->gb.buffer[s->gb.size_in_bits >> 3], (length - 1)); &s->gb.buffer[s->gb.size_in_bits >> 3], (length - 1));
} }
} }
...@@ -939,10 +939,10 @@ static int svq3_decode_frame (AVCodecContext *avctx, ...@@ -939,10 +939,10 @@ static int svq3_decode_frame (AVCodecContext *avctx,
for (s->mb_y=0; s->mb_y < s->mb_height; s->mb_y++) { for (s->mb_y=0; s->mb_y < s->mb_height; s->mb_y++) {
for (s->mb_x=0; s->mb_x < s->mb_width; s->mb_x++) { for (s->mb_x=0; s->mb_x < s->mb_width; s->mb_x++) {
if ( (s->gb.index + 7) >= s->gb.size_in_bits && if ( (get_bits_count(&s->gb) + 7) >= s->gb.size_in_bits &&
((s->gb.index & 7) == 0 || show_bits (&s->gb, (-s->gb.index & 7)) == 0)) { ((get_bits_count(&s->gb) & 7) == 0 || show_bits (&s->gb, (-get_bits_count(&s->gb) & 7)) == 0)) {
s->gb.index = h->next_slice_index; skip_bits(&s->gb, h->next_slice_index - get_bits_count(&s->gb));
s->gb.size_in_bits = 8*buf_size; s->gb.size_in_bits = 8*buf_size;
if (svq3_decode_slice_header (h)) if (svq3_decode_slice_header (h))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment