More docs, cleanup and some fixes

(ector I think you'll want to review DSPInterpreter.cpp changes)


git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@2917 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
nakeee 2009-04-07 17:10:50 +00:00
parent d2b11faa05
commit 8e87735afa
3 changed files with 81 additions and 76 deletions

View File

@ -490,6 +490,7 @@ void clrl(const UDSPInstruction& opc)
g_dsp.r[reg] &= 0x0000; g_dsp.r[reg] &= 0x0000;
// Should this be 64bit? // Should this be 64bit?
// nakee: it says the whole reg in doddie's doc sounds weird
Update_SR_Register64((s64)reg); Update_SR_Register64((s64)reg);
} }
@ -505,6 +506,10 @@ void clrp(const UDSPInstruction& opc)
g_dsp.r[0x17] = 0x0010; g_dsp.r[0x17] = 0x0010;
} }
// MULC $acS.m, $axT.h
// 110s t000 xxxx xxxx
// Multiply mid part of accumulator register $acS.m by high part $axS.h of
// secondary accumulator $axS (treat them both as signed).
void mulc(const UDSPInstruction& opc) void mulc(const UDSPInstruction& opc)
{ {
// math new prod // math new prod
@ -517,6 +522,7 @@ void mulc(const UDSPInstruction& opc)
Update_SR_Register64(prod); Update_SR_Register64(prod);
} }
void mulcmvz(const UDSPInstruction& opc) void mulcmvz(const UDSPInstruction& opc)
{ {
s64 TempProd = dsp_get_long_prod(); s64 TempProd = dsp_get_long_prod();
@ -616,12 +622,17 @@ void mulcac(const UDSPInstruction& opc)
dsp_set_long_acc(rreg, TempProd + g_dsp.r[rreg]); dsp_set_long_acc(rreg, TempProd + g_dsp.r[rreg]);
} }
// MOVR $acD, $axS.R
// 0110 0srd xxxx xxxx
// Moves register $axS.R (sign extended) to middle accumulator $acD.hm.
// Sets $acD.l to 0.
void movr(const UDSPInstruction& opc) void movr(const UDSPInstruction& opc)
{ {
u8 areg = (opc.hex >> 8) & 0x1; u8 areg = (opc.hex >> 8) & 0x1;
u8 sreg = ((opc.hex >> 9) & 0x3) + 0x18; u8 rreg = ((opc.hex >> 9) & 0x1);
u8 sreg = ((opc.hex >> 10) & 0x1) + DSP_REG_AXL0;
s64 acc = (s16)g_dsp.r[sreg];
s64 acc = (s16)g_dsp.r[sreg + rreg];
acc <<= 16; acc <<= 16;
acc &= ~0xffff; acc &= ~0xffff;
@ -630,24 +641,18 @@ void movr(const UDSPInstruction& opc)
Update_SR_Register64(acc); Update_SR_Register64(acc);
} }
// MOVAX $acD, $axS
// 0110 10sd xxxx xxxx
// Moves secondary accumulator $axS to accumulator $axD.
void movax(const UDSPInstruction& opc) void movax(const UDSPInstruction& opc)
{ {
u8 sreg = (opc.hex >> 9) & 0x1;
u8 dreg = (opc.hex >> 8) & 0x1; u8 dreg = (opc.hex >> 8) & 0x1;
u8 sreg = (opc.hex >> 9) & 0x1;
g_dsp.r[0x1c + dreg] = g_dsp.r[0x18 + sreg]; s64 acx = dsp_get_long_acx(sreg);
g_dsp.r[0x1e + dreg] = g_dsp.r[0x1a + sreg]; dsp_set_long_acc(dreg, acx);
if ((s16)g_dsp.r[0x1a + sreg] < 0) Update_SR_Register64(acx);
{
g_dsp.r[0x10 + dreg] = 0xffff;
}
else
{
g_dsp.r[0x10 + dreg] = 0;
}
tsta(dreg);
} }
void xorr(const UDSPInstruction& opc) void xorr(const UDSPInstruction& opc)
@ -877,6 +882,10 @@ void addpaxz(const UDSPInstruction& opc)
Update_SR_Register64(acc); Update_SR_Register64(acc);
} }
// MOVPZ $acD
// 1111 111d xxxx xxxx
// Moves multiply product from $prod register to accumulator $acD
// register and sets $acD.l to 0
void movpz(const UDSPInstruction& opc) void movpz(const UDSPInstruction& opc)
{ {
u8 dreg = (opc.hex >> 8) & 0x01; u8 dreg = (opc.hex >> 8) & 0x01;
@ -956,6 +965,8 @@ void movnp(const UDSPInstruction& opc)
s64 prod = dsp_get_long_prod(); s64 prod = dsp_get_long_prod();
s64 acc = -prod; s64 acc = -prod;
dsp_set_long_acc(dreg, acc); dsp_set_long_acc(dreg, acc);
Update_SR_Register64(acc);
} }
// MOV $acD, $ac(1-D) // MOV $acD, $ac(1-D)
@ -964,9 +975,10 @@ void movnp(const UDSPInstruction& opc)
void mov(const UDSPInstruction& opc) void mov(const UDSPInstruction& opc)
{ {
u8 D = (opc.hex >> 8) & 0x1; u8 D = (opc.hex >> 8) & 0x1;
u16 acc = dsp_get_acc_m(1 - D); u16 acc = dsp_get_long_acc(1 - D);
dsp_set_long_acc(D, acc); dsp_set_long_acc(D, acc);
Update_SR_Register64(acc);
} }
// ADDAX $acD, $axS // ADDAX $acD, $axS
@ -1023,10 +1035,10 @@ void subax(const UDSPInstruction& opc)
int regD = (opc.hex >> 8) & 0x1; int regD = (opc.hex >> 8) & 0x1;
int regT = (opc.hex >> 9) & 0x1; int regT = (opc.hex >> 9) & 0x1;
s64 Acc = dsp_get_long_acc(regD) - dsp_get_long_acx(regT); s64 acc = dsp_get_long_acc(regD) - dsp_get_long_acx(regT);
dsp_set_long_acc(regD, Acc); dsp_set_long_acc(regD, acc);
Update_SR_Register64(Acc); Update_SR_Register64(acc);
} }
// ADDIS $acD, #I // ADDIS $acD, #I
@ -1076,6 +1088,11 @@ void lsl16(const UDSPInstruction& opc)
Update_SR_Register64(acc); Update_SR_Register64(acc);
} }
// MADD $axS.l, $axS.h
// 1111 001s xxxx xxxx
// Multiply low part $axS.l of secondary accumulator $axS by high part
// $axS.h of secondary accumulator $axS (treat them both as signed) and add
// result to product register.
void madd(const UDSPInstruction& opc) void madd(const UDSPInstruction& opc)
{ {
u8 sreg = (opc.hex >> 8) & 0x1; u8 sreg = (opc.hex >> 8) & 0x1;
@ -1085,6 +1102,11 @@ void madd(const UDSPInstruction& opc)
dsp_set_long_prod(prod); dsp_set_long_prod(prod);
} }
// MSUB $axS.l, $axS.h
// 1111 011s xxxx xxxx
// Multiply low part $axS.l of secondary accumulator $axS by high part
// $axS.h of secondary accumulator $axS (treat them both as signed) and
// subtract result from product register.
void msub(const UDSPInstruction& opc) void msub(const UDSPInstruction& opc)
{ {
u8 sreg = (opc.hex >> 8) & 0x1; u8 sreg = (opc.hex >> 8) & 0x1;
@ -1295,15 +1317,23 @@ void srbith(const UDSPInstruction& opc)
//------------------------------------------------------------- //-------------------------------------------------------------
// MOVP $acD
// 0110 111d xxxx xxxx
// Moves multiply product from $prod register to accumulator $acD register.
void movp(const UDSPInstruction& opc) void movp(const UDSPInstruction& opc)
{ {
u8 dreg = (opc.hex >> 8) & 0x1; u8 dreg = (opc.hex >> 8) & 0x1;
s64 prod = dsp_get_long_prod(); s64 prod = dsp_get_long_prod();
s64 acc = prod; dsp_set_long_acc(dreg, prod);
dsp_set_long_acc(dreg, acc);
Update_SR_Register64(prod);
} }
// MUL $axS.l, $axS.h
// 1001 s000 xxxx xxxx
// Multiply low part $axS.l of secondary accumulator $axS by high part
// $axS.h of secondary accumulator $axS (treat them both as signed).
void mul(const UDSPInstruction& opc) void mul(const UDSPInstruction& opc)
{ {
u8 sreg = (opc.hex >> 11) & 0x1; u8 sreg = (opc.hex >> 11) & 0x1;
@ -1311,9 +1341,15 @@ void mul(const UDSPInstruction& opc)
dsp_set_long_prod(prod); dsp_set_long_prod(prod);
// FIXME: no update in doddie's docs
Update_SR_Register64(prod); Update_SR_Register64(prod);
} }
// MULAC $axS.l, $axS.h, $acR
// 1001 s10r xxxx xxxx
// Add product register to accumulator register $acR. Multiply low part
// $axS.l of secondary accumulator $axS by high part $axS.h of secondary
// accumulator $axS (treat them both as signed).
void mulac(const UDSPInstruction& opc) void mulac(const UDSPInstruction& opc)
{ {
// add old prod to acc // add old prod to acc
@ -1321,11 +1357,12 @@ void mulac(const UDSPInstruction& opc)
s64 acR = dsp_get_long_acc(rreg) + dsp_get_long_prod(); s64 acR = dsp_get_long_acc(rreg) + dsp_get_long_prod();
dsp_set_long_acc(rreg, acR); dsp_set_long_acc(rreg, acR);
// math new prod // calculate new prod
u8 sreg = (opc.hex >> 11) & 0x1; u8 sreg = (opc.hex >> 11) & 0x1;
s64 prod = dsp_get_ax_l(sreg) * dsp_get_ax_h(sreg) * GetMultiplyModifier(); s64 prod = dsp_get_ax_l(sreg) * dsp_get_ax_h(sreg) * GetMultiplyModifier();
dsp_set_long_prod(prod); dsp_set_long_prod(prod);
// FIXME: no update in doddie's docs
Update_SR_Register64(prod); Update_SR_Register64(prod);
} }
@ -1458,6 +1495,11 @@ void sub(const UDSPInstruction& opc)
// //
//------------------------------------------------------------- //-------------------------------------------------------------
// MADDX ax0.S ax1.T
// 1110 00st xxxx xxxx
// Multiply one part of secondary accumulator $ax0 (selected by S) by
// one part of secondary accumulator $ax1 (selected by T) (treat them both as
// signed) and add result to product register.
void maddx(const UDSPInstruction& opc) void maddx(const UDSPInstruction& opc)
{ {
u8 sreg = (opc.hex >> 9) & 0x1; u8 sreg = (opc.hex >> 9) & 0x1;
@ -1471,6 +1513,11 @@ void maddx(const UDSPInstruction& opc)
dsp_set_long_prod(prod); dsp_set_long_prod(prod);
} }
// MSUBX $(0x18+S*2), $(0x19+T*2)
// 1110 01st xxxx xxxx
// Multiply one part of secondary accumulator $ax0 (selected by S) by
// one part of secondary accumulator $ax1 (selected by T) (treat them both as
// signed) and subtract result from product register.
void msubx(const UDSPInstruction& opc) void msubx(const UDSPInstruction& opc)
{ {
u8 sreg = (opc.hex >> 9) & 0x1; u8 sreg = (opc.hex >> 9) & 0x1;
@ -1484,6 +1531,11 @@ void msubx(const UDSPInstruction& opc)
dsp_set_long_prod(prod); dsp_set_long_prod(prod);
} }
// MADDC $acS.m, $axT.h
// 1110 10st xxxx xxxx
// Multiply middle part of accumulator $acS.m by high part of secondary
// accumulator $axT.h (treat them both as signed) and add result to product
// register.
void maddc(const UDSPInstruction& opc) void maddc(const UDSPInstruction& opc)
{ {
u32 sreg = (opc.hex >> 9) & 0x1; u32 sreg = (opc.hex >> 9) & 0x1;
@ -1497,6 +1549,11 @@ void maddc(const UDSPInstruction& opc)
dsp_set_long_prod(prod); dsp_set_long_prod(prod);
} }
// MSUBC $acS.m, $axT.h
// 1110 11st xxxx xxxx
// Multiply middle part of accumulator $acS.m by high part of secondary
// accumulator $axT.h (treat them both as signed) and subtract result from
// product register.
void msubc(const UDSPInstruction& opc) void msubc(const UDSPInstruction& opc)
{ {
u32 sreg = (opc.hex >> 9) & 0x1; u32 sreg = (opc.hex >> 9) & 0x1;

View File

@ -35,33 +35,6 @@
#include "Tools.h" #include "Tools.h"
#ifndef NULL
#define NULL 0
#endif
const char* reg_names[] =
{
// a0
"COEF_A1_0", "COEF_A2_0", "COEF_A1_1", "COEF_A2_1", "COEF_A1_2", "COEF_A2_2", "COEF_A1_3", "COEF_A2_3",
"COEF_A1_4", "COEF_A2_4", "COEF_A1_5", "COEF_A2_5", "COEF_A1_6", "COEF_A2_6", "COEF_A1_7", "COEF_A2_7",
// b0
NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
// c0
NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
NULL, "DSCR", NULL, "DSBL", NULL, "DSPA", "DSMAH", "DSMAL",
// d0
NULL, "SampleFormat", NULL, NULL, "ACSAH", "ACSAL", "ACEAH", "ACEAL",
"ACCAH", "ACCAL", "PRED_SCALE", "YN1", "YN2", "ARAM", "GAIN", NULL,
// e0
NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
NULL, NULL, NULL, NULL, NULL, NULL, NULL, "AMDM",
// f0
NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
NULL, NULL, NULL, NULL, "DMBH", "DMBL", "CMBH", "CMBL",
};
void gdsp_dma(); void gdsp_dma();
#if WITH_DSP_ON_THREAD #if WITH_DSP_ON_THREAD

View File

@ -185,27 +185,6 @@ THREAD_RETURN dsp_thread(void* lpParameter)
return 0; return 0;
} }
// Debug thread
THREAD_RETURN dsp_thread_debug(void* lpParameter)
{
#if defined(HAVE_WX) && HAVE_WX
while (bIsRunning)
{
// Logging(); // logging
if (m_DebuggerFrame->CanDoStep())
{
gdsp_runx(1);
}
else
{
SLEEP(100);
}
}
#endif
return NULL;
}
void DSP_DebugBreak() void DSP_DebugBreak()
{ {
#if defined(HAVE_WX) && HAVE_WX #if defined(HAVE_WX) && HAVE_WX
@ -369,10 +348,6 @@ void DSP_SendAIBuffer(unsigned int address, int sample_rate)
{ {
samples[i] = Memory_Read_U16(address + i * 2); samples[i] = Memory_Read_U16(address + i * 2);
} }
// Write the audio to a file
//if (log_ai)
// g_wave_writer.AddStereoSamples(samples, 8);
} }
soundStream->GetMixer()->PushSamples(samples, 32 / 4, sample_rate); soundStream->GetMixer()->PushSamples(samples, 32 / 4, sample_rate);
} }