aboutsummaryrefslogtreecommitdiff
path: root/source/dsp1.c
diff options
context:
space:
mode:
Diffstat (limited to 'source/dsp1.c')
-rw-r--r--source/dsp1.c53
1 files changed, 0 insertions, 53 deletions
diff --git a/source/dsp1.c b/source/dsp1.c
index 7c50acc..cccae23 100644
--- a/source/dsp1.c
+++ b/source/dsp1.c
@@ -40,22 +40,18 @@ uint8_t S9xGetDSP(uint16_t address)
uint8_t t;
t = (*GetDSP)(address);
- //DSP1GetByte(address);
return (t);
}
void S9xSetDSP(uint8_t byte, uint16_t address)
{
(*SetDSP)(byte, address);
- //DSP1SetByte(byte, address);
}
void DSP1SetByte(uint8_t byte, uint16_t address)
{
if ((address & 0xf000) == 0x6000 || (address & 0x7fff) < 0x4000)
{
- // if ((address & 1) == 0)
- // {
if ((DSP1.command == 0x0A || DSP1.command == 0x1A) && DSP1.out_count != 0)
{
DSP1.out_count--;
@@ -68,7 +64,6 @@ void DSP1SetByte(uint8_t byte, uint16_t address)
DSP1.in_index = 0;
DSP1.waiting4command = false;
DSP1.first_parameter = true;
- // printf("Op%02X\n",byte);
// Mario Kart uses 0x00, 0x02, 0x06, 0x0c, 0x28, 0x0a
switch (byte)
{
@@ -200,9 +195,7 @@ void DSP1SetByte(uint8_t byte, uint16_t address)
case 0x1f:
DSP1.in_count = 1;
break;
- // case 0x80: DSP1.in_count = 2; break;
default:
- //printf("Op%02X\n",byte);
case 0x80:
DSP1.in_count = 0;
DSP1.waiting4command = true;
@@ -228,14 +221,10 @@ void DSP1SetByte(uint8_t byte, uint16_t address)
&& DSP1.in_index == 0)))
{
}
- // else if (DSP1.first_parameter)
- // {
- // }
else
{
if (DSP1.in_count)
{
- //DSP1.parameters [DSP1.in_index] |= (byte << 8);
if (--DSP1.in_count == 0)
{
// Actually execute the command
@@ -325,7 +314,6 @@ void DSP1SetByte(uint8_t byte, uint16_t address)
break;
case 0x38: // Range
-
Op38X = (int16_t)(DSP1.parameters [0] | (DSP1.parameters[1] << 8));
Op38Y = (int16_t)(DSP1.parameters [2] | (DSP1.parameters[3] << 8));
Op38Z = (int16_t)(DSP1.parameters [4] | (DSP1.parameters[5] << 8));
@@ -694,16 +682,11 @@ uint8_t DSP1GetByte(uint16_t address)
{
uint8_t t;
if ((address & 0xf000) == 0x6000 ||
- // (address >= 0x8000 && address < 0xc000))
(address & 0x7fff) < 0x4000)
{
if (DSP1.out_count)
{
- //if ((address & 1) == 0)
t = (uint8_t) DSP1.output [DSP1.out_index];
- //else
- //{
- // t = (uint8_t) (DSP1.output [DSP1.out_index] >> 8);
DSP1.out_index++;
if (--DSP1.out_count == 0)
{
@@ -730,15 +713,10 @@ uint8_t DSP1GetByte(uint16_t address)
}
}
DSP1.waiting4command = true;
- //}
}
else
{
- // Top Gear 3000 requires this value....
- // if(4==Settings.DSPVersion)
t = 0xff;
- //Ballz3d requires this one:
- // else t = 0x00;
}
}
else t = 0x80;
@@ -755,8 +733,6 @@ void DSP2SetByte(uint8_t byte, uint16_t address)
DSP1.command = byte;
DSP1.in_index = 0;
DSP1.waiting4command = false;
- // DSP1.first_parameter = true;
- // printf("Op%02X\n",byte);
switch (byte)
{
case 0x01:
@@ -787,13 +763,11 @@ void DSP2SetByte(uint8_t byte, uint16_t address)
else
{
DSP1.parameters [DSP1.in_index] = byte;
- // DSP1.first_parameter = false;
DSP1.in_index++;
}
if (DSP1.in_count == DSP1.in_index)
{
- //DSP1.parameters [DSP1.in_index] |= (byte << 8);
// Actually execute the command
DSP1.waiting4command = true;
DSP1.out_index = 0;
@@ -877,7 +851,6 @@ void DSP2SetByte(uint8_t byte, uint16_t address)
case 0x03:
DSP2Op05Transparent = DSP1.parameters[0];
- //DSP2Op03();
break;
case 0x0f:
default:
@@ -909,7 +882,6 @@ uint8_t DSP2GetByte(uint16_t address)
//Disable non-working chips?
#ifdef DSP_DUMMY_LOOPS
-//static const uint16_t DSP1ROM[1024] from SNES9X v1.53
uint16_t Dsp3Rom[1024] =
{
0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
@@ -1053,8 +1025,6 @@ void DSP3SetByte(uint8_t byte, uint16_t address)
DSP1.command = byte;
DSP1.in_index = 0;
DSP1.waiting4command = false;
- // DSP1.first_parameter = true;
- // printf("Op%02X\n",byte);
switch (byte)
{
case 0x2F:
@@ -1070,20 +1040,17 @@ void DSP3SetByte(uint8_t byte, uint16_t address)
DSP1.in_count = 4;
break;
default:
- // printf("Op%02X\n",byte);
break;
}
}
else
{
DSP1.parameters [DSP1.in_index] = byte;
- // DSP1.first_parameter = false;
DSP1.in_index++;
}
if (DSP1.in_count == DSP1.in_index)
{
- //DSP1.parameters [DSP1.in_index] |= (byte << 8);
// Actually execute the command
DSP1.waiting4command = true;
DSP1.out_index = 0;
@@ -1133,7 +1100,6 @@ uint8_t DSP3GetByte(uint16_t address)
t = (uint8_t)Dsp3Rom[DSP1.out_index >> 1];
else
t = Dsp3Rom[DSP1.out_index >> 1] >> 8;
- // t=Dsp3Rom[DSP1.out_index];
DSP1.out_index++;
}
else
@@ -1151,18 +1117,6 @@ uint8_t DSP3GetByte(uint16_t address)
else
{
t = 0x80;
- /* if(DSP1.command=0x38&&DSP1.out_count==0)
- {
- t=0xC0;
- static int Op38c;
- if(Op38c==14)
- {
- Op38c=0;
- t=0x80;
- DSP1.in_count=4;
- }
- Op38c++;
- }*/
}
return t;
}
@@ -1213,7 +1167,6 @@ void DSP4SetByte(uint8_t byte, uint16_t address)
DSP4.command |= (byte << 8);
DSP4.in_index = 0;
DSP4.waiting4command = false;
- // DSP4.first_parameter = true;
DSP4.half_command = 0;
DSP4.out_count = 0;
DSP4.out_index = 0;
@@ -1262,7 +1215,6 @@ void DSP4SetByte(uint8_t byte, uint16_t address)
break;
default:
DSP4.waiting4command = true;
- //printf("(line %d) Unknown Op%02X\n",line,DSP4.command);
break;
}
}
@@ -1275,13 +1227,11 @@ void DSP4SetByte(uint8_t byte, uint16_t address)
else
{
DSP4.parameters [DSP4.in_index] = byte;
- // DSP4.first_parameter = false;
DSP4.in_index++;
}
if (!DSP4.waiting4command && DSP4.in_count == DSP4.in_index)
{
- //DSP4.parameters [DSP4.in_index] |= (byte << 8);
// Actually execute the command
DSP4.waiting4command = true;
DSP4.out_index = 0;
@@ -1388,9 +1338,6 @@ void DSP4SetByte(uint8_t byte, uint16_t address)
// unknown
case 0x000A:
{
- int16_t in1a = DSP4_READ_WORD(0);
- int16_t in2a = DSP4_READ_WORD(2);
- int16_t in3a = DSP4_READ_WORD(4);
int16_t out1a, out2a;
out1a = (int16_t)0xff40;