fixed bug where if fall in to next section, and section fails to compile then it was not working correctly.

This commit is contained in:
zilmar 2012-10-17 22:25:25 +11:00
parent 923576c93c
commit 22fd128452
1 changed files with 24 additions and 11 deletions

View File

@ -510,8 +510,6 @@ void CCodeSection::GenerateSectionLinkage (void)
SetJump32((DWORD *)m_RecompPos - 1,(DWORD *)(TargetSection[i]->m_CompiledLocation)); SetJump32((DWORD *)m_RecompPos - 1,(DWORD *)(TargetSection[i]->m_CompiledLocation));
} }
} }
//BlockCycleCount() = 0;
//BlockRandomModifier() = 0;
for (i = 0; i < 2; i ++) { for (i = 0; i < 2; i ++) {
if (TargetSection[i] == NULL) { continue; } if (TargetSection[i] == NULL) { continue; }
@ -552,9 +550,13 @@ void CCodeSection::GenerateSectionLinkage (void)
CPU_Message("====== End of Section %d ======",m_SectionID); CPU_Message("====== End of Section %d ======",m_SectionID);
for (i = 0; i < 2; i ++) { for (i = 0; i < 2; i ++)
if (JumpInfo[i]->FallThrough) { {
TargetSection[i]->GenerateX86Code(m_BlockInfo->NextTest()); if (JumpInfo[i]->FallThrough && !TargetSection[i]->GenerateX86Code(m_BlockInfo->NextTest()))
{
JumpInfo[i]->FallThrough = FALSE;
JmpLabel32(JumpInfo[i]->BranchLabel.c_str(),0);
JumpInfo[i]->LinkLocation = (DWORD *)(m_RecompPos - 4);
} }
} }
@ -1652,11 +1654,22 @@ bool CCodeSection::InheritParentInfo ( void )
ParentList.push_back(BlockParent); ParentList.push_back(BlockParent);
} }
} }
size_t FirstParent = 0; int FirstParent = -1;
for (size_t i = 1;i < NoOfCompiledParents;i++) { for (size_t i = 0; i < NoOfCompiledParents;i++)
if (ParentList[i].JumpInfo->FallThrough) { {
FirstParent = i; break; if (!ParentList[i].JumpInfo->FallThrough)
{
continue;
} }
if (FirstParent != -1)
{
_Notify->BreakPoint(__FILE__,__LINE__);
}
FirstParent = i;
}
if (FirstParent == -1)
{
FirstParent = 0;
} }
//Link First Parent to start //Link First Parent to start
@ -1701,7 +1714,7 @@ bool CCodeSection::InheritParentInfo ( void )
x86Reg MemoryStackPos; x86Reg MemoryStackPos;
int i2; int i2;
if (i == FirstParent) { continue; } if (i == (size_t)FirstParent) { continue; }
Parent = ParentList[i].Parent; Parent = ParentList[i].Parent;
if (Parent->m_CompiledLocation == NULL) if (Parent->m_CompiledLocation == NULL)
{ {
@ -1794,7 +1807,7 @@ bool CCodeSection::InheritParentInfo ( void )
CRegInfo * RegSet; CRegInfo * RegSet;
int i2; int i2;
if (i == FirstParent) { continue; } if (i == (size_t)FirstParent) { continue; }
Parent = ParentList[i].Parent; Parent = ParentList[i].Parent;
JumpInfo = ParentList[i].JumpInfo; JumpInfo = ParentList[i].JumpInfo;
RegSet = &ParentList[i].JumpInfo->RegSet; RegSet = &ParentList[i].JumpInfo->RegSet;