[SCM] libav/experimental: Store CRC context locally to reduce number of calls to av_crc_get_table().
siretart at users.alioth.debian.org
siretart at users.alioth.debian.org
Sun Jun 30 17:20:47 UTC 2013
The following commit has been merged in the experimental branch:
commit a897423baa09dd651d7c339fdf386c954577d6d6
Author: Justin Ruggles <justin.ruggles at gmail.com>
Date: Thu Dec 23 18:01:23 2010 +0000
Store CRC context locally to reduce number of calls to av_crc_get_table().
Originally committed as revision 26082 to svn://svn.ffmpeg.org/ffmpeg/trunk
diff --git a/libavcodec/ac3enc.c b/libavcodec/ac3enc.c
index edd9167..ed86e61 100644
--- a/libavcodec/ac3enc.c
+++ b/libavcodec/ac3enc.c
@@ -1571,6 +1571,7 @@ static unsigned int pow_poly(unsigned int a, unsigned int n, unsigned int poly)
*/
static void output_frame_end(AC3EncodeContext *s)
{
+ const AVCRC *crc_ctx = av_crc_get_table(AV_CRC_16_ANSI);
int frame_size_58, pad_bytes, crc1, crc2, crc_inv;
uint8_t *frame;
@@ -1586,14 +1587,14 @@ static void output_frame_end(AC3EncodeContext *s)
/* compute crc1 */
/* this is not so easy because it is at the beginning of the data... */
- crc1 = av_bswap16(av_crc(av_crc_get_table(AV_CRC_16_ANSI), 0,
+ crc1 = av_bswap16(av_crc(crc_ctx, 0,
frame + 4, frame_size_58 - 4));
crc_inv = s->crc_inv[s->frame_size > s->frame_size_min];
crc1 = mul_poly(crc_inv, crc1, CRC16_POLY);
AV_WB16(frame + 2, crc1);
/* compute crc2 */
- crc2 = av_bswap16(av_crc(av_crc_get_table(AV_CRC_16_ANSI), 0,
+ crc2 = av_bswap16(av_crc(crc_ctx, 0,
frame + frame_size_58,
s->frame_size - frame_size_58 - 2));
AV_WB16(frame + s->frame_size - 2, crc2);
--
Libav/FFmpeg packaging
More information about the pkg-multimedia-commits
mailing list