aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec
diff options
context:
space:
mode:
authorLaurent Aimar <fenrir@via.ecp.fr>2008-12-03 01:14:06 +0000
committerRamiro Polla <ramiro.polla@gmail.com>2008-12-03 01:14:06 +0000
commit7a2efd2e447d5e7c7c0af61417a838b042fb7d0a (patch)
treee355330c3d8bb90886842a6fb70db7062f04ead1 /libavcodec
parent751ccc48521d40505449d1fbfed8c6cd4ad1257d (diff)
downloadffmpeg-7a2efd2e447d5e7c7c0af61417a838b042fb7d0a.tar.gz
mlp: initialize all CRC tables in a common function.
This way the decoder does not have to depend on the parser being initialized before. Patch by Laurent Aimar <fenrir at via dot ecp dot fr>. Originally committed as revision 15986 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec')
-rw-r--r--libavcodec/mlp.c14
-rw-r--r--libavcodec/mlp.h2
-rw-r--r--libavcodec/mlp_parser.c8
3 files changed, 8 insertions, 16 deletions
diff --git a/libavcodec/mlp.c b/libavcodec/mlp.c
index 2ac2e658f1..7ef7f97526 100644
--- a/libavcodec/mlp.c
+++ b/libavcodec/mlp.c
@@ -43,26 +43,14 @@ const uint8_t ff_mlp_huffman_tables[3][18][2] = {
static int crc_init = 0;
static AVCRC crc_63[1024];
static AVCRC crc_1D[1024];
-
-
-static int crc_init_2D = 0;
static AVCRC crc_2D[1024];
-int av_cold ff_mlp_init_crc2D(AVCodecParserContext *s)
-{
- if (!crc_init_2D) {
- av_crc_init(crc_2D, 0, 16, 0x002D, sizeof(crc_2D));
- crc_init_2D = 1;
- }
-
- return 0;
-}
-
void av_cold ff_mlp_init_crc()
{
if (!crc_init) {
av_crc_init(crc_63, 0, 8, 0x63, sizeof(crc_63));
av_crc_init(crc_1D, 0, 8, 0x1D, sizeof(crc_1D));
+ av_crc_init(crc_2D, 0, 16, 0x002D, sizeof(crc_2D));
crc_init = 1;
}
}
diff --git a/libavcodec/mlp.h b/libavcodec/mlp.h
index 338a7a3310..b81c735d1f 100644
--- a/libavcodec/mlp.h
+++ b/libavcodec/mlp.h
@@ -106,8 +106,6 @@ uint8_t ff_mlp_restart_checksum(const uint8_t *buf, unsigned int bit_size);
*/
uint8_t ff_mlp_calculate_parity(const uint8_t *buf, unsigned int buf_size);
-int ff_mlp_init_crc2D(AVCodecParserContext *s);
-
void ff_mlp_init_crc();
/** XOR four bytes into one. */
diff --git a/libavcodec/mlp_parser.c b/libavcodec/mlp_parser.c
index 4400d71fc4..191433376a 100644
--- a/libavcodec/mlp_parser.c
+++ b/libavcodec/mlp_parser.c
@@ -150,6 +150,12 @@ typedef struct MLPParseContext
int num_substreams;
} MLPParseContext;
+static av_cold int mlp_init(AVCodecParserContext *s)
+{
+ ff_mlp_init_crc();
+ return 0;
+}
+
static int mlp_parse(AVCodecParserContext *s,
AVCodecContext *avctx,
const uint8_t **poutbuf, int *poutbuf_size,
@@ -283,7 +289,7 @@ lost_sync:
AVCodecParser mlp_parser = {
{ CODEC_ID_MLP },
sizeof(MLPParseContext),
- ff_mlp_init_crc2D,
+ mlp_init,
mlp_parse,
NULL,
};