SPU2-X: Revert the ENDX changes from r4700 as they weren't based on testing but confusing documentation.

SPU2-X: Found a crash on writing to the low word of the effects end address during testing.

git-svn-id: http://pcsx2.googlecode.com/svn/trunk@4717 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
sudonim1@gmail.com 2011-06-08 18:53:55 +00:00
parent 3f450d3158
commit 73db84d024
2 changed files with 10 additions and 10 deletions

View File

@ -122,7 +122,7 @@ u16 const* const regtable_original[0x401] =
PREVB_REG(0,MIX_DEST_B1), PREVB_REG(0,MIX_DEST_B1),
PCORE(0,EffectsEndA)+1, PCORE(0,EffectsEndA)+1,
NULL, PCORE(0,EffectsEndA),
PCORE(0,Regs.ENDX), PCORE(0,Regs.ENDX),
PCORE(0,Regs.ENDX)+1, PCORE(0,Regs.ENDX)+1,
@ -225,7 +225,7 @@ u16 const* const regtable_original[0x401] =
PREVB_REG(1,MIX_DEST_B1), PREVB_REG(1,MIX_DEST_B1),
PCORE(1,EffectsEndA)+1, PCORE(1,EffectsEndA)+1,
NULL, PCORE(1,EffectsEndA),
PCORE(1,Regs.ENDX), PCORE(1,Regs.ENDX),
PCORE(1,Regs.ENDX)+1, PCORE(1,Regs.ENDX)+1,

View File

@ -1159,15 +1159,11 @@ static void __fastcall RegWrite_Core( u16 value )
break; break;
case REG_S_ENDX: case REG_S_ENDX:
// If writing any value other than 0 ENDX becomes 0. thiscore.Regs.ENDX &= 0xff0000;
if (value)
thiscore.Regs.ENDX = 0;
break; break;
case (REG_S_ENDX + 2): case (REG_S_ENDX + 2):
// If writing any value other than 0 ENDX becomes 0. thiscore.Regs.ENDX &= 0xffff;
if (value)
thiscore.Regs.ENDX = 0;
break; break;
// Reverb Start and End Address Writes! // Reverb Start and End Address Writes!
@ -1319,6 +1315,10 @@ static void __fastcall RegWrite_Raw( u16 value )
*(regtable[addr>>1]) = value; *(regtable[addr>>1]) = value;
} }
static void __fastcall RegWrite_Null( u16 value )
{
}
// -------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------
// Macros for tbl_reg_writes // Macros for tbl_reg_writes
// -------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------
@ -1413,7 +1413,7 @@ static RegWriteHandler * const tbl_reg_writes[0x401] =
ReverbPair(0,R_MIX_DEST_B0), // 0x0334 ReverbPair(0,R_MIX_DEST_B0), // 0x0334
ReverbPair(0,R_MIX_DEST_B1), // 0x0338 ReverbPair(0,R_MIX_DEST_B1), // 0x0338
RegWrite_Core<0,REG_A_EEA>, NULL, RegWrite_Core<0,REG_A_EEA>, RegWrite_Null,
CoreParamsPair(0,REG_S_ENDX), // 0x0340 // End Point passed flag CoreParamsPair(0,REG_S_ENDX), // 0x0340 // End Point passed flag
RegWrite_Core<0,REG_P_STATX>, // 0x0344 // Status register? RegWrite_Core<0,REG_P_STATX>, // 0x0344 // Status register?
@ -1503,7 +1503,7 @@ static RegWriteHandler * const tbl_reg_writes[0x401] =
ReverbPair(1,R_MIX_DEST_B0), // 0x0334 ReverbPair(1,R_MIX_DEST_B0), // 0x0334
ReverbPair(1,R_MIX_DEST_B1), // 0x0338 ReverbPair(1,R_MIX_DEST_B1), // 0x0338
RegWrite_Core<1,REG_A_EEA>, NULL, RegWrite_Core<1,REG_A_EEA>, RegWrite_Null,
CoreParamsPair(1,REG_S_ENDX), // 0x0340 // End Point passed flag CoreParamsPair(1,REG_S_ENDX), // 0x0340 // End Point passed flag
RegWrite_Core<1,REG_P_STATX>, // 0x0344 // Status register? RegWrite_Core<1,REG_P_STATX>, // 0x0344 // Status register?