- /*
- * Mpeg Layer-1,2,3 audio decoder
- * ------------------------------
- * copyright (c) 1995,1996,1997 by Michael Hipp, All rights reserved.
- * modified by Aleksander Korzynski (Olcios) '2003
- * See also 'README'
- *
- * slighlty optimized for machines without autoincrement/decrement.
- * The performance is highly compiler dependend. Maybe
- * the decode.c version for 'normal' processor may be faster
- * even for Intel processors.
- */
-
- /* $Id: decode_i386.c,v 1.17 2004/04/14 22:15:44 robert Exp $ */
-
- #ifdef HAVE_CONFIG_H
- #include <config.h>
- #endif
-
- #ifdef STDC_HEADERS
- # include <stdlib.h>
- # include <string.h>
- #else
- # ifndef HAVE_STRCHR
- # define strchr index
- # define strrchr rindex
- # endif
- char *strchr (), *strrchr ();
- # ifndef HAVE_MEMCPY
- # define memcpy(d, s, n) bcopy ((s), (d), (n))
- # define memmove(d, s, n) bcopy ((s), (d), (n))
- # endif
- #endif
-
- #if defined(__riscos__) && defined(FPA10)
- #include "ymath.h"
- #else
- #include <math.h>
- #endif
-
- #include "decode_i386.h"
- #include "dct64_i386.h"
- #include "tabinit.h"
-
- #ifdef WITH_DMALLOC
- #include <dmalloc.h>
- #endif
-
-
- /* old WRITE_SAMPLE_CLIPPED */
- #define WRITE_SAMPLE_CLIPPED(samples,sum,clip) \
- if( (sum) > 32767.0) { *(samples) = 0x7fff; (clip)++; } \
- else if( (sum) < -32768.0) { *(samples) = -0x8000; (clip)++; } \
- else { *(samples) = ((sum)>0 ? (sum)+0.5 : (sum)-0.5) ; }
-
- #define WRITE_SAMPLE_UNCLIPPED(samples,sum,clip) \
- *samples = sum;
-
-
- /* versions: clipped (when TYPE == short) and unclipped (when TYPE == real) of synth_1to1_mono* functions */
- #define SYNTH_1TO1_MONO_CLIPCHOICE(TYPE,SYNTH_1TO1) \
- TYPE samples_tmp[64]; \
- TYPE *tmp1 = samples_tmp; \
- int i,ret; \
- int pnt1 = 0; \
- \
- ret = SYNTH_1TO1 (mp,bandPtr,0,(unsigned char *) samples_tmp,&pnt1); \
- out += *pnt; \
- \
- for(i=0;i<32;i++) { \
- *( (TYPE *) out) = *tmp1; \
- out += sizeof(TYPE); \
- tmp1 += 2; \
- } \
- *pnt += 32*sizeof(TYPE); \
- \
- return ret;
-
-
- int synth_1to1_mono(PMPSTR mp, real *bandPtr,unsigned char *out,int *pnt)
- {
- SYNTH_1TO1_MONO_CLIPCHOICE(short,synth_1to1)
- }
-
- int synth_1to1_mono_unclipped(PMPSTR mp, real *bandPtr, unsigned char *out,int *pnt)
- {
- SYNTH_1TO1_MONO_CLIPCHOICE(real,synth_1to1_unclipped)
- }
-
- /* versions: clipped (when TYPE == short) and unclipped (when TYPE == real) of synth_1to1* functions */
- #define SYNTH_1TO1_CLIPCHOICE(TYPE,WRITE_SAMPLE) \
- static const int step = 2; \
- int bo; \
- TYPE *samples = (TYPE *) (out + *pnt); \
- \
- real *b0,(*buf)[0x110]; \
- int clip = 0; \
- int bo1; \
- \
- bo = mp->synth_bo; \
- \
- if(!channel) { \
- bo--; \
- bo &= 0xf; \
- buf = mp->synth_buffs[0]; \
- } \
- else { \
- samples++; \
- buf = mp->synth_buffs[1]; \
- } \
- \
- if(bo & 0x1) { \
- b0 = buf[0]; \
- bo1 = bo; \
- dct64(buf[1]+((bo+1)&0xf),buf[0]+bo,bandPtr); \
- } \
- else { \
- b0 = buf[1]; \
- bo1 = bo+1; \
- dct64(buf[0]+bo,buf[1]+bo+1,bandPtr); \
- } \
- \
- mp->synth_bo = bo; \
- \
- { \
- int j; \
- real *window = decwin + 16 - bo1; \
- \
- for (j=16;j;j--,b0+=0x10,window+=0x20,samples+=step) \
- { \
- real sum; \
- sum = window[0x0] * b0[0x0]; \
- sum -= window[0x1] * b0[0x1]; \
- sum += window[0x2] * b0[0x2]; \
- sum -= window[0x3] * b0[0x3]; \
- sum += window[0x4] * b0[0x4]; \
- sum -= window[0x5] * b0[0x5]; \
- sum += window[0x6] * b0[0x6]; \
- sum -= window[0x7] * b0[0x7]; \
- sum += window[0x8] * b0[0x8]; \
- sum -= window[0x9] * b0[0x9]; \
- sum += window[0xA] * b0[0xA]; \
- sum -= window[0xB] * b0[0xB]; \
- sum += window[0xC] * b0[0xC]; \
- sum -= window[0xD] * b0[0xD]; \
- sum += window[0xE] * b0[0xE]; \
- sum -= window[0xF] * b0[0xF]; \
- \
- WRITE_SAMPLE (samples,sum,clip); \
- } \
- \
- { \
- real sum; \
- sum = window[0x0] * b0[0x0]; \
- sum += window[0x2] * b0[0x2]; \
- sum += window[0x4] * b0[0x4]; \
- sum += window[0x6] * b0[0x6]; \
- sum += window[0x8] * b0[0x8]; \
- sum += window[0xA] * b0[0xA]; \
- sum += window[0xC] * b0[0xC]; \
- sum += window[0xE] * b0[0xE]; \
- WRITE_SAMPLE (samples,sum,clip); \
- b0-=0x10,window-=0x20,samples+=step; \
- } \
- window += bo1<<1; \
- \
- for (j=15;j;j--,b0-=0x10,window-=0x20,samples+=step) \
- { \
- real sum; \
- sum = -window[-0x1] * b0[0x0]; \
- sum -= window[-0x2] * b0[0x1]; \
- sum -= window[-0x3] * b0[0x2]; \
- sum -= window[-0x4] * b0[0x3]; \
- sum -= window[-0x5] * b0[0x4]; \
- sum -= window[-0x6] * b0[0x5]; \
- sum -= window[-0x7] * b0[0x6]; \
- sum -= window[-0x8] * b0[0x7]; \
- sum -= window[-0x9] * b0[0x8]; \
- sum -= window[-0xA] * b0[0x9]; \
- sum -= window[-0xB] * b0[0xA]; \
- sum -= window[-0xC] * b0[0xB]; \
- sum -= window[-0xD] * b0[0xC]; \
- sum -= window[-0xE] * b0[0xD]; \
- sum -= window[-0xF] * b0[0xE]; \
- sum -= window[-0x0] * b0[0xF]; \
- \
- WRITE_SAMPLE (samples,sum,clip); \
- } \
- } \
- *pnt += 64*sizeof(TYPE); \
- \
- return clip;
-
-
- int synth_1to1(PMPSTR mp, real *bandPtr,int channel,unsigned char *out, int *pnt)
- {
- SYNTH_1TO1_CLIPCHOICE(short,WRITE_SAMPLE_CLIPPED)
- }
-
- int synth_1to1_unclipped(PMPSTR mp, real *bandPtr,int channel, unsigned char *out, int *pnt)
- {
- SYNTH_1TO1_CLIPCHOICE(real,WRITE_SAMPLE_UNCLIPPED)
- }
-
-