Use the newly created vlc.h directly instead of including get_bits when needed. The VLC and RL_VLC_ELEM structures are independent from the bitreader. Signed-off-by: Luca Barbato <lu_zero@gentoo.org>tags/n3.1
@@ -31,8 +31,8 @@ | |||||
#include "avcodec.h" | #include "avcodec.h" | ||||
#include "internal.h" | #include "internal.h" | ||||
#include "mathops.h" | #include "mathops.h" | ||||
#include "get_bits.h" | |||||
#include "put_bits.h" | #include "put_bits.h" | ||||
#include "vlc.h" | |||||
const uint8_t ff_log2_run[41]={ | const uint8_t ff_log2_run[41]={ | ||||
0, 0, 0, 0, 1, 1, 1, 1, | 0, 0, 0, 0, 1, 1, 1, 1, | ||||
@@ -32,6 +32,7 @@ | |||||
#include "libavutil/intreadwrite.h" | #include "libavutil/intreadwrite.h" | ||||
#include "libavutil/log.h" | #include "libavutil/log.h" | ||||
#include "mathops.h" | #include "mathops.h" | ||||
#include "vlc.h" | |||||
/* | /* | ||||
* Safe bitstream reading: | * Safe bitstream reading: | ||||
@@ -59,20 +60,6 @@ typedef struct GetBitContext { | |||||
#endif | #endif | ||||
} GetBitContext; | } GetBitContext; | ||||
#define VLC_TYPE int16_t | |||||
typedef struct VLC { | |||||
int bits; | |||||
VLC_TYPE (*table)[2]; ///< code, bits | |||||
int table_size, table_allocated; | |||||
} VLC; | |||||
typedef struct RL_VLC_ELEM { | |||||
int16_t level; | |||||
int8_t len; | |||||
uint8_t run; | |||||
} RL_VLC_ELEM; | |||||
/* Bitstream reader API docs: | /* Bitstream reader API docs: | ||||
* name | * name | ||||
* arbitrary name which is used as prefix for the internal variables | * arbitrary name which is used as prefix for the internal variables | ||||
@@ -421,33 +408,6 @@ static inline const uint8_t *align_get_bits(GetBitContext *s) | |||||
return s->buffer + (s->index >> 3); | return s->buffer + (s->index >> 3); | ||||
} | } | ||||
#define init_vlc(vlc, nb_bits, nb_codes, \ | |||||
bits, bits_wrap, bits_size, \ | |||||
codes, codes_wrap, codes_size, \ | |||||
flags) \ | |||||
ff_init_vlc_sparse(vlc, nb_bits, nb_codes, \ | |||||
bits, bits_wrap, bits_size, \ | |||||
codes, codes_wrap, codes_size, \ | |||||
NULL, 0, 0, flags) | |||||
int ff_init_vlc_sparse(VLC *vlc, int nb_bits, int nb_codes, | |||||
const void *bits, int bits_wrap, int bits_size, | |||||
const void *codes, int codes_wrap, int codes_size, | |||||
const void *symbols, int symbols_wrap, int symbols_size, | |||||
int flags); | |||||
void ff_free_vlc(VLC *vlc); | |||||
#define INIT_VLC_LE 2 | |||||
#define INIT_VLC_USE_NEW_STATIC 4 | |||||
#define INIT_VLC_STATIC(vlc, bits, a, b, c, d, e, f, g, static_size) \ | |||||
do { \ | |||||
static VLC_TYPE table[static_size][2]; \ | |||||
(vlc)->table = table; \ | |||||
(vlc)->table_allocated = static_size; \ | |||||
init_vlc(vlc, bits, a, b, c, d, e, f, g, INIT_VLC_USE_NEW_STATIC); \ | |||||
} while (0) | |||||
/** | /** | ||||
* If the vlc code is invalid and max_depth=1, then no bits will be removed. | * If the vlc code is invalid and max_depth=1, then no bits will be removed. | ||||
* If the vlc code is invalid and max_depth>1, then the number of bits removed | * If the vlc code is invalid and max_depth>1, then the number of bits removed | ||||
@@ -26,8 +26,11 @@ | |||||
#include <stdint.h> | #include <stdint.h> | ||||
#include"libavutil/common.h" | |||||
#include "avcodec.h" | #include "avcodec.h" | ||||
#include "huffman.h" | #include "huffman.h" | ||||
#include "vlc.h" | |||||
/* symbol for Huffman tree node */ | /* symbol for Huffman tree node */ | ||||
#define HNODE -1 | #define HNODE -1 | ||||
@@ -27,7 +27,7 @@ | |||||
#define AVCODEC_HUFFMAN_H | #define AVCODEC_HUFFMAN_H | ||||
#include "avcodec.h" | #include "avcodec.h" | ||||
#include "get_bits.h" | |||||
#include "vlc.h" | |||||
typedef struct Node { | typedef struct Node { | ||||
int16_t sym; | int16_t sym; | ||||
@@ -17,6 +17,7 @@ | |||||
*/ | */ | ||||
#include <stdint.h> | #include <stdint.h> | ||||
#include <string.h> | |||||
#include "libavutil/attributes.h" | #include "libavutil/attributes.h" | ||||
#include "libavutil/mem.h" | #include "libavutil/mem.h" | ||||
@@ -28,7 +28,8 @@ | |||||
#define AVCODEC_RL_H | #define AVCODEC_RL_H | ||||
#include <stdint.h> | #include <stdint.h> | ||||
#include "get_bits.h" | |||||
#include "vlc.h" | |||||
/* run length table */ | /* run length table */ | ||||
#define MAX_RUN 64 | #define MAX_RUN 64 | ||||
@@ -0,0 +1,65 @@ | |||||
/* | |||||
* 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 | |||||
*/ | |||||
#ifndef AVCODEC_VLC_H | |||||
#define AVCODEC_VLC_H | |||||
#include <stdint.h> | |||||
#define VLC_TYPE int16_t | |||||
typedef struct VLC { | |||||
int bits; | |||||
VLC_TYPE (*table)[2]; ///< code, bits | |||||
int table_size, table_allocated; | |||||
} VLC; | |||||
typedef struct RL_VLC_ELEM { | |||||
int16_t level; | |||||
int8_t len; | |||||
uint8_t run; | |||||
} RL_VLC_ELEM; | |||||
#define init_vlc(vlc, nb_bits, nb_codes, \ | |||||
bits, bits_wrap, bits_size, \ | |||||
codes, codes_wrap, codes_size, \ | |||||
flags) \ | |||||
ff_init_vlc_sparse(vlc, nb_bits, nb_codes, \ | |||||
bits, bits_wrap, bits_size, \ | |||||
codes, codes_wrap, codes_size, \ | |||||
NULL, 0, 0, flags) | |||||
int ff_init_vlc_sparse(VLC *vlc, int nb_bits, int nb_codes, | |||||
const void *bits, int bits_wrap, int bits_size, | |||||
const void *codes, int codes_wrap, int codes_size, | |||||
const void *symbols, int symbols_wrap, int symbols_size, | |||||
int flags); | |||||
void ff_free_vlc(VLC *vlc); | |||||
#define INIT_VLC_LE 2 | |||||
#define INIT_VLC_USE_NEW_STATIC 4 | |||||
#define INIT_VLC_STATIC(vlc, bits, a, b, c, d, e, f, g, static_size) \ | |||||
do { \ | |||||
static VLC_TYPE table[static_size][2]; \ | |||||
(vlc)->table = table; \ | |||||
(vlc)->table_allocated = static_size; \ | |||||
init_vlc(vlc, bits, a, b, c, d, e, f, g, INIT_VLC_USE_NEW_STATIC); \ | |||||
} while (0) | |||||
#endif /* AVCODEC_VLC_H */ |