LCOV - code coverage report
Current view: top level - libavcodec - golomb.h (source / functions) Hit Total Coverage
Test: coverage.info Lines: 205 216 94.9 %
Date: 2017-12-16 13:57:32 Functions: 21 21 100.0 %

          Line data    Source code
       1             : /*
       2             :  * exp golomb vlc stuff
       3             :  * Copyright (c) 2003 Michael Niedermayer <michaelni@gmx.at>
       4             :  * Copyright (c) 2004 Alex Beregszaszi
       5             :  *
       6             :  * This file is part of FFmpeg.
       7             :  *
       8             :  * FFmpeg is free software; you can redistribute it and/or
       9             :  * modify it under the terms of the GNU Lesser General Public
      10             :  * License as published by the Free Software Foundation; either
      11             :  * version 2.1 of the License, or (at your option) any later version.
      12             :  *
      13             :  * FFmpeg is distributed in the hope that it will be useful,
      14             :  * but WITHOUT ANY WARRANTY; without even the implied warranty of
      15             :  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
      16             :  * Lesser General Public License for more details.
      17             :  *
      18             :  * You should have received a copy of the GNU Lesser General Public
      19             :  * License along with FFmpeg; if not, write to the Free Software
      20             :  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
      21             :  */
      22             : 
      23             : /**
      24             :  * @file
      25             :  * @brief
      26             :  *     exp golomb vlc stuff
      27             :  * @author Michael Niedermayer <michaelni@gmx.at> and Alex Beregszaszi
      28             :  */
      29             : 
      30             : #ifndef AVCODEC_GOLOMB_H
      31             : #define AVCODEC_GOLOMB_H
      32             : 
      33             : #include <stdint.h>
      34             : 
      35             : #include "get_bits.h"
      36             : #include "put_bits.h"
      37             : 
      38             : #define INVALID_VLC           0x80000000
      39             : 
      40             : extern const uint8_t ff_golomb_vlc_len[512];
      41             : extern const uint8_t ff_ue_golomb_vlc_code[512];
      42             : extern const  int8_t ff_se_golomb_vlc_code[512];
      43             : extern const uint8_t ff_ue_golomb_len[256];
      44             : 
      45             : extern const uint8_t ff_interleaved_golomb_vlc_len[256];
      46             : extern const uint8_t ff_interleaved_ue_golomb_vlc_code[256];
      47             : extern const  int8_t ff_interleaved_se_golomb_vlc_code[256];
      48             : extern const uint8_t ff_interleaved_dirac_golomb_vlc_code[256];
      49             : 
      50             : /**
      51             :  * Read an unsigned Exp-Golomb code in the range 0 to 8190.
      52             :  */
      53    30395513 : static inline int get_ue_golomb(GetBitContext *gb)
      54             : {
      55             :     unsigned int buf;
      56             : 
      57    30395513 :     OPEN_READER(re, gb);
      58    30395513 :     UPDATE_CACHE(re, gb);
      59    30395513 :     buf = GET_CACHE(re, gb);
      60             : 
      61    30395513 :     if (buf >= (1 << 27)) {
      62    29324428 :         buf >>= 32 - 9;
      63    29324428 :         LAST_SKIP_BITS(re, gb, ff_golomb_vlc_len[buf]);
      64    29324428 :         CLOSE_READER(re, gb);
      65             : 
      66    29324428 :         return ff_ue_golomb_vlc_code[buf];
      67             :     } else {
      68     1071085 :         int log = 2 * av_log2(buf) - 31;
      69     1071085 :         LAST_SKIP_BITS(re, gb, 32 - log);
      70     1071085 :         CLOSE_READER(re, gb);
      71     1071085 :         if (log < 7) {
      72         339 :             av_log(NULL, AV_LOG_ERROR, "Invalid UE golomb code\n");
      73         339 :             return AVERROR_INVALIDDATA;
      74             :         }
      75     1070746 :         buf >>= log;
      76     1070746 :         buf--;
      77             : 
      78     1070746 :         return buf;
      79             :     }
      80             : }
      81             : 
      82             : /**
      83             :  * Read an unsigned Exp-Golomb code in the range 0 to UINT32_MAX-1.
      84             :  */
      85     2820628 : static inline unsigned get_ue_golomb_long(GetBitContext *gb)
      86             : {
      87             :     unsigned buf, log;
      88             : 
      89     2820628 :     buf = show_bits_long(gb, 32);
      90     2820628 :     log = 31 - av_log2(buf);
      91     2820628 :     skip_bits_long(gb, log);
      92             : 
      93     2820628 :     return get_bits_long(gb, log + 1) - 1;
      94             : }
      95             : 
      96             : /**
      97             :  * read unsigned exp golomb code, constraint to a max of 31.
      98             :  * the return value is undefined if the stored value exceeds 31.
      99             :  */
     100     5364080 : static inline int get_ue_golomb_31(GetBitContext *gb)
     101             : {
     102             :     unsigned int buf;
     103             : 
     104     5364080 :     OPEN_READER(re, gb);
     105     5364080 :     UPDATE_CACHE(re, gb);
     106     5364080 :     buf = GET_CACHE(re, gb);
     107             : 
     108     5364080 :     buf >>= 32 - 9;
     109     5364080 :     LAST_SKIP_BITS(re, gb, ff_golomb_vlc_len[buf]);
     110     5364080 :     CLOSE_READER(re, gb);
     111             : 
     112     5364080 :     return ff_ue_golomb_vlc_code[buf];
     113             : }
     114             : 
     115     8496470 : static inline unsigned get_interleaved_ue_golomb(GetBitContext *gb)
     116             : {
     117             :     uint32_t buf;
     118             : 
     119     8496470 :     OPEN_READER(re, gb);
     120     8496470 :     UPDATE_CACHE(re, gb);
     121     8496470 :     buf = GET_CACHE(re, gb);
     122             : 
     123     8496470 :     if (buf & 0xAA800000) {
     124     8390710 :         buf >>= 32 - 8;
     125     8390710 :         LAST_SKIP_BITS(re, gb, ff_interleaved_golomb_vlc_len[buf]);
     126     8390710 :         CLOSE_READER(re, gb);
     127             : 
     128     8390710 :         return ff_interleaved_ue_golomb_vlc_code[buf];
     129             :     } else {
     130      105760 :         unsigned ret = 1;
     131             : 
     132             :         do {
     133      215657 :             buf >>= 32 - 8;
     134      215657 :             LAST_SKIP_BITS(re, gb,
     135             :                            FFMIN(ff_interleaved_golomb_vlc_len[buf], 8));
     136             : 
     137      215657 :             if (ff_interleaved_golomb_vlc_len[buf] != 9) {
     138      105760 :                 ret <<= (ff_interleaved_golomb_vlc_len[buf] - 1) >> 1;
     139      105760 :                 ret  |= ff_interleaved_dirac_golomb_vlc_code[buf];
     140      105760 :                 break;
     141             :             }
     142      109897 :             ret = (ret << 4) | ff_interleaved_dirac_golomb_vlc_code[buf];
     143      109897 :             UPDATE_CACHE(re, gb);
     144      109897 :             buf = GET_CACHE(re, gb);
     145      109897 :         } while (ret<0x8000000U && BITS_AVAILABLE(re, gb));
     146             : 
     147      105760 :         CLOSE_READER(re, gb);
     148      105760 :         return ret - 1;
     149             :     }
     150             : }
     151             : 
     152             : /**
     153             :  * read unsigned truncated exp golomb code.
     154             :  */
     155             : static inline int get_te0_golomb(GetBitContext *gb, int range)
     156             : {
     157             :     av_assert2(range >= 1);
     158             : 
     159             :     if (range == 1)
     160             :         return 0;
     161             :     else if (range == 2)
     162             :         return get_bits1(gb) ^ 1;
     163             :     else
     164             :         return get_ue_golomb(gb);
     165             : }
     166             : 
     167             : /**
     168             :  * read unsigned truncated exp golomb code.
     169             :  */
     170             : static inline int get_te_golomb(GetBitContext *gb, int range)
     171             : {
     172             :     av_assert2(range >= 1);
     173             : 
     174             :     if (range == 2)
     175             :         return get_bits1(gb) ^ 1;
     176             :     else
     177             :         return get_ue_golomb(gb);
     178             : }
     179             : 
     180             : /**
     181             :  * read signed exp golomb code.
     182             :  */
     183    16316466 : static inline int get_se_golomb(GetBitContext *gb)
     184             : {
     185             :     unsigned int buf;
     186             : 
     187    16316466 :     OPEN_READER(re, gb);
     188    16316466 :     UPDATE_CACHE(re, gb);
     189    16316466 :     buf = GET_CACHE(re, gb);
     190             : 
     191    16316466 :     if (buf >= (1 << 27)) {
     192    15525887 :         buf >>= 32 - 9;
     193    15525887 :         LAST_SKIP_BITS(re, gb, ff_golomb_vlc_len[buf]);
     194    15525887 :         CLOSE_READER(re, gb);
     195             : 
     196    15525887 :         return ff_se_golomb_vlc_code[buf];
     197             :     } else {
     198      790579 :         int log = av_log2(buf), sign;
     199      790579 :         LAST_SKIP_BITS(re, gb, 31 - log);
     200      790579 :         UPDATE_CACHE(re, gb);
     201      790579 :         buf = GET_CACHE(re, gb);
     202             : 
     203      790579 :         buf >>= log;
     204             : 
     205      790579 :         LAST_SKIP_BITS(re, gb, 32 - log);
     206      790579 :         CLOSE_READER(re, gb);
     207             : 
     208      790579 :         sign = -(buf & 1);
     209      790579 :         buf  = ((buf >> 1) ^ sign) - sign;
     210             : 
     211      790579 :         return buf;
     212             :     }
     213             : }
     214             : 
     215          23 : static inline int get_se_golomb_long(GetBitContext *gb)
     216             : {
     217          23 :     unsigned int buf = get_ue_golomb_long(gb);
     218          23 :     int sign = (buf & 1) - 1;
     219          23 :     return ((buf >> 1) ^ sign) + 1;
     220             : }
     221             : 
     222      796701 : static inline int get_interleaved_se_golomb(GetBitContext *gb)
     223             : {
     224             :     unsigned int buf;
     225             : 
     226      796701 :     OPEN_READER(re, gb);
     227      796701 :     UPDATE_CACHE(re, gb);
     228      796701 :     buf = GET_CACHE(re, gb);
     229             : 
     230      796701 :     if (buf & 0xAA800000) {
     231      754114 :         buf >>= 32 - 8;
     232      754114 :         LAST_SKIP_BITS(re, gb, ff_interleaved_golomb_vlc_len[buf]);
     233      754114 :         CLOSE_READER(re, gb);
     234             : 
     235      754114 :         return ff_interleaved_se_golomb_vlc_code[buf];
     236             :     } else {
     237             :         int log;
     238       42587 :         LAST_SKIP_BITS(re, gb, 8);
     239       42587 :         UPDATE_CACHE(re, gb);
     240       42587 :         buf |= 1 | (GET_CACHE(re, gb) >> 8);
     241             : 
     242       42587 :         if ((buf & 0xAAAAAAAA) == 0)
     243           0 :             return INVALID_VLC;
     244             : 
     245      286924 :         for (log = 31; (buf & 0x80000000) == 0; log--)
     246      244337 :             buf = (buf << 2) - ((buf << log) >> (log - 1)) + (buf >> 30);
     247             : 
     248       42587 :         LAST_SKIP_BITS(re, gb, 63 - 2 * log - 8);
     249       42587 :         CLOSE_READER(re, gb);
     250             : 
     251       42587 :         return (signed) (((((buf << log) >> log) - 1) ^ -(buf & 0x1)) + 1) >> 1;
     252             :     }
     253             : }
     254             : 
     255     1949306 : static inline int dirac_get_se_golomb(GetBitContext *gb)
     256             : {
     257     1949306 :     uint32_t ret = get_interleaved_ue_golomb(gb);
     258             : 
     259     1949306 :     if (ret) {
     260      336860 :         int sign = -get_bits1(gb);
     261      336860 :         ret = (ret ^ sign) - sign;
     262             :     }
     263             : 
     264     1949306 :     return ret;
     265             : }
     266             : 
     267             : /**
     268             :  * read unsigned golomb rice code (ffv1).
     269             :  */
     270   113342102 : static inline int get_ur_golomb(GetBitContext *gb, int k, int limit,
     271             :                                 int esc_len)
     272             : {
     273             :     unsigned int buf;
     274             :     int log;
     275             : 
     276   113342102 :     OPEN_READER(re, gb);
     277   113342102 :     UPDATE_CACHE(re, gb);
     278   113342102 :     buf = GET_CACHE(re, gb);
     279             : 
     280   113342102 :     log = av_log2(buf);
     281             : 
     282   113342102 :     if (log > 31 - limit) {
     283   112768247 :         buf >>= log - k;
     284   112768247 :         buf  += (30U - log) << k;
     285   112768247 :         LAST_SKIP_BITS(re, gb, 32 + k - log);
     286   112768247 :         CLOSE_READER(re, gb);
     287             : 
     288   112768247 :         return buf;
     289             :     } else {
     290      573855 :         LAST_SKIP_BITS(re, gb, limit);
     291      573855 :         UPDATE_CACHE(re, gb);
     292             : 
     293      573855 :         buf = SHOW_UBITS(re, gb, esc_len);
     294             : 
     295      573855 :         LAST_SKIP_BITS(re, gb, esc_len);
     296      573855 :         CLOSE_READER(re, gb);
     297             : 
     298      573855 :         return buf + limit - 1;
     299             :     }
     300             : }
     301             : 
     302             : /**
     303             :  * read unsigned golomb rice code (jpegls).
     304             :  */
     305   100781756 : static inline int get_ur_golomb_jpegls(GetBitContext *gb, int k, int limit,
     306             :                                        int esc_len)
     307             : {
     308             :     unsigned int buf;
     309             :     int log;
     310             : 
     311   100781756 :     OPEN_READER(re, gb);
     312   100781756 :     UPDATE_CACHE(re, gb);
     313   100781756 :     buf = GET_CACHE(re, gb);
     314             : 
     315   100781756 :     log = av_log2(buf);
     316             : 
     317             :     av_assert2(k <= 31);
     318             : 
     319   201514965 :     if (log - k >= 32 - MIN_CACHE_BITS + (MIN_CACHE_BITS == 32) &&
     320   100733209 :         32 - log < limit) {
     321   100691151 :         buf >>= log - k;
     322   100691151 :         buf  += (30U - log) << k;
     323   100691151 :         LAST_SKIP_BITS(re, gb, 32 + k - log);
     324   100691151 :         CLOSE_READER(re, gb);
     325             : 
     326   100691151 :         return buf;
     327             :     } else {
     328             :         int i;
     329     2166476 :         for (i = 0; i < limit && SHOW_UBITS(re, gb, 1) == 0; i++) {
     330     2075871 :             if (gb->size_in_bits <= re_index) {
     331           0 :                 CLOSE_READER(re, gb);
     332           0 :                 return -1;
     333             :             }
     334     2075871 :             LAST_SKIP_BITS(re, gb, 1);
     335     2075871 :             UPDATE_CACHE(re, gb);
     336             :         }
     337       90605 :         SKIP_BITS(re, gb, 1);
     338             : 
     339       90605 :         if (i < limit - 1) {
     340        2516 :             if (k) {
     341        2343 :                 if (k > MIN_CACHE_BITS - 1) {
     342           0 :                     buf = SHOW_UBITS(re, gb, 16) << (k-16);
     343           0 :                     LAST_SKIP_BITS(re, gb, 16);
     344           0 :                     UPDATE_CACHE(re, gb);
     345           0 :                     buf |= SHOW_UBITS(re, gb, k-16);
     346           0 :                     LAST_SKIP_BITS(re, gb, k-16);
     347             :                 } else {
     348        2343 :                     buf = SHOW_UBITS(re, gb, k);
     349        2343 :                     LAST_SKIP_BITS(re, gb, k);
     350             :                 }
     351             :             } else {
     352         173 :                 buf = 0;
     353             :             }
     354             : 
     355        2516 :             buf += ((SUINT)i << k);
     356       88089 :         } else if (i == limit - 1) {
     357       88089 :             buf = SHOW_UBITS(re, gb, esc_len);
     358       88089 :             LAST_SKIP_BITS(re, gb, esc_len);
     359             : 
     360       88089 :             buf ++;
     361             :         } else {
     362           0 :             buf = -1;
     363             :         }
     364       90605 :         CLOSE_READER(re, gb);
     365       90605 :         return buf;
     366             :     }
     367             : }
     368             : 
     369             : /**
     370             :  * read signed golomb rice code (ffv1).
     371             :  */
     372   113342102 : static inline int get_sr_golomb(GetBitContext *gb, int k, int limit,
     373             :                                 int esc_len)
     374             : {
     375   113342102 :     unsigned v = get_ur_golomb(gb, k, limit, esc_len);
     376   113342102 :     return (v >> 1) ^ -(v & 1);
     377             : }
     378             : 
     379             : /**
     380             :  * read signed golomb rice code (flac).
     381             :  */
     382    54722180 : static inline int get_sr_golomb_flac(GetBitContext *gb, int k, int limit,
     383             :                                      int esc_len)
     384             : {
     385    54722180 :     unsigned v = get_ur_golomb_jpegls(gb, k, limit, esc_len);
     386    54722180 :     return (v >> 1) ^ -(v & 1);
     387             : }
     388             : 
     389             : /**
     390             :  * read unsigned golomb rice code (shorten).
     391             :  */
     392        6320 : static inline unsigned int get_ur_golomb_shorten(GetBitContext *gb, int k)
     393             : {
     394        6320 :     return get_ur_golomb_jpegls(gb, k, INT_MAX, 0);
     395             : }
     396             : 
     397             : /**
     398             :  * read signed golomb rice code (shorten).
     399             :  */
     400      793344 : static inline int get_sr_golomb_shorten(GetBitContext *gb, int k)
     401             : {
     402      793344 :     int uvar = get_ur_golomb_jpegls(gb, k + 1, INT_MAX, 0);
     403      793344 :     return (uvar >> 1) ^ -(uvar & 1);
     404             : }
     405             : 
     406             : #ifdef TRACE
     407             : 
     408             : static inline int get_ue(GetBitContext *s, const char *file, const char *func,
     409             :                          int line)
     410             : {
     411             :     int show = show_bits(s, 24);
     412             :     int pos  = get_bits_count(s);
     413             :     int i    = get_ue_golomb(s);
     414             :     int len  = get_bits_count(s) - pos;
     415             :     int bits = show >> (24 - len);
     416             : 
     417             :     av_log(NULL, AV_LOG_DEBUG, "%5d %2d %3d ue  @%5d in %s %s:%d\n",
     418             :            bits, len, i, pos, file, func, line);
     419             : 
     420             :     return i;
     421             : }
     422             : 
     423             : static inline int get_se(GetBitContext *s, const char *file, const char *func,
     424             :                          int line)
     425             : {
     426             :     int show = show_bits(s, 24);
     427             :     int pos  = get_bits_count(s);
     428             :     int i    = get_se_golomb(s);
     429             :     int len  = get_bits_count(s) - pos;
     430             :     int bits = show >> (24 - len);
     431             : 
     432             :     av_log(NULL, AV_LOG_DEBUG, "%5d %2d %3d se  @%5d in %s %s:%d\n",
     433             :            bits, len, i, pos, file, func, line);
     434             : 
     435             :     return i;
     436             : }
     437             : 
     438             : static inline int get_te(GetBitContext *s, int r, char *file, const char *func,
     439             :                          int line)
     440             : {
     441             :     int show = show_bits(s, 24);
     442             :     int pos  = get_bits_count(s);
     443             :     int i    = get_te0_golomb(s, r);
     444             :     int len  = get_bits_count(s) - pos;
     445             :     int bits = show >> (24 - len);
     446             : 
     447             :     av_log(NULL, AV_LOG_DEBUG, "%5d %2d %3d te  @%5d in %s %s:%d\n",
     448             :            bits, len, i, pos, file, func, line);
     449             : 
     450             :     return i;
     451             : }
     452             : 
     453             : #define get_ue_golomb(a) get_ue(a, __FILE__, __func__, __LINE__)
     454             : #define get_se_golomb(a) get_se(a, __FILE__, __func__, __LINE__)
     455             : #define get_te_golomb(a, r)  get_te(a, r, __FILE__, __func__, __LINE__)
     456             : #define get_te0_golomb(a, r) get_te(a, r, __FILE__, __func__, __LINE__)
     457             : 
     458             : #endif /* TRACE */
     459             : 
     460             : /**
     461             :  * write unsigned exp golomb code. 2^16 - 2 at most
     462             :  */
     463       24573 : static inline void set_ue_golomb(PutBitContext *pb, int i)
     464             : {
     465             :     av_assert2(i >= 0);
     466             :     av_assert2(i <= 0xFFFE);
     467             : 
     468       24573 :     if (i < 256)
     469         544 :         put_bits(pb, ff_ue_golomb_len[i], i + 1);
     470             :     else {
     471       24029 :         int e = av_log2(i + 1);
     472       24029 :         put_bits(pb, 2 * e + 1, i + 1);
     473             :     }
     474       24573 : }
     475             : 
     476             : /**
     477             :  * write unsigned exp golomb code. 2^32-2 at most.
     478             :  */
     479        8191 : static inline void set_ue_golomb_long(PutBitContext *pb, uint32_t i)
     480             : {
     481             :     av_assert2(i <= (UINT32_MAX - 1));
     482             : 
     483        8191 :     if (i < 256)
     484          16 :         put_bits(pb, ff_ue_golomb_len[i], i + 1);
     485             :     else {
     486        8175 :         int e = av_log2(i + 1);
     487        8175 :         put_bits64(pb, 2 * e + 1, i + 1);
     488             :     }
     489        8191 : }
     490             : 
     491             : /**
     492             :  * write truncated unsigned exp golomb code.
     493             :  */
     494             : static inline void set_te_golomb(PutBitContext *pb, int i, int range)
     495             : {
     496             :     av_assert2(range >= 1);
     497             :     av_assert2(i <= range);
     498             : 
     499             :     if (range == 2)
     500             :         put_bits(pb, 1, i ^ 1);
     501             :     else
     502             :         set_ue_golomb(pb, i);
     503             : }
     504             : 
     505             : /**
     506             :  * write signed exp golomb code. 16 bits at most.
     507             :  */
     508        8191 : static inline void set_se_golomb(PutBitContext *pb, int i)
     509             : {
     510        8191 :     i = 2 * i - 1;
     511        8191 :     if (i < 0)
     512        4096 :         i ^= -1;    //FIXME check if gcc does the right thing
     513        8191 :     set_ue_golomb(pb, i);
     514        8191 : }
     515             : 
     516             : /**
     517             :  * write unsigned golomb rice code (ffv1).
     518             :  */
     519   110987686 : static inline void set_ur_golomb(PutBitContext *pb, int i, int k, int limit,
     520             :                                  int esc_len)
     521             : {
     522             :     int e;
     523             : 
     524             :     av_assert2(i >= 0);
     525             : 
     526   110987686 :     e = i >> k;
     527   110987686 :     if (e < limit)
     528   110433986 :         put_bits(pb, e + k + 1, (1 << k) + av_mod_uintp2(i, k));
     529             :     else
     530      553700 :         put_bits(pb, limit + esc_len, i - limit + 1);
     531   110987686 : }
     532             : 
     533             : /**
     534             :  * write unsigned golomb rice code (jpegls).
     535             :  */
     536    88335513 : static inline void set_ur_golomb_jpegls(PutBitContext *pb, int i, int k,
     537             :                                         int limit, int esc_len)
     538             : {
     539             :     int e;
     540             : 
     541             :     av_assert2(i >= 0);
     542             : 
     543    88335513 :     e = (i >> k) + 1;
     544    88335513 :     if (e < limit) {
     545   176498491 :         while (e > 31) {
     546          33 :             put_bits(pb, 31, 0);
     547          33 :             e -= 31;
     548             :         }
     549    88249229 :         put_bits(pb, e, 1);
     550    88249229 :         if (k)
     551    86264470 :             put_sbits(pb, k, i);
     552             :     } else {
     553      172568 :         while (limit > 31) {
     554           0 :             put_bits(pb, 31, 0);
     555           0 :             limit -= 31;
     556             :         }
     557       86284 :         put_bits(pb, limit, 1);
     558       86284 :         put_bits(pb, esc_len, i - 1);
     559             :     }
     560    88335513 : }
     561             : 
     562             : /**
     563             :  * write signed golomb rice code (ffv1).
     564             :  */
     565   110987686 : static inline void set_sr_golomb(PutBitContext *pb, int i, int k, int limit,
     566             :                                  int esc_len)
     567             : {
     568             :     int v;
     569             : 
     570   110987686 :     v  = -2 * i - 1;
     571   110987686 :     v ^= (v >> 31);
     572             : 
     573   110987686 :     set_ur_golomb(pb, v, k, limit, esc_len);
     574   110987686 : }
     575             : 
     576             : /**
     577             :  * write signed golomb rice code (flac).
     578             :  */
     579    44742164 : static inline void set_sr_golomb_flac(PutBitContext *pb, int i, int k,
     580             :                                       int limit, int esc_len)
     581             : {
     582             :     int v;
     583             : 
     584    44742164 :     v  = -2 * i - 1;
     585    44742164 :     v ^= (v >> 31);
     586             : 
     587    44742164 :     set_ur_golomb_jpegls(pb, v, k, limit, esc_len);
     588    44742164 : }
     589             : 
     590             : #endif /* AVCODEC_GOLOMB_H */

Generated by: LCOV version 1.13