# HG changeset patch # User nicodvb # Date 1138403236 0 # Node ID 3f420548c0ca6886818f3e40bcb34d9861872410 # Parent 1de8f7a7ad32bea712c09576da0c0d8b6841c6c1 export custom mp_a52_framesize(), needed to parse ac3 frames when liba52 is not present; will be moved in a more appropriate place sometimes in the future diff -r 1de8f7a7ad32 -r 3f420548c0ca libmpdemux/demux_ts.c --- a/libmpdemux/demux_ts.c Fri Jan 27 19:13:46 2006 +0000 +++ b/libmpdemux/demux_ts.c Fri Jan 27 23:07:16 2006 +0000 @@ -464,7 +464,7 @@ //stripped down version of a52_syncinfo() from liba52 //copyright belongs to Michel Lespinasse and Aaron Holtzman -static int a52_framesize(uint8_t * buf) +int mp_a52_framesize(uint8_t * buf, int *srate) { int rate[] = { 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384, 448, @@ -490,10 +490,13 @@ switch(buf[4] & 0xc0) { case 0: /* 48 KHz */ + *srate = 48000 >> half; return 4 * bitrate; case 0x40: /* 44.1 KHz */ + *srate = 44100 >> half; return 2 * (320 * bitrate / 147 + (frmsizecod & 1)); case 0x80: /* 32 KHz */ + *srate = 32000 >> half; return 6 * bitrate; } @@ -503,7 +506,7 @@ //second stage: returns the count of A52 syncwords found static int a52_check(char *buf, int len) { - int cnt, frame_length, ok; + int cnt, frame_length, ok, srate; cnt = ok = 0; if(len < 8) @@ -513,7 +516,7 @@ { if(buf[cnt] == 0x0B && buf[cnt+1] == 0x77) { - frame_length = a52_framesize(&buf[cnt]); + frame_length = mp_a52_framesize(&buf[cnt], &srate); if(frame_length>=7 && frame_length<=3840) { cnt += frame_length;