CRecompilerOps::Compile_BranchLikely: handle the case of continue fall through on 0xFFC
This commit is contained in:
parent
5cc6a91a41
commit
47e393e498
|
@ -355,8 +355,16 @@ void CRecompilerOps::Compile_BranchLikely (BranchFunction CompareFunc, BOOL Link
|
||||||
m_Section->m_Cont.RegSet = m_RegWorkingSet;
|
m_Section->m_Cont.RegSet = m_RegWorkingSet;
|
||||||
if ((m_CompilePC & 0xFFC) == 0xFFC)
|
if ((m_CompilePC & 0xFFC) == 0xFFC)
|
||||||
{
|
{
|
||||||
if (m_Section->m_Cont.FallThrough) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
if (m_Section->m_Cont.FallThrough)
|
||||||
|
{
|
||||||
|
if (m_Section->m_Jump.LinkLocation != NULL)
|
||||||
|
{
|
||||||
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (m_Section->m_Jump.LinkLocation != NULL || m_Section->m_Jump.FallThrough)
|
||||||
|
{
|
||||||
if (m_Section->m_Jump.LinkLocation != NULL) {
|
if (m_Section->m_Jump.LinkLocation != NULL) {
|
||||||
SetJump32(m_Section->m_Jump.LinkLocation,(DWORD *)m_RecompPos);
|
SetJump32(m_Section->m_Jump.LinkLocation,(DWORD *)m_RecompPos);
|
||||||
m_Section->m_Jump.LinkLocation = NULL;
|
m_Section->m_Jump.LinkLocation = NULL;
|
||||||
|
@ -370,6 +378,10 @@ void CRecompilerOps::Compile_BranchLikely (BranchFunction CompareFunc, BOOL Link
|
||||||
OverflowDelaySlot(false);
|
OverflowDelaySlot(false);
|
||||||
CPU_Message(" ");
|
CPU_Message(" ");
|
||||||
CPU_Message(" %s:",m_Section->m_Cont.BranchLabel.c_str());
|
CPU_Message(" %s:",m_Section->m_Cont.BranchLabel.c_str());
|
||||||
|
} else if (!m_Section->m_Cont.FallThrough) {
|
||||||
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
|
}
|
||||||
|
|
||||||
if (m_Section->m_Cont.LinkLocation != NULL) {
|
if (m_Section->m_Cont.LinkLocation != NULL) {
|
||||||
SetJump32(m_Section->m_Cont.LinkLocation,(DWORD *)m_RecompPos);
|
SetJump32(m_Section->m_Cont.LinkLocation,(DWORD *)m_RecompPos);
|
||||||
m_Section->m_Cont.LinkLocation = NULL;
|
m_Section->m_Cont.LinkLocation = NULL;
|
||||||
|
|
Loading…
Reference in New Issue