make A32 reader align its ptr during init no matter what missaligned mess is given...
authorMichael Niedermayer <michaelni@gmx.at>
Sat, 26 Aug 2006 11:37:33 +0000 (11:37 +0000)
committerMichael Niedermayer <michaelni@gmx.at>
Sat, 26 Aug 2006 11:37:33 +0000 (11:37 +0000)
Originally committed as revision 6096 to svn://svn.ffmpeg.org/ffmpeg/trunk

libavcodec/bitstream.h

index ed8c8fc..bb0eb0c 100644 (file)
@@ -719,20 +719,16 @@ static inline void init_get_bits(GetBitContext *s,
     s->bit_count = 16;
     s->cache = 0;
   }
-#elif defined A32_BITSTREAM_READER
-    s->buffer_ptr = (uint32_t*)buffer;
-    s->bit_count = 32;
-    s->cache0 = 0;
-    s->cache1 = 0;
-#endif
     {
         OPEN_READER(re, s)
         UPDATE_CACHE(re, s)
         UPDATE_CACHE(re, s)
         CLOSE_READER(re, s)
     }
-#ifdef A32_BITSTREAM_READER
-    s->cache1 = 0;
+#elif defined A32_BITSTREAM_READER
+    s->buffer_ptr = (uint32_t*)((intptr_t)buffer&(~3));
+    s->bit_count = 32 + 8*((intptr_t)buffer&3);
+    skip_bits_long(s, 0);
 #endif
 }