]> granicus.if.org Git - libvpx/commitdiff
Optimize bit_read_buffer.
authorhkuang <hkuang@google.com>
Fri, 12 Dec 2014 21:54:40 +0000 (13:54 -0800)
committerhkuang <hkuang@google.com>
Fri, 12 Dec 2014 22:38:12 +0000 (14:38 -0800)
Change-Id: Iee43c34909deec9787b29c1c33672213b9f049df

vp9/decoder/vp9_read_bit_buffer.c

index 3eef72844c101d1bd44a7dfce9b21534e24e8681..c3b38a9c710509817e8e228784876294825a5183 100644 (file)
 #include "vp9/decoder/vp9_read_bit_buffer.h"
 
 size_t vp9_rb_bytes_read(struct vp9_read_bit_buffer *rb) {
-  return (rb->bit_offset + CHAR_BIT - 1) / CHAR_BIT;
+  return (rb->bit_offset + 7) >> 3;
 }
 
 int vp9_rb_read_bit(struct vp9_read_bit_buffer *rb) {
   const size_t off = rb->bit_offset;
-  const size_t p = off / CHAR_BIT;
-  const int q = CHAR_BIT - 1 - (int)off % CHAR_BIT;
-  if (rb->bit_buffer + p >= rb->bit_buffer_end) {
-    rb->error_handler(rb->error_handler_data);
-    return 0;
-  } else {
-    const int bit = (rb->bit_buffer[p] & (1 << q)) >> q;
+  const size_t p = off >> 3;
+  const int q = 7 - (int)(off & 0x7);
+  if (rb->bit_buffer + p < rb->bit_buffer_end) {
+    const int bit = (rb->bit_buffer[p] >> q) & 1;
     rb->bit_offset = off + 1;
     return bit;
+  } else {
+    rb->error_handler(rb->error_handler_data);
+    return 0;
   }
 }