mirror of https://github.com/PCSX2/pcsx2.git
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:
parent
3f450d3158
commit
73db84d024
|
@ -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,
|
||||||
|
|
|
@ -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?
|
||||||
|
|
Loading…
Reference in New Issue