| @@ -26,7 +26,7 @@ | |||
| #include "bytestream.h" | |||
| #include "internal.h" | |||
| #include "get_bits.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "idctdsp.h" | |||
| #include "thread.h" | |||
| #include "unary_legacy.h" | |||
| @@ -27,7 +27,7 @@ | |||
| #include "avcodec.h" | |||
| #include "get_bits.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "h264chroma.h" | |||
| #include "idctdsp.h" | |||
| #include "internal.h" | |||
| @@ -27,7 +27,7 @@ | |||
| #include "avcodec.h" | |||
| #include "get_bits.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "cavs.h" | |||
| #include "internal.h" | |||
| #include "mpeg12data.h" | |||
| @@ -29,7 +29,7 @@ | |||
| #include "avcodec.h" | |||
| #include "dirac.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "internal.h" | |||
| #include "mpeg12data.h" | |||
| @@ -31,12 +31,13 @@ | |||
| #include "libavutil/opt.h" | |||
| #include "libavutil/imgutils.h" | |||
| #include "libavutil/timer.h" | |||
| #include "avcodec.h" | |||
| #include "golomb_legacy.h" | |||
| #include "internal.h" | |||
| #include "get_bits.h" | |||
| #include "put_bits.h" | |||
| #include "rangecoder.h" | |||
| #include "golomb.h" | |||
| #include "mathops.h" | |||
| #include "ffv1.h" | |||
| @@ -33,10 +33,10 @@ | |||
| #include "libavutil/imgutils.h" | |||
| #include "avcodec.h" | |||
| #include "golomb_legacy.h" | |||
| #include "internal.h" | |||
| #include "put_bits.h" | |||
| #include "rangecoder.h" | |||
| #include "golomb.h" | |||
| #include "mathops.h" | |||
| #include "ffv1.h" | |||
| @@ -22,10 +22,11 @@ | |||
| */ | |||
| #include "libavutil/common.h" | |||
| #include "avcodec.h" | |||
| #include "golomb_legacy.h" | |||
| #include "internal.h" | |||
| #include "get_bits.h" | |||
| #include "golomb.h" | |||
| typedef struct FICThreadContext { | |||
| DECLARE_ALIGNED(16, int16_t, block)[64]; | |||
| @@ -37,7 +37,7 @@ | |||
| #include "internal.h" | |||
| #include "get_bits.h" | |||
| #include "bytestream.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "flac.h" | |||
| #include "flacdata.h" | |||
| #include "flacdsp.h" | |||
| @@ -26,7 +26,7 @@ | |||
| #include "avcodec.h" | |||
| #include "bswapdsp.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "internal.h" | |||
| #include "lpc.h" | |||
| #include "flac.h" | |||
| @@ -32,7 +32,7 @@ | |||
| #include <stdint.h> | |||
| #include "get_bits.h" | |||
| #include "bitstream.h" | |||
| #include "put_bits.h" | |||
| #define INVALID_VLC 0x80000000 | |||
| @@ -50,26 +50,22 @@ extern const uint8_t ff_interleaved_dirac_golomb_vlc_code[256]; | |||
| /** | |||
| * read unsigned exp golomb code. | |||
| */ | |||
| static inline int get_ue_golomb(GetBitContext *gb) | |||
| static inline int get_ue_golomb(BitstreamContext *bc) | |||
| { | |||
| unsigned int buf; | |||
| OPEN_READER(re, gb); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = GET_CACHE(re, gb); | |||
| buf = bitstream_peek(bc, 32); | |||
| if (buf >= (1 << 27)) { | |||
| buf >>= 32 - 9; | |||
| LAST_SKIP_BITS(re, gb, ff_golomb_vlc_len[buf]); | |||
| CLOSE_READER(re, gb); | |||
| bitstream_skip(bc, ff_golomb_vlc_len[buf]); | |||
| return ff_ue_golomb_vlc_code[buf]; | |||
| } else { | |||
| int log = 2 * av_log2(buf) - 31; | |||
| buf >>= log; | |||
| buf--; | |||
| LAST_SKIP_BITS(re, gb, 32 - log); | |||
| CLOSE_READER(re, gb); | |||
| bitstream_skip(bc, 32 - log); | |||
| return buf; | |||
| } | |||
| @@ -78,48 +74,42 @@ static inline int get_ue_golomb(GetBitContext *gb) | |||
| /** | |||
| * Read an unsigned Exp-Golomb code in the range 0 to UINT32_MAX-1. | |||
| */ | |||
| static inline unsigned get_ue_golomb_long(GetBitContext *gb) | |||
| static inline unsigned get_ue_golomb_long(BitstreamContext *bc) | |||
| { | |||
| unsigned buf, log; | |||
| buf = show_bits_long(gb, 32); | |||
| buf = bitstream_peek(bc, 32); | |||
| log = 31 - av_log2(buf); | |||
| skip_bits_long(gb, log); | |||
| bitstream_skip(bc, log); | |||
| return get_bits_long(gb, log + 1) - 1; | |||
| return bitstream_read(bc, log + 1) - 1; | |||
| } | |||
| /** | |||
| * read unsigned exp golomb code, constraint to a max of 31. | |||
| * the return value is undefined if the stored value exceeds 31. | |||
| */ | |||
| static inline int get_ue_golomb_31(GetBitContext *gb) | |||
| static inline int get_ue_golomb_31(BitstreamContext *bc) | |||
| { | |||
| unsigned int buf; | |||
| OPEN_READER(re, gb); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = GET_CACHE(re, gb); | |||
| buf = bitstream_peek(bc, 32); | |||
| buf >>= 32 - 9; | |||
| LAST_SKIP_BITS(re, gb, ff_golomb_vlc_len[buf]); | |||
| CLOSE_READER(re, gb); | |||
| bitstream_skip(bc, ff_golomb_vlc_len[buf]); | |||
| return ff_ue_golomb_vlc_code[buf]; | |||
| } | |||
| static inline unsigned get_interleaved_ue_golomb(GetBitContext *gb) | |||
| static inline unsigned get_interleaved_ue_golomb(BitstreamContext *bc) | |||
| { | |||
| uint32_t buf; | |||
| OPEN_READER(re, gb); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = GET_CACHE(re, gb); | |||
| buf = bitstream_peek(bc, 32); | |||
| if (buf & 0xAA800000) { | |||
| buf >>= 32 - 8; | |||
| LAST_SKIP_BITS(re, gb, ff_interleaved_golomb_vlc_len[buf]); | |||
| CLOSE_READER(re, gb); | |||
| bitstream_skip(bc, ff_interleaved_golomb_vlc_len[buf]); | |||
| return ff_interleaved_ue_golomb_vlc_code[buf]; | |||
| } else { | |||
| @@ -127,8 +117,7 @@ static inline unsigned get_interleaved_ue_golomb(GetBitContext *gb) | |||
| do { | |||
| buf >>= 32 - 8; | |||
| LAST_SKIP_BITS(re, gb, | |||
| FFMIN(ff_interleaved_golomb_vlc_len[buf], 8)); | |||
| bitstream_skip(bc, FFMIN(ff_interleaved_golomb_vlc_len[buf], 8)); | |||
| if (ff_interleaved_golomb_vlc_len[buf] != 9) { | |||
| ret <<= (ff_interleaved_golomb_vlc_len[buf] - 1) >> 1; | |||
| @@ -136,11 +125,9 @@ static inline unsigned get_interleaved_ue_golomb(GetBitContext *gb) | |||
| break; | |||
| } | |||
| ret = (ret << 4) | ff_interleaved_dirac_golomb_vlc_code[buf]; | |||
| UPDATE_CACHE(re, gb); | |||
| buf = GET_CACHE(re, gb); | |||
| } while (BITS_AVAILABLE(re, gb)); | |||
| buf = bitstream_peek(bc, 32); | |||
| } while (bitstream_bits_left(bc) > 0); | |||
| CLOSE_READER(re, gb); | |||
| return ret - 1; | |||
| } | |||
| } | |||
| @@ -148,54 +135,50 @@ static inline unsigned get_interleaved_ue_golomb(GetBitContext *gb) | |||
| /** | |||
| * read unsigned truncated exp golomb code. | |||
| */ | |||
| static inline int get_te0_golomb(GetBitContext *gb, int range) | |||
| static inline int get_te0_golomb(BitstreamContext *bc, int range) | |||
| { | |||
| assert(range >= 1); | |||
| if (range == 1) | |||
| return 0; | |||
| else if (range == 2) | |||
| return get_bits1(gb) ^ 1; | |||
| return bitstream_read_bit(bc) ^ 1; | |||
| else | |||
| return get_ue_golomb(gb); | |||
| return get_ue_golomb(bc); | |||
| } | |||
| /** | |||
| * read unsigned truncated exp golomb code. | |||
| */ | |||
| static inline int get_te_golomb(GetBitContext *gb, int range) | |||
| static inline int get_te_golomb(BitstreamContext *bc, int range) | |||
| { | |||
| assert(range >= 1); | |||
| if (range == 2) | |||
| return get_bits1(gb) ^ 1; | |||
| return bitstream_read_bit(bc) ^ 1; | |||
| else | |||
| return get_ue_golomb(gb); | |||
| return get_ue_golomb(bc); | |||
| } | |||
| /** | |||
| * read signed exp golomb code. | |||
| */ | |||
| static inline int get_se_golomb(GetBitContext *gb) | |||
| static inline int get_se_golomb(BitstreamContext *bc) | |||
| { | |||
| unsigned int buf; | |||
| OPEN_READER(re, gb); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = GET_CACHE(re, gb); | |||
| buf = bitstream_peek(bc, 32); | |||
| if (buf >= (1 << 27)) { | |||
| buf >>= 32 - 9; | |||
| LAST_SKIP_BITS(re, gb, ff_golomb_vlc_len[buf]); | |||
| CLOSE_READER(re, gb); | |||
| bitstream_skip(bc, ff_golomb_vlc_len[buf]); | |||
| return ff_se_golomb_vlc_code[buf]; | |||
| } else { | |||
| int log = 2 * av_log2(buf) - 31; | |||
| buf >>= log; | |||
| LAST_SKIP_BITS(re, gb, 32 - log); | |||
| CLOSE_READER(re, gb); | |||
| bitstream_skip(bc, 32 - log); | |||
| if (buf & 1) | |||
| buf = -(buf >> 1); | |||
| @@ -206,9 +189,9 @@ static inline int get_se_golomb(GetBitContext *gb) | |||
| } | |||
| } | |||
| static inline int get_se_golomb_long(GetBitContext *gb) | |||
| static inline int get_se_golomb_long(BitstreamContext *bc) | |||
| { | |||
| unsigned int buf = get_ue_golomb_long(gb); | |||
| unsigned int buf = get_ue_golomb_long(bc); | |||
| if (buf & 1) | |||
| buf = (buf + 1) >> 1; | |||
| @@ -218,25 +201,21 @@ static inline int get_se_golomb_long(GetBitContext *gb) | |||
| return buf; | |||
| } | |||
| static inline int get_interleaved_se_golomb(GetBitContext *gb) | |||
| static inline int get_interleaved_se_golomb(BitstreamContext *bc) | |||
| { | |||
| unsigned int buf; | |||
| OPEN_READER(re, gb); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = GET_CACHE(re, gb); | |||
| buf = bitstream_peek(bc, 32); | |||
| if (buf & 0xAA800000) { | |||
| buf >>= 32 - 8; | |||
| LAST_SKIP_BITS(re, gb, ff_interleaved_golomb_vlc_len[buf]); | |||
| CLOSE_READER(re, gb); | |||
| bitstream_skip(bc, ff_interleaved_golomb_vlc_len[buf]); | |||
| return ff_interleaved_se_golomb_vlc_code[buf]; | |||
| } else { | |||
| int log; | |||
| LAST_SKIP_BITS(re, gb, 8); | |||
| UPDATE_CACHE(re, gb); | |||
| buf |= 1 | (GET_CACHE(re, gb) >> 8); | |||
| bitstream_skip(bc, 8); | |||
| buf |= 1 | bitstream_peek(bc, 24); | |||
| if ((buf & 0xAAAAAAAA) == 0) | |||
| return INVALID_VLC; | |||
| @@ -244,25 +223,20 @@ static inline int get_interleaved_se_golomb(GetBitContext *gb) | |||
| for (log = 31; (buf & 0x80000000) == 0; log--) | |||
| buf = (buf << 2) - ((buf << log) >> (log - 1)) + (buf >> 30); | |||
| LAST_SKIP_BITS(re, gb, 63 - 2 * log - 8); | |||
| CLOSE_READER(re, gb); | |||
| bitstream_skip(bc, 63 - 2 * log - 8); | |||
| return (signed) (((((buf << log) >> log) - 1) ^ -(buf & 0x1)) + 1) >> 1; | |||
| } | |||
| } | |||
| static inline int dirac_get_se_golomb(GetBitContext *gb) | |||
| static inline int dirac_get_se_golomb(BitstreamContext *bc) | |||
| { | |||
| uint32_t ret = get_interleaved_ue_golomb(gb); | |||
| uint32_t ret = get_interleaved_ue_golomb(bc); | |||
| if (ret) { | |||
| uint32_t buf; | |||
| OPEN_READER(re, gb); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = SHOW_SBITS(re, gb, 1); | |||
| LAST_SKIP_BITS(re, gb, 1); | |||
| buf = bitstream_read_signed(bc, 1); | |||
| ret = (ret ^ buf) - buf; | |||
| CLOSE_READER(re, gb); | |||
| } | |||
| return ret; | |||
| @@ -271,33 +245,25 @@ static inline int dirac_get_se_golomb(GetBitContext *gb) | |||
| /** | |||
| * read unsigned golomb rice code (ffv1). | |||
| */ | |||
| static inline int get_ur_golomb(GetBitContext *gb, int k, int limit, | |||
| static inline int get_ur_golomb(BitstreamContext *bc, int k, int limit, | |||
| int esc_len) | |||
| { | |||
| unsigned int buf; | |||
| int log; | |||
| OPEN_READER(re, gb); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = GET_CACHE(re, gb); | |||
| buf = bitstream_peek(bc, 32); | |||
| log = av_log2(buf); | |||
| if (log > 31 - limit) { | |||
| buf >>= log - k; | |||
| buf += (30 - log) << k; | |||
| LAST_SKIP_BITS(re, gb, 32 + k - log); | |||
| CLOSE_READER(re, gb); | |||
| bitstream_skip(bc, 32 + k - log); | |||
| return buf; | |||
| } else { | |||
| LAST_SKIP_BITS(re, gb, limit); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = SHOW_UBITS(re, gb, esc_len); | |||
| LAST_SKIP_BITS(re, gb, esc_len); | |||
| CLOSE_READER(re, gb); | |||
| bitstream_skip(bc, limit); | |||
| buf = bitstream_read(bc, esc_len); | |||
| return buf + limit - 1; | |||
| } | |||
| @@ -306,48 +272,38 @@ static inline int get_ur_golomb(GetBitContext *gb, int k, int limit, | |||
| /** | |||
| * read unsigned golomb rice code (jpegls). | |||
| */ | |||
| static inline int get_ur_golomb_jpegls(GetBitContext *gb, int k, int limit, | |||
| static inline int get_ur_golomb_jpegls(BitstreamContext *bc, int k, int limit, | |||
| int esc_len) | |||
| { | |||
| unsigned int buf; | |||
| int log; | |||
| OPEN_READER(re, gb); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = GET_CACHE(re, gb); | |||
| buf = bitstream_peek(bc, 32); | |||
| log = av_log2(buf); | |||
| if (log - k >= 32 - MIN_CACHE_BITS + (MIN_CACHE_BITS == 32) && | |||
| 32 - log < limit) { | |||
| if (log - k >= 1 && 32 - log < limit) { | |||
| buf >>= log - k; | |||
| buf += (30 - log) << k; | |||
| LAST_SKIP_BITS(re, gb, 32 + k - log); | |||
| CLOSE_READER(re, gb); | |||
| bitstream_skip(bc, 32 + k - log); | |||
| return buf; | |||
| } else { | |||
| int i; | |||
| for (i = 0; i < limit && SHOW_UBITS(re, gb, 1) == 0 && BITS_AVAILABLE(re, gb); i++) { | |||
| LAST_SKIP_BITS(re, gb, 1); | |||
| UPDATE_CACHE(re, gb); | |||
| } | |||
| SKIP_BITS(re, gb, 1); | |||
| for (i = 0; i < limit && bitstream_peek(bc, 1) == 0 && bitstream_bits_left(bc) > 0; i++) | |||
| bitstream_skip(bc, 1); | |||
| bitstream_skip(bc, 1); | |||
| if (i < limit - 1) { | |||
| if (k) { | |||
| buf = SHOW_UBITS(re, gb, k); | |||
| LAST_SKIP_BITS(re, gb, k); | |||
| buf = bitstream_read(bc, k); | |||
| } else { | |||
| buf = 0; | |||
| } | |||
| CLOSE_READER(re, gb); | |||
| return buf + (i << k); | |||
| } else if (i == limit - 1) { | |||
| buf = SHOW_UBITS(re, gb, esc_len); | |||
| LAST_SKIP_BITS(re, gb, esc_len); | |||
| CLOSE_READER(re, gb); | |||
| buf = bitstream_read(bc, esc_len); | |||
| return buf + 1; | |||
| } else | |||
| @@ -358,10 +314,10 @@ static inline int get_ur_golomb_jpegls(GetBitContext *gb, int k, int limit, | |||
| /** | |||
| * read signed golomb rice code (ffv1). | |||
| */ | |||
| static inline int get_sr_golomb(GetBitContext *gb, int k, int limit, | |||
| static inline int get_sr_golomb(BitstreamContext *bc, int k, int limit, | |||
| int esc_len) | |||
| { | |||
| int v = get_ur_golomb(gb, k, limit, esc_len); | |||
| int v = get_ur_golomb(bc, k, limit, esc_len); | |||
| v++; | |||
| if (v & 1) | |||
| @@ -375,27 +331,27 @@ static inline int get_sr_golomb(GetBitContext *gb, int k, int limit, | |||
| /** | |||
| * read signed golomb rice code (flac). | |||
| */ | |||
| static inline int get_sr_golomb_flac(GetBitContext *gb, int k, int limit, | |||
| static inline int get_sr_golomb_flac(BitstreamContext *bc, int k, int limit, | |||
| int esc_len) | |||
| { | |||
| int v = get_ur_golomb_jpegls(gb, k, limit, esc_len); | |||
| int v = get_ur_golomb_jpegls(bc, k, limit, esc_len); | |||
| return (v >> 1) ^ -(v & 1); | |||
| } | |||
| /** | |||
| * read unsigned golomb rice code (shorten). | |||
| */ | |||
| static inline unsigned int get_ur_golomb_shorten(GetBitContext *gb, int k) | |||
| static inline unsigned int get_ur_golomb_shorten(BitstreamContext *bc, int k) | |||
| { | |||
| return get_ur_golomb_jpegls(gb, k, INT_MAX, 0); | |||
| return get_ur_golomb_jpegls(bc, k, INT_MAX, 0); | |||
| } | |||
| /** | |||
| * read signed golomb rice code (shorten). | |||
| */ | |||
| static inline int get_sr_golomb_shorten(GetBitContext *gb, int k) | |||
| static inline int get_sr_golomb_shorten(BitstreamContext *bc, int k) | |||
| { | |||
| int uvar = get_ur_golomb_jpegls(gb, k + 1, INT_MAX, 0); | |||
| int uvar = get_ur_golomb_jpegls(bc, k + 1, INT_MAX, 0); | |||
| if (uvar & 1) | |||
| return ~(uvar >> 1); | |||
| else | |||
| @@ -404,13 +360,13 @@ static inline int get_sr_golomb_shorten(GetBitContext *gb, int k) | |||
| #ifdef TRACE | |||
| static inline int get_ue(GetBitContext *s, const char *file, const char *func, | |||
| static inline int get_ue(BitstreamContext *s, const char *file, const char *func, | |||
| int line) | |||
| { | |||
| int show = show_bits(s, 24); | |||
| int pos = get_bits_count(s); | |||
| int show = bitstream_peek(s, 24); | |||
| int pos = bitstream_tell(s); | |||
| int i = get_ue_golomb(s); | |||
| int len = get_bits_count(s) - pos; | |||
| int len = bitstream_tell(s) - pos; | |||
| int bits = show >> (24 - len); | |||
| av_log(NULL, AV_LOG_DEBUG, "%5d %2d %3d ue @%5d in %s %s:%d\n", | |||
| @@ -419,13 +375,13 @@ static inline int get_ue(GetBitContext *s, const char *file, const char *func, | |||
| return i; | |||
| } | |||
| static inline int get_se(GetBitContext *s, const char *file, const char *func, | |||
| static inline int get_se(BitstreamContext *s, const char *file, const char *func, | |||
| int line) | |||
| { | |||
| int show = show_bits(s, 24); | |||
| int pos = get_bits_count(s); | |||
| int show = bitstream_peek(s, 24); | |||
| int pos = bitstream_tell(s); | |||
| int i = get_se_golomb(s); | |||
| int len = get_bits_count(s) - pos; | |||
| int len = bitstream_tell(s) - pos; | |||
| int bits = show >> (24 - len); | |||
| av_log(NULL, AV_LOG_DEBUG, "%5d %2d %3d se @%5d in %s %s:%d\n", | |||
| @@ -434,13 +390,13 @@ static inline int get_se(GetBitContext *s, const char *file, const char *func, | |||
| return i; | |||
| } | |||
| static inline int get_te(GetBitContext *s, int r, char *file, const char *func, | |||
| static inline int get_te(BitstreamContext *s, int r, char *file, const char *func, | |||
| int line) | |||
| { | |||
| int show = show_bits(s, 24); | |||
| int pos = get_bits_count(s); | |||
| int show = bitstream_peek(s, 24); | |||
| int pos = bitstream_tell(s); | |||
| int i = get_te0_golomb(s, r); | |||
| int len = get_bits_count(s) - pos; | |||
| int len = bitstream_tell(s) - pos; | |||
| int bits = show >> (24 - len); | |||
| av_log(NULL, AV_LOG_DEBUG, "%5d %2d %3d te @%5d in %s %s:%d\n", | |||
| @@ -0,0 +1,573 @@ | |||
| /* | |||
| * exp golomb vlc stuff | |||
| * Copyright (c) 2003 Michael Niedermayer <michaelni@gmx.at> | |||
| * Copyright (c) 2004 Alex Beregszaszi | |||
| * | |||
| * This file is part of Libav. | |||
| * | |||
| * Libav is free software; you can redistribute it and/or | |||
| * modify it under the terms of the GNU Lesser General Public | |||
| * License as published by the Free Software Foundation; either | |||
| * version 2.1 of the License, or (at your option) any later version. | |||
| * | |||
| * Libav is distributed in the hope that it will be useful, | |||
| * but WITHOUT ANY WARRANTY; without even the implied warranty of | |||
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |||
| * Lesser General Public License for more details. | |||
| * | |||
| * You should have received a copy of the GNU Lesser General Public | |||
| * License along with Libav; if not, write to the Free Software | |||
| * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |||
| */ | |||
| /** | |||
| * @file | |||
| * @brief | |||
| * exp golomb vlc stuff | |||
| * @author Michael Niedermayer <michaelni@gmx.at> and Alex Beregszaszi | |||
| */ | |||
| #ifndef AVCODEC_GOLOMB_H | |||
| #define AVCODEC_GOLOMB_H | |||
| #include <stdint.h> | |||
| #include "get_bits.h" | |||
| #include "put_bits.h" | |||
| #define INVALID_VLC 0x80000000 | |||
| extern const uint8_t ff_golomb_vlc_len[512]; | |||
| extern const uint8_t ff_ue_golomb_vlc_code[512]; | |||
| extern const int8_t ff_se_golomb_vlc_code[512]; | |||
| extern const uint8_t ff_ue_golomb_len[256]; | |||
| extern const uint8_t ff_interleaved_golomb_vlc_len[256]; | |||
| extern const uint8_t ff_interleaved_ue_golomb_vlc_code[256]; | |||
| extern const int8_t ff_interleaved_se_golomb_vlc_code[256]; | |||
| extern const uint8_t ff_interleaved_dirac_golomb_vlc_code[256]; | |||
| /** | |||
| * read unsigned exp golomb code. | |||
| */ | |||
| static inline int get_ue_golomb(GetBitContext *gb) | |||
| { | |||
| unsigned int buf; | |||
| OPEN_READER(re, gb); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = GET_CACHE(re, gb); | |||
| if (buf >= (1 << 27)) { | |||
| buf >>= 32 - 9; | |||
| LAST_SKIP_BITS(re, gb, ff_golomb_vlc_len[buf]); | |||
| CLOSE_READER(re, gb); | |||
| return ff_ue_golomb_vlc_code[buf]; | |||
| } else { | |||
| int log = 2 * av_log2(buf) - 31; | |||
| buf >>= log; | |||
| buf--; | |||
| LAST_SKIP_BITS(re, gb, 32 - log); | |||
| CLOSE_READER(re, gb); | |||
| return buf; | |||
| } | |||
| } | |||
| /** | |||
| * Read an unsigned Exp-Golomb code in the range 0 to UINT32_MAX-1. | |||
| */ | |||
| static inline unsigned get_ue_golomb_long(GetBitContext *gb) | |||
| { | |||
| unsigned buf, log; | |||
| buf = show_bits_long(gb, 32); | |||
| log = 31 - av_log2(buf); | |||
| skip_bits_long(gb, log); | |||
| return get_bits_long(gb, log + 1) - 1; | |||
| } | |||
| /** | |||
| * read unsigned exp golomb code, constraint to a max of 31. | |||
| * the return value is undefined if the stored value exceeds 31. | |||
| */ | |||
| static inline int get_ue_golomb_31(GetBitContext *gb) | |||
| { | |||
| unsigned int buf; | |||
| OPEN_READER(re, gb); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = GET_CACHE(re, gb); | |||
| buf >>= 32 - 9; | |||
| LAST_SKIP_BITS(re, gb, ff_golomb_vlc_len[buf]); | |||
| CLOSE_READER(re, gb); | |||
| return ff_ue_golomb_vlc_code[buf]; | |||
| } | |||
| static inline unsigned get_interleaved_ue_golomb(GetBitContext *gb) | |||
| { | |||
| uint32_t buf; | |||
| OPEN_READER(re, gb); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = GET_CACHE(re, gb); | |||
| if (buf & 0xAA800000) { | |||
| buf >>= 32 - 8; | |||
| LAST_SKIP_BITS(re, gb, ff_interleaved_golomb_vlc_len[buf]); | |||
| CLOSE_READER(re, gb); | |||
| return ff_interleaved_ue_golomb_vlc_code[buf]; | |||
| } else { | |||
| unsigned ret = 1; | |||
| do { | |||
| buf >>= 32 - 8; | |||
| LAST_SKIP_BITS(re, gb, | |||
| FFMIN(ff_interleaved_golomb_vlc_len[buf], 8)); | |||
| if (ff_interleaved_golomb_vlc_len[buf] != 9) { | |||
| ret <<= (ff_interleaved_golomb_vlc_len[buf] - 1) >> 1; | |||
| ret |= ff_interleaved_dirac_golomb_vlc_code[buf]; | |||
| break; | |||
| } | |||
| ret = (ret << 4) | ff_interleaved_dirac_golomb_vlc_code[buf]; | |||
| UPDATE_CACHE(re, gb); | |||
| buf = GET_CACHE(re, gb); | |||
| } while (BITS_AVAILABLE(re, gb)); | |||
| CLOSE_READER(re, gb); | |||
| return ret - 1; | |||
| } | |||
| } | |||
| /** | |||
| * read unsigned truncated exp golomb code. | |||
| */ | |||
| static inline int get_te0_golomb(GetBitContext *gb, int range) | |||
| { | |||
| assert(range >= 1); | |||
| if (range == 1) | |||
| return 0; | |||
| else if (range == 2) | |||
| return get_bits1(gb) ^ 1; | |||
| else | |||
| return get_ue_golomb(gb); | |||
| } | |||
| /** | |||
| * read unsigned truncated exp golomb code. | |||
| */ | |||
| static inline int get_te_golomb(GetBitContext *gb, int range) | |||
| { | |||
| assert(range >= 1); | |||
| if (range == 2) | |||
| return get_bits1(gb) ^ 1; | |||
| else | |||
| return get_ue_golomb(gb); | |||
| } | |||
| /** | |||
| * read signed exp golomb code. | |||
| */ | |||
| static inline int get_se_golomb(GetBitContext *gb) | |||
| { | |||
| unsigned int buf; | |||
| OPEN_READER(re, gb); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = GET_CACHE(re, gb); | |||
| if (buf >= (1 << 27)) { | |||
| buf >>= 32 - 9; | |||
| LAST_SKIP_BITS(re, gb, ff_golomb_vlc_len[buf]); | |||
| CLOSE_READER(re, gb); | |||
| return ff_se_golomb_vlc_code[buf]; | |||
| } else { | |||
| int log = 2 * av_log2(buf) - 31; | |||
| buf >>= log; | |||
| LAST_SKIP_BITS(re, gb, 32 - log); | |||
| CLOSE_READER(re, gb); | |||
| if (buf & 1) | |||
| buf = -(buf >> 1); | |||
| else | |||
| buf = (buf >> 1); | |||
| return buf; | |||
| } | |||
| } | |||
| static inline int get_se_golomb_long(GetBitContext *gb) | |||
| { | |||
| unsigned int buf = get_ue_golomb_long(gb); | |||
| if (buf & 1) | |||
| buf = (buf + 1) >> 1; | |||
| else | |||
| buf = -(buf >> 1); | |||
| return buf; | |||
| } | |||
| static inline int get_interleaved_se_golomb(GetBitContext *gb) | |||
| { | |||
| unsigned int buf; | |||
| OPEN_READER(re, gb); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = GET_CACHE(re, gb); | |||
| if (buf & 0xAA800000) { | |||
| buf >>= 32 - 8; | |||
| LAST_SKIP_BITS(re, gb, ff_interleaved_golomb_vlc_len[buf]); | |||
| CLOSE_READER(re, gb); | |||
| return ff_interleaved_se_golomb_vlc_code[buf]; | |||
| } else { | |||
| int log; | |||
| LAST_SKIP_BITS(re, gb, 8); | |||
| UPDATE_CACHE(re, gb); | |||
| buf |= 1 | (GET_CACHE(re, gb) >> 8); | |||
| if ((buf & 0xAAAAAAAA) == 0) | |||
| return INVALID_VLC; | |||
| for (log = 31; (buf & 0x80000000) == 0; log--) | |||
| buf = (buf << 2) - ((buf << log) >> (log - 1)) + (buf >> 30); | |||
| LAST_SKIP_BITS(re, gb, 63 - 2 * log - 8); | |||
| CLOSE_READER(re, gb); | |||
| return (signed) (((((buf << log) >> log) - 1) ^ -(buf & 0x1)) + 1) >> 1; | |||
| } | |||
| } | |||
| static inline int dirac_get_se_golomb(GetBitContext *gb) | |||
| { | |||
| uint32_t ret = get_interleaved_ue_golomb(gb); | |||
| if (ret) { | |||
| uint32_t buf; | |||
| OPEN_READER(re, gb); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = SHOW_SBITS(re, gb, 1); | |||
| LAST_SKIP_BITS(re, gb, 1); | |||
| ret = (ret ^ buf) - buf; | |||
| CLOSE_READER(re, gb); | |||
| } | |||
| return ret; | |||
| } | |||
| /** | |||
| * read unsigned golomb rice code (ffv1). | |||
| */ | |||
| static inline int get_ur_golomb(GetBitContext *gb, int k, int limit, | |||
| int esc_len) | |||
| { | |||
| unsigned int buf; | |||
| int log; | |||
| OPEN_READER(re, gb); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = GET_CACHE(re, gb); | |||
| log = av_log2(buf); | |||
| if (log > 31 - limit) { | |||
| buf >>= log - k; | |||
| buf += (30 - log) << k; | |||
| LAST_SKIP_BITS(re, gb, 32 + k - log); | |||
| CLOSE_READER(re, gb); | |||
| return buf; | |||
| } else { | |||
| LAST_SKIP_BITS(re, gb, limit); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = SHOW_UBITS(re, gb, esc_len); | |||
| LAST_SKIP_BITS(re, gb, esc_len); | |||
| CLOSE_READER(re, gb); | |||
| return buf + limit - 1; | |||
| } | |||
| } | |||
| /** | |||
| * read unsigned golomb rice code (jpegls). | |||
| */ | |||
| static inline int get_ur_golomb_jpegls(GetBitContext *gb, int k, int limit, | |||
| int esc_len) | |||
| { | |||
| unsigned int buf; | |||
| int log; | |||
| OPEN_READER(re, gb); | |||
| UPDATE_CACHE(re, gb); | |||
| buf = GET_CACHE(re, gb); | |||
| log = av_log2(buf); | |||
| if (log - k >= 32 - MIN_CACHE_BITS + (MIN_CACHE_BITS == 32) && | |||
| 32 - log < limit) { | |||
| buf >>= log - k; | |||
| buf += (30 - log) << k; | |||
| LAST_SKIP_BITS(re, gb, 32 + k - log); | |||
| CLOSE_READER(re, gb); | |||
| return buf; | |||
| } else { | |||
| int i; | |||
| for (i = 0; i < limit && SHOW_UBITS(re, gb, 1) == 0 && BITS_AVAILABLE(re, gb); i++) { | |||
| LAST_SKIP_BITS(re, gb, 1); | |||
| UPDATE_CACHE(re, gb); | |||
| } | |||
| SKIP_BITS(re, gb, 1); | |||
| if (i < limit - 1) { | |||
| if (k) { | |||
| buf = SHOW_UBITS(re, gb, k); | |||
| LAST_SKIP_BITS(re, gb, k); | |||
| } else { | |||
| buf = 0; | |||
| } | |||
| CLOSE_READER(re, gb); | |||
| return buf + (i << k); | |||
| } else if (i == limit - 1) { | |||
| buf = SHOW_UBITS(re, gb, esc_len); | |||
| LAST_SKIP_BITS(re, gb, esc_len); | |||
| CLOSE_READER(re, gb); | |||
| return buf + 1; | |||
| } else | |||
| return -1; | |||
| } | |||
| } | |||
| /** | |||
| * read signed golomb rice code (ffv1). | |||
| */ | |||
| static inline int get_sr_golomb(GetBitContext *gb, int k, int limit, | |||
| int esc_len) | |||
| { | |||
| int v = get_ur_golomb(gb, k, limit, esc_len); | |||
| v++; | |||
| if (v & 1) | |||
| return v >> 1; | |||
| else | |||
| return -(v >> 1); | |||
| // return (v>>1) ^ -(v&1); | |||
| } | |||
| /** | |||
| * read signed golomb rice code (flac). | |||
| */ | |||
| static inline int get_sr_golomb_flac(GetBitContext *gb, int k, int limit, | |||
| int esc_len) | |||
| { | |||
| int v = get_ur_golomb_jpegls(gb, k, limit, esc_len); | |||
| return (v >> 1) ^ -(v & 1); | |||
| } | |||
| /** | |||
| * read unsigned golomb rice code (shorten). | |||
| */ | |||
| static inline unsigned int get_ur_golomb_shorten(GetBitContext *gb, int k) | |||
| { | |||
| return get_ur_golomb_jpegls(gb, k, INT_MAX, 0); | |||
| } | |||
| /** | |||
| * read signed golomb rice code (shorten). | |||
| */ | |||
| static inline int get_sr_golomb_shorten(GetBitContext *gb, int k) | |||
| { | |||
| int uvar = get_ur_golomb_jpegls(gb, k + 1, INT_MAX, 0); | |||
| if (uvar & 1) | |||
| return ~(uvar >> 1); | |||
| else | |||
| return uvar >> 1; | |||
| } | |||
| #ifdef TRACE | |||
| static inline int get_ue(GetBitContext *s, const char *file, const char *func, | |||
| int line) | |||
| { | |||
| int show = show_bits(s, 24); | |||
| int pos = get_bits_count(s); | |||
| int i = get_ue_golomb(s); | |||
| int len = get_bits_count(s) - pos; | |||
| int bits = show >> (24 - len); | |||
| av_log(NULL, AV_LOG_DEBUG, "%5d %2d %3d ue @%5d in %s %s:%d\n", | |||
| bits, len, i, pos, file, func, line); | |||
| return i; | |||
| } | |||
| static inline int get_se(GetBitContext *s, const char *file, const char *func, | |||
| int line) | |||
| { | |||
| int show = show_bits(s, 24); | |||
| int pos = get_bits_count(s); | |||
| int i = get_se_golomb(s); | |||
| int len = get_bits_count(s) - pos; | |||
| int bits = show >> (24 - len); | |||
| av_log(NULL, AV_LOG_DEBUG, "%5d %2d %3d se @%5d in %s %s:%d\n", | |||
| bits, len, i, pos, file, func, line); | |||
| return i; | |||
| } | |||
| static inline int get_te(GetBitContext *s, int r, char *file, const char *func, | |||
| int line) | |||
| { | |||
| int show = show_bits(s, 24); | |||
| int pos = get_bits_count(s); | |||
| int i = get_te0_golomb(s, r); | |||
| int len = get_bits_count(s) - pos; | |||
| int bits = show >> (24 - len); | |||
| av_log(NULL, AV_LOG_DEBUG, "%5d %2d %3d te @%5d in %s %s:%d\n", | |||
| bits, len, i, pos, file, func, line); | |||
| return i; | |||
| } | |||
| #define get_ue_golomb(a) get_ue(a, __FILE__, __func__, __LINE__) | |||
| #define get_se_golomb(a) get_se(a, __FILE__, __func__, __LINE__) | |||
| #define get_te_golomb(a, r) get_te(a, r, __FILE__, __func__, __LINE__) | |||
| #define get_te0_golomb(a, r) get_te(a, r, __FILE__, __func__, __LINE__) | |||
| #endif /* TRACE */ | |||
| /** | |||
| * write unsigned exp golomb code. | |||
| */ | |||
| static inline void set_ue_golomb(PutBitContext *pb, int i) | |||
| { | |||
| assert(i >= 0); | |||
| if (i < 256) | |||
| put_bits(pb, ff_ue_golomb_len[i], i + 1); | |||
| else { | |||
| int e = av_log2(i + 1); | |||
| put_bits(pb, 2 * e + 1, i + 1); | |||
| } | |||
| } | |||
| /** | |||
| * write truncated unsigned exp golomb code. | |||
| */ | |||
| static inline void set_te_golomb(PutBitContext *pb, int i, int range) | |||
| { | |||
| assert(range >= 1); | |||
| assert(i <= range); | |||
| if (range == 2) | |||
| put_bits(pb, 1, i ^ 1); | |||
| else | |||
| set_ue_golomb(pb, i); | |||
| } | |||
| /** | |||
| * write signed exp golomb code. 16 bits at most. | |||
| */ | |||
| static inline void set_se_golomb(PutBitContext *pb, int i) | |||
| { | |||
| i = 2 * i - 1; | |||
| if (i < 0) | |||
| i ^= -1; //FIXME check if gcc does the right thing | |||
| set_ue_golomb(pb, i); | |||
| } | |||
| /** | |||
| * write unsigned golomb rice code (ffv1). | |||
| */ | |||
| static inline void set_ur_golomb(PutBitContext *pb, int i, int k, int limit, | |||
| int esc_len) | |||
| { | |||
| int e; | |||
| assert(i >= 0); | |||
| e = i >> k; | |||
| if (e < limit) | |||
| put_bits(pb, e + k + 1, (1 << k) + (i & ((1 << k) - 1))); | |||
| else | |||
| put_bits(pb, limit + esc_len, i - limit + 1); | |||
| } | |||
| /** | |||
| * write unsigned golomb rice code (jpegls). | |||
| */ | |||
| static inline void set_ur_golomb_jpegls(PutBitContext *pb, int i, int k, | |||
| int limit, int esc_len) | |||
| { | |||
| int e; | |||
| assert(i >= 0); | |||
| e = (i >> k) + 1; | |||
| if (e < limit) { | |||
| while (e > 31) { | |||
| put_bits(pb, 31, 0); | |||
| e -= 31; | |||
| } | |||
| put_bits(pb, e, 1); | |||
| if (k) | |||
| put_sbits(pb, k, i); | |||
| } else { | |||
| while (limit > 31) { | |||
| put_bits(pb, 31, 0); | |||
| limit -= 31; | |||
| } | |||
| put_bits(pb, limit, 1); | |||
| put_bits(pb, esc_len, i - 1); | |||
| } | |||
| } | |||
| /** | |||
| * write signed golomb rice code (ffv1). | |||
| */ | |||
| static inline void set_sr_golomb(PutBitContext *pb, int i, int k, int limit, | |||
| int esc_len) | |||
| { | |||
| int v; | |||
| v = -2 * i - 1; | |||
| v ^= (v >> 31); | |||
| set_ur_golomb(pb, v, k, limit, esc_len); | |||
| } | |||
| /** | |||
| * write signed golomb rice code (flac). | |||
| */ | |||
| static inline void set_sr_golomb_flac(PutBitContext *pb, int i, int k, | |||
| int limit, int esc_len) | |||
| { | |||
| int v; | |||
| v = -2 * i - 1; | |||
| v ^= (v >> 31); | |||
| set_ur_golomb_jpegls(pb, v, k, limit, esc_len); | |||
| } | |||
| #endif /* AVCODEC_GOLOMB_H */ | |||
| @@ -32,7 +32,7 @@ | |||
| #include "h264dec.h" | |||
| #include "h264_mvpred.h" | |||
| #include "h264data.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "mpegutils.h" | |||
| #include <assert.h> | |||
| @@ -18,7 +18,7 @@ | |||
| #include "bytestream.h" | |||
| #include "get_bits.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "h264.h" | |||
| #include "h264dec.h" | |||
| #include "h264_parse.h" | |||
| @@ -36,7 +36,7 @@ | |||
| #include "avcodec.h" | |||
| #include "get_bits.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "h264.h" | |||
| #include "h264_sei.h" | |||
| #include "h264_ps.h" | |||
| @@ -28,12 +28,13 @@ | |||
| #include <inttypes.h> | |||
| #include "libavutil/imgutils.h" | |||
| #include "golomb_legacy.h" | |||
| #include "internal.h" | |||
| #include "mathops.h" | |||
| #include "avcodec.h" | |||
| #include "h264data.h" | |||
| #include "h264_ps.h" | |||
| #include "golomb.h" | |||
| #define MAX_LOG2_MAX_FRAME_NUM (12 + 4) | |||
| #define MIN_LOG2_MAX_FRAME_NUM 4 | |||
| @@ -27,11 +27,11 @@ | |||
| #include <inttypes.h> | |||
| #include "golomb_legacy.h" | |||
| #include "internal.h" | |||
| #include "avcodec.h" | |||
| #include "h264.h" | |||
| #include "h264dec.h" | |||
| #include "golomb.h" | |||
| #include "mpegutils.h" | |||
| #include <assert.h> | |||
| @@ -27,7 +27,7 @@ | |||
| #include "avcodec.h" | |||
| #include "get_bits.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "h264_ps.h" | |||
| #include "h264_sei.h" | |||
| #include "internal.h" | |||
| @@ -34,6 +34,7 @@ | |||
| #include "cabac.h" | |||
| #include "cabac_functions.h" | |||
| #include "error_resilience.h" | |||
| #include "golomb_legacy.h" | |||
| #include "avcodec.h" | |||
| #include "h264.h" | |||
| #include "h264dec.h" | |||
| @@ -41,7 +42,6 @@ | |||
| #include "h264chroma.h" | |||
| #include "h264_mvpred.h" | |||
| #include "h264_ps.h" | |||
| #include "golomb.h" | |||
| #include "mathops.h" | |||
| #include "mpegutils.h" | |||
| #include "rectangle.h" | |||
| @@ -36,6 +36,7 @@ | |||
| #include "cabac_functions.h" | |||
| #include "error_resilience.h" | |||
| #include "avcodec.h" | |||
| #include "golomb_legacy.h" | |||
| #include "h264.h" | |||
| #include "h264dec.h" | |||
| #include "h2645_parse.h" | |||
| @@ -43,7 +44,6 @@ | |||
| #include "h264chroma.h" | |||
| #include "h264_mvpred.h" | |||
| #include "h264_ps.h" | |||
| #include "golomb.h" | |||
| #include "mathops.h" | |||
| #include "me_cmp.h" | |||
| #include "mpegutils.h" | |||
| @@ -22,7 +22,7 @@ | |||
| #include "libavutil/common.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "hevc.h" | |||
| #include "hevcdec.h" | |||
| #include "h2645_parse.h" | |||
| @@ -25,7 +25,7 @@ | |||
| #include "libavutil/imgutils.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "hevc_data.h" | |||
| #include "hevc_ps.h" | |||
| @@ -18,7 +18,7 @@ | |||
| * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |||
| */ | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "hevc_ps.h" | |||
| #include "put_bits.h" | |||
| @@ -22,7 +22,7 @@ | |||
| * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |||
| */ | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "hevcdec.h" | |||
| enum HEVC_SEI_TYPE { | |||
| @@ -35,7 +35,7 @@ | |||
| #include "bswapdsp.h" | |||
| #include "bytestream.h" | |||
| #include "cabac_functions.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "hevc.h" | |||
| #include "hevc_data.h" | |||
| #include "hevcdec.h" | |||
| @@ -27,7 +27,7 @@ | |||
| #include "avcodec.h" | |||
| #include "get_bits.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "internal.h" | |||
| #include "mathops.h" | |||
| #include "mjpeg.h" | |||
| @@ -27,7 +27,7 @@ | |||
| #include "avcodec.h" | |||
| #include "get_bits.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "internal.h" | |||
| #include "mathops.h" | |||
| #include "mjpeg.h" | |||
| @@ -26,7 +26,7 @@ | |||
| #include "avcodec.h" | |||
| #include "get_bits.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "internal.h" | |||
| #include "mathops.h" | |||
| @@ -30,7 +30,7 @@ | |||
| #include "libavutil/channel_layout.h" | |||
| #include "avcodec.h" | |||
| #include "get_bits.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "internal.h" | |||
| #include "unary_legacy.h" | |||
| #include "ralfdata.h" | |||
| @@ -25,9 +25,9 @@ | |||
| */ | |||
| #include "avcodec.h" | |||
| #include "golomb_legacy.h" | |||
| #include "mpegutils.h" | |||
| #include "mpegvideo.h" | |||
| #include "golomb.h" | |||
| #include "rv34.h" | |||
| #include "rv30data.h" | |||
| @@ -28,9 +28,9 @@ | |||
| #include "avcodec.h" | |||
| #include "error_resilience.h" | |||
| #include "golomb_legacy.h" | |||
| #include "mpegutils.h" | |||
| #include "mpegvideo.h" | |||
| #include "golomb.h" | |||
| #include "internal.h" | |||
| #include "mathops.h" | |||
| #include "mpeg_er.h" | |||
| @@ -27,9 +27,9 @@ | |||
| #include "libavutil/imgutils.h" | |||
| #include "avcodec.h" | |||
| #include "golomb_legacy.h" | |||
| #include "mpegutils.h" | |||
| #include "mpegvideo.h" | |||
| #include "golomb.h" | |||
| #include "rv34.h" | |||
| #include "rv40vlc2.h" | |||
| @@ -29,7 +29,7 @@ | |||
| #include "avcodec.h" | |||
| #include "bytestream.h" | |||
| #include "get_bits.h" | |||
| #include "golomb.h" | |||
| #include "golomb_legacy.h" | |||
| #include "internal.h" | |||
| #define MAX_CHANNELS 8 | |||
| @@ -43,12 +43,13 @@ | |||
| #include <inttypes.h> | |||
| #include "libavutil/attributes.h" | |||
| #include "golomb_legacy.h" | |||
| #include "internal.h" | |||
| #include "avcodec.h" | |||
| #include "mpegutils.h" | |||
| #include "h264dec.h" | |||
| #include "h264data.h" | |||
| #include "golomb.h" | |||
| #include "hpeldsp.h" | |||
| #include "mathops.h" | |||
| #include "rectangle.h" | |||
| @@ -21,7 +21,7 @@ | |||
| #include "libavutil/mem.h" | |||
| #include "libavcodec/get_bits.h" | |||
| #include "libavcodec/bitstream.h" | |||
| #include "libavcodec/put_bits.h" | |||
| #include "libavcodec/golomb.h" | |||
| @@ -33,7 +33,7 @@ int main(void) | |||
| int i, ret = 0; | |||
| uint8_t *temp; | |||
| PutBitContext pb; | |||
| GetBitContext gb; | |||
| BitstreamContext bc; | |||
| temp = av_malloc(SIZE); | |||
| if (!temp) | |||
| @@ -44,11 +44,11 @@ int main(void) | |||
| set_ue_golomb(&pb, i); | |||
| flush_put_bits(&pb); | |||
| init_get_bits(&gb, temp, 8 * SIZE); | |||
| bitstream_init8(&bc, temp, SIZE); | |||
| for (i = 0; i < COUNT; i++) { | |||
| int j, s = show_bits(&gb, 25); | |||
| int j, s = bitstream_peek(&bc, 25); | |||
| j = get_ue_golomb(&gb); | |||
| j = get_ue_golomb(&bc); | |||
| if (j != i) { | |||
| fprintf(stderr, "get_ue_golomb: expected %d, got %d. bits: %7x\n", | |||
| i, j, s); | |||
| @@ -62,11 +62,11 @@ int main(void) | |||
| set_ue_golomb(&pb, EXTEND(i)); | |||
| flush_put_bits(&pb); | |||
| init_get_bits(&gb, temp, 8 * SIZE); | |||
| bitstream_init8(&bc, temp, SIZE); | |||
| for (i = 0; i < COUNT; i++) { | |||
| int j, s = show_bits_long(&gb, 32); | |||
| int j, s = bitstream_peek(&bc, 32); | |||
| j = get_ue_golomb_long(&gb); | |||
| j = get_ue_golomb_long(&bc); | |||
| if (j != EXTEND(i)) { | |||
| fprintf(stderr, "get_ue_golomb_long: expected %d, got %d. " | |||
| "bits: %8x\n", EXTEND(i), j, s); | |||
| @@ -79,11 +79,11 @@ int main(void) | |||
| set_se_golomb(&pb, i - COUNT / 2); | |||
| flush_put_bits(&pb); | |||
| init_get_bits(&gb, temp, 8 * SIZE); | |||
| bitstream_init8(&bc, temp, SIZE); | |||
| for (i = 0; i < COUNT; i++) { | |||
| int j, s = show_bits(&gb, 25); | |||
| int j, s = bitstream_peek(&bc, 25); | |||
| j = get_se_golomb(&gb); | |||
| j = get_se_golomb(&bc); | |||
| if (j != i - COUNT / 2) { | |||
| fprintf(stderr, "get_se_golomb: expected %d, got %d. bits: %7x\n", | |||
| i - COUNT / 2, j, s); | |||
| @@ -20,7 +20,7 @@ | |||
| #include "libavcodec/avcodec.h" | |||
| #include "libavcodec/get_bits.h" | |||
| #include "libavcodec/golomb.h" | |||
| #include "libavcodec/golomb_legacy.h" | |||
| #include "libavcodec/hevc.h" | |||
| #include "libavutil/intreadwrite.h" | |||
| #include "avc.h" | |||