diff options
author | Laurent Aimar <fenrir@via.ecp.fr> | 2008-12-03 01:14:06 +0000 |
---|---|---|
committer | Ramiro Polla <ramiro.polla@gmail.com> | 2008-12-03 01:14:06 +0000 |
commit | 7a2efd2e447d5e7c7c0af61417a838b042fb7d0a (patch) | |
tree | e355330c3d8bb90886842a6fb70db7062f04ead1 /libavcodec | |
parent | 751ccc48521d40505449d1fbfed8c6cd4ad1257d (diff) | |
download | ffmpeg-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.c | 14 | ||||
-rw-r--r-- | libavcodec/mlp.h | 2 | ||||
-rw-r--r-- | libavcodec/mlp_parser.c | 8 |
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, }; |