changeset 3170:1475eb5f8649 libavcodec

switch ac3enc to av_crc
author michael
date Mon, 06 Mar 2006 14:53:13 +0000
parents 53f0b29ff865
children 47f2f56a6a28
files ac3enc.c ac3tab.h utils.c
diffstat 3 files changed, 5 insertions(+), 34 deletions(-) [+]
line wrap: on
line diff
--- a/ac3enc.c	Mon Mar 06 14:13:01 2006 +0000
+++ b/ac3enc.c	Mon Mar 06 14:53:13 2006 +0000
@@ -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;
 
--- a/ac3tab.h	Mon Mar 06 14:13:01 2006 +0000
+++ b/ac3tab.h	Mon Mar 06 14:53:13 2006 +0000
@@ -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];
--- a/utils.c	Mon Mar 06 14:13:01 2006 +0000
+++ b/utils.c	Mon Mar 06 14:53:13 2006 +0000
@@ -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 */