# HG changeset patch # User atmos4 # Date 1001209477 0 # Node ID 2668fc1b8839ff4219f0980a8842e54641732a13 # Parent 420c8c66c7bafb78dd7efb9ec851b65a753d4ccc Fix for mp3 decoding on alpha/64bit platforms wupposed by Bob McElrath. diff -r 420c8c66c7ba -r 2668fc1b8839 mp3lib/decod386.c --- a/mp3lib/decod386.c Sat Sep 22 22:44:23 2001 +0000 +++ b/mp3lib/decod386.c Sun Sep 23 01:44:37 2001 +0000 @@ -56,7 +56,7 @@ /* sizeof(int) == 4 */ #define WRITE_SAMPLE(samples,sum,clip) { \ - double dtemp; long v; \ + double dtemp; int v; \ dtemp = ((((65536.0 * 65536.0 * 16)+(65536.0 * 0.5))* 65536.0)) + (sum);\ v = (((int *)&dtemp)[MANTISSA_OFFSET] - 0x80000000); \ if( v > 32767) { *(samples) = 0x7fff; (clip)++; } \ @@ -150,11 +150,13 @@ synth_func_t synth_func; #ifdef HAVE_MMX -int synth_1to1_MMX( real *bandPtr,int channel,short * samples) +int synth_1to1_MMX( real *bandPtr ,int channel,short * samples) { - static short buffs[2][2][0x110]; - static int bo = 1; - synth_1to1_MMX_s(bandPtr, channel, samples, (short *) buffs, &bo); + real *mybandPtr __attribute__((aligned(16))) = bandPtr; + short *mysamples __attribute__((aligned(16))) = samples; + static short buffs[2][2][0x110] __attribute__((aligned(16))); + static int bo __attribute__((aligned(16))) = 1; + synth_1to1_MMX_s(mybandPtr, channel, mysamples, (short *) buffs, &bo); return 0; } #endif