[Ffmpeg-cvslog] CVS: ffmpeg/libavcodec ac3enc.c, 1.27, 1.28 ac3tab.h, 1.6, 1.7 utils.c, 1.176, 1.177
Michael Niedermayer CVS
michael
Mon Mar 6 15:53:16 CET 2006
Update of /cvsroot/ffmpeg/ffmpeg/libavcodec
In directory mail:/var2/tmp/cvs-serv8463
Modified Files:
ac3enc.c ac3tab.h utils.c
Log Message:
switch ac3enc to av_crc
Index: ac3enc.c
===================================================================
RCS file: /cvsroot/ffmpeg/ffmpeg/libavcodec/ac3enc.c,v
retrieving revision 1.27
retrieving revision 1.28
diff -u -d -r1.27 -r1.28
--- ac3enc.c 12 Jan 2006 22:43:14 -0000 1.27
+++ ac3enc.c 6 Mar 2006 14:53:13 -0000 1.28
@@ -25,6 +25,7 @@
//#define DEBUG_BITALLOC
#include "avcodec.h"
#include "bitstream.h"
+#include "crc.h"
#include "ac3.h"
typedef struct AC3EncodeContext {
@@ -66,7 +67,6 @@
#define EXP_DIFF_THRESHOLD 1000
static void fft_init(int ln);
-static void ac3_crc_init(void);
static inline int16_t fix15(float a)
{
@@ -886,8 +886,6 @@
xsin1[i] = fix15(-sin(alpha));
}
- ac3_crc_init();
-
avctx->coded_frame= avcodec_alloc_frame();
avctx->coded_frame->key_frame= 1;
@@ -1236,35 +1234,8 @@
}
}
-/* compute the ac3 crc */
-
#define CRC16_POLY ((1 << 0) | (1 << 2) | (1 << 15) | (1 << 16))
-static void ac3_crc_init(void)
-{
- unsigned int c, n, k;
-
- for(n=0;n<256;n++) {
- c = n << 8;
- for (k = 0; k < 8; k++) {
- if (c & (1 << 15))
- c = ((c << 1) & 0xffff) ^ (CRC16_POLY & 0xffff);
- else
- c = c << 1;
- }
- crc_table[n] = c;
- }
-}
-
-static unsigned int ac3_crc(uint8_t *data, int n, unsigned int crc)
-{
- int i;
- for(i=0;i<n;i++) {
- crc = (crc_table[data[i] ^ (crc >> 8)] ^ (crc << 8)) & 0xffff;
- }
- return crc;
-}
-
static unsigned int mul_poly(unsigned int a, unsigned int b, unsigned int poly)
{
unsigned int c;
@@ -1342,14 +1313,14 @@
/* Now we must compute both crcs : this is not so easy for crc1
because it is at the beginning of the data... */
frame_size_58 = (frame_size >> 1) + (frame_size >> 3);
- crc1 = ac3_crc(frame + 4, (2 * frame_size_58) - 4, 0);
+ crc1 = bswap_16(av_crc(av_crc8005, 0, frame + 4, 2 * frame_size_58 - 4));
/* XXX: could precompute crc_inv */
crc_inv = pow_poly((CRC16_POLY >> 1), (16 * frame_size_58) - 16, CRC16_POLY);
crc1 = mul_poly(crc_inv, crc1, CRC16_POLY);
frame[2] = crc1 >> 8;
frame[3] = crc1;
- crc2 = ac3_crc(frame + 2 * frame_size_58, (frame_size - frame_size_58) * 2 - 2, 0);
+ crc2 = bswap_16(av_crc(av_crc8005, 0, frame + 2 * frame_size_58, (frame_size - frame_size_58) * 2 - 2));
frame[2*frame_size - 2] = crc2 >> 8;
frame[2*frame_size - 1] = crc2;
Index: ac3tab.h
===================================================================
RCS file: /cvsroot/ffmpeg/ffmpeg/libavcodec/ac3tab.h,v
retrieving revision 1.6
retrieving revision 1.7
diff -u -d -r1.6 -r1.7
--- ac3tab.h 17 Dec 2005 18:14:26 -0000 1.6
+++ ac3tab.h 6 Mar 2006 14:53:13 -0000 1.7
@@ -182,5 +182,3 @@
static int16_t fft_rev[512];
static int16_t xcos1[128];
static int16_t xsin1[128];
-
-static uint16_t crc_table[256];
Index: utils.c
===================================================================
RCS file: /cvsroot/ffmpeg/ffmpeg/libavcodec/utils.c,v
retrieving revision 1.176
retrieving revision 1.177
diff -u -d -r1.176 -r1.177
--- utils.c 6 Mar 2006 14:13:01 -0000 1.176
+++ utils.c 6 Mar 2006 14:53:13 -0000 1.177
@@ -1221,7 +1221,9 @@
static void init_crcs(void){
av_crc04C11DB7= av_mallocz_static(sizeof(AVCRC) * 257);
+ av_crc8005 = av_mallocz_static(sizeof(AVCRC) * 257);
av_crc_init(av_crc04C11DB7, 0, 32, 0x04c11db7, sizeof(AVCRC)*257);
+ av_crc_init(av_crc8005 , 0, 16, 0x8005 , sizeof(AVCRC)*257);
}
/* must be called before any other functions */
More information about the ffmpeg-cvslog
mailing list