sVU_zerorec.cpp: Correctly guard against invalid VU indexes

recVUHeaders and recVUBlocks are both arrays of size 2. Prior to this, it would allow an index of 2, which is out of range.
This commit is contained in:
Lioncash 2014-07-14 22:33:25 -04:00
parent f85a4c0467
commit a1080f4853
1 changed files with 3 additions and 3 deletions

View File

@ -395,7 +395,7 @@ void DestroyVUHeaders(int vuindex)
// destroy VU resources // destroy VU resources
void SuperVUDestroy(int vuindex) void SuperVUDestroy(int vuindex)
{ {
pxAssertDev(vuindex >= 0 && vuindex <= 2, "Invalid VU index parameter!"); pxAssertDev(vuindex == 0 || vuindex == 1, "Invalid VU index parameter!");
safe_delete_array(recVUHeaders[vuindex]); safe_delete_array(recVUHeaders[vuindex]);
safe_delete_array(recVUBlocks[vuindex]); safe_delete_array(recVUBlocks[vuindex]);
@ -417,7 +417,7 @@ void SuperVUDestroy(int vuindex)
// reset VU // reset VU
void SuperVUReset(int vuindex) void SuperVUReset(int vuindex)
{ {
pxAssertDev(vuindex >= 0 && vuindex <= 2, "Invalid VU index parameter!"); pxAssertDev(vuindex == 0 || vuindex == 1, "Invalid VU index parameter!");
#ifdef PCSX2_DEBUG #ifdef PCSX2_DEBUG
s_vucount = 0; s_vucount = 0;
@ -816,7 +816,7 @@ void VuBaseBlock::GetInstsAtPc(int instpc, list<VuInstruction*>& listinsts)
static VuFunctionHeader* SuperVURecompileProgram(u32 startpc, int vuindex) static VuFunctionHeader* SuperVURecompileProgram(u32 startpc, int vuindex)
{ {
pxAssert(vuindex < 2); pxAssert(vuindex == 0 || vuindex == 1);
pxAssert(s_recVUPtr[vuindex] != NULL); pxAssert(s_recVUPtr[vuindex] != NULL);
//Console.WriteLn("svu%c rec: %x", '0'+vuindex, startpc); //Console.WriteLn("svu%c rec: %x", '0'+vuindex, startpc);