]> git.sesse.net Git - ffmpeg/commitdiff
tta: use get_unary() instead of a custom implementation
authorAnton Khirnov <anton@khirnov.net>
Wed, 23 Nov 2016 12:02:52 +0000 (13:02 +0100)
committerDiego Biurrun <diego@biurrun.de>
Fri, 25 Nov 2016 20:42:33 +0000 (21:42 +0100)
Signed-off-by: Diego Biurrun <diego@biurrun.de>
libavcodec/tta.c

index 2b57406686bcf13f0c00a2dcabe000357d1d56ea..2ac825554ec15e34cc4792c677d3ba5e11527f15 100644 (file)
@@ -35,6 +35,7 @@
 #include "avcodec.h"
 #include "get_bits.h"
 #include "internal.h"
+#include "unary.h"
 
 #define FORMAT_SIMPLE    1
 #define FORMAT_ENCRYPTED 2
@@ -171,16 +172,6 @@ static void rice_init(TTARice *c, uint32_t k0, uint32_t k1)
     c->sum1 = shift_16[k1];
 }
 
-static int tta_get_unary(GetBitContext *gb)
-{
-    int ret = 0;
-
-    // count ones
-    while (get_bits_left(gb) > 0 && get_bits1(gb))
-        ret++;
-    return ret;
-}
-
 static int tta_check_crc(TTAContext *s, const uint8_t *buf, int buf_size)
 {
     uint32_t crc, CRC;
@@ -352,7 +343,7 @@ static int tta_decode_frame(AVCodecContext *avctx, void *data,
         uint32_t unary, depth, k;
         int32_t value;
 
-        unary = tta_get_unary(&s->gb);
+        unary = get_unary(&s->gb, 0, get_bits_left(&s->gb));
 
         if (unary == 0) {
             depth = 0;