Fixed MSVC.

This commit is contained in:
n-a-c-h
2006-03-19 18:27:49 +00:00
parent ddbaf42a41
commit 21dc4f654d

View File

@@ -415,22 +415,24 @@ const short DSP1_SinTable[256] = {
short DSP1_Sin(short Angle) short DSP1_Sin(short Angle)
{ {
int S;
if (Angle < 0) { if (Angle < 0) {
if (Angle == -32768) return 0; if (Angle == -32768) return 0;
return -DSP1_Sin(-Angle); return -DSP1_Sin(-Angle);
} }
int S = DSP1_SinTable[Angle >> 8] + (DSP1_MulTable[Angle & 0xff] * DSP1_SinTable[0x40 + (Angle >> 8)] >> 15); S = DSP1_SinTable[Angle >> 8] + (DSP1_MulTable[Angle & 0xff] * DSP1_SinTable[0x40 + (Angle >> 8)] >> 15);
if (S > 32767) S = 32767; if (S > 32767) S = 32767;
return (short) S; return (short) S;
} }
short DSP1_Cos(short Angle) short DSP1_Cos(short Angle)
{ {
int S;
if (Angle < 0) { if (Angle < 0) {
if (Angle == -32768) return -32768; if (Angle == -32768) return -32768;
Angle = -Angle; Angle = -Angle;
} }
int S = DSP1_SinTable[0x40 + (Angle >> 8)] - (DSP1_MulTable[Angle & 0xff] * DSP1_SinTable[Angle >> 8] >> 15); S = DSP1_SinTable[0x40 + (Angle >> 8)] - (DSP1_MulTable[Angle & 0xff] * DSP1_SinTable[Angle >> 8] >> 15);
if (S < -32768) S = -32767; if (S < -32768) S = -32767;
return (short) S; return (short) S;
} }
@@ -566,7 +568,7 @@ const short MaxAZS_Exp[16] = {
void DSP1_Parameter(short Fx, short Fy, short Fz, short Lfe, short Les, short Aas, short Azs, short *Vof, short *Vva, short *Cx, short *Cy) void DSP1_Parameter(short Fx, short Fy, short Fz, short Lfe, short Les, short Aas, short Azs, short *Vof, short *Vva, short *Cx, short *Cy)
{ {
short CSec, C, E; short CSec, C, E, MaxAZS, Aux;
// Copy Zenith angle for clipping // Copy Zenith angle for clipping
short AZS = Azs; short AZS = Azs;
@@ -588,7 +590,7 @@ void DSP1_Parameter(short Fx, short Fy, short Fz, short Lfe, short Les, short Aa
VPlane_E = E; VPlane_E = E;
// Determine clip boundary and clip Zenith angle if necessary // Determine clip boundary and clip Zenith angle if necessary
short MaxAZS = MaxAZS_Exp[-E]; MaxAZS = MaxAZS_Exp[-E];
if (AZS < 0) { if (AZS < 0) {
MaxAZS = -MaxAZS; MaxAZS = -MaxAZS;
@@ -622,7 +624,7 @@ void DSP1_Parameter(short Fx, short Fy, short Fz, short Lfe, short Les, short Aa
C = Azs - MaxAZS; C = Azs - MaxAZS;
if (C >= 0) C--; if (C >= 0) C--;
short Aux = ~(C << 2); Aux = ~(C << 2);
C = Aux * DSP1ROM[0x0328] >> 15; C = Aux * DSP1ROM[0x0328] >> 15;
C = (C * Aux >> 15) + DSP1ROM[0x0327]; C = (C * Aux >> 15) + DSP1ROM[0x0327];
@@ -1203,14 +1205,14 @@ void DSPOp28()
if (Radius == 0) Op28R = 0; if (Radius == 0) Op28R = 0;
else else
{ {
short C, E; short C, E, Pos, Node1, Node2;
DSP1_NormalizeDouble(Radius, &C, &E); DSP1_NormalizeDouble(Radius, &C, &E);
if (E & 1) C = C * 0x4000 >> 15; if (E & 1) C = C * 0x4000 >> 15;
short Pos = C * 0x0040 >> 15; Pos = C * 0x0040 >> 15;
short Node1 = DSP1ROM[0x00d5 + Pos]; Node1 = DSP1ROM[0x00d5 + Pos];
short Node2 = DSP1ROM[0x00d6 + Pos]; Node2 = DSP1ROM[0x00d6 + Pos];
Op28R = ((Node2 - Node1) * (C & 0x1ff) >> 9) + Node1; Op28R = ((Node2 - Node1) * (C & 0x1ff) >> 9) + Node1;
Op28R >>= (E >> 1); Op28R >>= (E >> 1);