Global Variable: Rename _Notify to g_Notify
This commit is contained in:
parent
ca161dfd07
commit
ab57cdbc7e
|
@ -841,7 +841,7 @@ int DisplayR4300iCommand (DWORD location, int InsertPos) {
|
||||||
return LinesUsed;
|
return LinesUsed;
|
||||||
}
|
}
|
||||||
} __except( r4300i_Command_MemoryFilter( GetExceptionCode(), GetExceptionInformation()) ) {
|
} __except( r4300i_Command_MemoryFilter( GetExceptionCode(), GetExceptionInformation()) ) {
|
||||||
_Notify->DisplayError(GS(MSG_UNKNOWN_MEM_ACTION));
|
g_Notify->DisplayError(GS(MSG_UNKNOWN_MEM_ACTION));
|
||||||
ExitThread(0);
|
ExitThread(0);
|
||||||
}
|
}
|
||||||
if (SelfModCheck == ModCode_ChangeMemory) {
|
if (SelfModCheck == ModCode_ChangeMemory) {
|
||||||
|
|
|
@ -473,7 +473,7 @@ void CCheats::AddCodeLayers (int CheatNumber, const stdstr &CheatName, WND_HANDL
|
||||||
|
|
||||||
//Work out text to add
|
//Work out text to add
|
||||||
char Text[500], Item[500];
|
char Text[500], Item[500];
|
||||||
if (CheatName.length() > (sizeof(Text) - 5)) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (CheatName.length() > (sizeof(Text) - 5)) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
strcpy(Text,CheatName.c_str());
|
strcpy(Text,CheatName.c_str());
|
||||||
if (strchr(Text,'\\') > 0) { *strchr(Text,'\\') = 0; }
|
if (strchr(Text,'\\') > 0) { *strchr(Text,'\\') = 0; }
|
||||||
|
|
||||||
|
@ -517,7 +517,7 @@ void CCheats::AddCodeLayers (int CheatNumber, const stdstr &CheatName, WND_HANDL
|
||||||
|
|
||||||
stdstr CCheats::GetCheatName(int CheatNo, bool AddExtension) const
|
stdstr CCheats::GetCheatName(int CheatNo, bool AddExtension) const
|
||||||
{
|
{
|
||||||
if (CheatNo > MaxCheats) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (CheatNo > MaxCheats) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
stdstr LineEntry = _Settings->LoadStringIndex(Cheat_Entry,CheatNo);
|
stdstr LineEntry = _Settings->LoadStringIndex(Cheat_Entry,CheatNo);
|
||||||
if (LineEntry.length() == 0) { return LineEntry; }
|
if (LineEntry.length() == 0) { return LineEntry; }
|
||||||
|
|
||||||
|
@ -756,13 +756,13 @@ int CALLBACK CCheats::CheatAddProc (WND_HANDLE hDlg,DWORD uMsg,DWORD wParam, DWO
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (_stricmp(CheatName.c_str(),NewCheatName.c_str()) == 0) {
|
if (_stricmp(CheatName.c_str(),NewCheatName.c_str()) == 0) {
|
||||||
_Notify->DisplayError(GS(MSG_CHEAT_NAME_IN_USE));
|
g_Notify->DisplayError(GS(MSG_CHEAT_NAME_IN_USE));
|
||||||
SetFocus(GetDlgItem((HWND)hDlg,IDC_CODE_NAME));
|
SetFocus(GetDlgItem((HWND)hDlg,IDC_CODE_NAME));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (_this->m_EditCheat < 0 && i == MaxCheats) {
|
if (_this->m_EditCheat < 0 && i == MaxCheats) {
|
||||||
_Notify->DisplayError(GS(MSG_MAX_CHEATS));
|
g_Notify->DisplayError(GS(MSG_MAX_CHEATS));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -79,7 +79,7 @@ LRESULT CDumpMemory::OnClicked(WORD /*wNotifyCode*/, WORD wID, HWND /*hWndCtl*/,
|
||||||
GetDlgItemText(IDC_FILENAME,FileName,sizeof(FileName));
|
GetDlgItemText(IDC_FILENAME,FileName,sizeof(FileName));
|
||||||
if (strlen(FileName) == 0)
|
if (strlen(FileName) == 0)
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("Please Choose target file");
|
g_Notify->DisplayError("Please Choose target file");
|
||||||
::SetFocus(GetDlgItem(IDC_FILENAME));
|
::SetFocus(GetDlgItem(IDC_FILENAME));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -255,7 +255,7 @@ LRESULT CDumpMemory::OnClicked(WORD /*wNotifyCode*/, WORD wID, HWND /*hWndCtl*/,
|
||||||
// GetDlgItemText((HWND)hDlg,IDC_FILENAME,FileName,sizeof(FileName));
|
// GetDlgItemText((HWND)hDlg,IDC_FILENAME,FileName,sizeof(FileName));
|
||||||
// if (strlen(FileName) == 0)
|
// if (strlen(FileName) == 0)
|
||||||
// {
|
// {
|
||||||
// _Notify->DisplayError("Please Choose target file");
|
// g_Notify->DisplayError("Please Choose target file");
|
||||||
// SetFocus(GetDlgItem((HWND)hDlg,IDC_FILENAME));
|
// SetFocus(GetDlgItem((HWND)hDlg,IDC_FILENAME));
|
||||||
// return false;
|
// return false;
|
||||||
// }
|
// }
|
||||||
|
@ -299,12 +299,12 @@ bool CDumpMemory::DumpMemory ( LPCSTR FileName,DumpFormat Format, DWORD StartPC,
|
||||||
CLog LogFile;
|
CLog LogFile;
|
||||||
if (!LogFile.Open(FileName))
|
if (!LogFile.Open(FileName))
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("Failed to open\n%s",FileName);
|
g_Notify->DisplayError("Failed to open\n%s",FileName);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
LogFile.SetFlush(false);
|
LogFile.SetFlush(false);
|
||||||
LogFile.SetTruncateFile(false);
|
LogFile.SetTruncateFile(false);
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
char Command[200];
|
char Command[200];
|
||||||
for (COpcode OpCode(StartPC); OpCode.PC() < EndPC; OpCode.Next())
|
for (COpcode OpCode(StartPC); OpCode.PC() < EndPC; OpCode.Next())
|
||||||
|
@ -479,7 +479,7 @@ bool CDumpMemory::DumpMemory ( LPCSTR FileName,DumpFormat Format, DWORD StartPC,
|
||||||
//
|
//
|
||||||
// if (strlen(FileName) == 0)
|
// if (strlen(FileName) == 0)
|
||||||
// {
|
// {
|
||||||
// _Notify->DisplayError("Please Choose target file");
|
// g_Notify->DisplayError("Please Choose target file");
|
||||||
// SetFocus(GetDlgItem((HWND)hDlg,IDC_FILENAME));
|
// SetFocus(GetDlgItem((HWND)hDlg,IDC_FILENAME));
|
||||||
// return false;
|
// return false;
|
||||||
// }
|
// }
|
||||||
|
@ -524,7 +524,7 @@ bool CDumpMemory::DumpMemory ( LPCSTR FileName,DumpFormat Format, DWORD StartPC,
|
||||||
// CLog LogFile(FileName);
|
// CLog LogFile(FileName);
|
||||||
// if (!LogFile.IsOpen())
|
// if (!LogFile.IsOpen())
|
||||||
// {
|
// {
|
||||||
// _Notify->DisplayError("Failed to open\n%s",FileName);
|
// g_Notify->DisplayError("Failed to open\n%s",FileName);
|
||||||
// return false;
|
// return false;
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
|
|
|
@ -13,7 +13,7 @@ CDebugMemorySearch::~CDebugMemorySearch()
|
||||||
void CDebugMemorySearch::AddAlignmentOptions (CComboBox & ctrl)
|
void CDebugMemorySearch::AddAlignmentOptions (CComboBox & ctrl)
|
||||||
{
|
{
|
||||||
/*int Index =*/ ctrl.AddString("32 bits (aligned)");
|
/*int Index =*/ ctrl.AddString("32 bits (aligned)");
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
ctrl.SetItemData(Index,_32Bit);
|
ctrl.SetItemData(Index,_32Bit);
|
||||||
Index = ctrl.AddString("16bits (aligned)");
|
Index = ctrl.AddString("16bits (aligned)");
|
||||||
|
@ -225,7 +225,7 @@ void CDebugMemorySearch::EnableUnknownOptions( bool Enable )
|
||||||
|
|
||||||
void CDebugMemorySearch::SearchForValue( void )
|
void CDebugMemorySearch::SearchForValue( void )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
MemorySize Size = (MemorySize)m_ValueSize.GetItemData(m_ValueSize.GetCurSel());
|
MemorySize Size = (MemorySize)m_ValueSize.GetItemData(m_ValueSize.GetCurSel());
|
||||||
DWORD Value = m_SearchValue.GetValue();
|
DWORD Value = m_SearchValue.GetValue();
|
||||||
|
|
|
@ -5,14 +5,14 @@ DWORD CInterpreterCPU::m_CountPerOp = 2;
|
||||||
|
|
||||||
void ExecuteInterpreterOps (DWORD /*Cycles*/)
|
void ExecuteInterpreterOps (DWORD /*Cycles*/)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool DelaySlotEffectsCompare (DWORD PC, DWORD Reg1, DWORD Reg2) {
|
bool DelaySlotEffectsCompare (DWORD PC, DWORD Reg1, DWORD Reg2) {
|
||||||
OPCODE Command;
|
OPCODE Command;
|
||||||
|
|
||||||
if (!_MMU->LW_VAddr(PC + 4, Command.Hex)) {
|
if (!_MMU->LW_VAddr(PC + 4, Command.Hex)) {
|
||||||
//_Notify->DisplayError("Failed to load word 2");
|
//g_Notify->DisplayError("Failed to load word 2");
|
||||||
//ExitThread(0);
|
//ExitThread(0);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -68,7 +68,7 @@ bool DelaySlotEffectsCompare (DWORD PC, DWORD Reg1, DWORD Reg2) {
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Does %s effect Delay slot at %X?",R4300iOpcodeName(Command.Hex,PC+4), PC);
|
g_Notify->DisplayError("Does %s effect Delay slot at %X?",R4300iOpcodeName(Command.Hex,PC+4), PC);
|
||||||
#endif
|
#endif
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -90,13 +90,13 @@ bool DelaySlotEffectsCompare (DWORD PC, DWORD Reg1, DWORD Reg2) {
|
||||||
case R4300i_COP0_CO_TLBP: break;
|
case R4300i_COP0_CO_TLBP: break;
|
||||||
default:
|
default:
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Does %s effect Delay slot at %X?\n6",R4300iOpcodeName(Command.Hex,PC+4), PC);
|
g_Notify->DisplayError("Does %s effect Delay slot at %X?\n6",R4300iOpcodeName(Command.Hex,PC+4), PC);
|
||||||
#endif
|
#endif
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Does %s effect Delay slot at %X?\n7",R4300iOpcodeName(Command.Hex,PC+4), PC);
|
g_Notify->DisplayError("Does %s effect Delay slot at %X?\n7",R4300iOpcodeName(Command.Hex,PC+4), PC);
|
||||||
#endif
|
#endif
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -118,7 +118,7 @@ bool DelaySlotEffectsCompare (DWORD PC, DWORD Reg1, DWORD Reg2) {
|
||||||
case R4300i_COP1_L: break;
|
case R4300i_COP1_L: break;
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
default:
|
default:
|
||||||
_Notify->DisplayError("Does %s effect Delay slot at %X?",R4300iOpcodeName(Command.Hex,PC+4), PC);
|
g_Notify->DisplayError("Does %s effect Delay slot at %X?",R4300iOpcodeName(Command.Hex,PC+4), PC);
|
||||||
#endif
|
#endif
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -160,7 +160,7 @@ bool DelaySlotEffectsCompare (DWORD PC, DWORD Reg1, DWORD Reg2) {
|
||||||
case R4300i_SD: break;
|
case R4300i_SD: break;
|
||||||
default:
|
default:
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Does %s effect Delay slot at %X?",R4300iOpcodeName(Command.Hex,PC+4), PC);
|
g_Notify->DisplayError("Does %s effect Delay slot at %X?",R4300iOpcodeName(Command.Hex,PC+4), PC);
|
||||||
#endif
|
#endif
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -206,7 +206,7 @@ void CInterpreterCPU::InPermLoop (void) {
|
||||||
//CurrentFrame = 0;
|
//CurrentFrame = 0;
|
||||||
//CurrentPercent = 0;
|
//CurrentPercent = 0;
|
||||||
//DisplayFPS();
|
//DisplayFPS();
|
||||||
_Notify->DisplayError(GS(MSG_PERM_LOOP));
|
g_Notify->DisplayError(GS(MSG_PERM_LOOP));
|
||||||
_System->CloseCpu();
|
_System->CloseCpu();
|
||||||
} else {
|
} else {
|
||||||
/* check sound playing */
|
/* check sound playing */
|
||||||
|
@ -290,7 +290,7 @@ void CInterpreterCPU::ExecuteCPU (void )
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
_Reg->DoTLBReadMiss(R4300iOp::m_NextInstruction == JUMP,PROGRAM_COUNTER);
|
_Reg->DoTLBReadMiss(R4300iOp::m_NextInstruction == JUMP,PROGRAM_COUNTER);
|
||||||
|
@ -298,7 +298,7 @@ void CInterpreterCPU::ExecuteCPU (void )
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} __except( _MMU->MemoryFilter( GetExceptionCode(), GetExceptionInformation()) ) {
|
} __except( _MMU->MemoryFilter( GetExceptionCode(), GetExceptionInformation()) ) {
|
||||||
_Notify->DisplayError(GS(MSG_UNKNOWN_MEM_ACTION));
|
g_Notify->DisplayError(GS(MSG_UNKNOWN_MEM_ACTION));
|
||||||
ExitThread(0);
|
ExitThread(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -396,7 +396,7 @@ void CInterpreterCPU::ExecuteOps ( int Cycles )
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
_Reg->DoTLBReadMiss(R4300iOp::m_NextInstruction == JUMP,PROGRAM_COUNTER);
|
_Reg->DoTLBReadMiss(R4300iOp::m_NextInstruction == JUMP,PROGRAM_COUNTER);
|
||||||
|
@ -404,7 +404,7 @@ void CInterpreterCPU::ExecuteOps ( int Cycles )
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} __except( _MMU->MemoryFilter( GetExceptionCode(), GetExceptionInformation()) ) {
|
} __except( _MMU->MemoryFilter( GetExceptionCode(), GetExceptionInformation()) ) {
|
||||||
_Notify->DisplayError(GS(MSG_UNKNOWN_MEM_ACTION));
|
g_Notify->DisplayError(GS(MSG_UNKNOWN_MEM_ACTION));
|
||||||
ExitThread(0);
|
ExitThread(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -834,7 +834,7 @@ void R4300iOp32::LB (void) {
|
||||||
if (!_MMU->LB_VAddr(Address,_GPR[m_Opcode.rt].UB[0])) {
|
if (!_MMU->LB_VAddr(Address,_GPR[m_Opcode.rt].UB[0])) {
|
||||||
if (bShowTLBMisses()) {
|
if (bShowTLBMisses()) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("LB TLB: %X",Address);
|
g_Notify->DisplayError("LB TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
TLB_READ_EXCEPTION(Address);
|
TLB_READ_EXCEPTION(Address);
|
||||||
|
@ -848,7 +848,7 @@ void R4300iOp32::LH (void) {
|
||||||
if ((Address & 1) != 0) { ADDRESS_ERROR_EXCEPTION(Address,TRUE); }
|
if ((Address & 1) != 0) { ADDRESS_ERROR_EXCEPTION(Address,TRUE); }
|
||||||
if (!_MMU->LH_VAddr(Address,_GPR[m_Opcode.rt].UHW[0])) {
|
if (!_MMU->LH_VAddr(Address,_GPR[m_Opcode.rt].UHW[0])) {
|
||||||
if (bShowTLBMisses()) {
|
if (bShowTLBMisses()) {
|
||||||
_Notify->DisplayError("LH TLB: %X",Address);
|
g_Notify->DisplayError("LH TLB: %X",Address);
|
||||||
}
|
}
|
||||||
TLB_READ_EXCEPTION(Address);
|
TLB_READ_EXCEPTION(Address);
|
||||||
} else {
|
} else {
|
||||||
|
@ -864,10 +864,10 @@ void R4300iOp32::LWL (void) {
|
||||||
|
|
||||||
if (!_MMU->LW_VAddr((Address & ~3),Value))
|
if (!_MMU->LW_VAddr((Address & ~3),Value))
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
if (bShowTLBMisses())
|
if (bShowTLBMisses())
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("LWL TLB: %X",Address);
|
g_Notify->DisplayError("LWL TLB: %X",Address);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -891,7 +891,7 @@ void R4300iOp32::LW (void) {
|
||||||
|
|
||||||
if (!_MMU->LW_VAddr(Address,_GPR[m_Opcode.rt].UW[0])) {
|
if (!_MMU->LW_VAddr(Address,_GPR[m_Opcode.rt].UW[0])) {
|
||||||
if (bShowTLBMisses()) {
|
if (bShowTLBMisses()) {
|
||||||
_Notify->DisplayError("LW TLB: %X",Address);
|
g_Notify->DisplayError("LW TLB: %X",Address);
|
||||||
}
|
}
|
||||||
TLB_READ_EXCEPTION(Address);
|
TLB_READ_EXCEPTION(Address);
|
||||||
} else {
|
} else {
|
||||||
|
@ -903,7 +903,7 @@ void R4300iOp32::LBU (void) {
|
||||||
DWORD Address = _GPR[m_Opcode.base].UW[0] + (short)m_Opcode.offset;
|
DWORD Address = _GPR[m_Opcode.base].UW[0] + (short)m_Opcode.offset;
|
||||||
if (!_MMU->LB_VAddr(Address,_GPR[m_Opcode.rt].UB[0])) {
|
if (!_MMU->LB_VAddr(Address,_GPR[m_Opcode.rt].UB[0])) {
|
||||||
if (bShowTLBMisses()) {
|
if (bShowTLBMisses()) {
|
||||||
_Notify->DisplayError("LBU TLB: %X",Address);
|
g_Notify->DisplayError("LBU TLB: %X",Address);
|
||||||
}
|
}
|
||||||
TLB_READ_EXCEPTION(Address);
|
TLB_READ_EXCEPTION(Address);
|
||||||
} else {
|
} else {
|
||||||
|
@ -916,7 +916,7 @@ void R4300iOp32::LHU (void) {
|
||||||
if ((Address & 1) != 0) { ADDRESS_ERROR_EXCEPTION(Address,TRUE); }
|
if ((Address & 1) != 0) { ADDRESS_ERROR_EXCEPTION(Address,TRUE); }
|
||||||
if (!_MMU->LH_VAddr(Address,_GPR[m_Opcode.rt].UHW[0])) {
|
if (!_MMU->LH_VAddr(Address,_GPR[m_Opcode.rt].UHW[0])) {
|
||||||
if (bShowTLBMisses()) {
|
if (bShowTLBMisses()) {
|
||||||
_Notify->DisplayError("LHU TLB: %X",Address);
|
g_Notify->DisplayError("LHU TLB: %X",Address);
|
||||||
}
|
}
|
||||||
TLB_READ_EXCEPTION(Address);
|
TLB_READ_EXCEPTION(Address);
|
||||||
} else {
|
} else {
|
||||||
|
@ -932,10 +932,10 @@ void R4300iOp32::LWR (void) {
|
||||||
|
|
||||||
if (!_MMU->LW_VAddr((Address & ~3),Value))
|
if (!_MMU->LW_VAddr((Address & ~3),Value))
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
if (bShowTLBMisses())
|
if (bShowTLBMisses())
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("LWR TLB: %X",Address);
|
g_Notify->DisplayError("LWR TLB: %X",Address);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -951,7 +951,7 @@ void R4300iOp32::LWU (void) {
|
||||||
|
|
||||||
if (!_MMU->LW_VAddr(Address,_GPR[m_Opcode.rt].UW[0])) {
|
if (!_MMU->LW_VAddr(Address,_GPR[m_Opcode.rt].UW[0])) {
|
||||||
if (bShowTLBMisses()) {
|
if (bShowTLBMisses()) {
|
||||||
_Notify->DisplayError("LWU TLB: %X",Address);
|
g_Notify->DisplayError("LWU TLB: %X",Address);
|
||||||
}
|
}
|
||||||
TLB_READ_EXCEPTION(Address);
|
TLB_READ_EXCEPTION(Address);
|
||||||
} else {
|
} else {
|
||||||
|
@ -968,7 +968,7 @@ void R4300iOp32::LL (void) {
|
||||||
|
|
||||||
if (!_MMU->LW_VAddr(Address,_GPR[m_Opcode.rt].UW[0])) {
|
if (!_MMU->LW_VAddr(Address,_GPR[m_Opcode.rt].UW[0])) {
|
||||||
if (bShowTLBMisses()) {
|
if (bShowTLBMisses()) {
|
||||||
_Notify->DisplayError("LL TLB: %X",Address);
|
g_Notify->DisplayError("LL TLB: %X",Address);
|
||||||
}
|
}
|
||||||
TLB_READ_EXCEPTION(Address);
|
TLB_READ_EXCEPTION(Address);
|
||||||
} else {
|
} else {
|
||||||
|
@ -1062,7 +1062,7 @@ void R4300iOp32::SPECIAL_SLTU (void) {
|
||||||
void R4300iOp32::SPECIAL_TEQ (void) {
|
void R4300iOp32::SPECIAL_TEQ (void) {
|
||||||
if (_GPR[m_Opcode.rs].W[0] == _GPR[m_Opcode.rt].W[0]) {
|
if (_GPR[m_Opcode.rs].W[0] == _GPR[m_Opcode.rt].W[0]) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Should trap this ???");
|
g_Notify->DisplayError("Should trap this ???");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1245,7 +1245,7 @@ void R4300iOp32::COP0_MT (void) {
|
||||||
}
|
}
|
||||||
if ((_CP0[m_Opcode.rd] & 0x18) != 0) {
|
if ((_CP0[m_Opcode.rd] & 0x18) != 0) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Left kernel mode ??");
|
g_Notify->DisplayError("Left kernel mode ??");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
_Reg->CheckInterrupts();
|
_Reg->CheckInterrupts();
|
||||||
|
@ -1253,7 +1253,7 @@ void R4300iOp32::COP0_MT (void) {
|
||||||
case 13: //cause
|
case 13: //cause
|
||||||
_CP0[m_Opcode.rd] &= 0xFFFFCFF;
|
_CP0[m_Opcode.rd] &= 0xFFFFCFF;
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
if ((_GPR[m_Opcode.rt].UW[0] & 0x300) != 0 ){ _Notify->DisplayError("Set IP0 or IP1"); }
|
if ((_GPR[m_Opcode.rt].UW[0] & 0x300) != 0 ){ g_Notify->DisplayError("Set IP0 or IP1"); }
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -1271,7 +1271,7 @@ void R4300iOp32::COP1_CF (void) {
|
||||||
TEST_COP1_USABLE_EXCEPTION
|
TEST_COP1_USABLE_EXCEPTION
|
||||||
if (m_Opcode.fs != 31 && m_Opcode.fs != 0) {
|
if (m_Opcode.fs != 31 && m_Opcode.fs != 0) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("CFC1 what register are you writing to ?");
|
g_Notify->DisplayError("CFC1 what register are you writing to ?");
|
||||||
#endif
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -958,10 +958,10 @@ void R4300iOp::LDL (void) {
|
||||||
|
|
||||||
if (!_MMU->LD_VAddr((Address & ~7),Value))
|
if (!_MMU->LD_VAddr((Address & ~7),Value))
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
if (bShowTLBMisses())
|
if (bShowTLBMisses())
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("LDL TLB: %X",Address);
|
g_Notify->DisplayError("LDL TLB: %X",Address);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -984,10 +984,10 @@ void R4300iOp::LDR (void) {
|
||||||
|
|
||||||
if (!_MMU->LD_VAddr((Address & ~7),Value))
|
if (!_MMU->LD_VAddr((Address & ~7),Value))
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
if (bShowTLBMisses())
|
if (bShowTLBMisses())
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("LDR TLB: %X",Address);
|
g_Notify->DisplayError("LDR TLB: %X",Address);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1003,7 +1003,7 @@ void R4300iOp::LB (void) {
|
||||||
if (!_MMU->LB_VAddr(Address,_GPR[m_Opcode.rt].UB[0])) {
|
if (!_MMU->LB_VAddr(Address,_GPR[m_Opcode.rt].UB[0])) {
|
||||||
if (bShowTLBMisses()) {
|
if (bShowTLBMisses()) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("LB TLB: %X",Address);
|
g_Notify->DisplayError("LB TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
TLB_READ_EXCEPTION(Address);
|
TLB_READ_EXCEPTION(Address);
|
||||||
|
@ -1017,7 +1017,7 @@ void R4300iOp::LH (void) {
|
||||||
if ((Address & 1) != 0) { ADDRESS_ERROR_EXCEPTION(Address,TRUE); }
|
if ((Address & 1) != 0) { ADDRESS_ERROR_EXCEPTION(Address,TRUE); }
|
||||||
if (!_MMU->LH_VAddr(Address,_GPR[m_Opcode.rt].UHW[0])) {
|
if (!_MMU->LH_VAddr(Address,_GPR[m_Opcode.rt].UHW[0])) {
|
||||||
if (bShowTLBMisses()) {
|
if (bShowTLBMisses()) {
|
||||||
_Notify->DisplayError("LH TLB: %X",Address);
|
g_Notify->DisplayError("LH TLB: %X",Address);
|
||||||
}
|
}
|
||||||
TLB_READ_EXCEPTION(Address);
|
TLB_READ_EXCEPTION(Address);
|
||||||
} else {
|
} else {
|
||||||
|
@ -1033,10 +1033,10 @@ void R4300iOp::LWL (void) {
|
||||||
|
|
||||||
if (!_MMU->LW_VAddr((Address & ~3),Value))
|
if (!_MMU->LW_VAddr((Address & ~3),Value))
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
if (bShowTLBMisses())
|
if (bShowTLBMisses())
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("LWL TLB: %X",Address);
|
g_Notify->DisplayError("LWL TLB: %X",Address);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1060,7 +1060,7 @@ void R4300iOp::LW (void) {
|
||||||
|
|
||||||
if (!_MMU->LW_VAddr(Address,_GPR[m_Opcode.rt].UW[0])) {
|
if (!_MMU->LW_VAddr(Address,_GPR[m_Opcode.rt].UW[0])) {
|
||||||
if (bShowTLBMisses()) {
|
if (bShowTLBMisses()) {
|
||||||
_Notify->DisplayError("LW TLB: %X",Address);
|
g_Notify->DisplayError("LW TLB: %X",Address);
|
||||||
}
|
}
|
||||||
TLB_READ_EXCEPTION(Address);
|
TLB_READ_EXCEPTION(Address);
|
||||||
} else {
|
} else {
|
||||||
|
@ -1072,7 +1072,7 @@ void R4300iOp::LBU (void) {
|
||||||
DWORD Address = _GPR[m_Opcode.base].UW[0] + (short)m_Opcode.offset;
|
DWORD Address = _GPR[m_Opcode.base].UW[0] + (short)m_Opcode.offset;
|
||||||
if (!_MMU->LB_VAddr(Address,_GPR[m_Opcode.rt].UB[0])) {
|
if (!_MMU->LB_VAddr(Address,_GPR[m_Opcode.rt].UB[0])) {
|
||||||
if (bShowTLBMisses()) {
|
if (bShowTLBMisses()) {
|
||||||
_Notify->DisplayError("LBU TLB: %X",Address);
|
g_Notify->DisplayError("LBU TLB: %X",Address);
|
||||||
}
|
}
|
||||||
TLB_READ_EXCEPTION(Address);
|
TLB_READ_EXCEPTION(Address);
|
||||||
} else {
|
} else {
|
||||||
|
@ -1085,7 +1085,7 @@ void R4300iOp::LHU (void) {
|
||||||
if ((Address & 1) != 0) { ADDRESS_ERROR_EXCEPTION(Address,TRUE); }
|
if ((Address & 1) != 0) { ADDRESS_ERROR_EXCEPTION(Address,TRUE); }
|
||||||
if (!_MMU->LH_VAddr(Address,_GPR[m_Opcode.rt].UHW[0])) {
|
if (!_MMU->LH_VAddr(Address,_GPR[m_Opcode.rt].UHW[0])) {
|
||||||
if (bShowTLBMisses()) {
|
if (bShowTLBMisses()) {
|
||||||
_Notify->DisplayError("LHU TLB: %X",Address);
|
g_Notify->DisplayError("LHU TLB: %X",Address);
|
||||||
}
|
}
|
||||||
TLB_READ_EXCEPTION(Address);
|
TLB_READ_EXCEPTION(Address);
|
||||||
} else {
|
} else {
|
||||||
|
@ -1101,10 +1101,10 @@ void R4300iOp::LWR (void) {
|
||||||
|
|
||||||
if (!_MMU->LW_VAddr((Address & ~3),Value))
|
if (!_MMU->LW_VAddr((Address & ~3),Value))
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
if (bShowTLBMisses())
|
if (bShowTLBMisses())
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("LWR TLB: %X",Address);
|
g_Notify->DisplayError("LWR TLB: %X",Address);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1120,7 +1120,7 @@ void R4300iOp::LWU (void) {
|
||||||
|
|
||||||
if (!_MMU->LW_VAddr(Address,_GPR[m_Opcode.rt].UW[0])) {
|
if (!_MMU->LW_VAddr(Address,_GPR[m_Opcode.rt].UW[0])) {
|
||||||
if (bShowTLBMisses()) {
|
if (bShowTLBMisses()) {
|
||||||
_Notify->DisplayError("LWU TLB: %X",Address);
|
g_Notify->DisplayError("LWU TLB: %X",Address);
|
||||||
}
|
}
|
||||||
TLB_READ_EXCEPTION(Address);
|
TLB_READ_EXCEPTION(Address);
|
||||||
} else {
|
} else {
|
||||||
|
@ -1131,9 +1131,9 @@ void R4300iOp::LWU (void) {
|
||||||
void R4300iOp::SB (void) {
|
void R4300iOp::SB (void) {
|
||||||
DWORD Address = _GPR[m_Opcode.base].UW[0] + (short)m_Opcode.offset;
|
DWORD Address = _GPR[m_Opcode.base].UW[0] + (short)m_Opcode.offset;
|
||||||
if (!_MMU->SB_VAddr(Address,_GPR[m_Opcode.rt].UB[0])) {
|
if (!_MMU->SB_VAddr(Address,_GPR[m_Opcode.rt].UB[0])) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SB TLB: %X",Address);
|
g_Notify->DisplayError("SB TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1142,9 +1142,9 @@ void R4300iOp::SH (void) {
|
||||||
DWORD Address = _GPR[m_Opcode.base].UW[0] + (short)m_Opcode.offset;
|
DWORD Address = _GPR[m_Opcode.base].UW[0] + (short)m_Opcode.offset;
|
||||||
if ((Address & 1) != 0) { ADDRESS_ERROR_EXCEPTION(Address,FALSE); }
|
if ((Address & 1) != 0) { ADDRESS_ERROR_EXCEPTION(Address,FALSE); }
|
||||||
if (!_MMU->SH_VAddr(Address,_GPR[m_Opcode.rt].UHW[0])) {
|
if (!_MMU->SH_VAddr(Address,_GPR[m_Opcode.rt].UHW[0])) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SH TLB: %X",Address);
|
g_Notify->DisplayError("SH TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1157,9 +1157,9 @@ void R4300iOp::SWL (void) {
|
||||||
|
|
||||||
if (!_MMU->LW_VAddr((Address & ~3),Value)) {
|
if (!_MMU->LW_VAddr((Address & ~3),Value)) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SWL TLB: %X",Address);
|
g_Notify->DisplayError("SWL TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1168,9 +1168,9 @@ void R4300iOp::SWL (void) {
|
||||||
|
|
||||||
if (!_MMU->SW_VAddr((Address & ~0x03),Value)) {
|
if (!_MMU->SW_VAddr((Address & ~0x03),Value)) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SWL TLB: %X",Address);
|
g_Notify->DisplayError("SWL TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1186,10 +1186,10 @@ void R4300iOp::SW (void) {
|
||||||
#endif
|
#endif
|
||||||
if (!_MMU->SW_VAddr(Address,_GPR[m_Opcode.rt].UW[0]))
|
if (!_MMU->SW_VAddr(Address,_GPR[m_Opcode.rt].UW[0]))
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
if (bShowTLBMisses())
|
if (bShowTLBMisses())
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("SW TLB: %X",Address);
|
g_Notify->DisplayError("SW TLB: %X",Address);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1212,9 +1212,9 @@ void R4300iOp::SDL (void) {
|
||||||
Offset = Address & 7;
|
Offset = Address & 7;
|
||||||
|
|
||||||
if (!_MMU->LD_VAddr((Address & ~7),Value)) {
|
if (!_MMU->LD_VAddr((Address & ~7),Value)) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SDL TLB: %X",Address);
|
g_Notify->DisplayError("SDL TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1223,9 +1223,9 @@ void R4300iOp::SDL (void) {
|
||||||
Value += _GPR[m_Opcode.rt].UDW >> SDL_SHIFT[Offset];
|
Value += _GPR[m_Opcode.rt].UDW >> SDL_SHIFT[Offset];
|
||||||
|
|
||||||
if (!_MMU->SD_VAddr((Address & ~7),Value)) {
|
if (!_MMU->SD_VAddr((Address & ~7),Value)) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SDL TLB: %X",Address);
|
g_Notify->DisplayError("SDL TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1249,9 +1249,9 @@ void R4300iOp::SDR (void) {
|
||||||
Offset = Address & 7;
|
Offset = Address & 7;
|
||||||
|
|
||||||
if (!_MMU->LD_VAddr((Address & ~7),Value)) {
|
if (!_MMU->LD_VAddr((Address & ~7),Value)) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SDL TLB: %X",Address);
|
g_Notify->DisplayError("SDL TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1260,9 +1260,9 @@ void R4300iOp::SDR (void) {
|
||||||
Value += _GPR[m_Opcode.rt].UDW << SDR_SHIFT[Offset];
|
Value += _GPR[m_Opcode.rt].UDW << SDR_SHIFT[Offset];
|
||||||
|
|
||||||
if (!_MMU->SD_VAddr((Address & ~7),Value)) {
|
if (!_MMU->SD_VAddr((Address & ~7),Value)) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SDL TLB: %X",Address);
|
g_Notify->DisplayError("SDL TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1274,9 +1274,9 @@ void R4300iOp::SWR (void) {
|
||||||
Offset = Address & 3;
|
Offset = Address & 3;
|
||||||
|
|
||||||
if (!_MMU->LW_VAddr((Address & ~3),Value)) {
|
if (!_MMU->LW_VAddr((Address & ~3),Value)) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SWL TLB: %X",Address);
|
g_Notify->DisplayError("SWL TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1285,9 +1285,9 @@ void R4300iOp::SWR (void) {
|
||||||
Value += _GPR[m_Opcode.rt].UW[0] << SWR_SHIFT[Offset];
|
Value += _GPR[m_Opcode.rt].UW[0] << SWR_SHIFT[Offset];
|
||||||
|
|
||||||
if (!_MMU->SW_VAddr((Address & ~0x03),Value)) {
|
if (!_MMU->SW_VAddr((Address & ~0x03),Value)) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SWL TLB: %X",Address);
|
g_Notify->DisplayError("SWL TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1308,7 +1308,7 @@ void R4300iOp::LL (void) {
|
||||||
|
|
||||||
if (!_MMU->LW_VAddr(Address,_GPR[m_Opcode.rt].UW[0])) {
|
if (!_MMU->LW_VAddr(Address,_GPR[m_Opcode.rt].UW[0])) {
|
||||||
if (bShowTLBMisses()) {
|
if (bShowTLBMisses()) {
|
||||||
_Notify->DisplayError("LL TLB: %X",Address);
|
g_Notify->DisplayError("LL TLB: %X",Address);
|
||||||
}
|
}
|
||||||
TLB_READ_EXCEPTION(Address);
|
TLB_READ_EXCEPTION(Address);
|
||||||
} else {
|
} else {
|
||||||
|
@ -1323,7 +1323,7 @@ void R4300iOp::LWC1 (void) {
|
||||||
if ((Address & 3) != 0) { ADDRESS_ERROR_EXCEPTION(Address,TRUE); }
|
if ((Address & 3) != 0) { ADDRESS_ERROR_EXCEPTION(Address,TRUE); }
|
||||||
if (!_MMU->LW_VAddr(Address,*(DWORD *)_FPR_S[m_Opcode.ft])) {
|
if (!_MMU->LW_VAddr(Address,*(DWORD *)_FPR_S[m_Opcode.ft])) {
|
||||||
if (bShowTLBMisses()) {
|
if (bShowTLBMisses()) {
|
||||||
_Notify->DisplayError("LWC1 TLB: %X",Address);
|
g_Notify->DisplayError("LWC1 TLB: %X",Address);
|
||||||
}
|
}
|
||||||
TLB_READ_EXCEPTION(Address);
|
TLB_READ_EXCEPTION(Address);
|
||||||
}
|
}
|
||||||
|
@ -1338,10 +1338,10 @@ void R4300iOp::SC (void) {
|
||||||
if ((*_LLBit) == 1) {
|
if ((*_LLBit) == 1) {
|
||||||
if (!_MMU->SW_VAddr(Address,_GPR[m_Opcode.rt].UW[0]))
|
if (!_MMU->SW_VAddr(Address,_GPR[m_Opcode.rt].UW[0]))
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
if (bShowTLBMisses())
|
if (bShowTLBMisses())
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("SC TLB: %X",Address);
|
g_Notify->DisplayError("SC TLB: %X",Address);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1352,9 +1352,9 @@ void R4300iOp::LD (void) {
|
||||||
DWORD Address = _GPR[m_Opcode.base].UW[0] + (short)m_Opcode.offset;
|
DWORD Address = _GPR[m_Opcode.base].UW[0] + (short)m_Opcode.offset;
|
||||||
if ((Address & 7) != 0) { ADDRESS_ERROR_EXCEPTION(Address,TRUE); }
|
if ((Address & 7) != 0) { ADDRESS_ERROR_EXCEPTION(Address,TRUE); }
|
||||||
if (!_MMU->LD_VAddr(Address,_GPR[m_Opcode.rt].UDW)) {
|
if (!_MMU->LD_VAddr(Address,_GPR[m_Opcode.rt].UDW)) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("LD TLB: %X",Address);
|
g_Notify->DisplayError("LD TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
#ifdef Interpreter_StackTest
|
#ifdef Interpreter_StackTest
|
||||||
|
@ -1371,9 +1371,9 @@ void R4300iOp::LDC1 (void) {
|
||||||
TEST_COP1_USABLE_EXCEPTION
|
TEST_COP1_USABLE_EXCEPTION
|
||||||
if ((Address & 7) != 0) { ADDRESS_ERROR_EXCEPTION(Address,TRUE); }
|
if ((Address & 7) != 0) { ADDRESS_ERROR_EXCEPTION(Address,TRUE); }
|
||||||
if (!_MMU->LD_VAddr(Address,*(unsigned __int64 *)_FPR_D[m_Opcode.ft])) {
|
if (!_MMU->LD_VAddr(Address,*(unsigned __int64 *)_FPR_D[m_Opcode.ft])) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("LD TLB: %X",Address);
|
g_Notify->DisplayError("LD TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1384,9 +1384,9 @@ void R4300iOp::SWC1 (void) {
|
||||||
if ((Address & 3) != 0) { ADDRESS_ERROR_EXCEPTION(Address,FALSE); }
|
if ((Address & 3) != 0) { ADDRESS_ERROR_EXCEPTION(Address,FALSE); }
|
||||||
|
|
||||||
if (!_MMU->SW_VAddr(Address,*(DWORD *)_FPR_S[m_Opcode.ft])) {
|
if (!_MMU->SW_VAddr(Address,*(DWORD *)_FPR_S[m_Opcode.ft])) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SWC1 TLB: %X",Address);
|
g_Notify->DisplayError("SWC1 TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1397,9 +1397,9 @@ void R4300iOp::SDC1 (void) {
|
||||||
TEST_COP1_USABLE_EXCEPTION
|
TEST_COP1_USABLE_EXCEPTION
|
||||||
if ((Address & 7) != 0) { ADDRESS_ERROR_EXCEPTION(Address,FALSE); }
|
if ((Address & 7) != 0) { ADDRESS_ERROR_EXCEPTION(Address,FALSE); }
|
||||||
if (!_MMU->SD_VAddr(Address,*(__int64 *)_FPR_D[m_Opcode.ft])) {
|
if (!_MMU->SD_VAddr(Address,*(__int64 *)_FPR_D[m_Opcode.ft])) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SDC1 TLB: %X",Address);
|
g_Notify->DisplayError("SDC1 TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1408,9 +1408,9 @@ void R4300iOp::SD (void) {
|
||||||
DWORD Address = _GPR[m_Opcode.base].UW[0] + (short)m_Opcode.offset;
|
DWORD Address = _GPR[m_Opcode.base].UW[0] + (short)m_Opcode.offset;
|
||||||
if ((Address & 7) != 0) { ADDRESS_ERROR_EXCEPTION(Address,FALSE); }
|
if ((Address & 7) != 0) { ADDRESS_ERROR_EXCEPTION(Address,FALSE); }
|
||||||
if (!_MMU->SD_VAddr(Address,_GPR[m_Opcode.rt].UDW)) {
|
if (!_MMU->SD_VAddr(Address,_GPR[m_Opcode.rt].UDW)) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SD TLB: %X",Address);
|
g_Notify->DisplayError("SD TLB: %X",Address);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1513,7 +1513,7 @@ void R4300iOp::SPECIAL_DIV (void) {
|
||||||
_RegLO->DW = _GPR[m_Opcode.rs].W[0] / _GPR[m_Opcode.rt].W[0];
|
_RegLO->DW = _GPR[m_Opcode.rs].W[0] / _GPR[m_Opcode.rt].W[0];
|
||||||
_RegHI->DW = _GPR[m_Opcode.rs].W[0] % _GPR[m_Opcode.rt].W[0];
|
_RegHI->DW = _GPR[m_Opcode.rs].W[0] % _GPR[m_Opcode.rt].W[0];
|
||||||
} else {
|
} else {
|
||||||
if (bShowDivByZero()) { _Notify->DisplayError("DIV by 0 ???"); }
|
if (bShowDivByZero()) { g_Notify->DisplayError("DIV by 0 ???"); }
|
||||||
_RegLO->DW = 0;
|
_RegLO->DW = 0;
|
||||||
_RegHI->DW = 0;
|
_RegHI->DW = 0;
|
||||||
}
|
}
|
||||||
|
@ -1524,7 +1524,7 @@ void R4300iOp::SPECIAL_DIVU (void) {
|
||||||
_RegLO->DW = (int)(_GPR[m_Opcode.rs].UW[0] / _GPR[m_Opcode.rt].UW[0]);
|
_RegLO->DW = (int)(_GPR[m_Opcode.rs].UW[0] / _GPR[m_Opcode.rt].UW[0]);
|
||||||
_RegHI->DW = (int)(_GPR[m_Opcode.rs].UW[0] % _GPR[m_Opcode.rt].UW[0]);
|
_RegHI->DW = (int)(_GPR[m_Opcode.rs].UW[0] % _GPR[m_Opcode.rt].UW[0]);
|
||||||
} else {
|
} else {
|
||||||
if (bShowDivByZero()) { _Notify->DisplayError("DIVU by 0 ???"); }
|
if (bShowDivByZero()) { g_Notify->DisplayError("DIVU by 0 ???"); }
|
||||||
_RegLO->DW = 0;
|
_RegLO->DW = 0;
|
||||||
_RegHI->DW = 0;
|
_RegHI->DW = 0;
|
||||||
}
|
}
|
||||||
|
@ -1563,7 +1563,7 @@ void R4300iOp::SPECIAL_DDIV (void) {
|
||||||
_RegHI->DW = _GPR[m_Opcode.rs].DW % _GPR[m_Opcode.rt].DW;
|
_RegHI->DW = _GPR[m_Opcode.rs].DW % _GPR[m_Opcode.rt].DW;
|
||||||
} else {
|
} else {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("DDIV by 0 ???");
|
g_Notify->DisplayError("DDIV by 0 ???");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1574,7 +1574,7 @@ void R4300iOp::SPECIAL_DDIVU (void) {
|
||||||
_RegHI->UDW = _GPR[m_Opcode.rs].UDW % _GPR[m_Opcode.rt].UDW;
|
_RegHI->UDW = _GPR[m_Opcode.rs].UDW % _GPR[m_Opcode.rt].UDW;
|
||||||
} else {
|
} else {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("DDIVU by 0 ???");
|
g_Notify->DisplayError("DDIVU by 0 ???");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1651,7 +1651,7 @@ void R4300iOp::SPECIAL_DSUBU (void) {
|
||||||
void R4300iOp::SPECIAL_TEQ (void) {
|
void R4300iOp::SPECIAL_TEQ (void) {
|
||||||
if (_GPR[m_Opcode.rs].DW == _GPR[m_Opcode.rt].DW) {
|
if (_GPR[m_Opcode.rs].DW == _GPR[m_Opcode.rt].DW) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Should trap this ???");
|
g_Notify->DisplayError("Should trap this ???");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1848,7 +1848,7 @@ void R4300iOp::COP0_MT (void) {
|
||||||
}
|
}
|
||||||
if ((_CP0[m_Opcode.rd] & 0x18) != 0) {
|
if ((_CP0[m_Opcode.rd] & 0x18) != 0) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Left kernel mode ??");
|
g_Notify->DisplayError("Left kernel mode ??");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
_Reg->CheckInterrupts();
|
_Reg->CheckInterrupts();
|
||||||
|
@ -1856,7 +1856,7 @@ void R4300iOp::COP0_MT (void) {
|
||||||
case 13: //cause
|
case 13: //cause
|
||||||
_CP0[m_Opcode.rd] &= 0xFFFFCFF;
|
_CP0[m_Opcode.rd] &= 0xFFFFCFF;
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
if ((_GPR[m_Opcode.rt].UW[0] & 0x300) != 0 ){ _Notify->DisplayError("Set IP0 or IP1"); }
|
if ((_GPR[m_Opcode.rt].UW[0] & 0x300) != 0 ){ g_Notify->DisplayError("Set IP0 or IP1"); }
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -1914,7 +1914,7 @@ void R4300iOp::COP1_CF (void) {
|
||||||
TEST_COP1_USABLE_EXCEPTION
|
TEST_COP1_USABLE_EXCEPTION
|
||||||
if (m_Opcode.fs != 31 && m_Opcode.fs != 0) {
|
if (m_Opcode.fs != 31 && m_Opcode.fs != 0) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("CFC1 what register are you writing to ?");
|
g_Notify->DisplayError("CFC1 what register are you writing to ?");
|
||||||
#endif
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1944,7 +1944,7 @@ void R4300iOp::COP1_CT (void) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("CTC1 what register are you writing to ?");
|
g_Notify->DisplayError("CTC1 what register are you writing to ?");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2139,14 +2139,14 @@ void R4300iOp::COP1_S_CMP (void) {
|
||||||
|
|
||||||
if (_isnan(Temp0) || _isnan(Temp1)) {
|
if (_isnan(Temp0) || _isnan(Temp1)) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Nan ?");
|
g_Notify->DisplayError("Nan ?");
|
||||||
#endif
|
#endif
|
||||||
less = FALSE;
|
less = FALSE;
|
||||||
equal = FALSE;
|
equal = FALSE;
|
||||||
unorded = TRUE;
|
unorded = TRUE;
|
||||||
if ((m_Opcode.funct & 8) != 0) {
|
if ((m_Opcode.funct & 8) != 0) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Signal InvalidOperationException\nin r4300i_COP1_S_CMP\n%X %ff\n%X %ff",
|
g_Notify->DisplayError("Signal InvalidOperationException\nin r4300i_COP1_S_CMP\n%X %ff\n%X %ff",
|
||||||
Temp0,Temp0,Temp1,Temp1);
|
Temp0,Temp0,Temp1,Temp1);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -2305,14 +2305,14 @@ void R4300iOp::COP1_D_CMP (void) {
|
||||||
|
|
||||||
if (_isnan(Temp0.D) || _isnan(Temp1.D)) {
|
if (_isnan(Temp0.D) || _isnan(Temp1.D)) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Nan ?");
|
g_Notify->DisplayError("Nan ?");
|
||||||
#endif
|
#endif
|
||||||
less = FALSE;
|
less = FALSE;
|
||||||
equal = FALSE;
|
equal = FALSE;
|
||||||
unorded = TRUE;
|
unorded = TRUE;
|
||||||
if ((m_Opcode.funct & 8) != 0) {
|
if ((m_Opcode.funct & 8) != 0) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Signal InvalidOperationException\nin r4300i_COP1_D_CMP");
|
g_Notify->DisplayError("Signal InvalidOperationException\nin r4300i_COP1_D_CMP");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -2360,11 +2360,11 @@ void R4300iOp::COP1_L_CVT_D (void) {
|
||||||
/************************** Other functions **************************/
|
/************************** Other functions **************************/
|
||||||
void R4300iOp::UnknownOpcode (void)
|
void R4300iOp::UnknownOpcode (void)
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("%s: %08X\n%s\n\nStopping Emulation !", GS(MSG_UNHANDLED_OP), (*_PROGRAM_COUNTER),
|
g_Notify->DisplayError("%s: %08X\n%s\n\nStopping Emulation !", GS(MSG_UNHANDLED_OP), (*_PROGRAM_COUNTER),
|
||||||
R4300iOpcodeName(m_Opcode.Hex,(*_PROGRAM_COUNTER)));
|
R4300iOpcodeName(m_Opcode.Hex,(*_PROGRAM_COUNTER)));
|
||||||
_System->m_EndEmulation = true;
|
_System->m_EndEmulation = true;
|
||||||
|
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
if (HaveDebugger && !inFullScreen) {
|
if (HaveDebugger && !inFullScreen) {
|
||||||
int response;
|
int response;
|
||||||
|
@ -2377,7 +2377,7 @@ void R4300iOp::UnknownOpcode (void)
|
||||||
}
|
}
|
||||||
ExitThread(0);
|
ExitThread(0);
|
||||||
} else {
|
} else {
|
||||||
_Notify->DisplayError(Message);
|
g_Notify->DisplayError(Message);
|
||||||
ExitThread(0);
|
ExitThread(0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -50,7 +50,7 @@ void CAudio::LenChanged ( void )
|
||||||
{
|
{
|
||||||
if (m_SecondBuff)
|
if (m_SecondBuff)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
WriteTraceF(TraceAudio,__FUNCTION__ ": Set Timer AI_LEN_REG: %d m_CountsPerByte: %d",_Reg->AI_LEN_REG,m_CountsPerByte);
|
WriteTraceF(TraceAudio,__FUNCTION__ ": Set Timer AI_LEN_REG: %d m_CountsPerByte: %d",_Reg->AI_LEN_REG,m_CountsPerByte);
|
||||||
_SystemTimer->SetTimer(CSystemTimer::AiTimer,_Reg->AI_LEN_REG * m_CountsPerByte,false);
|
_SystemTimer->SetTimer(CSystemTimer::AiTimer,_Reg->AI_LEN_REG * m_CountsPerByte,false);
|
||||||
|
|
|
@ -13,7 +13,7 @@ void CDMA::OnFirstDMA (void) {
|
||||||
case 3: *(DWORD *)&((_MMU->Rdram())[0x318]) = _MMU->RdramSize(); break;
|
case 3: *(DWORD *)&((_MMU->Rdram())[0x318]) = _MMU->RdramSize(); break;
|
||||||
case 5: *(DWORD *)&((_MMU->Rdram())[0x3F0]) = _MMU->RdramSize(); break;
|
case 5: *(DWORD *)&((_MMU->Rdram())[0x3F0]) = _MMU->RdramSize(); break;
|
||||||
case 6: *(DWORD *)&((_MMU->Rdram())[0x318]) = _MMU->RdramSize(); break;
|
case 6: *(DWORD *)&((_MMU->Rdram())[0x318]) = _MMU->RdramSize(); break;
|
||||||
default: _Notify->DisplayError("Unhandled CicChip(%d) in first DMA",_Rom->CicChipID());
|
default: g_Notify->DisplayError("Unhandled CicChip(%d) in first DMA",_Rom->CicChipID());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -22,7 +22,7 @@ void CDMA::PI_DMA_READ (void) {
|
||||||
|
|
||||||
if ( _Reg->PI_DRAM_ADDR_REG + _Reg->PI_RD_LEN_REG + 1 > _MMU->RdramSize()) {
|
if ( _Reg->PI_DRAM_ADDR_REG + _Reg->PI_RD_LEN_REG + 1 > _MMU->RdramSize()) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("PI_DMA_READ not in Memory");
|
g_Notify->DisplayError("PI_DMA_READ not in Memory");
|
||||||
#endif
|
#endif
|
||||||
_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY;
|
_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY;
|
||||||
_Reg->MI_INTR_REG |= MI_INTR_PI;
|
_Reg->MI_INTR_REG |= MI_INTR_PI;
|
||||||
|
@ -57,14 +57,14 @@ void CDMA::PI_DMA_READ (void) {
|
||||||
}
|
}
|
||||||
if (_System->m_SaveUsing == SaveChip_FlashRam)
|
if (_System->m_SaveUsing == SaveChip_FlashRam)
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("**** FLashRam DMA Read address %X *****",_Reg->PI_CART_ADDR_REG);
|
g_Notify->DisplayError("**** FLashRam DMA Read address %X *****",_Reg->PI_CART_ADDR_REG);
|
||||||
_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY;
|
_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY;
|
||||||
_Reg->MI_INTR_REG |= MI_INTR_PI;
|
_Reg->MI_INTR_REG |= MI_INTR_PI;
|
||||||
_Reg->CheckInterrupts();
|
_Reg->CheckInterrupts();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("PI_DMA_READ where are you dmaing to ?");
|
g_Notify->DisplayError("PI_DMA_READ where are you dmaing to ?");
|
||||||
#endif
|
#endif
|
||||||
_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY;
|
_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY;
|
||||||
_Reg->MI_INTR_REG |= MI_INTR_PI;
|
_Reg->MI_INTR_REG |= MI_INTR_PI;
|
||||||
|
@ -77,7 +77,7 @@ void CDMA::PI_DMA_WRITE (void) {
|
||||||
_Reg->PI_STATUS_REG |= PI_STATUS_DMA_BUSY;
|
_Reg->PI_STATUS_REG |= PI_STATUS_DMA_BUSY;
|
||||||
if ( _Reg->PI_DRAM_ADDR_REG + _Reg->PI_WR_LEN_REG + 1 > _MMU->RdramSize())
|
if ( _Reg->PI_DRAM_ADDR_REG + _Reg->PI_WR_LEN_REG + 1 > _MMU->RdramSize())
|
||||||
{
|
{
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("PI_DMA_WRITE not in Memory"); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("PI_DMA_WRITE not in Memory"); }
|
||||||
_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY;
|
_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY;
|
||||||
_Reg->MI_INTR_REG |= MI_INTR_PI;
|
_Reg->MI_INTR_REG |= MI_INTR_PI;
|
||||||
_Reg->CheckInterrupts();
|
_Reg->CheckInterrupts();
|
||||||
|
@ -157,7 +157,7 @@ void CDMA::PI_DMA_WRITE (void) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("PI_DMA_WRITE not in ROM"); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("PI_DMA_WRITE not in ROM"); }
|
||||||
_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY;
|
_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY;
|
||||||
_Reg->MI_INTR_REG |= MI_INTR_PI;
|
_Reg->MI_INTR_REG |= MI_INTR_PI;
|
||||||
_Reg->CheckInterrupts();
|
_Reg->CheckInterrupts();
|
||||||
|
@ -169,7 +169,7 @@ void CDMA::SP_DMA_READ (void) {
|
||||||
|
|
||||||
if (_Reg->SP_DRAM_ADDR_REG > _MMU->RdramSize()) {
|
if (_Reg->SP_DRAM_ADDR_REG > _MMU->RdramSize()) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SP DMA\nSP_DRAM_ADDR_REG not in RDRam space");
|
g_Notify->DisplayError("SP DMA\nSP_DRAM_ADDR_REG not in RDRam space");
|
||||||
#endif
|
#endif
|
||||||
_Reg->SP_DMA_BUSY_REG = 0;
|
_Reg->SP_DMA_BUSY_REG = 0;
|
||||||
_Reg->SP_STATUS_REG &= ~SP_STATUS_DMA_BUSY;
|
_Reg->SP_STATUS_REG &= ~SP_STATUS_DMA_BUSY;
|
||||||
|
@ -178,14 +178,14 @@ void CDMA::SP_DMA_READ (void) {
|
||||||
|
|
||||||
if (_Reg->SP_RD_LEN_REG + 1 + (_Reg->SP_MEM_ADDR_REG & 0xFFF) > 0x1000) {
|
if (_Reg->SP_RD_LEN_REG + 1 + (_Reg->SP_MEM_ADDR_REG & 0xFFF) > 0x1000) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SP DMA\ncould not fit copy in memory segement");
|
g_Notify->DisplayError("SP DMA\ncould not fit copy in memory segement");
|
||||||
#endif
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((_Reg->SP_MEM_ADDR_REG & 3) != 0) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if ((_Reg->SP_MEM_ADDR_REG & 3) != 0) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
if ((_Reg->SP_DRAM_ADDR_REG & 3) != 0) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if ((_Reg->SP_DRAM_ADDR_REG & 3) != 0) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
if (((_Reg->SP_RD_LEN_REG + 1) & 3) != 0) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (((_Reg->SP_RD_LEN_REG + 1) & 3) != 0) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
|
|
||||||
memcpy( _MMU->Dmem() + (_Reg->SP_MEM_ADDR_REG & 0x1FFF), _MMU->Rdram() + _Reg->SP_DRAM_ADDR_REG,
|
memcpy( _MMU->Dmem() + (_Reg->SP_MEM_ADDR_REG & 0x1FFF), _MMU->Rdram() + _Reg->SP_DRAM_ADDR_REG,
|
||||||
_Reg->SP_RD_LEN_REG + 1 );
|
_Reg->SP_RD_LEN_REG + 1 );
|
||||||
|
@ -197,21 +197,21 @@ void CDMA::SP_DMA_READ (void) {
|
||||||
void CDMA::SP_DMA_WRITE (void) {
|
void CDMA::SP_DMA_WRITE (void) {
|
||||||
if (_Reg->SP_DRAM_ADDR_REG > _MMU->RdramSize()) {
|
if (_Reg->SP_DRAM_ADDR_REG > _MMU->RdramSize()) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SP DMA WRITE\nSP_DRAM_ADDR_REG not in RDRam space");
|
g_Notify->DisplayError("SP DMA WRITE\nSP_DRAM_ADDR_REG not in RDRam space");
|
||||||
#endif
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_Reg->SP_WR_LEN_REG + 1 + (_Reg->SP_MEM_ADDR_REG & 0xFFF) > 0x1000) {
|
if (_Reg->SP_WR_LEN_REG + 1 + (_Reg->SP_MEM_ADDR_REG & 0xFFF) > 0x1000) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("SP DMA WRITE\ncould not fit copy in memory segement");
|
g_Notify->DisplayError("SP DMA WRITE\ncould not fit copy in memory segement");
|
||||||
#endif
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((_Reg->SP_MEM_ADDR_REG & 3) != 0) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if ((_Reg->SP_MEM_ADDR_REG & 3) != 0) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
if ((_Reg->SP_DRAM_ADDR_REG & 3) != 0) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if ((_Reg->SP_DRAM_ADDR_REG & 3) != 0) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
if (((_Reg->SP_WR_LEN_REG + 1) & 3) != 0) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (((_Reg->SP_WR_LEN_REG + 1) & 3) != 0) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
|
|
||||||
memcpy( _MMU->Rdram() + _Reg->SP_DRAM_ADDR_REG, _MMU->Dmem() + (_Reg->SP_MEM_ADDR_REG & 0x1FFF),
|
memcpy( _MMU->Rdram() + _Reg->SP_DRAM_ADDR_REG, _MMU->Dmem() + (_Reg->SP_MEM_ADDR_REG & 0x1FFF),
|
||||||
_Reg->SP_WR_LEN_REG + 1);
|
_Reg->SP_WR_LEN_REG + 1);
|
||||||
|
|
|
@ -51,15 +51,15 @@ void CEeprom::EepromCommand ( BYTE * Command) {
|
||||||
break;
|
break;
|
||||||
case 4: // Read from Eeprom
|
case 4: // Read from Eeprom
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
if (Command[0] != 2) { _Notify->DisplayError("What am I meant to do with this Eeprom Command"); }
|
if (Command[0] != 2) { g_Notify->DisplayError("What am I meant to do with this Eeprom Command"); }
|
||||||
if (Command[1] != 8) { _Notify->DisplayError("What am I meant to do with this Eeprom Command"); }
|
if (Command[1] != 8) { g_Notify->DisplayError("What am I meant to do with this Eeprom Command"); }
|
||||||
#endif
|
#endif
|
||||||
ReadFrom(&Command[4],Command[3]);
|
ReadFrom(&Command[4],Command[3]);
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
if (Command[0] != 10) { _Notify->DisplayError("What am I meant to do with this Eeprom Command"); }
|
if (Command[0] != 10) { g_Notify->DisplayError("What am I meant to do with this Eeprom Command"); }
|
||||||
if (Command[1] != 1) { _Notify->DisplayError("What am I meant to do with this Eeprom Command"); }
|
if (Command[1] != 1) { g_Notify->DisplayError("What am I meant to do with this Eeprom Command"); }
|
||||||
#endif
|
#endif
|
||||||
WriteTo(&Command[4],Command[3]);
|
WriteTo(&Command[4],Command[3]);
|
||||||
break;
|
break;
|
||||||
|
@ -98,7 +98,7 @@ void CEeprom::EepromCommand ( BYTE * Command) {
|
||||||
//Write RTC, unimplemented
|
//Write RTC, unimplemented
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (_Settings->LoadDword(Debugger_ShowPifErrors)) { _Notify->DisplayError("Unknown EepromCommand %d",Command[2]); }
|
if (_Settings->LoadDword(Debugger_ShowPifErrors)) { g_Notify->DisplayError("Unknown EepromCommand %d",Command[2]); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -122,7 +122,7 @@ void CEeprom::LoadEeprom (void) {
|
||||||
if (m_hFile == INVALID_HANDLE_VALUE)
|
if (m_hFile == INVALID_HANDLE_VALUE)
|
||||||
{
|
{
|
||||||
WriteTraceF(TraceError,"CEeprom::LoadEeprom: Failed to open (%s), ReadOnly = %d, LastError = %X",(LPCTSTR)FileName, m_ReadOnly, GetLastError());
|
WriteTraceF(TraceError,"CEeprom::LoadEeprom: Failed to open (%s), ReadOnly = %d, LastError = %X",(LPCTSTR)FileName, m_ReadOnly, GetLastError());
|
||||||
_Notify->DisplayError(GS(MSG_FAIL_OPEN_EEPROM));
|
g_Notify->DisplayError(GS(MSG_FAIL_OPEN_EEPROM));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
SetFilePointer(m_hFile,0,NULL,FILE_BEGIN);
|
SetFilePointer(m_hFile,0,NULL,FILE_BEGIN);
|
||||||
|
|
|
@ -29,13 +29,13 @@ void CFlashram::DmaFromFlashram ( BYTE * dest, int StartOffset, int len)
|
||||||
}
|
}
|
||||||
if (len > 0x10000) {
|
if (len > 0x10000) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("DmaFromFlashram FlipBuffer to small (len: %d)",len);
|
g_Notify->DisplayError("DmaFromFlashram FlipBuffer to small (len: %d)",len);
|
||||||
#endif
|
#endif
|
||||||
len = 0x10000;
|
len = 0x10000;
|
||||||
}
|
}
|
||||||
if ((len & 3) != 0) {
|
if ((len & 3) != 0) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Unaligned flash ram read ???");
|
g_Notify->DisplayError("Unaligned flash ram read ???");
|
||||||
#endif
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -64,7 +64,7 @@ void CFlashram::DmaFromFlashram ( BYTE * dest, int StartOffset, int len)
|
||||||
case FLASHRAM_MODE_STATUS:
|
case FLASHRAM_MODE_STATUS:
|
||||||
if (StartOffset != 0 && len != 8) {
|
if (StartOffset != 0 && len != 8) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Reading m_FlashStatus not being handled correctly\nStart: %X len: %X",StartOffset,len);
|
g_Notify->DisplayError("Reading m_FlashStatus not being handled correctly\nStart: %X len: %X",StartOffset,len);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
*((DWORD *)(dest)) = (DWORD)((m_FlashStatus >> 32) & 0xFFFFFFFF);
|
*((DWORD *)(dest)) = (DWORD)((m_FlashStatus >> 32) & 0xFFFFFFFF);
|
||||||
|
@ -72,7 +72,7 @@ void CFlashram::DmaFromFlashram ( BYTE * dest, int StartOffset, int len)
|
||||||
break;
|
break;
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
default:
|
default:
|
||||||
_Notify->DisplayError("DmaFromFlashram Start: %X, Offset: %X len: %X",dest - _MMU->Rdram(),StartOffset,len);
|
g_Notify->DisplayError("DmaFromFlashram Start: %X, Offset: %X len: %X",dest - _MMU->Rdram(),StartOffset,len);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -84,7 +84,7 @@ void CFlashram::DmaToFlashram(BYTE * Source, int StartOffset, int len) {
|
||||||
break;
|
break;
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
default:
|
default:
|
||||||
_Notify->DisplayError("DmaToFlashram Start: %X, Offset: %X len: %X",Source - _MMU->Rdram(),StartOffset,len);
|
g_Notify->DisplayError("DmaToFlashram Start: %X, Offset: %X len: %X",Source - _MMU->Rdram(),StartOffset,len);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -96,7 +96,7 @@ DWORD CFlashram::ReadFromFlashStatus (DWORD PAddr)
|
||||||
case 0x08000000: return (DWORD)(m_FlashStatus >> 32);
|
case 0x08000000: return (DWORD)(m_FlashStatus >> 32);
|
||||||
default:
|
default:
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Reading from flash ram status (%X)",PAddr);
|
g_Notify->DisplayError("Reading from flash ram status (%X)",PAddr);
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -120,7 +120,7 @@ bool CFlashram::LoadFlashram (void) {
|
||||||
if (m_hFile == INVALID_HANDLE_VALUE)
|
if (m_hFile == INVALID_HANDLE_VALUE)
|
||||||
{
|
{
|
||||||
WriteTraceF(TraceError,"CFlashram::LoadFlashram: Failed to open (%s), ReadOnly = %d, LastError = %X",(LPCTSTR)FileName, m_ReadOnly, GetLastError());
|
WriteTraceF(TraceError,"CFlashram::LoadFlashram: Failed to open (%s), ReadOnly = %d, LastError = %X",(LPCTSTR)FileName, m_ReadOnly, GetLastError());
|
||||||
_Notify->DisplayError(GS(MSG_FAIL_OPEN_FLASH));
|
g_Notify->DisplayError(GS(MSG_FAIL_OPEN_FLASH));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
SetFilePointer(m_hFile,0,NULL,FILE_BEGIN);
|
SetFilePointer(m_hFile,0,NULL,FILE_BEGIN);
|
||||||
|
@ -174,7 +174,7 @@ void CFlashram::WriteToFlashCommand(DWORD FlashRAM_Command) {
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->DisplayError("Writing %X to flash ram command register\nm_FlashFlag: %d",FlashRAM_Command,m_FlashFlag);
|
g_Notify->DisplayError("Writing %X to flash ram command register\nm_FlashFlag: %d",FlashRAM_Command,m_FlashFlag);
|
||||||
}
|
}
|
||||||
m_FlashFlag = FLASHRAM_MODE_NOPES;
|
m_FlashFlag = FLASHRAM_MODE_NOPES;
|
||||||
break;
|
break;
|
||||||
|
@ -202,7 +202,7 @@ void CFlashram::WriteToFlashCommand(DWORD FlashRAM_Command) {
|
||||||
break;
|
break;
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
default:
|
default:
|
||||||
_Notify->DisplayError("Writing %X to flash ram command register",FlashRAM_Command);
|
g_Notify->DisplayError("Writing %X to flash ram command register",FlashRAM_Command);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -210,7 +210,7 @@ BOOL CMipsMemoryVM::LW_VAddr ( DWORD VAddr, DWORD & Value )
|
||||||
|
|
||||||
// if (LookUpMode == FuncFind_ChangeMemory)
|
// if (LookUpMode == FuncFind_ChangeMemory)
|
||||||
// {
|
// {
|
||||||
// _Notify->BreakPoint(__FILE__,__LINE__);
|
// g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
// if ( (Command.Hex >> 16) == 0x7C7C) {
|
// if ( (Command.Hex >> 16) == 0x7C7C) {
|
||||||
// Command.Hex = OrigMem[(Command.Hex & 0xFFFF)].OriginalValue;
|
// Command.Hex = OrigMem[(Command.Hex & 0xFFFF)].OriginalValue;
|
||||||
// }
|
// }
|
||||||
|
@ -293,7 +293,7 @@ void CMipsMemoryVM::Compile_LB ( x86Reg Reg, DWORD VAddr, BOOL SignExtend) {
|
||||||
if (!TranslateVaddr(VAddr,PAddr)) {
|
if (!TranslateVaddr(VAddr,PAddr)) {
|
||||||
MoveConstToX86reg(0,Reg);
|
MoveConstToX86reg(0,Reg);
|
||||||
CPU_Message("Compile_LB\nFailed to translate address %X",VAddr);
|
CPU_Message("Compile_LB\nFailed to translate address %X",VAddr);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_LB\nFailed to translate address %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_LB\nFailed to translate address %X",VAddr); }
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -316,7 +316,7 @@ void CMipsMemoryVM::Compile_LB ( x86Reg Reg, DWORD VAddr, BOOL SignExtend) {
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
MoveConstToX86reg(0,Reg);
|
MoveConstToX86reg(0,Reg);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_LB\nFailed to compile address: %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_LB\nFailed to compile address: %X",VAddr); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -327,7 +327,7 @@ void CMipsMemoryVM::Compile_LH ( x86Reg Reg, DWORD VAddr, BOOL SignExtend) {
|
||||||
if (!TranslateVaddr(VAddr, PAddr)) {
|
if (!TranslateVaddr(VAddr, PAddr)) {
|
||||||
MoveConstToX86reg(0,Reg);
|
MoveConstToX86reg(0,Reg);
|
||||||
CPU_Message("Compile_LH\nFailed to translate address %X",VAddr);
|
CPU_Message("Compile_LH\nFailed to translate address %X",VAddr);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_LH\nFailed to translate address %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_LH\nFailed to translate address %X",VAddr); }
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -350,7 +350,7 @@ void CMipsMemoryVM::Compile_LH ( x86Reg Reg, DWORD VAddr, BOOL SignExtend) {
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
MoveConstToX86reg(0,Reg);
|
MoveConstToX86reg(0,Reg);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_LHU\nFailed to compile address: %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_LHU\nFailed to compile address: %X",VAddr); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -363,7 +363,7 @@ void CMipsMemoryVM::Compile_LW (x86Reg Reg, DWORD VAddr ) {
|
||||||
{
|
{
|
||||||
if (!bUseTlb())
|
if (!bUseTlb())
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -376,7 +376,7 @@ void CMipsMemoryVM::Compile_LW (x86Reg Reg, DWORD VAddr ) {
|
||||||
} else {
|
} else {
|
||||||
if (!TranslateVaddr(VAddr, PAddr))
|
if (!TranslateVaddr(VAddr, PAddr))
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (PAddr & 0xFFF00000) {
|
switch (PAddr & 0xFFF00000) {
|
||||||
|
@ -405,7 +405,7 @@ void CMipsMemoryVM::Compile_LW (x86Reg Reg, DWORD VAddr ) {
|
||||||
case 0x04080000: MoveVariableToX86reg(&_Reg->SP_PC_REG,"SP_PC_REG",Reg); break;
|
case 0x04080000: MoveVariableToX86reg(&_Reg->SP_PC_REG,"SP_PC_REG",Reg); break;
|
||||||
default:
|
default:
|
||||||
MoveConstToX86reg(0,Reg);
|
MoveConstToX86reg(0,Reg);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError(__FUNCTION__ "\nFailed to translate address: %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError(__FUNCTION__ "\nFailed to translate address: %X",VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04100000:
|
case 0x04100000:
|
||||||
|
@ -428,7 +428,7 @@ void CMipsMemoryVM::Compile_LW (x86Reg Reg, DWORD VAddr ) {
|
||||||
case 0x0430000C: MoveVariableToX86reg(&_Reg->MI_INTR_MASK_REG,"MI_INTR_MASK_REG",Reg); break;
|
case 0x0430000C: MoveVariableToX86reg(&_Reg->MI_INTR_MASK_REG,"MI_INTR_MASK_REG",Reg); break;
|
||||||
default:
|
default:
|
||||||
MoveConstToX86reg(0,Reg);
|
MoveConstToX86reg(0,Reg);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError(__FUNCTION__ "\nFailed to translate address: %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError(__FUNCTION__ "\nFailed to translate address: %X",VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04400000:
|
case 0x04400000:
|
||||||
|
@ -445,7 +445,7 @@ void CMipsMemoryVM::Compile_LW (x86Reg Reg, DWORD VAddr ) {
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
MoveConstToX86reg(0,Reg);
|
MoveConstToX86reg(0,Reg);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError(__FUNCTION__ "\nFailed to translate address: %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError(__FUNCTION__ "\nFailed to translate address: %X",VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04500000: /* AI registers */
|
case 0x04500000: /* AI registers */
|
||||||
|
@ -489,7 +489,7 @@ void CMipsMemoryVM::Compile_LW (x86Reg Reg, DWORD VAddr ) {
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
MoveConstToX86reg(0,Reg);
|
MoveConstToX86reg(0,Reg);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError(__FUNCTION__ "\nFailed to translate address: %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError(__FUNCTION__ "\nFailed to translate address: %X",VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04600000:
|
case 0x04600000:
|
||||||
|
@ -505,7 +505,7 @@ void CMipsMemoryVM::Compile_LW (x86Reg Reg, DWORD VAddr ) {
|
||||||
case 0x04600030: MoveVariableToX86reg(&_Reg->PI_BSD_DOM2_RLS_REG,"PI_BSD_DOM2_RLS_REG",Reg); break;
|
case 0x04600030: MoveVariableToX86reg(&_Reg->PI_BSD_DOM2_RLS_REG,"PI_BSD_DOM2_RLS_REG",Reg); break;
|
||||||
default:
|
default:
|
||||||
MoveConstToX86reg(0,Reg);
|
MoveConstToX86reg(0,Reg);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError(__FUNCTION__ "\nFailed to translate address: %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError(__FUNCTION__ "\nFailed to translate address: %X",VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04700000:
|
case 0x04700000:
|
||||||
|
@ -514,7 +514,7 @@ void CMipsMemoryVM::Compile_LW (x86Reg Reg, DWORD VAddr ) {
|
||||||
case 0x04700010: MoveVariableToX86reg(&_Reg->RI_REFRESH_REG,"RI_REFRESH_REG",Reg); break;
|
case 0x04700010: MoveVariableToX86reg(&_Reg->RI_REFRESH_REG,"RI_REFRESH_REG",Reg); break;
|
||||||
default:
|
default:
|
||||||
MoveConstToX86reg(0,Reg);
|
MoveConstToX86reg(0,Reg);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError(__FUNCTION__ "\nFailed to translate address: %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError(__FUNCTION__ "\nFailed to translate address: %X",VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04800000:
|
case 0x04800000:
|
||||||
|
@ -522,7 +522,7 @@ void CMipsMemoryVM::Compile_LW (x86Reg Reg, DWORD VAddr ) {
|
||||||
case 0x04800018: MoveVariableToX86reg(&_Reg->SI_STATUS_REG,"SI_STATUS_REG",Reg); break;
|
case 0x04800018: MoveVariableToX86reg(&_Reg->SI_STATUS_REG,"SI_STATUS_REG",Reg); break;
|
||||||
default:
|
default:
|
||||||
MoveConstToX86reg(0,Reg);
|
MoveConstToX86reg(0,Reg);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError(__FUNCTION__ "\nFailed to translate address: %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError(__FUNCTION__ "\nFailed to translate address: %X",VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x1FC00000:
|
case 0x1FC00000:
|
||||||
|
@ -533,7 +533,7 @@ void CMipsMemoryVM::Compile_LW (x86Reg Reg, DWORD VAddr ) {
|
||||||
MoveConstToX86reg(((PAddr & 0xFFFF) << 16) | (PAddr & 0xFFFF),Reg);
|
MoveConstToX86reg(((PAddr & 0xFFFF) << 16) | (PAddr & 0xFFFF),Reg);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) {
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) {
|
||||||
CPU_Message(__FUNCTION__ "\nFailed to translate address: %X",VAddr);
|
CPU_Message(__FUNCTION__ "\nFailed to translate address: %X",VAddr);
|
||||||
_Notify->DisplayError(__FUNCTION__ "\nFailed to translate address: %X",VAddr);
|
g_Notify->DisplayError(__FUNCTION__ "\nFailed to translate address: %X",VAddr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -545,7 +545,7 @@ void CMipsMemoryVM::Compile_SB_Const ( BYTE Value, DWORD VAddr ) {
|
||||||
|
|
||||||
if (!TranslateVaddr(VAddr, PAddr)) {
|
if (!TranslateVaddr(VAddr, PAddr)) {
|
||||||
CPU_Message("Compile_SB\nFailed to translate address %X",VAddr);
|
CPU_Message("Compile_SB\nFailed to translate address %X",VAddr);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SB\nFailed to translate address %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SB\nFailed to translate address %X",VAddr); }
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -562,7 +562,7 @@ void CMipsMemoryVM::Compile_SB_Const ( BYTE Value, DWORD VAddr ) {
|
||||||
MoveConstByteToVariable(Value,PAddr + m_RDRAM,VarName);
|
MoveConstByteToVariable(Value,PAddr + m_RDRAM,VarName);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SB_Const\ntrying to store %X in %X?",Value,VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SB_Const\ntrying to store %X in %X?",Value,VAddr); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -572,7 +572,7 @@ void CMipsMemoryVM::Compile_SB_Register ( x86Reg Reg, DWORD VAddr ) {
|
||||||
|
|
||||||
if (!TranslateVaddr(VAddr, PAddr)) {
|
if (!TranslateVaddr(VAddr, PAddr)) {
|
||||||
CPU_Message("Compile_SB\nFailed to translate address %X",VAddr);
|
CPU_Message("Compile_SB\nFailed to translate address %X",VAddr);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SB\nFailed to translate address %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SB\nFailed to translate address %X",VAddr); }
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -589,7 +589,7 @@ void CMipsMemoryVM::Compile_SB_Register ( x86Reg Reg, DWORD VAddr ) {
|
||||||
MoveX86regByteToVariable(Reg,PAddr + m_RDRAM,VarName);
|
MoveX86regByteToVariable(Reg,PAddr + m_RDRAM,VarName);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SB_Register\ntrying to store in %X?",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SB_Register\ntrying to store in %X?",VAddr); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -599,7 +599,7 @@ void CMipsMemoryVM::Compile_SH_Const ( WORD Value, DWORD VAddr ) {
|
||||||
|
|
||||||
if (!TranslateVaddr(VAddr, PAddr)) {
|
if (!TranslateVaddr(VAddr, PAddr)) {
|
||||||
CPU_Message("Compile_SH\nFailed to translate address %X",VAddr);
|
CPU_Message("Compile_SH\nFailed to translate address %X",VAddr);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SH\nFailed to translate address %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SH\nFailed to translate address %X",VAddr); }
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -616,7 +616,7 @@ void CMipsMemoryVM::Compile_SH_Const ( WORD Value, DWORD VAddr ) {
|
||||||
MoveConstHalfToVariable(Value,PAddr + m_RDRAM,VarName);
|
MoveConstHalfToVariable(Value,PAddr + m_RDRAM,VarName);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SH_Const\ntrying to store %X in %X?",Value,VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SH_Const\ntrying to store %X in %X?",Value,VAddr); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -626,7 +626,7 @@ void CMipsMemoryVM::Compile_SH_Register ( x86Reg Reg, DWORD VAddr ) {
|
||||||
|
|
||||||
if (!TranslateVaddr(VAddr, PAddr)) {
|
if (!TranslateVaddr(VAddr, PAddr)) {
|
||||||
CPU_Message("Compile_SH\nFailed to translate address %X",VAddr);
|
CPU_Message("Compile_SH\nFailed to translate address %X",VAddr);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SH\nFailed to translate address %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SH\nFailed to translate address %X",VAddr); }
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -643,7 +643,7 @@ void CMipsMemoryVM::Compile_SH_Register ( x86Reg Reg, DWORD VAddr ) {
|
||||||
MoveX86regHalfToVariable(Reg,PAddr + m_RDRAM,VarName);
|
MoveX86regHalfToVariable(Reg,PAddr + m_RDRAM,VarName);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SH_Register\ntrying to store in %X?",PAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SH_Register\ntrying to store in %X?",PAddr); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -654,7 +654,7 @@ void CMipsMemoryVM::Compile_SW_Const ( DWORD Value, DWORD VAddr ) {
|
||||||
|
|
||||||
if (!TranslateVaddr(VAddr, PAddr)) {
|
if (!TranslateVaddr(VAddr, PAddr)) {
|
||||||
CPU_Message("Compile_SW\nFailed to translate address %X",VAddr);
|
CPU_Message("Compile_SW\nFailed to translate address %X",VAddr);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW\nFailed to translate address %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW\nFailed to translate address %X",VAddr); }
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -689,7 +689,7 @@ void CMipsMemoryVM::Compile_SW_Const ( DWORD Value, DWORD VAddr ) {
|
||||||
case 0x03F8000C: break;
|
case 0x03F8000C: break;
|
||||||
case 0x03F80014: break;
|
case 0x03F80014: break;
|
||||||
default:
|
default:
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04000000:
|
case 0x04000000:
|
||||||
|
@ -771,7 +771,7 @@ void CMipsMemoryVM::Compile_SW_Const ( DWORD Value, DWORD VAddr ) {
|
||||||
case 0x0404001C: MoveConstToVariable(0,&_Reg->SP_SEMAPHORE_REG,"SP_SEMAPHORE_REG"); break;
|
case 0x0404001C: MoveConstToVariable(0,&_Reg->SP_SEMAPHORE_REG,"SP_SEMAPHORE_REG"); break;
|
||||||
case 0x04080000: MoveConstToVariable(Value & 0xFFC,&_Reg->SP_PC_REG,"SP_PC_REG"); break;
|
case 0x04080000: MoveConstToVariable(Value & 0xFFC,&_Reg->SP_PC_REG,"SP_PC_REG"); break;
|
||||||
default:
|
default:
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04300000:
|
case 0x04300000:
|
||||||
|
@ -827,7 +827,7 @@ void CMipsMemoryVM::Compile_SW_Const ( DWORD Value, DWORD VAddr ) {
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04400000:
|
case 0x04400000:
|
||||||
|
@ -879,7 +879,7 @@ void CMipsMemoryVM::Compile_SW_Const ( DWORD Value, DWORD VAddr ) {
|
||||||
case 0x04400030: MoveConstToVariable(Value,&_Reg->VI_X_SCALE_REG,"VI_X_SCALE_REG"); break;
|
case 0x04400030: MoveConstToVariable(Value,&_Reg->VI_X_SCALE_REG,"VI_X_SCALE_REG"); break;
|
||||||
case 0x04400034: MoveConstToVariable(Value,&_Reg->VI_Y_SCALE_REG,"VI_Y_SCALE_REG"); break;
|
case 0x04400034: MoveConstToVariable(Value,&_Reg->VI_Y_SCALE_REG,"VI_Y_SCALE_REG"); break;
|
||||||
default:
|
default:
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04500000: /* AI registers */
|
case 0x04500000: /* AI registers */
|
||||||
|
@ -919,7 +919,7 @@ void CMipsMemoryVM::Compile_SW_Const ( DWORD Value, DWORD VAddr ) {
|
||||||
default:
|
default:
|
||||||
sprintf(VarName,"m_RDRAM + %X",PAddr);
|
sprintf(VarName,"m_RDRAM + %X",PAddr);
|
||||||
MoveConstToVariable(Value,PAddr + m_RDRAM,VarName);
|
MoveConstToVariable(Value,PAddr + m_RDRAM,VarName);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04600000:
|
case 0x04600000:
|
||||||
|
@ -954,7 +954,7 @@ void CMipsMemoryVM::Compile_SW_Const ( DWORD Value, DWORD VAddr ) {
|
||||||
case 0x0460001C: MoveConstToVariable((Value & 0xFF),&_Reg->PI_BSD_DOM1_PGS_REG,"PI_BSD_DOM1_PGS_REG"); break;
|
case 0x0460001C: MoveConstToVariable((Value & 0xFF),&_Reg->PI_BSD_DOM1_PGS_REG,"PI_BSD_DOM1_PGS_REG"); break;
|
||||||
case 0x04600020: MoveConstToVariable((Value & 0xFF),&_Reg->PI_BSD_DOM1_RLS_REG,"PI_BSD_DOM1_RLS_REG"); break;
|
case 0x04600020: MoveConstToVariable((Value & 0xFF),&_Reg->PI_BSD_DOM1_RLS_REG,"PI_BSD_DOM1_RLS_REG"); break;
|
||||||
default:
|
default:
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04700000:
|
case 0x04700000:
|
||||||
|
@ -964,7 +964,7 @@ void CMipsMemoryVM::Compile_SW_Const ( DWORD Value, DWORD VAddr ) {
|
||||||
case 0x04700008: MoveConstToVariable(Value,&_Reg->RI_CURRENT_LOAD_REG,"RI_CURRENT_LOAD_REG"); break;
|
case 0x04700008: MoveConstToVariable(Value,&_Reg->RI_CURRENT_LOAD_REG,"RI_CURRENT_LOAD_REG"); break;
|
||||||
case 0x0470000C: MoveConstToVariable(Value,&_Reg->RI_SELECT_REG,"RI_SELECT_REG"); break;
|
case 0x0470000C: MoveConstToVariable(Value,&_Reg->RI_SELECT_REG,"RI_SELECT_REG"); break;
|
||||||
default:
|
default:
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04800000:
|
case 0x04800000:
|
||||||
|
@ -999,11 +999,11 @@ void CMipsMemoryVM::Compile_SW_Const ( DWORD Value, DWORD VAddr ) {
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Const\ntrying to store %X in %X?",Value,VAddr); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1015,7 +1015,7 @@ void CMipsMemoryVM::Compile_SW_Register (x86Reg Reg, DWORD VAddr )
|
||||||
|
|
||||||
if (!TranslateVaddr(VAddr, PAddr)) {
|
if (!TranslateVaddr(VAddr, PAddr)) {
|
||||||
CPU_Message("Compile_SW_Register\nFailed to translate address %X",VAddr);
|
CPU_Message("Compile_SW_Register\nFailed to translate address %X",VAddr);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Register\nFailed to translate address %X",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Register\nFailed to translate address %X",VAddr); }
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1069,7 +1069,7 @@ void CMipsMemoryVM::Compile_SW_Register (x86Reg Reg, DWORD VAddr )
|
||||||
MoveX86regToVariable(Reg,PAddr + m_RDRAM,VarName);
|
MoveX86regToVariable(Reg,PAddr + m_RDRAM,VarName);
|
||||||
} else {
|
} else {
|
||||||
CPU_Message(" Should be moving %s in to %X ?!?",x86_Name(Reg),VAddr);
|
CPU_Message(" Should be moving %s in to %X ?!?",x86_Name(Reg),VAddr);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Register\ntrying to store at %X?",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Register\ntrying to store at %X?",VAddr); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -1103,7 +1103,7 @@ void CMipsMemoryVM::Compile_SW_Register (x86Reg Reg, DWORD VAddr )
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
CPU_Message(" Should be moving %s in to %X ?!?",x86_Name(Reg),VAddr);
|
CPU_Message(" Should be moving %s in to %X ?!?",x86_Name(Reg),VAddr);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Register\ntrying to store at %X?",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Register\ntrying to store at %X?",VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04400000:
|
case 0x04400000:
|
||||||
|
@ -1159,7 +1159,7 @@ void CMipsMemoryVM::Compile_SW_Register (x86Reg Reg, DWORD VAddr )
|
||||||
case 0x04400034: MoveX86regToVariable(Reg,&_Reg->VI_Y_SCALE_REG,"VI_Y_SCALE_REG"); break;
|
case 0x04400034: MoveX86regToVariable(Reg,&_Reg->VI_Y_SCALE_REG,"VI_Y_SCALE_REG"); break;
|
||||||
default:
|
default:
|
||||||
CPU_Message(" Should be moving %s in to %X ?!?",x86_Name(Reg),VAddr);
|
CPU_Message(" Should be moving %s in to %X ?!?",x86_Name(Reg),VAddr);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Register\ntrying to store at %X?",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Register\ntrying to store at %X?",VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04500000: /* AI registers */
|
case 0x04500000: /* AI registers */
|
||||||
|
@ -1203,7 +1203,7 @@ void CMipsMemoryVM::Compile_SW_Register (x86Reg Reg, DWORD VAddr )
|
||||||
default:
|
default:
|
||||||
sprintf(VarName,"m_RDRAM + %X",PAddr);
|
sprintf(VarName,"m_RDRAM + %X",PAddr);
|
||||||
MoveX86regToVariable(Reg,PAddr + m_RDRAM,VarName);
|
MoveX86regToVariable(Reg,PAddr + m_RDRAM,VarName);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Register\ntrying to store at %X?",VAddr); } }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Register\ntrying to store at %X?",VAddr); } }
|
||||||
break;
|
break;
|
||||||
case 0x04600000:
|
case 0x04600000:
|
||||||
switch (PAddr) {
|
switch (PAddr) {
|
||||||
|
@ -1224,7 +1224,7 @@ void CMipsMemoryVM::Compile_SW_Register (x86Reg Reg, DWORD VAddr )
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
break;
|
break;
|
||||||
case 0x04600010:
|
case 0x04600010:
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Register\ntrying to store at %X?",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Register\ntrying to store at %X?",VAddr); }
|
||||||
AndConstToVariable((DWORD)~MI_INTR_PI,&_Reg->MI_INTR_REG,"MI_INTR_REG");
|
AndConstToVariable((DWORD)~MI_INTR_PI,&_Reg->MI_INTR_REG,"MI_INTR_REG");
|
||||||
BeforeCallDirect(m_RegWorkingSet);
|
BeforeCallDirect(m_RegWorkingSet);
|
||||||
MoveConstToX86reg((DWORD)_Reg,x86_ECX);
|
MoveConstToX86reg((DWORD)_Reg,x86_ECX);
|
||||||
|
@ -1251,14 +1251,14 @@ void CMipsMemoryVM::Compile_SW_Register (x86Reg Reg, DWORD VAddr )
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
CPU_Message(" Should be moving %s in to %X ?!?",x86_Name(Reg),VAddr);
|
CPU_Message(" Should be moving %s in to %X ?!?",x86_Name(Reg),VAddr);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Register\ntrying to store at %X?",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Register\ntrying to store at %X?",VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04700000:
|
case 0x04700000:
|
||||||
switch (PAddr) {
|
switch (PAddr) {
|
||||||
case 0x04700010: MoveX86regToVariable(Reg,&_Reg->RI_REFRESH_REG,"RI_REFRESH_REG"); break;
|
case 0x04700010: MoveX86regToVariable(Reg,&_Reg->RI_REFRESH_REG,"RI_REFRESH_REG"); break;
|
||||||
default:
|
default:
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Register\ntrying to store at %X?",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Register\ntrying to store at %X?",VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x04800000:
|
case 0x04800000:
|
||||||
|
@ -1287,7 +1287,7 @@ void CMipsMemoryVM::Compile_SW_Register (x86Reg Reg, DWORD VAddr )
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Register\ntrying to store at %X?",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Register\ntrying to store at %X?",VAddr); }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x1FC00000:
|
case 0x1FC00000:
|
||||||
|
@ -1296,7 +1296,7 @@ void CMipsMemoryVM::Compile_SW_Register (x86Reg Reg, DWORD VAddr )
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
CPU_Message(" Should be moving %s in to %X ?!?",x86_Name(Reg),VAddr);
|
CPU_Message(" Should be moving %s in to %X ?!?",x86_Name(Reg),VAddr);
|
||||||
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { _Notify->DisplayError("Compile_SW_Register\ntrying to store in %X?",VAddr); }
|
if (_Settings->LoadBool(Debugger_ShowUnhandledMemory)) { g_Notify->DisplayError("Compile_SW_Register\ntrying to store in %X?",VAddr); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1338,7 +1338,7 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
{
|
{
|
||||||
if (dwExptCode != EXCEPTION_ACCESS_VIOLATION)
|
if (dwExptCode != EXCEPTION_ACCESS_VIOLATION)
|
||||||
{
|
{
|
||||||
if (bHaveDebugger()) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (bHaveDebugger()) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
return EXCEPTION_EXECUTE_HANDLER;
|
return EXCEPTION_EXECUTE_HANDLER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1348,7 +1348,7 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
DWORD MemAddress = (char *)lpEP->ExceptionRecord->ExceptionInformation[1] - (char *)_MMU->Rdram();
|
DWORD MemAddress = (char *)lpEP->ExceptionRecord->ExceptionInformation[1] - (char *)_MMU->Rdram();
|
||||||
if ((int)(MemAddress) < 0 || MemAddress > 0x1FFFFFFF)
|
if ((int)(MemAddress) < 0 || MemAddress > 0x1FFFFFFF)
|
||||||
{
|
{
|
||||||
// if (bHaveDebugger()) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
// if (bHaveDebugger()) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
return EXCEPTION_EXECUTE_HANDLER;
|
return EXCEPTION_EXECUTE_HANDLER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1364,7 +1364,7 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
if ((int)Start < 0)
|
if ((int)Start < 0)
|
||||||
{
|
{
|
||||||
if (bHaveDebugger()) {
|
if (bHaveDebugger()) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
return EXCEPTION_EXECUTE_HANDLER;
|
return EXCEPTION_EXECUTE_HANDLER;
|
||||||
}
|
}
|
||||||
|
@ -1390,7 +1390,7 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
_Recompiler->ClearRecompCode_Phys(Start & ~0xFFF,0x1000,CRecompiler::Remove_ProtectedMem);
|
_Recompiler->ClearRecompCode_Phys(Start & ~0xFFF,0x1000,CRecompiler::Remove_ProtectedMem);
|
||||||
return EXCEPTION_CONTINUE_EXECUTION;
|
return EXCEPTION_CONTINUE_EXECUTION;
|
||||||
}
|
}
|
||||||
if (bHaveDebugger()) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (bHaveDebugger()) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
return EXCEPTION_EXECUTE_HANDLER;
|
return EXCEPTION_EXECUTE_HANDLER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1435,7 +1435,7 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
case 6: ReadPos += 1; break;
|
case 6: ReadPos += 1; break;
|
||||||
case 7: ReadPos += 1; break;
|
case 7: ReadPos += 1; break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 5: ReadPos += 5; break;
|
case 5: ReadPos += 5; break;
|
||||||
|
@ -1455,13 +1455,13 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
case 0x86: ReadPos += 5; break;
|
case 0x86: ReadPos += 5; break;
|
||||||
case 0x87: ReadPos += 5; break;
|
case 0x87: ReadPos += 5; break;
|
||||||
default:
|
default:
|
||||||
if (bHaveDebugger()) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (bHaveDebugger()) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
return EXCEPTION_EXECUTE_HANDLER;
|
return EXCEPTION_EXECUTE_HANDLER;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Reg == NULL)
|
if (Reg == NULL)
|
||||||
{
|
{
|
||||||
if (bHaveDebugger()) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (bHaveDebugger()) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
return EXCEPTION_EXECUTE_HANDLER;
|
return EXCEPTION_EXECUTE_HANDLER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1471,7 +1471,7 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
case 0xB6:
|
case 0xB6:
|
||||||
if (!LB_NonMemory(MemAddress,(DWORD *)Reg,FALSE)) {
|
if (!LB_NonMemory(MemAddress,(DWORD *)Reg,FALSE)) {
|
||||||
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
||||||
_Notify->DisplayError("Failed to load byte\n\nMIPS Address: %X\nX86 Address",
|
g_Notify->DisplayError("Failed to load byte\n\nMIPS Address: %X\nX86 Address",
|
||||||
(char *)exRec.ExceptionInformation[1] - (char *)m_RDRAM,
|
(char *)exRec.ExceptionInformation[1] - (char *)m_RDRAM,
|
||||||
*(unsigned char *)lpEP->ContextRecord->Eip);
|
*(unsigned char *)lpEP->ContextRecord->Eip);
|
||||||
}
|
}
|
||||||
|
@ -1481,7 +1481,7 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
case 0xB7:
|
case 0xB7:
|
||||||
if (!LH_NonMemory(MemAddress,(DWORD *)Reg,FALSE)) {
|
if (!LH_NonMemory(MemAddress,(DWORD *)Reg,FALSE)) {
|
||||||
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
||||||
_Notify->DisplayError("Failed to load half word\n\nMIPS Address: %X\nX86 Address",
|
g_Notify->DisplayError("Failed to load half word\n\nMIPS Address: %X\nX86 Address",
|
||||||
(char *)exRec.ExceptionInformation[1] - (char *)m_RDRAM,
|
(char *)exRec.ExceptionInformation[1] - (char *)m_RDRAM,
|
||||||
*(unsigned char *)lpEP->ContextRecord->Eip);
|
*(unsigned char *)lpEP->ContextRecord->Eip);
|
||||||
}
|
}
|
||||||
|
@ -1491,7 +1491,7 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
case 0xBE:
|
case 0xBE:
|
||||||
if (!LB_NonMemory(MemAddress,Reg,TRUE)) {
|
if (!LB_NonMemory(MemAddress,Reg,TRUE)) {
|
||||||
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
||||||
_Notify->DisplayError("Failed to load byte\n\nMIPS Address: %X\nX86 Address",
|
g_Notify->DisplayError("Failed to load byte\n\nMIPS Address: %X\nX86 Address",
|
||||||
(char *)exRec.ExceptionInformation[1] - (char *)m_RDRAM,
|
(char *)exRec.ExceptionInformation[1] - (char *)m_RDRAM,
|
||||||
*(unsigned char *)lpEP->ContextRecord->Eip);
|
*(unsigned char *)lpEP->ContextRecord->Eip);
|
||||||
}
|
}
|
||||||
|
@ -1501,7 +1501,7 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
case 0xBF:
|
case 0xBF:
|
||||||
if (!LH_NonMemory(MemAddress,Reg,TRUE)) {
|
if (!LH_NonMemory(MemAddress,Reg,TRUE)) {
|
||||||
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
||||||
_Notify->DisplayError("Failed to load half word\n\nMIPS Address: %X\nX86 Address",
|
g_Notify->DisplayError("Failed to load half word\n\nMIPS Address: %X\nX86 Address",
|
||||||
(char *)exRec.ExceptionInformation[1] - (char *)m_RDRAM,
|
(char *)exRec.ExceptionInformation[1] - (char *)m_RDRAM,
|
||||||
*(unsigned char *)lpEP->ContextRecord->Eip);
|
*(unsigned char *)lpEP->ContextRecord->Eip);
|
||||||
}
|
}
|
||||||
|
@ -1509,7 +1509,7 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
lpEP->ContextRecord->Eip = (DWORD)ReadPos;
|
lpEP->ContextRecord->Eip = (DWORD)ReadPos;
|
||||||
return EXCEPTION_CONTINUE_EXECUTION;
|
return EXCEPTION_CONTINUE_EXECUTION;
|
||||||
default:
|
default:
|
||||||
if (bHaveDebugger()) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (bHaveDebugger()) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
return EXCEPTION_EXECUTE_HANDLER;
|
return EXCEPTION_EXECUTE_HANDLER;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -1518,7 +1518,7 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
case 0x8B:
|
case 0x8B:
|
||||||
if (!LH_NonMemory(MemAddress,Reg,FALSE)) {
|
if (!LH_NonMemory(MemAddress,Reg,FALSE)) {
|
||||||
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
||||||
_Notify->DisplayError("Failed to half word\n\nMIPS Address: %X\nX86 Address",
|
g_Notify->DisplayError("Failed to half word\n\nMIPS Address: %X\nX86 Address",
|
||||||
(char *)exRec.ExceptionInformation[1] - (char *)m_RDRAM,
|
(char *)exRec.ExceptionInformation[1] - (char *)m_RDRAM,
|
||||||
*(unsigned char *)lpEP->ContextRecord->Eip);
|
*(unsigned char *)lpEP->ContextRecord->Eip);
|
||||||
}
|
}
|
||||||
|
@ -1528,7 +1528,7 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
case 0x89:
|
case 0x89:
|
||||||
if (!SH_NonMemory(MemAddress,*(WORD *)Reg)) {
|
if (!SH_NonMemory(MemAddress,*(WORD *)Reg)) {
|
||||||
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
||||||
_Notify->DisplayError("Failed to store half word\n\nMIPS Address: %X\nX86 Address",MemAddress,
|
g_Notify->DisplayError("Failed to store half word\n\nMIPS Address: %X\nX86 Address",MemAddress,
|
||||||
*(unsigned char *)lpEP->ContextRecord->Eip);
|
*(unsigned char *)lpEP->ContextRecord->Eip);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1537,26 +1537,26 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
case 0xC7:
|
case 0xC7:
|
||||||
if (Reg != &lpEP->ContextRecord->Eax)
|
if (Reg != &lpEP->ContextRecord->Eax)
|
||||||
{
|
{
|
||||||
if (bHaveDebugger()) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (bHaveDebugger()) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
return EXCEPTION_EXECUTE_HANDLER;
|
return EXCEPTION_EXECUTE_HANDLER;
|
||||||
}
|
}
|
||||||
if (!SH_NonMemory(MemAddress,*(WORD *)ReadPos)) {
|
if (!SH_NonMemory(MemAddress,*(WORD *)ReadPos)) {
|
||||||
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
||||||
_Notify->DisplayError("Failed to store half word\n\nMIPS Address: %X\nX86 Address",MemAddress,
|
g_Notify->DisplayError("Failed to store half word\n\nMIPS Address: %X\nX86 Address",MemAddress,
|
||||||
*(unsigned char *)lpEP->ContextRecord->Eip);
|
*(unsigned char *)lpEP->ContextRecord->Eip);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
lpEP->ContextRecord->Eip = (DWORD)(ReadPos + 2);
|
lpEP->ContextRecord->Eip = (DWORD)(ReadPos + 2);
|
||||||
return EXCEPTION_CONTINUE_EXECUTION;
|
return EXCEPTION_CONTINUE_EXECUTION;
|
||||||
default:
|
default:
|
||||||
if (bHaveDebugger()) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (bHaveDebugger()) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
return EXCEPTION_EXECUTE_HANDLER;
|
return EXCEPTION_EXECUTE_HANDLER;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x88:
|
case 0x88:
|
||||||
if (!SB_NonMemory(MemAddress,*(BYTE *)Reg)) {
|
if (!SB_NonMemory(MemAddress,*(BYTE *)Reg)) {
|
||||||
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
||||||
_Notify->DisplayError("Failed to store byte\n\nMIPS Address: %X\nX86 Address",
|
g_Notify->DisplayError("Failed to store byte\n\nMIPS Address: %X\nX86 Address",
|
||||||
(char *)exRec.ExceptionInformation[1] - (char *)m_RDRAM,
|
(char *)exRec.ExceptionInformation[1] - (char *)m_RDRAM,
|
||||||
*(unsigned char *)lpEP->ContextRecord->Eip);
|
*(unsigned char *)lpEP->ContextRecord->Eip);
|
||||||
}
|
}
|
||||||
|
@ -1566,7 +1566,7 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
case 0x8A:
|
case 0x8A:
|
||||||
if (!LB_NonMemory(MemAddress,Reg,FALSE)) {
|
if (!LB_NonMemory(MemAddress,Reg,FALSE)) {
|
||||||
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
||||||
_Notify->DisplayError("Failed to load byte\n\nMIPS Address: %X\nX86 Address",
|
g_Notify->DisplayError("Failed to load byte\n\nMIPS Address: %X\nX86 Address",
|
||||||
(char *)exRec.ExceptionInformation[1] - (char *)m_RDRAM,
|
(char *)exRec.ExceptionInformation[1] - (char *)m_RDRAM,
|
||||||
*(unsigned char *)lpEP->ContextRecord->Eip);
|
*(unsigned char *)lpEP->ContextRecord->Eip);
|
||||||
}
|
}
|
||||||
|
@ -1576,7 +1576,7 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
case 0x8B:
|
case 0x8B:
|
||||||
if (!LW_NonMemory(MemAddress,Reg)) {
|
if (!LW_NonMemory(MemAddress,Reg)) {
|
||||||
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
||||||
_Notify->DisplayError("Failed to load word\n\nMIPS Address: %X\nX86 Address",
|
g_Notify->DisplayError("Failed to load word\n\nMIPS Address: %X\nX86 Address",
|
||||||
(char *)exRec.ExceptionInformation[1] - (char *)m_RDRAM,
|
(char *)exRec.ExceptionInformation[1] - (char *)m_RDRAM,
|
||||||
*(unsigned char *)lpEP->ContextRecord->Eip);
|
*(unsigned char *)lpEP->ContextRecord->Eip);
|
||||||
}
|
}
|
||||||
|
@ -1586,7 +1586,7 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
case 0x89:
|
case 0x89:
|
||||||
if (!SW_NonMemory(MemAddress,*(DWORD *)Reg)) {
|
if (!SW_NonMemory(MemAddress,*(DWORD *)Reg)) {
|
||||||
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
||||||
_Notify->DisplayError("Failed to store word\n\nMIPS Address: %X\nX86 Address",MemAddress,
|
g_Notify->DisplayError("Failed to store word\n\nMIPS Address: %X\nX86 Address",MemAddress,
|
||||||
*(unsigned char *)lpEP->ContextRecord->Eip);
|
*(unsigned char *)lpEP->ContextRecord->Eip);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1595,12 +1595,12 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
case 0xC6:
|
case 0xC6:
|
||||||
if (Reg != &lpEP->ContextRecord->Eax)
|
if (Reg != &lpEP->ContextRecord->Eax)
|
||||||
{
|
{
|
||||||
if (bHaveDebugger()) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (bHaveDebugger()) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
return EXCEPTION_EXECUTE_HANDLER;
|
return EXCEPTION_EXECUTE_HANDLER;
|
||||||
}
|
}
|
||||||
if (!SB_NonMemory(MemAddress,*(BYTE *)ReadPos)) {
|
if (!SB_NonMemory(MemAddress,*(BYTE *)ReadPos)) {
|
||||||
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
||||||
_Notify->DisplayError("Failed to store byte\n\nMIPS Address: %X\nX86 Address",MemAddress,
|
g_Notify->DisplayError("Failed to store byte\n\nMIPS Address: %X\nX86 Address",MemAddress,
|
||||||
*(unsigned char *)lpEP->ContextRecord->Eip);
|
*(unsigned char *)lpEP->ContextRecord->Eip);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1609,22 +1609,22 @@ int CMipsMemoryVM::MemoryFilter( DWORD dwExptCode, void * lpExceptionPointer )
|
||||||
case 0xC7:
|
case 0xC7:
|
||||||
if (Reg != &lpEP->ContextRecord->Eax)
|
if (Reg != &lpEP->ContextRecord->Eax)
|
||||||
{
|
{
|
||||||
if (bHaveDebugger()) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (bHaveDebugger()) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
return EXCEPTION_EXECUTE_HANDLER;
|
return EXCEPTION_EXECUTE_HANDLER;
|
||||||
}
|
}
|
||||||
if (!SW_NonMemory(MemAddress,*(DWORD *)ReadPos)) {
|
if (!SW_NonMemory(MemAddress,*(DWORD *)ReadPos)) {
|
||||||
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
if (_Settings->LoadDword(Debugger_ShowUnhandledMemory)) {
|
||||||
_Notify->DisplayError("Failed to store word\n\nMIPS Address: %X\nX86 Address",MemAddress,
|
g_Notify->DisplayError("Failed to store word\n\nMIPS Address: %X\nX86 Address",MemAddress,
|
||||||
*(unsigned char *)lpEP->ContextRecord->Eip);
|
*(unsigned char *)lpEP->ContextRecord->Eip);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
lpEP->ContextRecord->Eip = (DWORD)(ReadPos + 4);
|
lpEP->ContextRecord->Eip = (DWORD)(ReadPos + 4);
|
||||||
return EXCEPTION_CONTINUE_EXECUTION;
|
return EXCEPTION_CONTINUE_EXECUTION;
|
||||||
default:
|
default:
|
||||||
if (bHaveDebugger()) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (bHaveDebugger()) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
return EXCEPTION_EXECUTE_HANDLER;
|
return EXCEPTION_EXECUTE_HANDLER;
|
||||||
}
|
}
|
||||||
if (bHaveDebugger()) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (bHaveDebugger()) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
return EXCEPTION_EXECUTE_HANDLER;
|
return EXCEPTION_EXECUTE_HANDLER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1635,7 +1635,7 @@ int CMipsMemoryVM::LB_NonMemory ( DWORD PAddr, DWORD * Value, BOOL /*SignExtend*
|
||||||
* Value = 0;
|
* Value = 0;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
if (PAddr >= 0x10000000 && PAddr < 0x16000000) {
|
if (PAddr >= 0x10000000 && PAddr < 0x16000000) {
|
||||||
if (WrittenToRom) { return FALSE; }
|
if (WrittenToRom) { return FALSE; }
|
||||||
|
@ -1670,7 +1670,7 @@ int CMipsMemoryVM::LH_NonMemory ( DWORD PAddr, DWORD * Value, int/* SignExtend*/
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
// switch (PAddr & 0xFFF00000) {
|
// switch (PAddr & 0xFFF00000) {
|
||||||
// default:
|
// default:
|
||||||
* Value = 0;
|
* Value = 0;
|
||||||
|
@ -1879,7 +1879,7 @@ int CMipsMemoryVM::LW_NonMemory ( DWORD PAddr, DWORD * Value ) {
|
||||||
mov ToSwap,eax
|
mov ToSwap,eax
|
||||||
}
|
}
|
||||||
* Value = ToSwap;*/
|
* Value = ToSwap;*/
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
else if (PAddr < 0x1FC00800)
|
else if (PAddr < 0x1FC00800)
|
||||||
|
@ -1897,7 +1897,7 @@ int CMipsMemoryVM::LW_NonMemory ( DWORD PAddr, DWORD * Value ) {
|
||||||
* Value = 0;
|
* Value = 0;
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
*Value = PAddr & 0xFFFF;
|
*Value = PAddr & 0xFFFF;
|
||||||
|
@ -1924,7 +1924,7 @@ int CMipsMemoryVM::SB_NonMemory ( DWORD PAddr, BYTE Value ) {
|
||||||
VirtualProtect(m_RDRAM+(PAddr & ~0xFFF),0xFFC,PAGE_READWRITE, &OldProtect);
|
VirtualProtect(m_RDRAM+(PAddr & ~0xFFF),0xFFC,PAGE_READWRITE, &OldProtect);
|
||||||
*(BYTE *)(m_RDRAM+PAddr) = Value;
|
*(BYTE *)(m_RDRAM+PAddr) = Value;
|
||||||
VirtualProtect(m_RDRAM+(PAddr & ~0xFFF),0xFFC,OldProtect, &OldProtect);
|
VirtualProtect(m_RDRAM+(PAddr & ~0xFFF),0xFFC,OldProtect, &OldProtect);
|
||||||
_Notify->DisplayError("FrameBufferWrite");
|
g_Notify->DisplayError("FrameBufferWrite");
|
||||||
if (FrameBufferWrite) { FrameBufferWrite(PAddr,1); }
|
if (FrameBufferWrite) { FrameBufferWrite(PAddr,1); }
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1962,7 +1962,7 @@ int CMipsMemoryVM::SH_NonMemory ( DWORD PAddr, WORD Value ) {
|
||||||
if (FrameBufferWrite) { FrameBufferWrite(PAddr & ~0xFFF,2); }
|
if (FrameBufferWrite) { FrameBufferWrite(PAddr & ~0xFFF,2); }
|
||||||
//*(WORD *)(m_RDRAM+PAddr) = 0xFFFF;
|
//*(WORD *)(m_RDRAM+PAddr) = 0xFFFF;
|
||||||
//VirtualProtect(m_RDRAM+(PAddr & ~0xFFF),0xFFC,PAGE_NOACCESS, &OldProtect);
|
//VirtualProtect(m_RDRAM+(PAddr & ~0xFFF),0xFFC,PAGE_NOACCESS, &OldProtect);
|
||||||
_Notify->DisplayError("PAddr = %x",PAddr);
|
g_Notify->DisplayError("PAddr = %x",PAddr);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -2013,7 +2013,7 @@ int CMipsMemoryVM::SW_NonMemory ( DWORD PAddr, DWORD Value ) {
|
||||||
VirtualProtect(m_RDRAM+(PAddr & ~0xFFF),0xFFC,PAGE_READWRITE, &OldProtect);
|
VirtualProtect(m_RDRAM+(PAddr & ~0xFFF),0xFFC,PAGE_READWRITE, &OldProtect);
|
||||||
*(DWORD *)(m_RDRAM+PAddr) = Value;
|
*(DWORD *)(m_RDRAM+PAddr) = Value;
|
||||||
VirtualProtect(m_RDRAM+(PAddr & ~0xFFF),0xFFC,OldProtect, &OldProtect);
|
VirtualProtect(m_RDRAM+(PAddr & ~0xFFF),0xFFC,OldProtect, &OldProtect);
|
||||||
_Notify->DisplayError("FrameBufferWrite %X",PAddr);
|
g_Notify->DisplayError("FrameBufferWrite %X",PAddr);
|
||||||
if (FrameBufferWrite) { FrameBufferWrite(PAddr,4); }
|
if (FrameBufferWrite) { FrameBufferWrite(PAddr,4); }
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -2073,7 +2073,7 @@ int CMipsMemoryVM::SW_NonMemory ( DWORD PAddr, DWORD Value ) {
|
||||||
_Reg->CheckInterrupts();
|
_Reg->CheckInterrupts();
|
||||||
}
|
}
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
if ( ( Value & SP_SET_INTR ) != 0) { _Notify->DisplayError("SP_SET_INTR"); }
|
if ( ( Value & SP_SET_INTR ) != 0) { g_Notify->DisplayError("SP_SET_INTR"); }
|
||||||
#endif
|
#endif
|
||||||
if ( ( Value & SP_CLR_SSTEP ) != 0) { _Reg->SP_STATUS_REG &= ~SP_STATUS_SSTEP; }
|
if ( ( Value & SP_CLR_SSTEP ) != 0) { _Reg->SP_STATUS_REG &= ~SP_STATUS_SSTEP; }
|
||||||
if ( ( Value & SP_SET_SSTEP ) != 0) { _Reg->SP_STATUS_REG |= SP_STATUS_SSTEP; }
|
if ( ( Value & SP_SET_SSTEP ) != 0) { _Reg->SP_STATUS_REG |= SP_STATUS_SSTEP; }
|
||||||
|
@ -2106,7 +2106,7 @@ int CMipsMemoryVM::SW_NonMemory ( DWORD PAddr, DWORD Value ) {
|
||||||
try {
|
try {
|
||||||
_System->RunRSP();
|
_System->RunRSP();
|
||||||
} catch (...) {
|
} catch (...) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
//}
|
//}
|
||||||
break;
|
break;
|
||||||
|
@ -2144,17 +2144,17 @@ int CMipsMemoryVM::SW_NonMemory ( DWORD PAddr, DWORD Value ) {
|
||||||
try {
|
try {
|
||||||
_System->RunRSP();
|
_System->RunRSP();
|
||||||
} catch (...) {
|
} catch (...) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
if (ShowUnhandledMemory) {
|
if (ShowUnhandledMemory) {
|
||||||
//if ( ( Value & DPC_CLR_TMEM_CTR ) != 0) { _Notify->DisplayError("RSP: DPC_STATUS_REG: DPC_CLR_TMEM_CTR"); }
|
//if ( ( Value & DPC_CLR_TMEM_CTR ) != 0) { g_Notify->DisplayError("RSP: DPC_STATUS_REG: DPC_CLR_TMEM_CTR"); }
|
||||||
//if ( ( Value & DPC_CLR_PIPE_CTR ) != 0) { _Notify->DisplayError("RSP: DPC_STATUS_REG: DPC_CLR_PIPE_CTR"); }
|
//if ( ( Value & DPC_CLR_PIPE_CTR ) != 0) { g_Notify->DisplayError("RSP: DPC_STATUS_REG: DPC_CLR_PIPE_CTR"); }
|
||||||
//if ( ( Value & DPC_CLR_CMD_CTR ) != 0) { _Notify->DisplayError("RSP: DPC_STATUS_REG: DPC_CLR_CMD_CTR"); }
|
//if ( ( Value & DPC_CLR_CMD_CTR ) != 0) { g_Notify->DisplayError("RSP: DPC_STATUS_REG: DPC_CLR_CMD_CTR"); }
|
||||||
//if ( ( Value & DPC_CLR_CLOCK_CTR ) != 0) { _Notify->DisplayError("RSP: DPC_STATUS_REG: DPC_CLR_CLOCK_CTR"); }
|
//if ( ( Value & DPC_CLR_CLOCK_CTR ) != 0) { g_Notify->DisplayError("RSP: DPC_STATUS_REG: DPC_CLR_CLOCK_CTR"); }
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
|
@ -2283,7 +2283,7 @@ int CMipsMemoryVM::SW_NonMemory ( DWORD PAddr, DWORD Value ) {
|
||||||
PI_DMA_WRITE();
|
PI_DMA_WRITE();
|
||||||
break;
|
break;
|
||||||
case 0x04600010:
|
case 0x04600010:
|
||||||
//if ((Value & PI_SET_RESET) != 0 ) { _Notify->DisplayError("reset Controller"); }
|
//if ((Value & PI_SET_RESET) != 0 ) { g_Notify->DisplayError("reset Controller"); }
|
||||||
if ((Value & PI_CLR_INTR) != 0 ) {
|
if ((Value & PI_CLR_INTR) != 0 ) {
|
||||||
_Reg->MI_INTR_REG &= ~MI_INTR_PI;
|
_Reg->MI_INTR_REG &= ~MI_INTR_PI;
|
||||||
_Reg->CheckInterrupts();
|
_Reg->CheckInterrupts();
|
||||||
|
@ -2384,12 +2384,12 @@ void CMipsMemoryVM::ProtectMemory( DWORD StartVaddr, DWORD EndVaddr )
|
||||||
|
|
||||||
//Get Physical Addresses passed
|
//Get Physical Addresses passed
|
||||||
DWORD StartPAddr, EndPAddr;
|
DWORD StartPAddr, EndPAddr;
|
||||||
if (!TranslateVaddr(StartVaddr,StartPAddr)) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (!TranslateVaddr(StartVaddr,StartPAddr)) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
if (!TranslateVaddr(EndVaddr,EndPAddr)) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (!TranslateVaddr(EndVaddr,EndPAddr)) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
|
|
||||||
//Get Length of memory being protected
|
//Get Length of memory being protected
|
||||||
int Length = ((EndPAddr + 3) - StartPAddr) & ~3;
|
int Length = ((EndPAddr + 3) - StartPAddr) & ~3;
|
||||||
if (Length < 0) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (Length < 0) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
|
|
||||||
//Proect that memory address space
|
//Proect that memory address space
|
||||||
DWORD OldProtect;
|
DWORD OldProtect;
|
||||||
|
@ -2406,12 +2406,12 @@ void CMipsMemoryVM::UnProtectMemory( DWORD StartVaddr, DWORD EndVaddr )
|
||||||
|
|
||||||
//Get Physical Addresses passed
|
//Get Physical Addresses passed
|
||||||
DWORD StartPAddr, EndPAddr;
|
DWORD StartPAddr, EndPAddr;
|
||||||
if (!TranslateVaddr(StartVaddr,StartPAddr)) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (!TranslateVaddr(StartVaddr,StartPAddr)) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
if (!TranslateVaddr(EndVaddr,EndPAddr)) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (!TranslateVaddr(EndVaddr,EndPAddr)) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
|
|
||||||
//Get Length of memory being protected
|
//Get Length of memory being protected
|
||||||
int Length = ((EndPAddr + 3) - StartPAddr) & ~3;
|
int Length = ((EndPAddr + 3) - StartPAddr) & ~3;
|
||||||
if (Length < 0) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (Length < 0) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
|
|
||||||
//Proect that memory address space
|
//Proect that memory address space
|
||||||
DWORD OldProtect;
|
DWORD OldProtect;
|
||||||
|
@ -3558,7 +3558,7 @@ void CMipsMemoryVM::Compile_StoreInstructClean (x86Reg AddressReg, int Length )
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
stdstr_f strLen("%d",Length);
|
stdstr_f strLen("%d",Length);
|
||||||
|
@ -3851,7 +3851,7 @@ void CMipsMemoryVM::RdramChanged ( CMipsMemoryVM * _this )
|
||||||
if (VirtualAlloc(_this->m_RDRAM + 0x400000, 0x400000, MEM_COMMIT, PAGE_READWRITE)==NULL)
|
if (VirtualAlloc(_this->m_RDRAM + 0x400000, 0x400000, MEM_COMMIT, PAGE_READWRITE)==NULL)
|
||||||
{
|
{
|
||||||
WriteTrace(TraceError,"CMipsMemoryVM::RdramChanged: failed to allocate extended memory");
|
WriteTrace(TraceError,"CMipsMemoryVM::RdramChanged: failed to allocate extended memory");
|
||||||
_Notify->FatalError(GS(MSG_MEM_ALLOC_ERROR));
|
g_Notify->FatalError(GS(MSG_MEM_ALLOC_ERROR));
|
||||||
}
|
}
|
||||||
_this->m_AllocatedRdramSize = 0x800000;
|
_this->m_AllocatedRdramSize = 0x800000;
|
||||||
} else {
|
} else {
|
||||||
|
@ -3872,7 +3872,7 @@ void CMipsMemoryVM::ChangeSpStatus (void)
|
||||||
_Reg->CheckInterrupts();
|
_Reg->CheckInterrupts();
|
||||||
}
|
}
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
if ( ( RegModValue & SP_SET_INTR ) != 0) { _Notify->DisplayError("SP_SET_INTR"); }
|
if ( ( RegModValue & SP_SET_INTR ) != 0) { g_Notify->DisplayError("SP_SET_INTR"); }
|
||||||
#endif
|
#endif
|
||||||
if ( ( RegModValue & SP_CLR_SSTEP ) != 0) { _Reg->SP_STATUS_REG &= ~SP_STATUS_SSTEP; }
|
if ( ( RegModValue & SP_CLR_SSTEP ) != 0) { _Reg->SP_STATUS_REG &= ~SP_STATUS_SSTEP; }
|
||||||
if ( ( RegModValue & SP_SET_SSTEP ) != 0) { _Reg->SP_STATUS_REG |= SP_STATUS_SSTEP; }
|
if ( ( RegModValue & SP_SET_SSTEP ) != 0) { _Reg->SP_STATUS_REG |= SP_STATUS_SSTEP; }
|
||||||
|
@ -3906,7 +3906,7 @@ void CMipsMemoryVM::ChangeSpStatus (void)
|
||||||
try {
|
try {
|
||||||
_System->RunRSP();
|
_System->RunRSP();
|
||||||
} catch (...) {
|
} catch (...) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
//}
|
//}
|
||||||
}
|
}
|
||||||
|
|
|
@ -51,7 +51,7 @@ bool COpcodeAnalysis::DelaySlotEffectsCompare (DWORD Reg1, DWORD Reg2) {
|
||||||
case R4300i_SPECIAL_JALR:
|
case R4300i_SPECIAL_JALR:
|
||||||
return true;
|
return true;
|
||||||
default:
|
default:
|
||||||
//_Notify->DisplayError("%s\nDoes %s effect Delay slot at %X?",Name().c_str(),DelayOp.Name().c_str(),DelayOp.PC());
|
//g_Notify->DisplayError("%s\nDoes %s effect Delay slot at %X?",Name().c_str(),DelayOp.Name().c_str(),DelayOp.PC());
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -72,11 +72,11 @@ bool COpcodeAnalysis::DelaySlotEffectsCompare (DWORD Reg1, DWORD Reg2) {
|
||||||
case R4300i_COP0_CO_TLBWR: break;
|
case R4300i_COP0_CO_TLBWR: break;
|
||||||
case R4300i_COP0_CO_TLBP: break;
|
case R4300i_COP0_CO_TLBP: break;
|
||||||
default:
|
default:
|
||||||
//_Notify->DisplayError("%s\nDoes %s effect Delay slot at %X?",Name().c_str(),DelayOp.Name().c_str(),DelayOp.PC());
|
//g_Notify->DisplayError("%s\nDoes %s effect Delay slot at %X?",Name().c_str(),DelayOp.Name().c_str(),DelayOp.PC());
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
//_Notify->DisplayError("%s\nDoes %s effect Delay slot at %X?",Name().c_str(),DelayOp.Name().c_str(),DelayOp.PC());
|
//g_Notify->DisplayError("%s\nDoes %s effect Delay slot at %X?",Name().c_str(),DelayOp.Name().c_str(),DelayOp.PC());
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -97,7 +97,7 @@ bool COpcodeAnalysis::DelaySlotEffectsCompare (DWORD Reg1, DWORD Reg2) {
|
||||||
case R4300i_COP1_W: break;
|
case R4300i_COP1_W: break;
|
||||||
case R4300i_COP1_L: break;
|
case R4300i_COP1_L: break;
|
||||||
default:
|
default:
|
||||||
//_Notify->DisplayError("%s\nDoes %s effect Delay slot at %X?",Name().c_str(),DelayOp.Name().c_str(),DelayOp.PC(),DelayOp.m_opcode.op);
|
//g_Notify->DisplayError("%s\nDoes %s effect Delay slot at %X?",Name().c_str(),DelayOp.Name().c_str(),DelayOp.PC(),DelayOp.m_opcode.op);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -155,7 +155,7 @@ bool COpcodeAnalysis::DelaySlotEffectsCompare (DWORD Reg1, DWORD Reg2) {
|
||||||
case 0x3E:
|
case 0x3E:
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
//_Notify->DisplayError("%s\nDoes %s effect Delay slot at %X?\n%x",Name().c_str(),DelayOp.Name().c_str(),DelayOp.PC(),DelayOp.m_opcode.op);
|
//g_Notify->DisplayError("%s\nDoes %s effect Delay slot at %X?\n%x",Name().c_str(),DelayOp.Name().c_str(),DelayOp.PC(),DelayOp.m_opcode.op);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
@ -458,7 +458,7 @@ stdstr COpcodeAnalysis::FullName(bool * MultipleOps) {
|
||||||
OpParam = stdstr(Param);
|
OpParam = stdstr(Param);
|
||||||
}
|
}
|
||||||
|
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
// if (OpName.length() == 0) { OpName = OpcodeName(); }
|
// if (OpName.length() == 0) { OpName = OpcodeName(); }
|
||||||
// if (OpParam.length() == 0) { OpParam = OpcodeParam(); }
|
// if (OpParam.length() == 0) { OpParam = OpcodeParam(); }
|
||||||
while (OpName.length() < 7) { OpName += " "; }
|
while (OpName.length() < 7) { OpName += " "; }
|
||||||
|
|
|
@ -41,7 +41,7 @@ COpcode::COpcode ( DWORD VirtualAddress ):
|
||||||
//set up the details about the current opcode
|
//set up the details about the current opcode
|
||||||
m_opcode.VirtualAddress = VirtualAddress & ~3;
|
m_opcode.VirtualAddress = VirtualAddress & ~3;
|
||||||
if (!SetPC(m_opcode.VirtualAddress)) {
|
if (!SetPC(m_opcode.VirtualAddress)) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -84,7 +84,7 @@ bool COpcode::Next (void) {
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
m_opcode.VirtualAddress += m_OpLen;
|
m_opcode.VirtualAddress += m_OpLen;
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!_MMU->LW_VAddr(m_opcode.VirtualAddress,m_opcode.Hex)) {
|
if (!_MMU->LW_VAddr(m_opcode.VirtualAddress,m_opcode.Hex)) {
|
||||||
|
|
|
@ -107,7 +107,7 @@ void CPifRam::PifRamRead (void)
|
||||||
CurPos += m_PifRam[CurPos] + (m_PifRam[CurPos + 1] & 0x3F) + 1;
|
CurPos += m_PifRam[CurPos] + (m_PifRam[CurPos + 1] & 0x3F) + 1;
|
||||||
Channel += 1;
|
Channel += 1;
|
||||||
} else {
|
} else {
|
||||||
if (bShowPifRamErrors()) { _Notify->DisplayError("Unknown Command in PifRamRead(%X)",m_PifRam[CurPos]); }
|
if (bShowPifRamErrors()) { g_Notify->DisplayError("Unknown Command in PifRamRead(%X)",m_PifRam[CurPos]); }
|
||||||
CurPos = 0x40;
|
CurPos = 0x40;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -158,7 +158,7 @@ void CPifRam::PifRamWrite (void) {
|
||||||
memset(m_PifRam,0,0x40);
|
memset(m_PifRam,0,0x40);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (bShowPifRamErrors()) { _Notify->DisplayError("Unkown PifRam control: %d",m_PifRam[0x3F]); }
|
if (bShowPifRamErrors()) { g_Notify->DisplayError("Unkown PifRam control: %d",m_PifRam[0x3F]); }
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -185,13 +185,13 @@ void CPifRam::PifRamWrite (void) {
|
||||||
} else {
|
} else {
|
||||||
if (bShowPifRamErrors())
|
if (bShowPifRamErrors())
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("Command on channel 5?");
|
g_Notify->DisplayError("Command on channel 5?");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
CurPos += m_PifRam[CurPos] + (m_PifRam[CurPos + 1] & 0x3F) + 1;
|
CurPos += m_PifRam[CurPos] + (m_PifRam[CurPos + 1] & 0x3F) + 1;
|
||||||
Channel += 1;
|
Channel += 1;
|
||||||
} else {
|
} else {
|
||||||
if (bShowPifRamErrors()) { _Notify->DisplayError("Unknown Command in PifRamWrite(%X)",m_PifRam[CurPos]); }
|
if (bShowPifRamErrors()) { g_Notify->DisplayError("Unknown Command in PifRamWrite(%X)",m_PifRam[CurPos]); }
|
||||||
CurPos = 0x40;
|
CurPos = 0x40;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -211,7 +211,7 @@ void CPifRam::SI_DMA_READ (void)
|
||||||
{
|
{
|
||||||
if (bShowPifRamErrors())
|
if (bShowPifRamErrors())
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("SI DMA\nSI_DRAM_ADDR_REG not in RDRam space");
|
g_Notify->DisplayError("SI DMA\nSI_DRAM_ADDR_REG not in RDRam space");
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -303,7 +303,7 @@ void CPifRam::SI_DMA_WRITE (void)
|
||||||
{
|
{
|
||||||
if (bShowPifRamErrors())
|
if (bShowPifRamErrors())
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("SI DMA\nSI_DRAM_ADDR_REG not in RDRam space");
|
g_Notify->DisplayError("SI DMA\nSI_DRAM_ADDR_REG not in RDRam space");
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -400,8 +400,8 @@ void CPifRam::ProcessControllerCommand ( int Control, BYTE * Command)
|
||||||
if ((Command[1] & 0x80) != 0) { break; }
|
if ((Command[1] & 0x80) != 0) { break; }
|
||||||
if (bShowPifRamErrors())
|
if (bShowPifRamErrors())
|
||||||
{
|
{
|
||||||
if (Command[0] != 1) { _Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
if (Command[0] != 1) { g_Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
||||||
if (Command[1] != 3) { _Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
if (Command[1] != 3) { g_Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
||||||
}
|
}
|
||||||
if (Controllers[Control].Present == TRUE) {
|
if (Controllers[Control].Present == TRUE) {
|
||||||
Command[3] = 0x05;
|
Command[3] = 0x05;
|
||||||
|
@ -419,8 +419,8 @@ void CPifRam::ProcessControllerCommand ( int Control, BYTE * Command)
|
||||||
case 0x01: // read controller
|
case 0x01: // read controller
|
||||||
if (bShowPifRamErrors())
|
if (bShowPifRamErrors())
|
||||||
{
|
{
|
||||||
if (Command[0] != 1) { _Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
if (Command[0] != 1) { g_Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
||||||
if (Command[1] != 4) { _Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
if (Command[1] != 4) { g_Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
||||||
}
|
}
|
||||||
if (Controllers[Control].Present == FALSE) {
|
if (Controllers[Control].Present == FALSE) {
|
||||||
Command[1] |= 0x80;
|
Command[1] |= 0x80;
|
||||||
|
@ -432,8 +432,8 @@ void CPifRam::ProcessControllerCommand ( int Control, BYTE * Command)
|
||||||
#endif
|
#endif
|
||||||
if (bShowPifRamErrors())
|
if (bShowPifRamErrors())
|
||||||
{
|
{
|
||||||
if (Command[0] != 3) { _Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
if (Command[0] != 3) { g_Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
||||||
if (Command[1] != 33) { _Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
if (Command[1] != 33) { g_Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
||||||
}
|
}
|
||||||
if (Controllers[Control].Present == TRUE) {
|
if (Controllers[Control].Present == TRUE) {
|
||||||
DWORD address = ((Command[3] << 8) | Command[4]);
|
DWORD address = ((Command[3] << 8) | Command[4]);
|
||||||
|
@ -462,8 +462,8 @@ void CPifRam::ProcessControllerCommand ( int Control, BYTE * Command)
|
||||||
#endif
|
#endif
|
||||||
if (bShowPifRamErrors())
|
if (bShowPifRamErrors())
|
||||||
{
|
{
|
||||||
if (Command[0] != 35) { _Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
if (Command[0] != 35) { g_Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
||||||
if (Command[1] != 1) { _Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
if (Command[1] != 1) { g_Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
||||||
}
|
}
|
||||||
if (Controllers[Control].Present == TRUE) {
|
if (Controllers[Control].Present == TRUE) {
|
||||||
DWORD address = ((Command[3] << 8) | Command[4]);
|
DWORD address = ((Command[3] << 8) | Command[4]);
|
||||||
|
@ -485,7 +485,7 @@ void CPifRam::ProcessControllerCommand ( int Control, BYTE * Command)
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (bShowPifRamErrors()) { _Notify->DisplayError("Unknown ControllerCommand %d",Command[2]); }
|
if (bShowPifRamErrors()) { g_Notify->DisplayError("Unknown ControllerCommand %d",Command[2]); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -498,8 +498,8 @@ void CPifRam::ReadControllerCommand (int Control, BYTE * Command) {
|
||||||
{
|
{
|
||||||
if (bShowPifRamErrors())
|
if (bShowPifRamErrors())
|
||||||
{
|
{
|
||||||
if (Command[0] != 1) { _Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
if (Command[0] != 1) { g_Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
||||||
if (Command[1] != 4) { _Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
if (Command[1] != 4) { g_Notify->DisplayError("What am I meant to do with this Controller Command"); }
|
||||||
}
|
}
|
||||||
*(DWORD *)&Command[3] = _BaseSystem->GetButtons(Control);
|
*(DWORD *)&Command[3] = _BaseSystem->GetButtons(Control);
|
||||||
}
|
}
|
||||||
|
|
|
@ -296,12 +296,12 @@ void CRegisters::CheckInterrupts ( void )
|
||||||
void CRegisters::DoAddressError ( BOOL DelaySlot, DWORD BadVaddr, BOOL FromRead)
|
void CRegisters::DoAddressError ( BOOL DelaySlot, DWORD BadVaddr, BOOL FromRead)
|
||||||
{
|
{
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("AddressError");
|
g_Notify->DisplayError("AddressError");
|
||||||
if (( STATUS_REGISTER & STATUS_EXL ) != 0 ) {
|
if (( STATUS_REGISTER & STATUS_EXL ) != 0 ) {
|
||||||
_Notify->DisplayError("EXL set in AddressError Exception");
|
g_Notify->DisplayError("EXL set in AddressError Exception");
|
||||||
}
|
}
|
||||||
if (( STATUS_REGISTER & STATUS_ERL ) != 0 ) {
|
if (( STATUS_REGISTER & STATUS_ERL ) != 0 ) {
|
||||||
_Notify->DisplayError("ERL set in AddressError Exception");
|
g_Notify->DisplayError("ERL set in AddressError Exception");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (FromRead) {
|
if (FromRead) {
|
||||||
|
@ -338,10 +338,10 @@ void CRegisters::DoBreakException ( BOOL DelaySlot)
|
||||||
{
|
{
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
if (( STATUS_REGISTER & STATUS_EXL ) != 0 ) {
|
if (( STATUS_REGISTER & STATUS_EXL ) != 0 ) {
|
||||||
_Notify->DisplayError("EXL set in Break Exception");
|
g_Notify->DisplayError("EXL set in Break Exception");
|
||||||
}
|
}
|
||||||
if (( STATUS_REGISTER & STATUS_ERL ) != 0 ) {
|
if (( STATUS_REGISTER & STATUS_ERL ) != 0 ) {
|
||||||
_Notify->DisplayError("ERL set in Break Exception");
|
g_Notify->DisplayError("ERL set in Break Exception");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -360,10 +360,10 @@ void CRegisters::DoCopUnusableException ( BOOL DelaySlot, int Coprocessor )
|
||||||
{
|
{
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
if (( STATUS_REGISTER & STATUS_EXL ) != 0 ) {
|
if (( STATUS_REGISTER & STATUS_EXL ) != 0 ) {
|
||||||
_Notify->DisplayError("EXL set in Break Exception");
|
g_Notify->DisplayError("EXL set in Break Exception");
|
||||||
}
|
}
|
||||||
if (( STATUS_REGISTER & STATUS_ERL ) != 0 ) {
|
if (( STATUS_REGISTER & STATUS_ERL ) != 0 ) {
|
||||||
_Notify->DisplayError("ERL set in Break Exception");
|
g_Notify->DisplayError("ERL set in Break Exception");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -426,7 +426,7 @@ void CRegisters::DoTLBReadMiss ( BOOL DelaySlot, DWORD BadVaddr )
|
||||||
STATUS_REGISTER |= STATUS_EXL;
|
STATUS_REGISTER |= STATUS_EXL;
|
||||||
} else {
|
} else {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("TLBMiss - EXL Set\nBadVaddr = %X\nAddress Defined: %s",BadVaddr,_TLB->AddressDefined(BadVaddr)?"TRUE":"FALSE");
|
g_Notify->DisplayError("TLBMiss - EXL Set\nBadVaddr = %X\nAddress Defined: %s",BadVaddr,_TLB->AddressDefined(BadVaddr)?"TRUE":"FALSE");
|
||||||
#endif
|
#endif
|
||||||
m_PROGRAM_COUNTER = 0x80000180;
|
m_PROGRAM_COUNTER = 0x80000180;
|
||||||
}
|
}
|
||||||
|
@ -436,10 +436,10 @@ void CRegisters::DoSysCallException ( BOOL DelaySlot)
|
||||||
{
|
{
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
if (( STATUS_REGISTER & STATUS_EXL ) != 0 ) {
|
if (( STATUS_REGISTER & STATUS_EXL ) != 0 ) {
|
||||||
_Notify->DisplayError("EXL set in SysCall Exception");
|
g_Notify->DisplayError("EXL set in SysCall Exception");
|
||||||
}
|
}
|
||||||
if (( STATUS_REGISTER & STATUS_ERL ) != 0 ) {
|
if (( STATUS_REGISTER & STATUS_ERL ) != 0 ) {
|
||||||
_Notify->DisplayError("ERL set in SysCall Exception");
|
g_Notify->DisplayError("ERL set in SysCall Exception");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -108,7 +108,7 @@ void CSystemEvents::ExecuteEvents ( void )
|
||||||
ChangePluginFunc();
|
ChangePluginFunc();
|
||||||
break;
|
break;
|
||||||
case SysEvent_ChangingFullScreen:
|
case SysEvent_ChangingFullScreen:
|
||||||
_Notify->ChangeFullScreen();
|
g_Notify->ChangeFullScreen();
|
||||||
break;
|
break;
|
||||||
case SysEvent_GSButtonPressed:
|
case SysEvent_GSButtonPressed:
|
||||||
if (_BaseSystem == NULL)
|
if (_BaseSystem == NULL)
|
||||||
|
@ -174,7 +174,7 @@ void CSystemEvents::ExecuteEvents ( void )
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -187,7 +187,7 @@ void CSystemEvents::ExecuteEvents ( void )
|
||||||
|
|
||||||
void CSystemEvents::ChangePluginFunc ( void )
|
void CSystemEvents::ChangePluginFunc ( void )
|
||||||
{
|
{
|
||||||
_Notify->DisplayMessage(0,MSG_PLUGIN_INIT);
|
g_Notify->DisplayMessage(0,MSG_PLUGIN_INIT);
|
||||||
if (_Settings->LoadBool(Plugin_GFX_Changed))
|
if (_Settings->LoadBool(Plugin_GFX_Changed))
|
||||||
{
|
{
|
||||||
_Plugins->Reset(PLUGIN_TYPE_GFX);
|
_Plugins->Reset(PLUGIN_TYPE_GFX);
|
||||||
|
@ -210,10 +210,10 @@ void CSystemEvents::ChangePluginFunc ( void )
|
||||||
_Settings->SaveBool(Plugin_AUDIO_Changed,false);
|
_Settings->SaveBool(Plugin_AUDIO_Changed,false);
|
||||||
_Settings->SaveBool(Plugin_GFX_Changed, false);
|
_Settings->SaveBool(Plugin_GFX_Changed, false);
|
||||||
_Settings->SaveBool(Plugin_CONT_Changed, false);
|
_Settings->SaveBool(Plugin_CONT_Changed, false);
|
||||||
_Notify->RefreshMenu();
|
g_Notify->RefreshMenu();
|
||||||
if (!_Plugins->Initiate())
|
if (!_Plugins->Initiate())
|
||||||
{
|
{
|
||||||
_Notify->DisplayMessage(5,MSG_PLUGIN_NOT_INIT);
|
g_Notify->DisplayMessage(5,MSG_PLUGIN_NOT_INIT);
|
||||||
_BaseSystem->m_EndEmulation = true;
|
_BaseSystem->m_EndEmulation = true;
|
||||||
}
|
}
|
||||||
_Recompiler->ResetRecompCode();
|
_Recompiler->ResetRecompCode();
|
||||||
|
|
|
@ -26,7 +26,7 @@ void CSystemTimer::SetTimer ( TimerType Type, DWORD Cycles, bool bRelative )
|
||||||
{
|
{
|
||||||
if (Type >= MaxTimer || Type == UnknownTimer)
|
if (Type >= MaxTimer || Type == UnknownTimer)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
UpdateTimers();
|
UpdateTimers();
|
||||||
|
@ -50,7 +50,7 @@ DWORD CSystemTimer::GetTimer ( TimerType Type )
|
||||||
{
|
{
|
||||||
if (Type >= MaxTimer || Type == UnknownTimer)
|
if (Type >= MaxTimer || Type == UnknownTimer)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (!m_TimerDetatils[Type].Active)
|
if (!m_TimerDetatils[Type].Active)
|
||||||
|
@ -73,7 +73,7 @@ void CSystemTimer::StopTimer ( TimerType Type )
|
||||||
{
|
{
|
||||||
if (Type >= MaxTimer || Type == UnknownTimer)
|
if (Type >= MaxTimer || Type == UnknownTimer)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
m_TimerDetatils[Type].Active = false;
|
m_TimerDetatils[Type].Active = false;
|
||||||
|
@ -206,7 +206,7 @@ void CSystemTimer::TimerDone (void)
|
||||||
try {
|
try {
|
||||||
_System->RunRSP();
|
_System->RunRSP();
|
||||||
} catch (...) {
|
} catch (...) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case CSystemTimer::RSPTimerDlist:
|
case CSystemTimer::RSPTimerDlist:
|
||||||
|
@ -219,7 +219,7 @@ void CSystemTimer::TimerDone (void)
|
||||||
_Audio->TimerDone();
|
_Audio->TimerDone();
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
//CheckTimer();
|
//CheckTimer();
|
||||||
/*if (Profiling) {
|
/*if (Profiling) {
|
||||||
|
@ -283,8 +283,8 @@ void CSystemTimer::LoadData ( void * file )
|
||||||
unzReadCurrentFile( file,&TimerDetailsSize,sizeof(TimerDetailsSize));
|
unzReadCurrentFile( file,&TimerDetailsSize,sizeof(TimerDetailsSize));
|
||||||
unzReadCurrentFile( file,&Entries,sizeof(Entries));
|
unzReadCurrentFile( file,&Entries,sizeof(Entries));
|
||||||
|
|
||||||
if (TimerDetailsSize != sizeof(TIMER_DETAILS)) { _Notify->BreakPoint(__FILE__,__LINE__); return; }
|
if (TimerDetailsSize != sizeof(TIMER_DETAILS)) { g_Notify->BreakPoint(__FILE__,__LINE__); return; }
|
||||||
if (Entries != sizeof(m_TimerDetatils)/sizeof(m_TimerDetatils[0])) { _Notify->BreakPoint(__FILE__,__LINE__); return; }
|
if (Entries != sizeof(m_TimerDetatils)/sizeof(m_TimerDetatils[0])) { g_Notify->BreakPoint(__FILE__,__LINE__); return; }
|
||||||
|
|
||||||
unzReadCurrentFile(file,(void *)&m_TimerDetatils,sizeof(m_TimerDetatils));
|
unzReadCurrentFile(file,(void *)&m_TimerDetatils,sizeof(m_TimerDetatils));
|
||||||
unzReadCurrentFile(file,(void *)&m_LastUpdate,sizeof(m_LastUpdate));
|
unzReadCurrentFile(file,(void *)&m_LastUpdate,sizeof(m_LastUpdate));
|
||||||
|
|
|
@ -7,8 +7,8 @@
|
||||||
CN64System::CN64System ( CPlugins * Plugins, bool SavesReadOnly ) :
|
CN64System::CN64System ( CPlugins * Plugins, bool SavesReadOnly ) :
|
||||||
m_MMU_VM(this,SavesReadOnly),
|
m_MMU_VM(this,SavesReadOnly),
|
||||||
m_TLB(this),
|
m_TLB(this),
|
||||||
m_FPS(_Notify),
|
m_FPS(g_Notify),
|
||||||
m_Limitor(_Notify),
|
m_Limitor(g_Notify),
|
||||||
m_Plugins(Plugins),
|
m_Plugins(Plugins),
|
||||||
m_Cheats(NULL),
|
m_Cheats(NULL),
|
||||||
m_SyncCPU(NULL),
|
m_SyncCPU(NULL),
|
||||||
|
@ -133,7 +133,7 @@ void CN64System::ExternalEvent ( SystemEvent action )
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
WriteTraceF(TraceError,"CN64System::ExternalEvent - Unknown event %d",action);
|
WriteTraceF(TraceError,"CN64System::ExternalEvent - Unknown event %d",action);
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -176,7 +176,7 @@ bool CN64System::EmulationStarting ( HANDLE hThread, DWORD ThreadId )
|
||||||
_BaseSystem = NULL;
|
_BaseSystem = NULL;
|
||||||
}
|
}
|
||||||
WriteTrace(TraceDebug,"CN64System::stLoadFileImage: Hide Rom Browser");
|
WriteTrace(TraceDebug,"CN64System::stLoadFileImage: Hide Rom Browser");
|
||||||
_Notify->HideRomBrowser();
|
g_Notify->HideRomBrowser();
|
||||||
WriteTrace(TraceDebug,"CN64System::stLoadFileImage: Creating N64 system");
|
WriteTrace(TraceDebug,"CN64System::stLoadFileImage: Creating N64 system");
|
||||||
_BaseSystem = new CN64System(_Plugins,false);
|
_BaseSystem = new CN64System(_Plugins,false);
|
||||||
WriteTrace(TraceDebug,"CN64System::stLoadFileImage: Setting N64 system as active");
|
WriteTrace(TraceDebug,"CN64System::stLoadFileImage: Setting N64 system as active");
|
||||||
|
@ -186,7 +186,7 @@ bool CN64System::EmulationStarting ( HANDLE hThread, DWORD ThreadId )
|
||||||
_BaseSystem->m_CPU_ThreadID = ThreadId;
|
_BaseSystem->m_CPU_ThreadID = ThreadId;
|
||||||
WriteTrace(TraceDebug,"CN64System::stLoadFileImage: Setting up N64 system done");
|
WriteTrace(TraceDebug,"CN64System::stLoadFileImage: Setting up N64 system done");
|
||||||
_Settings->SaveBool(GameRunning_LoadingInProgress,false);
|
_Settings->SaveBool(GameRunning_LoadingInProgress,false);
|
||||||
_Notify->RefreshMenu();
|
g_Notify->RefreshMenu();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
WriteTrace(TraceDebug,"CN64System::stLoadFileImage: Game set to auto start, starting");
|
WriteTrace(TraceDebug,"CN64System::stLoadFileImage: Game set to auto start, starting");
|
||||||
|
@ -204,9 +204,9 @@ bool CN64System::EmulationStarting ( HANDLE hThread, DWORD ThreadId )
|
||||||
_BaseSystem->m_CPU_ThreadID = 0;
|
_BaseSystem->m_CPU_ThreadID = 0;
|
||||||
} else {
|
} else {
|
||||||
WriteTrace(TraceError,"CN64System::stLoadFileImage: SetActiveSystem failed");
|
WriteTrace(TraceError,"CN64System::stLoadFileImage: SetActiveSystem failed");
|
||||||
_Notify->DisplayError("Failed to Initialize N64 System");
|
g_Notify->DisplayError("Failed to Initialize N64 System");
|
||||||
_Settings->SaveBool(GameRunning_LoadingInProgress,false);
|
_Settings->SaveBool(GameRunning_LoadingInProgress,false);
|
||||||
_Notify->RefreshMenu();
|
g_Notify->RefreshMenu();
|
||||||
bRes = false;
|
bRes = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -234,7 +234,7 @@ void CN64System::stLoadFileImage ( FileImageInfo * Info )
|
||||||
|
|
||||||
//Mark the rom as loading
|
//Mark the rom as loading
|
||||||
_Settings->SaveBool(GameRunning_LoadingInProgress,true);
|
_Settings->SaveBool(GameRunning_LoadingInProgress,true);
|
||||||
_Notify->RefreshMenu();
|
g_Notify->RefreshMenu();
|
||||||
|
|
||||||
//Try to load the passed N64 rom
|
//Try to load the passed N64 rom
|
||||||
if (_Rom == NULL)
|
if (_Rom == NULL)
|
||||||
|
@ -249,21 +249,21 @@ void CN64System::stLoadFileImage ( FileImageInfo * Info )
|
||||||
if (_Rom->LoadN64Image(ImageInfo.FileName.c_str()))
|
if (_Rom->LoadN64Image(ImageInfo.FileName.c_str()))
|
||||||
{
|
{
|
||||||
WriteTrace(TraceDebug,"CN64System::stLoadFileImage: Add Recent Rom");
|
WriteTrace(TraceDebug,"CN64System::stLoadFileImage: Add Recent Rom");
|
||||||
_Notify->AddRecentRom(ImageInfo.FileName.c_str());
|
g_Notify->AddRecentRom(ImageInfo.FileName.c_str());
|
||||||
_Notify->SetWindowCaption(_Settings->LoadString(Game_GoodName).c_str());
|
g_Notify->SetWindowCaption(_Settings->LoadString(Game_GoodName).c_str());
|
||||||
if (_Settings->LoadDword(Setting_AutoStart) != 0)
|
if (_Settings->LoadDword(Setting_AutoStart) != 0)
|
||||||
{
|
{
|
||||||
EmulationStarting(*((HANDLE *)ImageInfo.ThreadHandle),ImageInfo.ThreadID);
|
EmulationStarting(*((HANDLE *)ImageInfo.ThreadHandle),ImageInfo.ThreadID);
|
||||||
}
|
}
|
||||||
_Settings->SaveBool(GameRunning_LoadingInProgress,false);
|
_Settings->SaveBool(GameRunning_LoadingInProgress,false);
|
||||||
_Notify->RefreshMenu();
|
g_Notify->RefreshMenu();
|
||||||
} else {
|
} else {
|
||||||
WriteTraceF(TraceError,"CN64System::stLoadFileImage: LoadN64Image failed (\"%s\")",ImageInfo.FileName.c_str());
|
WriteTraceF(TraceError,"CN64System::stLoadFileImage: LoadN64Image failed (\"%s\")",ImageInfo.FileName.c_str());
|
||||||
_Notify->DisplayError(_Rom->GetError());
|
g_Notify->DisplayError(_Rom->GetError());
|
||||||
delete _Rom;
|
delete _Rom;
|
||||||
_Rom = NULL;
|
_Rom = NULL;
|
||||||
_Settings->SaveBool(GameRunning_LoadingInProgress,false);
|
_Settings->SaveBool(GameRunning_LoadingInProgress,false);
|
||||||
_Notify->RefreshMenu();
|
g_Notify->RefreshMenu();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
CoUninitialize();
|
CoUninitialize();
|
||||||
|
@ -288,31 +288,31 @@ void CN64System::StartEmulation2 ( bool NewThread )
|
||||||
}
|
}
|
||||||
WriteTrace(TraceDebug,"CN64System::StartEmulation2: Starting");
|
WriteTrace(TraceDebug,"CN64System::StartEmulation2: Starting");
|
||||||
|
|
||||||
_Notify->HideRomBrowser();
|
g_Notify->HideRomBrowser();
|
||||||
//RefreshSettings();
|
//RefreshSettings();
|
||||||
|
|
||||||
if (!SetActiveSystem())
|
if (!SetActiveSystem())
|
||||||
{
|
{
|
||||||
_Settings->SaveBool(GameRunning_LoadingInProgress,false);
|
_Settings->SaveBool(GameRunning_LoadingInProgress,false);
|
||||||
_Notify->DisplayError(MSG_PLUGIN_NOT_INIT);
|
g_Notify->DisplayError(MSG_PLUGIN_NOT_INIT);
|
||||||
|
|
||||||
//Set handle to NULL so this thread is not terminated
|
//Set handle to NULL so this thread is not terminated
|
||||||
m_CPU_Handle = NULL;
|
m_CPU_Handle = NULL;
|
||||||
m_CPU_ThreadID = 0;
|
m_CPU_ThreadID = 0;
|
||||||
|
|
||||||
_Notify->RefreshMenu();
|
g_Notify->RefreshMenu();
|
||||||
_Notify->ShowRomBrowser();
|
g_Notify->ShowRomBrowser();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
_Notify->MakeWindowOnTop(_Settings->LoadBool(UserInterface_AlwaysOnTop));
|
g_Notify->MakeWindowOnTop(_Settings->LoadBool(UserInterface_AlwaysOnTop));
|
||||||
if (!_Settings->LoadBool(Beta_IsValidExe))
|
if (!_Settings->LoadBool(Beta_IsValidExe))
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
//mark the emulation as starting and fix up menus
|
//mark the emulation as starting and fix up menus
|
||||||
_Notify->DisplayMessage(5,MSG_EMULATION_STARTED);
|
g_Notify->DisplayMessage(5,MSG_EMULATION_STARTED);
|
||||||
|
|
||||||
if (_Settings->LoadBool(Setting_AutoFullscreen))
|
if (_Settings->LoadBool(Setting_AutoFullscreen))
|
||||||
{
|
{
|
||||||
|
@ -324,7 +324,7 @@ void CN64System::StartEmulation2 ( bool NewThread )
|
||||||
RomIniFile.GetString("Rom Status",stdstr_f("%s.AutoFullScreen", Status.c_str()).c_str(),"true",String,sizeof(String));
|
RomIniFile.GetString("Rom Status",stdstr_f("%s.AutoFullScreen", Status.c_str()).c_str(),"true",String,sizeof(String));
|
||||||
if (_stricmp(String,"true") == 0)
|
if (_stricmp(String,"true") == 0)
|
||||||
{
|
{
|
||||||
_Notify->ChangeFullScreen();
|
g_Notify->ChangeFullScreen();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ExecuteCPU();
|
ExecuteCPU();
|
||||||
|
@ -376,7 +376,7 @@ void CN64System::CloseCpu ( void )
|
||||||
for (int count = 0; count < 200; count ++ )
|
for (int count = 0; count < 200; count ++ )
|
||||||
{
|
{
|
||||||
Sleep(100);
|
Sleep(100);
|
||||||
if (_Notify->ProcessGuiMessages())
|
if (g_Notify->ProcessGuiMessages())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -423,13 +423,13 @@ void CN64System::Pause(void)
|
||||||
}
|
}
|
||||||
ResetEvent(m_hPauseEvent);
|
ResetEvent(m_hPauseEvent);
|
||||||
_Settings->SaveBool(GameRunning_CPU_Paused,true);
|
_Settings->SaveBool(GameRunning_CPU_Paused,true);
|
||||||
_Notify->RefreshMenu();
|
g_Notify->RefreshMenu();
|
||||||
_Notify->DisplayMessage(5,MSG_CPU_PAUSED);
|
g_Notify->DisplayMessage(5,MSG_CPU_PAUSED);
|
||||||
WaitForSingleObject(m_hPauseEvent, INFINITE);
|
WaitForSingleObject(m_hPauseEvent, INFINITE);
|
||||||
ResetEvent(m_hPauseEvent);
|
ResetEvent(m_hPauseEvent);
|
||||||
_Settings->SaveBool(GameRunning_CPU_Paused,(DWORD)false);
|
_Settings->SaveBool(GameRunning_CPU_Paused,(DWORD)false);
|
||||||
_Notify->RefreshMenu();
|
g_Notify->RefreshMenu();
|
||||||
_Notify->DisplayMessage(5,MSG_CPU_RESUMED);
|
g_Notify->DisplayMessage(5,MSG_CPU_RESUMED);
|
||||||
}
|
}
|
||||||
|
|
||||||
stdstr CN64System::ChooseFileToOpen ( WND_HANDLE hParent ) {
|
stdstr CN64System::ChooseFileToOpen ( WND_HANDLE hParent ) {
|
||||||
|
@ -577,7 +577,7 @@ bool CN64System::SetActiveSystem( bool bActive )
|
||||||
if (bInitPlugin)
|
if (bInitPlugin)
|
||||||
{
|
{
|
||||||
WriteTrace(TraceDebug,"CN64System::SetActiveSystem: Reseting Plugins");
|
WriteTrace(TraceDebug,"CN64System::SetActiveSystem: Reseting Plugins");
|
||||||
_Notify->DisplayMessage(5,MSG_PLUGIN_INIT);
|
g_Notify->DisplayMessage(5,MSG_PLUGIN_INIT);
|
||||||
_Plugins->Reset();
|
_Plugins->Reset();
|
||||||
bRes = _Plugins->Initiate();
|
bRes = _Plugins->Initiate();
|
||||||
if (!bRes)
|
if (!bRes)
|
||||||
|
@ -765,10 +765,10 @@ void CN64System::ExecuteCPU ( void )
|
||||||
//reset code
|
//reset code
|
||||||
_Settings->SaveBool(GameRunning_CPU_Running,true);
|
_Settings->SaveBool(GameRunning_CPU_Running,true);
|
||||||
_Settings->SaveBool(GameRunning_CPU_Paused,false);
|
_Settings->SaveBool(GameRunning_CPU_Paused,false);
|
||||||
_Notify->DisplayMessage(5,MSG_EMULATION_STARTED);
|
g_Notify->DisplayMessage(5,MSG_EMULATION_STARTED);
|
||||||
|
|
||||||
m_EndEmulation = false;
|
m_EndEmulation = false;
|
||||||
_Notify->RefreshMenu();
|
g_Notify->RefreshMenu();
|
||||||
|
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
LogOptions.GenerateLog = _Settings->LoadDword(Debugger_GenerateDebugLog);
|
LogOptions.GenerateLog = _Settings->LoadDword(Debugger_GenerateDebugLog);
|
||||||
|
@ -802,7 +802,7 @@ void CN64System::ExecuteRecompiler ()
|
||||||
|
|
||||||
void CN64System::ExecuteSyncCPU ()
|
void CN64System::ExecuteSyncCPU ()
|
||||||
{
|
{
|
||||||
_Notify->DisplayMessage(5,"Copy Plugins");
|
g_Notify->DisplayMessage(5,"Copy Plugins");
|
||||||
_Plugins->CopyPlugins(_Settings->LoadString(Directory_PluginSync));
|
_Plugins->CopyPlugins(_Settings->LoadString(Directory_PluginSync));
|
||||||
CMainGui SyncWindow(false);
|
CMainGui SyncWindow(false);
|
||||||
CPlugins SyncPlugins ( _Settings->LoadString(Directory_PluginSync) );
|
CPlugins SyncPlugins ( _Settings->LoadString(Directory_PluginSync) );
|
||||||
|
@ -818,13 +818,13 @@ void CN64System::ExecuteSyncCPU ()
|
||||||
m_Recomp->Run();
|
m_Recomp->Run();
|
||||||
} else {
|
} else {
|
||||||
SetActiveSystem();
|
SetActiveSystem();
|
||||||
_Notify->DisplayError(MSG_PLUGIN_NOT_INIT);
|
g_Notify->DisplayError(MSG_PLUGIN_NOT_INIT);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CN64System::CpuStopped ( void ) {
|
void CN64System::CpuStopped ( void ) {
|
||||||
_Settings->SaveBool(GameRunning_CPU_Running,(DWORD)false);
|
_Settings->SaveBool(GameRunning_CPU_Running,(DWORD)false);
|
||||||
_Notify->WindowMode();
|
g_Notify->WindowMode();
|
||||||
if (!m_InReset)
|
if (!m_InReset)
|
||||||
{
|
{
|
||||||
CloseCpu();
|
CloseCpu();
|
||||||
|
@ -838,11 +838,11 @@ void CN64System::CpuStopped ( void ) {
|
||||||
m_hPauseEvent = NULL;
|
m_hPauseEvent = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
_Notify->RefreshMenu();
|
g_Notify->RefreshMenu();
|
||||||
_Notify->MakeWindowOnTop(false);
|
g_Notify->MakeWindowOnTop(false);
|
||||||
_Notify->DisplayMessage(5,MSG_EMULATION_ENDED);
|
g_Notify->DisplayMessage(5,MSG_EMULATION_ENDED);
|
||||||
if (_Settings->LoadDword(RomBrowser_Enabled)) {
|
if (_Settings->LoadDword(RomBrowser_Enabled)) {
|
||||||
_Notify->ShowRomBrowser();
|
g_Notify->ShowRomBrowser();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (m_SyncCPU)
|
if (m_SyncCPU)
|
||||||
|
@ -974,7 +974,7 @@ void CN64System::SyncCPU (CN64System * const SecondCPU)
|
||||||
}
|
}
|
||||||
m_LastSuccessSyncPC[0] = m_Reg.m_PROGRAM_COUNTER;
|
m_LastSuccessSyncPC[0] = m_Reg.m_PROGRAM_COUNTER;
|
||||||
// if (PROGRAM_COUNTER == 0x8009BBD8) {
|
// if (PROGRAM_COUNTER == 0x8009BBD8) {
|
||||||
// _Notify->BreakPoint(__FILE__,__LINE__);
|
// g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
// }
|
// }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1152,8 +1152,8 @@ void CN64System::DumpSyncErrors (CN64System * SecondCPU) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
_Notify->DisplayError("Sync Error");
|
g_Notify->DisplayError("Sync Error");
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
// AddEvent(CloseCPU);
|
// AddEvent(CloseCPU);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1249,7 +1249,7 @@ bool CN64System::SaveState(void)
|
||||||
HANDLE hSaveFile = CreateFile(FileName.c_str(),GENERIC_WRITE | GENERIC_READ, FILE_SHARE_READ,
|
HANDLE hSaveFile = CreateFile(FileName.c_str(),GENERIC_WRITE | GENERIC_READ, FILE_SHARE_READ,
|
||||||
NULL,OPEN_ALWAYS,FILE_ATTRIBUTE_NORMAL | FILE_FLAG_RANDOM_ACCESS, NULL);
|
NULL,OPEN_ALWAYS,FILE_ATTRIBUTE_NORMAL | FILE_FLAG_RANDOM_ACCESS, NULL);
|
||||||
if (hSaveFile == INVALID_HANDLE_VALUE) {
|
if (hSaveFile == INVALID_HANDLE_VALUE) {
|
||||||
_Notify->DisplayError(GS(MSG_FAIL_OPEN_SAVE));
|
g_Notify->DisplayError(GS(MSG_FAIL_OPEN_SAVE));
|
||||||
m_Reg.MI_INTR_REG = MiInterReg;
|
m_Reg.MI_INTR_REG = MiInterReg;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1290,8 +1290,8 @@ bool CN64System::SaveState(void)
|
||||||
|
|
||||||
CPath SavedFileName(FileName);
|
CPath SavedFileName(FileName);
|
||||||
|
|
||||||
_Notify->DisplayMessage(5,"%s %s",SaveMessage.c_str(),SavedFileName.GetNameExtension().c_str());
|
g_Notify->DisplayMessage(5,"%s %s",SaveMessage.c_str(),SavedFileName.GetNameExtension().c_str());
|
||||||
_Notify->RefreshMenu();
|
g_Notify->RefreshMenu();
|
||||||
WriteTrace(TraceDebug,"CN64System::SaveState 20");
|
WriteTrace(TraceDebug,"CN64System::SaveState 20");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1434,7 +1434,7 @@ bool CN64System::LoadState(LPCSTR FileName) {
|
||||||
HANDLE hSaveFile = CreateFile(FileNameStr.c_str(),GENERIC_WRITE | GENERIC_READ, FILE_SHARE_READ,NULL,
|
HANDLE hSaveFile = CreateFile(FileNameStr.c_str(),GENERIC_WRITE | GENERIC_READ, FILE_SHARE_READ,NULL,
|
||||||
OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL | FILE_FLAG_RANDOM_ACCESS, NULL);
|
OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL | FILE_FLAG_RANDOM_ACCESS, NULL);
|
||||||
if (hSaveFile == INVALID_HANDLE_VALUE) {
|
if (hSaveFile == INVALID_HANDLE_VALUE) {
|
||||||
_Notify->DisplayMessage(5,"%s %s",GS(MSG_UNABLED_LOAD_STATE),FileNameStr.c_str());
|
g_Notify->DisplayMessage(5,"%s %s",GS(MSG_UNABLED_LOAD_STATE),FileNameStr.c_str());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
SetFilePointer(hSaveFile,0,NULL,FILE_BEGIN);
|
SetFilePointer(hSaveFile,0,NULL,FILE_BEGIN);
|
||||||
|
@ -1526,7 +1526,7 @@ bool CN64System::LoadState(LPCSTR FileName) {
|
||||||
WriteTrace(TraceDebug,"CN64System::LoadState 14");
|
WriteTrace(TraceDebug,"CN64System::LoadState 14");
|
||||||
stdstr LoadMsg = _Lang->GetString(MSG_LOADED_STATE);
|
stdstr LoadMsg = _Lang->GetString(MSG_LOADED_STATE);
|
||||||
WriteTrace(TraceDebug,"CN64System::LoadState 15");
|
WriteTrace(TraceDebug,"CN64System::LoadState 15");
|
||||||
_Notify->DisplayMessage(5,"%s %s",LoadMsg.c_str(),CPath(FileNameStr).GetNameExtension().c_str());
|
g_Notify->DisplayMessage(5,"%s %s",LoadMsg.c_str(),CPath(FileNameStr).GetNameExtension().c_str());
|
||||||
WriteTrace(TraceDebug,"CN64System::LoadState 16");
|
WriteTrace(TraceDebug,"CN64System::LoadState 16");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1560,7 +1560,7 @@ void CN64System::RunRSP ( void ) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (bShowDListAListCount()) {
|
if (bShowDListAListCount()) {
|
||||||
_Notify->DisplayMessage(0,"Dlist: %d Alist: %d Unknown: %d",m_DlistCount,m_AlistCount,m_UnknownCount);
|
g_Notify->DisplayMessage(0,"Dlist: %d Alist: %d Unknown: %d",m_DlistCount,m_AlistCount,m_UnknownCount);
|
||||||
}
|
}
|
||||||
if (bShowCPUPer()) {
|
if (bShowCPUPer()) {
|
||||||
switch (Task) {
|
switch (Task) {
|
||||||
|
@ -1582,7 +1582,7 @@ void CN64System::RunRSP ( void ) {
|
||||||
WriteTrace(TraceRSP, "RunRSP: do cycles - Done");
|
WriteTrace(TraceRSP, "RunRSP: do cycles - Done");
|
||||||
} __except( _MMU->MemoryFilter( GetExceptionCode(), GetExceptionInformation()) ) {
|
} __except( _MMU->MemoryFilter( GetExceptionCode(), GetExceptionInformation()) ) {
|
||||||
WriteTrace(TraceError, "RunRSP: exception generated");
|
WriteTrace(TraceError, "RunRSP: exception generated");
|
||||||
_Notify->FatalError("Unknown memory action\n\nEmulation stop");
|
g_Notify->FatalError("Unknown memory action\n\nEmulation stop");
|
||||||
}
|
}
|
||||||
if (Task == 1 && bDelayDP() && ((m_Reg.m_GfxIntrReg & MI_INTR_DP) != 0))
|
if (Task == 1 && bDelayDP() && ((m_Reg.m_GfxIntrReg & MI_INTR_DP) != 0))
|
||||||
{
|
{
|
||||||
|
@ -1735,7 +1735,7 @@ bool CN64System::WriteToProtectedMemory (DWORD Address, int length)
|
||||||
WriteTraceF(TraceDebug,"WriteToProtectedMemory Addres: %X Len: %d",Address,length);
|
WriteTraceF(TraceDebug,"WriteToProtectedMemory Addres: %X Len: %d",Address,length);
|
||||||
if (m_Recomp)
|
if (m_Recomp)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
return m_Recomp->ClearRecompCode_Phys(Address,length,CRecompiler::Remove_ProtectedMem);
|
return m_Recomp->ClearRecompCode_Phys(Address,length,CRecompiler::Remove_ProtectedMem);
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -47,7 +47,7 @@ bool CN64Rom::AllocateAndLoadN64Image ( const char * FileLoc, bool LoadBootCodeO
|
||||||
}
|
}
|
||||||
|
|
||||||
//Load the n64 rom to the allocated memory
|
//Load the n64 rom to the allocated memory
|
||||||
_Notify->DisplayMessage(5,MSG_LOADING);
|
g_Notify->DisplayMessage(5,MSG_LOADING);
|
||||||
SetFilePointer(hFile,0,0,FILE_BEGIN);
|
SetFilePointer(hFile,0,0,FILE_BEGIN);
|
||||||
|
|
||||||
DWORD count, TotalRead = 0;
|
DWORD count, TotalRead = 0;
|
||||||
|
@ -64,7 +64,7 @@ bool CN64Rom::AllocateAndLoadN64Image ( const char * FileLoc, bool LoadBootCodeO
|
||||||
TotalRead += dwRead;
|
TotalRead += dwRead;
|
||||||
|
|
||||||
//Show Message of how much % wise of the rom has been loaded
|
//Show Message of how much % wise of the rom has been loaded
|
||||||
_Notify->DisplayMessage(0,"%s: %.2f%c",GS(MSG_LOADED),((float)TotalRead/(float)RomFileSize) * 100.0f,'%');
|
g_Notify->DisplayMessage(0,"%s: %.2f%c",GS(MSG_LOADED),((float)TotalRead/(float)RomFileSize) * 100.0f,'%');
|
||||||
}
|
}
|
||||||
dwRead = TotalRead;
|
dwRead = TotalRead;
|
||||||
|
|
||||||
|
@ -80,7 +80,7 @@ bool CN64Rom::AllocateAndLoadN64Image ( const char * FileLoc, bool LoadBootCodeO
|
||||||
m_ROMImage = Image;
|
m_ROMImage = Image;
|
||||||
m_RomFileSize = RomFileSize;
|
m_RomFileSize = RomFileSize;
|
||||||
|
|
||||||
_Notify->DisplayMessage(5,MSG_BYTESWAP);
|
g_Notify->DisplayMessage(5,MSG_BYTESWAP);
|
||||||
ByteSwapRom();
|
ByteSwapRom();
|
||||||
|
|
||||||
//Protect the memory so that it can not be written to.
|
//Protect the memory so that it can not be written to.
|
||||||
|
@ -129,7 +129,7 @@ bool CN64Rom::AllocateAndLoadZipImage ( const char * FileLoc, bool LoadBootCodeO
|
||||||
}
|
}
|
||||||
|
|
||||||
//Load the n64 rom to the allocated memory
|
//Load the n64 rom to the allocated memory
|
||||||
_Notify->DisplayMessage(5,MSG_LOADING);
|
g_Notify->DisplayMessage(5,MSG_LOADING);
|
||||||
memcpy(Image,Test,4);
|
memcpy(Image,Test,4);
|
||||||
|
|
||||||
DWORD dwRead, count, TotalRead = 0;
|
DWORD dwRead, count, TotalRead = 0;
|
||||||
|
@ -147,7 +147,7 @@ bool CN64Rom::AllocateAndLoadZipImage ( const char * FileLoc, bool LoadBootCodeO
|
||||||
TotalRead += dwRead;
|
TotalRead += dwRead;
|
||||||
|
|
||||||
//Show Message of how much % wise of the rom has been loaded
|
//Show Message of how much % wise of the rom has been loaded
|
||||||
_Notify->DisplayMessage(5,"%s: %.2f%c",GS(MSG_LOADED),((float)TotalRead/(float)RomFileSize) * 100.0f,'%');
|
g_Notify->DisplayMessage(5,"%s: %.2f%c",GS(MSG_LOADED),((float)TotalRead/(float)RomFileSize) * 100.0f,'%');
|
||||||
}
|
}
|
||||||
dwRead = TotalRead + 4;
|
dwRead = TotalRead + 4;
|
||||||
|
|
||||||
|
@ -155,7 +155,7 @@ bool CN64Rom::AllocateAndLoadZipImage ( const char * FileLoc, bool LoadBootCodeO
|
||||||
VirtualFree(Image,0,MEM_RELEASE);
|
VirtualFree(Image,0,MEM_RELEASE);
|
||||||
unzCloseCurrentFile(file);
|
unzCloseCurrentFile(file);
|
||||||
SetError(MSG_FAIL_ZIP);
|
SetError(MSG_FAIL_ZIP);
|
||||||
_Notify->DisplayMessage(1,"");
|
g_Notify->DisplayMessage(1,"");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -165,13 +165,13 @@ bool CN64Rom::AllocateAndLoadZipImage ( const char * FileLoc, bool LoadBootCodeO
|
||||||
m_RomFileSize = RomFileSize;
|
m_RomFileSize = RomFileSize;
|
||||||
FoundRom = true;
|
FoundRom = true;
|
||||||
|
|
||||||
_Notify->DisplayMessage(5,MSG_BYTESWAP);
|
g_Notify->DisplayMessage(5,MSG_BYTESWAP);
|
||||||
ByteSwapRom();
|
ByteSwapRom();
|
||||||
|
|
||||||
//Protect the memory so that it can not be written to.
|
//Protect the memory so that it can not be written to.
|
||||||
DWORD OldProtect;
|
DWORD OldProtect;
|
||||||
VirtualProtect(m_ROMImage,m_RomFileSize,PAGE_READONLY,&OldProtect);
|
VirtualProtect(m_ROMImage,m_RomFileSize,PAGE_READONLY,&OldProtect);
|
||||||
_Notify->DisplayMessage(1,"");
|
g_Notify->DisplayMessage(1,"");
|
||||||
}
|
}
|
||||||
unzCloseCurrentFile(file);
|
unzCloseCurrentFile(file);
|
||||||
if (FoundRom == FALSE) {
|
if (FoundRom == FALSE) {
|
||||||
|
@ -209,7 +209,7 @@ void CN64Rom::ByteSwapRom (void) {
|
||||||
break;
|
break;
|
||||||
case 0x80371240: break;
|
case 0x80371240: break;
|
||||||
default:
|
default:
|
||||||
_Notify->DisplayError("ByteSwapRom: %X",m_ROMImage[0]);
|
g_Notify->DisplayError("ByteSwapRom: %X",m_ROMImage[0]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -252,7 +252,7 @@ bool CN64Rom::IsValidRomImage ( BYTE Test[4] ) {
|
||||||
|
|
||||||
void CN64Rom::NotificationCB ( LPCSTR Status, CN64Rom * /*_this*/ )
|
void CN64Rom::NotificationCB ( LPCSTR Status, CN64Rom * /*_this*/ )
|
||||||
{
|
{
|
||||||
_Notify->DisplayMessage(5,"%s",Status);
|
g_Notify->DisplayMessage(5,"%s",Status);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CN64Rom::LoadN64Image ( const char * FileLoc, bool LoadBootCodeOnly ) {
|
bool CN64Rom::LoadN64Image ( const char * FileLoc, bool LoadBootCodeOnly ) {
|
||||||
|
@ -306,7 +306,7 @@ bool CN64Rom::LoadN64Image ( const char * FileLoc, bool LoadBootCodeOnly ) {
|
||||||
}
|
}
|
||||||
|
|
||||||
//Load the n64 rom to the allocated memory
|
//Load the n64 rom to the allocated memory
|
||||||
_Notify->DisplayMessage(5,MSG_LOADING);
|
g_Notify->DisplayMessage(5,MSG_LOADING);
|
||||||
if (!ZipFile.GetFile(i,Image,RomFileSize))
|
if (!ZipFile.GetFile(i,Image,RomFileSize))
|
||||||
{
|
{
|
||||||
VirtualFree(Image,0,MEM_RELEASE);
|
VirtualFree(Image,0,MEM_RELEASE);
|
||||||
|
@ -325,7 +325,7 @@ bool CN64Rom::LoadN64Image ( const char * FileLoc, bool LoadBootCodeOnly ) {
|
||||||
m_ROMImage = Image;
|
m_ROMImage = Image;
|
||||||
m_RomFileSize = RomFileSize;
|
m_RomFileSize = RomFileSize;
|
||||||
|
|
||||||
_Notify->DisplayMessage(5,MSG_BYTESWAP);
|
g_Notify->DisplayMessage(5,MSG_BYTESWAP);
|
||||||
ByteSwapRom();
|
ByteSwapRom();
|
||||||
|
|
||||||
//Protect the memory so that it can not be written to.
|
//Protect the memory so that it can not be written to.
|
||||||
|
|
|
@ -85,7 +85,7 @@ void CProfiling::ShowCPU_Usage (void) {
|
||||||
|
|
||||||
TotalTime = CPU + Alist + Dlist + Idle;
|
TotalTime = CPU + Alist + Dlist + Idle;
|
||||||
|
|
||||||
_Notify->DisplayMessage(0,"r4300i: %0.1f%c GFX: %0.1f%c Alist: %0.1f%c Idle: %0.1f%c",
|
g_Notify->DisplayMessage(0,"r4300i: %0.1f%c GFX: %0.1f%c Alist: %0.1f%c Idle: %0.1f%c",
|
||||||
(float)(((double)CPU / (double)TotalTime) * 100),'%',
|
(float)(((double)CPU / (double)TotalTime) * 100),'%',
|
||||||
(float)(((double)Dlist / (double)TotalTime) * 100),'%',
|
(float)(((double)Dlist / (double)TotalTime) * 100),'%',
|
||||||
(float)(((double)Alist / (double)TotalTime) * 100),'%',
|
(float)(((double)Alist / (double)TotalTime) * 100),'%',
|
||||||
|
|
|
@ -13,7 +13,7 @@ CCodeBlock::CCodeBlock(DWORD VAddrEnter, BYTE * RecompPos) :
|
||||||
CCodeSection * baseSection = new CCodeSection(this, VAddrEnter, 0, false);
|
CCodeSection * baseSection = new CCodeSection(this, VAddrEnter, 0, false);
|
||||||
if (baseSection == NULL)
|
if (baseSection == NULL)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
m_Sections.push_back(baseSection);
|
m_Sections.push_back(baseSection);
|
||||||
baseSection->AddParent(NULL);
|
baseSection->AddParent(NULL);
|
||||||
|
@ -25,7 +25,7 @@ CCodeBlock::CCodeBlock(DWORD VAddrEnter, BYTE * RecompPos) :
|
||||||
m_EnterSection = new CCodeSection(this, VAddrEnter, 1, true);
|
m_EnterSection = new CCodeSection(this, VAddrEnter, 1, true);
|
||||||
if (m_EnterSection == NULL)
|
if (m_EnterSection == NULL)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
baseSection->m_ContinueSection = m_EnterSection;
|
baseSection->m_ContinueSection = m_EnterSection;
|
||||||
|
|
||||||
|
@ -59,7 +59,7 @@ bool CCodeBlock::SetSection ( CCodeSection * & Section, CCodeSection * CurrentSe
|
||||||
{
|
{
|
||||||
if (Section != NULL)
|
if (Section != NULL)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (TargetPC >= ((CurrentPC + 0x1000) & 0xFFFFF000))
|
if (TargetPC >= ((CurrentPC + 0x1000) & 0xFFFFF000))
|
||||||
|
@ -76,7 +76,7 @@ bool CCodeBlock::SetSection ( CCodeSection * & Section, CCodeSection * CurrentSe
|
||||||
{
|
{
|
||||||
if (Section != NULL)
|
if (Section != NULL)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
SectionMap::const_iterator itr = m_SectionMap.find(TargetPC);
|
SectionMap::const_iterator itr = m_SectionMap.find(TargetPC);
|
||||||
if (itr != m_SectionMap.end())
|
if (itr != m_SectionMap.end())
|
||||||
|
@ -91,7 +91,7 @@ bool CCodeBlock::SetSection ( CCodeSection * & Section, CCodeSection * CurrentSe
|
||||||
Section = new CCodeSection(this,TargetPC,m_Sections.size(),LinkAllowed);
|
Section = new CCodeSection(this,TargetPC,m_Sections.size(),LinkAllowed);
|
||||||
if (Section == NULL)
|
if (Section == NULL)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
m_Sections.push_back(Section);
|
m_Sections.push_back(Section);
|
||||||
|
@ -113,11 +113,11 @@ bool CCodeBlock::SetSection ( CCodeSection * & Section, CCodeSection * CurrentSe
|
||||||
}
|
}
|
||||||
if (SplitSection == NULL)
|
if (SplitSection == NULL)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (SplitSection->m_EndPC == (DWORD)-1)
|
if (SplitSection->m_EndPC == (DWORD)-1)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (SplitSection->m_EndPC >= TargetPC)
|
if (SplitSection->m_EndPC >= TargetPC)
|
||||||
{
|
{
|
||||||
|
@ -158,7 +158,7 @@ bool CCodeBlock::CreateBlockLinkage ( CCodeSection * EnterSection )
|
||||||
if (CurrentSection->m_ContinueSection != NULL &&
|
if (CurrentSection->m_ContinueSection != NULL &&
|
||||||
CurrentSection->m_ContinueSection != itr->second)
|
CurrentSection->m_ContinueSection != itr->second)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (CurrentSection->m_ContinueSection == NULL)
|
if (CurrentSection->m_ContinueSection == NULL)
|
||||||
{
|
{
|
||||||
|
@ -190,7 +190,7 @@ bool CCodeBlock::CreateBlockLinkage ( CCodeSection * EnterSection )
|
||||||
CurrentSection->m_EndPC = TestPC;
|
CurrentSection->m_EndPC = TestPC;
|
||||||
if (!AnalyzeInstruction(TestPC, TargetPC, ContinuePC, LikelyBranch, IncludeDelaySlot, EndBlock, PermLoop))
|
if (!AnalyzeInstruction(TestPC, TargetPC, ContinuePC, LikelyBranch, IncludeDelaySlot, EndBlock, PermLoop))
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -204,7 +204,7 @@ bool CCodeBlock::CreateBlockLinkage ( CCodeSection * EnterSection )
|
||||||
{
|
{
|
||||||
if (ContinuePC != (DWORD)-1)
|
if (ContinuePC != (DWORD)-1)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -239,7 +239,7 @@ bool CCodeBlock::CreateBlockLinkage ( CCodeSection * EnterSection )
|
||||||
JumpSection->SetDelaySlot();
|
JumpSection->SetDelaySlot();
|
||||||
SetSection(JumpSection->m_JumpSection,CurrentSection->m_JumpSection,TargetPC,true,TestPC);
|
SetSection(JumpSection->m_JumpSection,CurrentSection->m_JumpSection,TargetPC,true,TestPC);
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (TargetPC != ((DWORD)-1))
|
else if (TargetPC != ((DWORD)-1))
|
||||||
|
@ -276,7 +276,7 @@ bool CCodeBlock::CreateBlockLinkage ( CCodeSection * EnterSection )
|
||||||
}
|
}
|
||||||
if (CurrentSection == NewSection)
|
if (CurrentSection == NewSection)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
CurrentSection = NewSection;
|
CurrentSection = NewSection;
|
||||||
if (CurrentSection->m_JumpSection != NULL ||
|
if (CurrentSection->m_JumpSection != NULL ||
|
||||||
|
@ -304,7 +304,7 @@ bool CCodeBlock::CreateBlockLinkage ( CCodeSection * EnterSection )
|
||||||
}
|
}
|
||||||
if (CurrentSection->m_EndPC == (DWORD)-1)
|
if (CurrentSection->m_EndPC == (DWORD)-1)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -349,7 +349,7 @@ bool CCodeBlock::AnalyzeInstruction ( DWORD PC, DWORD & TargetPC, DWORD & Contin
|
||||||
|
|
||||||
OPCODE Command;
|
OPCODE Command;
|
||||||
if (!_MMU->LW_VAddr(PC, Command.Hex)) {
|
if (!_MMU->LW_VAddr(PC, Command.Hex)) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -387,7 +387,7 @@ bool CCodeBlock::AnalyzeInstruction ( DWORD PC, DWORD & TargetPC, DWORD & Contin
|
||||||
EndBlock = true;
|
EndBlock = true;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -399,11 +399,11 @@ bool CCodeBlock::AnalyzeInstruction ( DWORD PC, DWORD & TargetPC, DWORD & Contin
|
||||||
TargetPC = PC + ((short)Command.offset << 2) + 4;
|
TargetPC = PC + ((short)Command.offset << 2) + 4;
|
||||||
if (TargetPC == PC + 8)
|
if (TargetPC == PC + 8)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (TargetPC == PC)
|
if (TargetPC == PC)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
ContinuePC = PC + 8;
|
ContinuePC = PC + 8;
|
||||||
IncludeDelaySlot = true;
|
IncludeDelaySlot = true;
|
||||||
|
@ -450,7 +450,7 @@ bool CCodeBlock::AnalyzeInstruction ( DWORD PC, DWORD & TargetPC, DWORD & Contin
|
||||||
IncludeDelaySlot = true;
|
IncludeDelaySlot = true;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -519,11 +519,11 @@ bool CCodeBlock::AnalyzeInstruction ( DWORD PC, DWORD & TargetPC, DWORD & Contin
|
||||||
EndBlock = true;
|
EndBlock = true;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -546,7 +546,7 @@ bool CCodeBlock::AnalyzeInstruction ( DWORD PC, DWORD & TargetPC, DWORD & Contin
|
||||||
} else {
|
} else {
|
||||||
if (TargetPC == PC)
|
if (TargetPC == PC)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
ContinuePC = PC + 8;
|
ContinuePC = PC + 8;
|
||||||
IncludeDelaySlot = true;
|
IncludeDelaySlot = true;
|
||||||
|
@ -557,18 +557,18 @@ bool CCodeBlock::AnalyzeInstruction ( DWORD PC, DWORD & TargetPC, DWORD & Contin
|
||||||
TargetPC = PC + ((short)Command.offset << 2) + 4;
|
TargetPC = PC + ((short)Command.offset << 2) + 4;
|
||||||
if (TargetPC == PC)
|
if (TargetPC == PC)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
ContinuePC = PC + 8;
|
ContinuePC = PC + 8;
|
||||||
LikelyBranch = true;
|
LikelyBranch = true;
|
||||||
IncludeDelaySlot = true;
|
IncludeDelaySlot = true;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -619,7 +619,7 @@ bool CCodeBlock::AnalyzeInstruction ( DWORD PC, DWORD & TargetPC, DWORD & Contin
|
||||||
EndBlock = true;
|
EndBlock = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -104,7 +104,7 @@ void CCodeSection::CompileExit ( DWORD JumpPC, DWORD TargetPC, CRegInfo &ExitReg
|
||||||
sprintf(String,"Exit_%d",m_BlockInfo->m_ExitInfo.size());
|
sprintf(String,"Exit_%d",m_BlockInfo->m_ExitInfo.size());
|
||||||
if (x86Jmp == NULL)
|
if (x86Jmp == NULL)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
x86Jmp(String,0);
|
x86Jmp(String,0);
|
||||||
|
@ -158,7 +158,7 @@ void CCodeSection::CompileExit ( DWORD JumpPC, DWORD TargetPC, CRegInfo &ExitReg
|
||||||
{
|
{
|
||||||
if (LookUpMode() == FuncFind_ChangeMemory)
|
if (LookUpMode() == FuncFind_ChangeMemory)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
// BYTE * Jump, * Jump2;
|
// BYTE * Jump, * Jump2;
|
||||||
// if (TargetPC >= 0x80000000 && TargetPC < 0xC0000000) {
|
// if (TargetPC >= 0x80000000 && TargetPC < 0xC0000000) {
|
||||||
// DWORD pAddr = TargetPC & 0x1FFFFFFF;
|
// DWORD pAddr = TargetPC & 0x1FFFFFFF;
|
||||||
|
@ -279,7 +279,7 @@ void CCodeSection::CompileExit ( DWORD JumpPC, DWORD TargetPC, CRegInfo &ExitReg
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case CExitInfo::ExitResetRecompCode:
|
case CExitInfo::ExitResetRecompCode:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
if (m_NextInstruction == JUMP || m_NextInstruction == DELAY_SLOT) {
|
if (m_NextInstruction == JUMP || m_NextInstruction == DELAY_SLOT) {
|
||||||
X86BreakPoint(__FILE__,__LINE__);
|
X86BreakPoint(__FILE__,__LINE__);
|
||||||
|
@ -322,7 +322,7 @@ void CCodeSection::CompileExit ( DWORD JumpPC, DWORD TargetPC, CRegInfo &ExitReg
|
||||||
ExitCodeBlock();
|
ExitCodeBlock();
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->DisplayError("how did you want to exit on reason (%d) ???",reason);
|
g_Notify->DisplayError("how did you want to exit on reason (%d) ???",reason);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -343,7 +343,7 @@ void CCodeSection::GenerateSectionLinkage (void)
|
||||||
|
|
||||||
if ((CompilePC() & 0xFFC) == 0xFFC)
|
if ((CompilePC() & 0xFFC) == 0xFFC)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
//Handle Fall througth
|
//Handle Fall througth
|
||||||
BYTE * Jump = NULL;
|
BYTE * Jump = NULL;
|
||||||
|
@ -576,7 +576,7 @@ void CCodeSection::GenerateSectionLinkage (void)
|
||||||
}
|
}
|
||||||
if (JumpInfo[i]->TargetPC != TargetSection[i]->m_EnterPC)
|
if (JumpInfo[i]->TargetPC != TargetSection[i]->m_EnterPC)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (TargetSection[i]->m_CompiledLocation == NULL)
|
if (TargetSection[i]->m_CompiledLocation == NULL)
|
||||||
{
|
{
|
||||||
|
@ -669,19 +669,19 @@ void CCodeSection::SyncRegState ( const CRegInfo & SyncTo )
|
||||||
case CRegInfo::STATE_CONST_64:
|
case CRegInfo::STATE_CONST_64:
|
||||||
if (GetMipsReg(i) != SyncTo.GetMipsReg(i))
|
if (GetMipsReg(i) != SyncTo.GetMipsReg(i))
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
case CRegInfo::STATE_CONST_32:
|
case CRegInfo::STATE_CONST_32:
|
||||||
if (GetMipsRegLo(i) != SyncTo.GetMipsRegLo(i))
|
if (GetMipsRegLo(i) != SyncTo.GetMipsRegLo(i))
|
||||||
{
|
{
|
||||||
CPU_Message("Value of const is different Reg %d (%s) Value: 0x%08X to 0x%08X",i,CRegName::GPR[i],GetMipsRegLo(i),SyncTo.GetMipsRegLo(i));
|
CPU_Message("Value of const is different Reg %d (%s) Value: 0x%08X to 0x%08X",i,CRegName::GPR[i],GetMipsRegLo(i),SyncTo.GetMipsRegLo(i));
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
default:
|
default:
|
||||||
CPU_Message("Unhandled Reg state %d\nin SyncRegState",GetMipsRegState(i));
|
CPU_Message("Unhandled Reg state %d\nin SyncRegState",GetMipsRegState(i));
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
changed = true;
|
changed = true;
|
||||||
|
@ -726,7 +726,7 @@ void CCodeSection::SyncRegState ( const CRegInfo & SyncTo )
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
CPU_Message("Do something with states in SyncRegState\nSTATE_MAPPED_64\n%d",GetMipsRegState(i));
|
CPU_Message("Do something with states in SyncRegState\nSTATE_MAPPED_64\n%d",GetMipsRegState(i));
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
m_RegWorkingSet.SetMipsRegMapLo(i,Reg);
|
m_RegWorkingSet.SetMipsRegMapLo(i,Reg);
|
||||||
|
@ -764,7 +764,7 @@ void CCodeSection::SyncRegState ( const CRegInfo & SyncTo )
|
||||||
CPU_Message("hi %X\nLo %X",GetMipsRegHi(i),GetMipsRegLo(i));
|
CPU_Message("hi %X\nLo %X",GetMipsRegHi(i),GetMipsRegLo(i));
|
||||||
default:
|
default:
|
||||||
CPU_Message("Do something with states in SyncRegState\nSTATE_MAPPED_32_SIGN\n%d",GetMipsRegState(i));
|
CPU_Message("Do something with states in SyncRegState\nSTATE_MAPPED_32_SIGN\n%d",GetMipsRegState(i));
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
m_RegWorkingSet.SetMipsRegMapLo(i,Reg);
|
m_RegWorkingSet.SetMipsRegMapLo(i,Reg);
|
||||||
m_RegWorkingSet.SetMipsRegState(i, CRegInfo::STATE_MAPPED_32_SIGN);
|
m_RegWorkingSet.SetMipsRegState(i, CRegInfo::STATE_MAPPED_32_SIGN);
|
||||||
|
@ -792,7 +792,7 @@ void CCodeSection::SyncRegState ( const CRegInfo & SyncTo )
|
||||||
m_RegWorkingSet.SetX86Mapped(GetMipsRegMapLo(i),CRegInfo::NotMapped);
|
m_RegWorkingSet.SetX86Mapped(GetMipsRegMapLo(i),CRegInfo::NotMapped);
|
||||||
} else {
|
} else {
|
||||||
CPU_Message("Do something with states in SyncRegState\nSTATE_MAPPED_32_ZERO\n%d",GetMipsRegState(i));
|
CPU_Message("Do something with states in SyncRegState\nSTATE_MAPPED_32_ZERO\n%d",GetMipsRegState(i));
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case CRegInfo::STATE_CONST_32:
|
case CRegInfo::STATE_CONST_32:
|
||||||
|
@ -800,13 +800,13 @@ void CCodeSection::SyncRegState ( const CRegInfo & SyncTo )
|
||||||
{
|
{
|
||||||
CPU_Message("Sign Problems in SyncRegState\nSTATE_MAPPED_32_ZERO");
|
CPU_Message("Sign Problems in SyncRegState\nSTATE_MAPPED_32_ZERO");
|
||||||
CPU_Message("%s: %X",CRegName::GPR[i],GetMipsRegLo_S(i));
|
CPU_Message("%s: %X",CRegName::GPR[i],GetMipsRegLo_S(i));
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
MoveConstToX86reg(GetMipsRegLo(i),Reg);
|
MoveConstToX86reg(GetMipsRegLo(i),Reg);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
CPU_Message("Do something with states in SyncRegState\nSTATE_MAPPED_32_ZERO\n%d",GetMipsRegState(i));
|
CPU_Message("Do something with states in SyncRegState\nSTATE_MAPPED_32_ZERO\n%d",GetMipsRegState(i));
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
m_RegWorkingSet.SetMipsRegMapLo(i,Reg);
|
m_RegWorkingSet.SetMipsRegMapLo(i,Reg);
|
||||||
m_RegWorkingSet.SetMipsRegState(i, SyncTo.GetMipsRegState(i));
|
m_RegWorkingSet.SetMipsRegState(i, SyncTo.GetMipsRegState(i));
|
||||||
|
@ -816,7 +816,7 @@ void CCodeSection::SyncRegState ( const CRegInfo & SyncTo )
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
CPU_Message("%d - %d reg: %s (%d)",SyncTo.GetMipsRegState(i),GetMipsRegState(i),CRegName::GPR[i],i);
|
CPU_Message("%d - %d reg: %s (%d)",SyncTo.GetMipsRegState(i),GetMipsRegState(i),CRegName::GPR[i],i);
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
changed = false;
|
changed = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -874,7 +874,7 @@ void TestFunc ( void )
|
||||||
TestValue += 1;
|
TestValue += 1;
|
||||||
if (TestValue >= 4)
|
if (TestValue >= 4)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}*/
|
}*/
|
||||||
|
|
||||||
|
@ -914,11 +914,11 @@ bool CCodeSection::GenerateX86Code ( DWORD Test )
|
||||||
__try {
|
__try {
|
||||||
if (!_MMU->LW_VAddr(m_CompilePC,m_Opcode.Hex))
|
if (!_MMU->LW_VAddr(m_CompilePC,m_Opcode.Hex))
|
||||||
{
|
{
|
||||||
_Notify->DisplayError(GS(MSG_FAIL_LOAD_WORD));
|
g_Notify->DisplayError(GS(MSG_FAIL_LOAD_WORD));
|
||||||
ExitThread(0);
|
ExitThread(0);
|
||||||
}
|
}
|
||||||
} __except( _MMU->MemoryFilter( GetExceptionCode(), GetExceptionInformation()) ) {
|
} __except( _MMU->MemoryFilter( GetExceptionCode(), GetExceptionInformation()) ) {
|
||||||
_Notify->DisplayError(GS(MSG_UNKNOWN_MEM_ACTION));
|
g_Notify->DisplayError(GS(MSG_UNKNOWN_MEM_ACTION));
|
||||||
ExitThread(0);
|
ExitThread(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1018,7 +1018,7 @@ bool CCodeSection::GenerateX86Code ( DWORD Test )
|
||||||
/* if (m_CompilePC == 0x803245CC && m_NextInstruction == NORMAL)
|
/* if (m_CompilePC == 0x803245CC && m_NextInstruction == NORMAL)
|
||||||
{
|
{
|
||||||
//m_RegWorkingSet.UnMap_AllFPRs();
|
//m_RegWorkingSet.UnMap_AllFPRs();
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
//X86HardBreakPoint();
|
//X86HardBreakPoint();
|
||||||
//X86BreakPoint(__FILE__,__LINE__);
|
//X86BreakPoint(__FILE__,__LINE__);
|
||||||
//m_RegWorkingSet.UnMap_AllFPRs();
|
//m_RegWorkingSet.UnMap_AllFPRs();
|
||||||
|
@ -1273,7 +1273,7 @@ bool CCodeSection::GenerateX86Code ( DWORD Test )
|
||||||
{
|
{
|
||||||
if (m_NextInstruction == DO_DELAY_SLOT)
|
if (m_NextInstruction == DO_DELAY_SLOT)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (m_NextInstruction == NORMAL)
|
if (m_NextInstruction == NORMAL)
|
||||||
{
|
{
|
||||||
|
@ -1319,7 +1319,7 @@ bool CCodeSection::GenerateX86Code ( DWORD Test )
|
||||||
{
|
{
|
||||||
if (m_NextInstruction != NORMAL)
|
if (m_NextInstruction != NORMAL)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
m_CompilePC -= 4;
|
m_CompilePC -= 4;
|
||||||
m_Cont.RegSet = m_RegWorkingSet;
|
m_Cont.RegSet = m_RegWorkingSet;
|
||||||
|
@ -1358,7 +1358,7 @@ void CCodeSection::AddParent(CCodeSection * Parent )
|
||||||
} else if (Parent->m_JumpSection == this) {
|
} else if (Parent->m_JumpSection == this) {
|
||||||
m_RegEnter = Parent->m_Jump.RegSet;
|
m_RegEnter = Parent->m_Jump.RegSet;
|
||||||
} else {
|
} else {
|
||||||
_Notify->DisplayError("How are these sections joined?????");
|
g_Notify->DisplayError("How are these sections joined?????");
|
||||||
}
|
}
|
||||||
m_RegWorkingSet = m_RegEnter;
|
m_RegWorkingSet = m_RegEnter;
|
||||||
} else {
|
} else {
|
||||||
|
@ -1390,7 +1390,7 @@ void CCodeSection::SwitchParent(CCodeSection * OldParent, CCodeSection * NewPare
|
||||||
|
|
||||||
if (!bFoundOldParent)
|
if (!bFoundOldParent)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
m_ParentSection.push_back(NewParent);
|
m_ParentSection.push_back(NewParent);
|
||||||
}
|
}
|
||||||
|
@ -1504,7 +1504,7 @@ void CCodeSection::UnlinkParent( CCodeSection * Parent, bool ContinueSection )
|
||||||
CPU_Message(__FUNCTION__ ": Section %d Parent: %d ContinueSection = %s",m_SectionID,Parent->m_SectionID,ContinueSection?"Yes" :"No");
|
CPU_Message(__FUNCTION__ ": Section %d Parent: %d ContinueSection = %s",m_SectionID,Parent->m_SectionID,ContinueSection?"Yes" :"No");
|
||||||
if (Parent->m_ContinueSection == this && Parent->m_JumpSection == this)
|
if (Parent->m_ContinueSection == this && Parent->m_JumpSection == this)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION_LIST::iterator iter = m_ParentSection.begin();
|
SECTION_LIST::iterator iter = m_ParentSection.begin();
|
||||||
|
@ -1542,7 +1542,7 @@ void CCodeSection::UnlinkParent( CCodeSection * Parent, bool ContinueSection )
|
||||||
{
|
{
|
||||||
if (ParentIter->m_CompiledLocation)
|
if (ParentIter->m_CompiledLocation)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
ParentIter->m_ContinueSection = NULL;
|
ParentIter->m_ContinueSection = NULL;
|
||||||
}
|
}
|
||||||
|
@ -1551,7 +1551,7 @@ void CCodeSection::UnlinkParent( CCodeSection * Parent, bool ContinueSection )
|
||||||
{
|
{
|
||||||
if (ParentIter->m_CompiledLocation)
|
if (ParentIter->m_CompiledLocation)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
ParentIter->m_JumpSection = NULL;
|
ParentIter->m_JumpSection = NULL;
|
||||||
}
|
}
|
||||||
|
@ -1631,7 +1631,7 @@ bool CCodeSection::InheritParentInfo ( void )
|
||||||
CCodeSection * Parent = *(m_ParentSection.begin());
|
CCodeSection * Parent = *(m_ParentSection.begin());
|
||||||
if (Parent->m_CompiledLocation == NULL)
|
if (Parent->m_CompiledLocation == NULL)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
CJumpInfo * JumpInfo = this == Parent->m_ContinueSection ? &Parent->m_Cont : &Parent->m_Jump;
|
CJumpInfo * JumpInfo = this == Parent->m_ContinueSection ? &Parent->m_Cont : &Parent->m_Jump;
|
||||||
|
|
||||||
|
@ -1672,7 +1672,7 @@ bool CCodeSection::InheritParentInfo ( void )
|
||||||
size_t NoOfCompiledParents = ParentList.size();
|
size_t NoOfCompiledParents = ParentList.size();
|
||||||
if (NoOfCompiledParents == 0)
|
if (NoOfCompiledParents == 0)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1705,7 +1705,7 @@ bool CCodeSection::InheritParentInfo ( void )
|
||||||
}
|
}
|
||||||
if (FirstParent != -1)
|
if (FirstParent != -1)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
FirstParent = i;
|
FirstParent = i;
|
||||||
}
|
}
|
||||||
|
@ -1734,7 +1734,7 @@ bool CCodeSection::InheritParentInfo ( void )
|
||||||
UpdateCounters(m_RegWorkingSet,m_EnterPC < JumpInfo->JumpPC,true);
|
UpdateCounters(m_RegWorkingSet,m_EnterPC < JumpInfo->JumpPC,true);
|
||||||
if (JumpInfo->JumpPC == (DWORD)-1)
|
if (JumpInfo->JumpPC == (DWORD)-1)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (m_EnterPC <= JumpInfo->JumpPC)
|
if (m_EnterPC <= JumpInfo->JumpPC)
|
||||||
{
|
{
|
||||||
|
@ -1817,7 +1817,7 @@ bool CCodeSection::InheritParentInfo ( void )
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
CPU_Message("Unknown CPU State(%d) in InheritParentInfo",GetMipsRegState(i2));
|
CPU_Message("Unknown CPU State(%d) in InheritParentInfo",GetMipsRegState(i2));
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (IsConst(i2)) {
|
if (IsConst(i2)) {
|
||||||
|
@ -1832,7 +1832,7 @@ bool CCodeSection::InheritParentInfo ( void )
|
||||||
{
|
{
|
||||||
Map_GPR_32bit(i2,(GetMipsRegLo(i2) & 0x80000000) != 0,i2);
|
Map_GPR_32bit(i2,(GetMipsRegLo(i2) & 0x80000000) != 0,i2);
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case CRegInfo::STATE_MAPPED_32_SIGN:
|
case CRegInfo::STATE_MAPPED_32_SIGN:
|
||||||
|
@ -1840,7 +1840,7 @@ bool CCodeSection::InheritParentInfo ( void )
|
||||||
{
|
{
|
||||||
Map_GPR_32bit(i2,true,i2);
|
Map_GPR_32bit(i2,true,i2);
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case CRegInfo::STATE_UNKNOWN:
|
case CRegInfo::STATE_UNKNOWN:
|
||||||
|
@ -1853,7 +1853,7 @@ bool CCodeSection::InheritParentInfo ( void )
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
CPU_Message("Unknown CPU State(%d) in InheritParentInfo",RegSet->GetMipsRegState(i2));
|
CPU_Message("Unknown CPU State(%d) in InheritParentInfo",RegSet->GetMipsRegState(i2));
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else if (Is32Bit(i2) && GetMipsRegLo(i2) != RegSet->GetMipsRegLo(i2)) {
|
} else if (Is32Bit(i2) && GetMipsRegLo(i2) != RegSet->GetMipsRegLo(i2)) {
|
||||||
|
@ -1928,13 +1928,13 @@ bool CCodeSection::InheritParentInfo ( void )
|
||||||
case CRegInfo::STATE_CONST_32:
|
case CRegInfo::STATE_CONST_32:
|
||||||
if (GetMipsRegLo(i2) != RegSet->GetMipsRegLo(i2))
|
if (GetMipsRegLo(i2) != RegSet->GetMipsRegLo(i2))
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
NeedSync = true;
|
NeedSync = true;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
WriteTraceF(TraceError,"Unhandled Reg state %d\nin InheritParentInfo",GetMipsRegState(i2));
|
WriteTraceF(TraceError,"Unhandled Reg state %d\nin InheritParentInfo",GetMipsRegState(i2));
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (NeedSync == false) { continue; }
|
if (NeedSync == false) { continue; }
|
||||||
|
@ -1958,7 +1958,7 @@ bool CCodeSection::InheritParentInfo ( void )
|
||||||
}
|
}
|
||||||
//if (m_EnterPC == 0x8031CE44 && m_SectionID == 6)
|
//if (m_EnterPC == 0x8031CE44 && m_SectionID == 6)
|
||||||
//{
|
//{
|
||||||
// _Notify->BreakPoint(__FILE__,__LINE__);
|
// g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
//}
|
//}
|
||||||
m_RegWorkingSet = JumpInfo->RegSet;
|
m_RegWorkingSet = JumpInfo->RegSet;
|
||||||
if (m_EnterPC < JumpInfo->JumpPC )
|
if (m_EnterPC < JumpInfo->JumpPC )
|
||||||
|
|
|
@ -20,7 +20,7 @@ bool CFunctionMap::AllocateMemory()
|
||||||
m_FunctionTable = (PCCompiledFunc_TABLE *)VirtualAlloc(NULL,0xFFFFF * sizeof(CCompiledFunc *),MEM_RESERVE|MEM_COMMIT,PAGE_READWRITE);
|
m_FunctionTable = (PCCompiledFunc_TABLE *)VirtualAlloc(NULL,0xFFFFF * sizeof(CCompiledFunc *),MEM_RESERVE|MEM_COMMIT,PAGE_READWRITE);
|
||||||
if (m_FunctionTable == NULL) {
|
if (m_FunctionTable == NULL) {
|
||||||
WriteTrace(TraceError,"CFunctionMap::AllocateMemory: failed to allocate function table");
|
WriteTrace(TraceError,"CFunctionMap::AllocateMemory: failed to allocate function table");
|
||||||
_Notify->FatalError(MSG_MEM_ALLOC_ERROR);
|
g_Notify->FatalError(MSG_MEM_ALLOC_ERROR);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
memset(m_FunctionTable,0,0xFFFFF * sizeof(CCompiledFunc *));
|
memset(m_FunctionTable,0,0xFFFFF * sizeof(CCompiledFunc *));
|
||||||
|
@ -31,7 +31,7 @@ bool CFunctionMap::AllocateMemory()
|
||||||
m_JumpTable = new PCCompiledFunc[_MMU->RdramSize() >> 2];
|
m_JumpTable = new PCCompiledFunc[_MMU->RdramSize() >> 2];
|
||||||
if (m_JumpTable == NULL) {
|
if (m_JumpTable == NULL) {
|
||||||
WriteTrace(TraceError,"CFunctionMap::AllocateMemory: failed to allocate jump table");
|
WriteTrace(TraceError,"CFunctionMap::AllocateMemory: failed to allocate jump table");
|
||||||
_Notify->FatalError(MSG_MEM_ALLOC_ERROR);
|
g_Notify->FatalError(MSG_MEM_ALLOC_ERROR);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
memset(m_JumpTable,0,(_MMU->RdramSize() >> 2) * sizeof(PCCompiledFunc));
|
memset(m_JumpTable,0,(_MMU->RdramSize() >> 2) * sizeof(PCCompiledFunc));
|
||||||
|
@ -165,7 +165,7 @@ void CFunctionMap::Reset( bool AllocateMemory )
|
||||||
{
|
{
|
||||||
m_FunctionTable = (CCompiledFunc *)VirtualAlloc(NULL,0xFFFFF * sizeof(CCompiledFunc *),MEM_RESERVE|MEM_COMMIT,PAGE_READWRITE);
|
m_FunctionTable = (CCompiledFunc *)VirtualAlloc(NULL,0xFFFFF * sizeof(CCompiledFunc *),MEM_RESERVE|MEM_COMMIT,PAGE_READWRITE);
|
||||||
if (m_FunctionTable == NULL) {
|
if (m_FunctionTable == NULL) {
|
||||||
_Notify->FatalError(MSG_MEM_ALLOC_ERROR);
|
g_Notify->FatalError(MSG_MEM_ALLOC_ERROR);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
memset(m_FunctionTable,0,0xFFFFF * sizeof(DWORD));
|
memset(m_FunctionTable,0,0xFFFFF * sizeof(DWORD));
|
||||||
|
@ -181,7 +181,7 @@ CCompiledFunc * CFunctionMap::AddFunctionInfo( DWORD vAddr, DWORD pAddr )
|
||||||
table = new PCCompiledFunc[(0x1000 >> 2)];
|
table = new PCCompiledFunc[(0x1000 >> 2)];
|
||||||
if (table == NULL)
|
if (table == NULL)
|
||||||
{
|
{
|
||||||
_Notify->FatalError(MSG_MEM_ALLOC_ERROR);
|
g_Notify->FatalError(MSG_MEM_ALLOC_ERROR);
|
||||||
}
|
}
|
||||||
memset(table,0,sizeof(PCCompiledFunc) * (0x1000 >> 2));
|
memset(table,0,sizeof(PCCompiledFunc) * (0x1000 >> 2));
|
||||||
}
|
}
|
||||||
|
@ -219,7 +219,7 @@ void CFunctionMap::Remove(CCompiledFunc * info)
|
||||||
delete info;
|
delete info;
|
||||||
table[(vAddr & 0xFFF) >> 2] = NULL;
|
table[(vAddr & 0xFFF) >> 2] = NULL;
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
*/
|
*/
|
|
@ -60,7 +60,7 @@ bool LoopAnalysis::SetupEnterSection ( CCodeSection * Section, bool & bChanged,
|
||||||
{
|
{
|
||||||
bChanged = false;
|
bChanged = false;
|
||||||
bSkipedSection = false;
|
bSkipedSection = false;
|
||||||
if (Section->m_ParentSection.empty()) { _Notify->BreakPoint(__FILE__,__LINE__); return true; }
|
if (Section->m_ParentSection.empty()) { g_Notify->BreakPoint(__FILE__,__LINE__); return true; }
|
||||||
|
|
||||||
CPU_Message(__FUNCTION__ ": Block EnterPC: %X Section ID %d Test: %X Section Test: %X CompiledLocation: %X",m_BlockInfo->VAddrEnter(),Section->m_SectionID,m_Test,Section->m_Test, Section->m_CompiledLocation);
|
CPU_Message(__FUNCTION__ ": Block EnterPC: %X Section ID %d Test: %X Section Test: %X CompiledLocation: %X",m_BlockInfo->VAddrEnter(),Section->m_SectionID,m_Test,Section->m_Test, Section->m_CompiledLocation);
|
||||||
|
|
||||||
|
@ -106,7 +106,7 @@ bool LoopAnalysis::SetupEnterSection ( CCodeSection * Section, bool & bChanged,
|
||||||
|
|
||||||
if (bFirstParent)
|
if (bFirstParent)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
RegisterMap::iterator itr = m_EnterRegisters.find(Section->m_SectionID);
|
RegisterMap::iterator itr = m_EnterRegisters.find(Section->m_SectionID);
|
||||||
|
@ -157,7 +157,7 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
do {
|
do {
|
||||||
if (!_MMU->LW_VAddr(m_PC, m_Command.Hex))
|
if (!_MMU->LW_VAddr(m_PC, m_Command.Hex))
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
CPU_Message(" %08X: %s",m_PC,R4300iOpcodeName(m_Command.Hex,m_PC));
|
CPU_Message(" %08X: %s",m_PC,R4300iOpcodeName(m_Command.Hex,m_PC));
|
||||||
|
@ -211,10 +211,10 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
case R4300i_SPECIAL_DSRL32: SPECIAL_DSRL32(); break;
|
case R4300i_SPECIAL_DSRL32: SPECIAL_DSRL32(); break;
|
||||||
case R4300i_SPECIAL_DSRA32: SPECIAL_DSRA32(); break;
|
case R4300i_SPECIAL_DSRA32: SPECIAL_DSRA32(); break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
if (m_Command.Hex == 0x00000001) { break; }
|
if (m_Command.Hex == 0x00000001) { break; }
|
||||||
_Notify->DisplayError("Unhandled R4300i OpCode in FillSectionInfo 5\n%s",
|
g_Notify->DisplayError("Unhandled R4300i OpCode in FillSectionInfo 5\n%s",
|
||||||
R4300iOpcodeName(m_Command.Hex,m_PC));
|
R4300iOpcodeName(m_Command.Hex,m_PC));
|
||||||
#endif
|
#endif
|
||||||
m_NextInstruction = END_BLOCK;
|
m_NextInstruction = END_BLOCK;
|
||||||
|
@ -231,19 +231,19 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
Section->m_ContinueSection != NULL &&
|
Section->m_ContinueSection != NULL &&
|
||||||
Section->m_Cont.TargetPC != (DWORD)-1)
|
Section->m_Cont.TargetPC != (DWORD)-1)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (Section->m_Jump.TargetPC != m_PC + ((short)m_Command.offset << 2) + 4 &&
|
if (Section->m_Jump.TargetPC != m_PC + ((short)m_Command.offset << 2) + 4 &&
|
||||||
Section->m_JumpSection != NULL &&
|
Section->m_JumpSection != NULL &&
|
||||||
Section->m_Jump.TargetPC != (DWORD)-1)
|
Section->m_Jump.TargetPC != (DWORD)-1)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (m_PC == Section->m_Jump.TargetPC)
|
if (m_PC == Section->m_Jump.TargetPC)
|
||||||
{
|
{
|
||||||
if (!DelaySlotEffectsCompare(m_PC,m_Command.rs,0) && !Section->m_Jump.PermLoop)
|
if (!DelaySlotEffectsCompare(m_PC,m_Command.rs,0) && !Section->m_Jump.PermLoop)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -256,27 +256,27 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
Section->m_ContinueSection != NULL &&
|
Section->m_ContinueSection != NULL &&
|
||||||
Section->m_Cont.TargetPC != (DWORD)-1)
|
Section->m_Cont.TargetPC != (DWORD)-1)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (Section->m_Jump.TargetPC != m_PC + 4)
|
if (Section->m_Jump.TargetPC != m_PC + 4)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
/*if (Section->m_Jump.TargetPC != m_PC + ((short)m_Command.offset << 2) + 4)
|
/*if (Section->m_Jump.TargetPC != m_PC + ((short)m_Command.offset << 2) + 4)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}*/
|
}*/
|
||||||
if (m_PC == m_PC + ((short)m_Command.offset << 2) + 4)
|
if (m_PC == m_PC + ((short)m_Command.offset << 2) + 4)
|
||||||
{
|
{
|
||||||
if (!DelaySlotEffectsCompare(m_PC,m_Command.rs,0) && !Section->m_Jump.PermLoop)
|
if (!DelaySlotEffectsCompare(m_PC,m_Command.rs,0) && !Section->m_Jump.PermLoop)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
case R4300i_REGIMM_BLTZAL:
|
case R4300i_REGIMM_BLTZAL:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
m_Reg.GetMipsRegLo(31) = m_PC + 8;
|
m_Reg.GetMipsRegLo(31) = m_PC + 8;
|
||||||
m_Reg.SetMipsRegState(31,CRegInfo::STATE_CONST_32);
|
m_Reg.SetMipsRegState(31,CRegInfo::STATE_CONST_32);
|
||||||
|
@ -290,7 +290,7 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
case R4300i_REGIMM_BGEZAL:
|
case R4300i_REGIMM_BGEZAL:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
m_NextInstruction = DELAY_SLOT;
|
m_NextInstruction = DELAY_SLOT;
|
||||||
if (m_Reg.IsConst(m_Command.rs))
|
if (m_Reg.IsConst(m_Command.rs))
|
||||||
|
@ -328,10 +328,10 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
if (m_Command.Hex == 0x0407000D) { break; }
|
if (m_Command.Hex == 0x0407000D) { break; }
|
||||||
_Notify->DisplayError("Unhandled R4300i OpCode in FillSectionInfo 4\n%s",
|
g_Notify->DisplayError("Unhandled R4300i OpCode in FillSectionInfo 4\n%s",
|
||||||
R4300iOpcodeName(m_Command.Hex,m_PC));
|
R4300iOpcodeName(m_Command.Hex,m_PC));
|
||||||
m_NextInstruction = END_BLOCK;
|
m_NextInstruction = END_BLOCK;
|
||||||
m_PC -= 4;
|
m_PC -= 4;
|
||||||
|
@ -339,7 +339,7 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case R4300i_JAL:
|
case R4300i_JAL:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
m_NextInstruction = DELAY_SLOT;
|
m_NextInstruction = DELAY_SLOT;
|
||||||
m_Reg.GetMipsRegLo(31) = m_PC + 8;
|
m_Reg.GetMipsRegLo(31) = m_PC + 8;
|
||||||
|
@ -357,11 +357,11 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
#ifdef CHECKED_BUILD
|
#ifdef CHECKED_BUILD
|
||||||
if (Section->m_Jump.TargetPC != (m_PC & 0xF0000000) + (m_Command.target << 2))
|
if (Section->m_Jump.TargetPC != (m_PC & 0xF0000000) + (m_Command.target << 2))
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (m_PC == Section->m_Jump.TargetPC && !Section->m_Jump.PermLoop)
|
if (m_PC == Section->m_Jump.TargetPC && !Section->m_Jump.PermLoop)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
|
@ -376,23 +376,23 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
Section->m_ContinueSection != NULL &&
|
Section->m_ContinueSection != NULL &&
|
||||||
Section->m_Cont.TargetPC != (DWORD)-1)
|
Section->m_Cont.TargetPC != (DWORD)-1)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (Section->m_Cont.TargetPC != (DWORD)-1)
|
if (Section->m_Cont.TargetPC != (DWORD)-1)
|
||||||
{
|
{
|
||||||
//_Notify->BreakPoint(__FILE__,__LINE__);
|
//g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (Section->m_Jump.TargetPC != m_PC + ((short)m_Command.offset << 2) + 4)
|
if (Section->m_Jump.TargetPC != m_PC + ((short)m_Command.offset << 2) + 4)
|
||||||
{
|
{
|
||||||
//_Notify->BreakPoint(__FILE__,__LINE__);
|
//g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (m_PC == Section->m_Jump.TargetPC)
|
if (m_PC == Section->m_Jump.TargetPC)
|
||||||
{
|
{
|
||||||
if (!DelaySlotEffectsCompare(m_PC,m_Command.rs,m_Command.rt) && !Section->m_Jump.PermLoop)
|
if (!DelaySlotEffectsCompare(m_PC,m_Command.rs,m_Command.rt) && !Section->m_Jump.PermLoop)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -409,19 +409,19 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
Section->m_ContinueSection != NULL &&
|
Section->m_ContinueSection != NULL &&
|
||||||
Section->m_Cont.TargetPC != (DWORD)-1)
|
Section->m_Cont.TargetPC != (DWORD)-1)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (Section->m_Jump.TargetPC != m_PC + ((short)m_Command.offset << 2) + 4 &&
|
if (Section->m_Jump.TargetPC != m_PC + ((short)m_Command.offset << 2) + 4 &&
|
||||||
Section->m_JumpSection != NULL &&
|
Section->m_JumpSection != NULL &&
|
||||||
Section->m_Jump.TargetPC != (DWORD)-1)
|
Section->m_Jump.TargetPC != (DWORD)-1)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (m_PC == Section->m_Jump.TargetPC)
|
if (m_PC == Section->m_Jump.TargetPC)
|
||||||
{
|
{
|
||||||
if (!DelaySlotEffectsCompare(m_PC,m_Command.rs,m_Command.rt) && !Section->m_Jump.PermLoop)
|
if (!DelaySlotEffectsCompare(m_PC,m_Command.rs,m_Command.rt) && !Section->m_Jump.PermLoop)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -517,13 +517,13 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
case R4300i_COP0_CO_TLBP: break;
|
case R4300i_COP0_CO_TLBP: break;
|
||||||
case R4300i_COP0_CO_ERET: m_NextInstruction = END_BLOCK; break;
|
case R4300i_COP0_CO_ERET: m_NextInstruction = END_BLOCK; break;
|
||||||
default:
|
default:
|
||||||
_Notify->DisplayError("Unhandled R4300i OpCode in FillSectionInfo\n%s",
|
g_Notify->DisplayError("Unhandled R4300i OpCode in FillSectionInfo\n%s",
|
||||||
R4300iOpcodeName(m_Command.Hex,m_PC));
|
R4300iOpcodeName(m_Command.Hex,m_PC));
|
||||||
m_NextInstruction = END_BLOCK;
|
m_NextInstruction = END_BLOCK;
|
||||||
m_PC -= 4;
|
m_PC -= 4;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
_Notify->DisplayError("Unhandled R4300i OpCode in FillSectionInfo 3\n%s",
|
g_Notify->DisplayError("Unhandled R4300i OpCode in FillSectionInfo 3\n%s",
|
||||||
R4300iOpcodeName(m_Command.Hex,m_PC));
|
R4300iOpcodeName(m_Command.Hex,m_PC));
|
||||||
m_NextInstruction = END_BLOCK;
|
m_NextInstruction = END_BLOCK;
|
||||||
m_PC -= 4;
|
m_PC -= 4;
|
||||||
|
@ -548,17 +548,17 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
Section->m_ContinueSection != NULL &&
|
Section->m_ContinueSection != NULL &&
|
||||||
Section->m_Cont.TargetPC != (DWORD)-1)
|
Section->m_Cont.TargetPC != (DWORD)-1)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (m_PC == m_PC + ((short)m_Command.offset << 2) + 4)
|
if (m_PC == m_PC + ((short)m_Command.offset << 2) + 4)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
if (!DelaySlotEffectsCompare(m_PC,m_Command.rs,m_Command.rt))
|
if (!DelaySlotEffectsCompare(m_PC,m_Command.rs,m_Command.rt))
|
||||||
{
|
{
|
||||||
if (!Section->m_Jump.PermLoop)
|
if (!Section->m_Jump.PermLoop)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -573,15 +573,15 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
Section->m_ContinueSection != NULL &&
|
Section->m_ContinueSection != NULL &&
|
||||||
Section->m_Cont.TargetPC != (DWORD)-1)
|
Section->m_Cont.TargetPC != (DWORD)-1)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (Section->m_Jump.TargetPC != m_PC + ((short)m_Command.offset << 2) + 4)
|
if (Section->m_Jump.TargetPC != m_PC + ((short)m_Command.offset << 2) + 4)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (m_PC == Section->m_Jump.TargetPC)
|
if (m_PC == Section->m_Jump.TargetPC)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
if (!DelaySlotEffectsCompare(m_PC,m_Command.rs,m_Command.rt)) {
|
if (!DelaySlotEffectsCompare(m_PC,m_Command.rs,m_Command.rt)) {
|
||||||
Section->m_Jump.PermLoop = true;
|
Section->m_Jump.PermLoop = true;
|
||||||
|
@ -600,7 +600,7 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
case R4300i_COP1_W: break;
|
case R4300i_COP1_W: break;
|
||||||
case R4300i_COP1_L: break;
|
case R4300i_COP1_L: break;
|
||||||
default:
|
default:
|
||||||
_Notify->DisplayError("Unhandled R4300i OpCode in FillSectionInfo 2\n%s",
|
g_Notify->DisplayError("Unhandled R4300i OpCode in FillSectionInfo 2\n%s",
|
||||||
R4300iOpcodeName(m_Command.Hex,m_PC));
|
R4300iOpcodeName(m_Command.Hex,m_PC));
|
||||||
m_NextInstruction = END_BLOCK;
|
m_NextInstruction = END_BLOCK;
|
||||||
m_PC -= 4;
|
m_PC -= 4;
|
||||||
|
@ -616,21 +616,21 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
Section->m_ContinueSection != NULL &&
|
Section->m_ContinueSection != NULL &&
|
||||||
Section->m_Cont.TargetPC != (DWORD)-1)
|
Section->m_Cont.TargetPC != (DWORD)-1)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (Section->m_Jump.TargetPC != m_PC + 4)
|
if (Section->m_Jump.TargetPC != m_PC + 4)
|
||||||
{
|
{
|
||||||
//_Notify->BreakPoint(__FILE__,__LINE__);
|
//g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
/*if (Section->m_Jump.TargetPC != m_PC + ((short)m_Command.offset << 2) + 4)
|
/*if (Section->m_Jump.TargetPC != m_PC + ((short)m_Command.offset << 2) + 4)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}*/
|
}*/
|
||||||
if (m_PC == m_PC + ((short)m_Command.offset << 2) + 4)
|
if (m_PC == m_PC + ((short)m_Command.offset << 2) + 4)
|
||||||
{
|
{
|
||||||
if (!DelaySlotEffectsCompare(m_PC,m_Command.rs,m_Command.rt) && !Section->m_Jump.PermLoop)
|
if (!DelaySlotEffectsCompare(m_PC,m_Command.rs,m_Command.rt) && !Section->m_Jump.PermLoop)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -695,7 +695,7 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
if (m_Command.Hex == 0xF1F3F5F7) { break; }
|
if (m_Command.Hex == 0xF1F3F5F7) { break; }
|
||||||
if (m_Command.Hex == 0xC1200000) { break; }
|
if (m_Command.Hex == 0xC1200000) { break; }
|
||||||
if (m_Command.Hex == 0x4C5A5353) { break; }
|
if (m_Command.Hex == 0x4C5A5353) { break; }
|
||||||
_Notify->DisplayError("Unhandled R4300i OpCode in FillSectionInfo 1\n%s\n%X",
|
g_Notify->DisplayError("Unhandled R4300i OpCode in FillSectionInfo 1\n%s\n%X",
|
||||||
R4300iOpcodeName(m_Command.Hex,m_PC),m_Command.Hex);
|
R4300iOpcodeName(m_Command.Hex,m_PC),m_Command.Hex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -703,7 +703,7 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
|
|
||||||
if (Section->m_DelaySlot)
|
if (Section->m_DelaySlot)
|
||||||
{
|
{
|
||||||
if (m_NextInstruction != NORMAL) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (m_NextInstruction != NORMAL) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
m_NextInstruction = END_BLOCK;
|
m_NextInstruction = END_BLOCK;
|
||||||
SetJumpRegSet(Section,m_Reg);
|
SetJumpRegSet(Section,m_Reg);
|
||||||
} else {
|
} else {
|
||||||
|
@ -716,7 +716,7 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
m_PC += 4;
|
m_PC += 4;
|
||||||
if ((m_PC & 0xFFFFF000) != (m_EnterSection->m_EnterPC & 0xFFFFF000))
|
if ((m_PC & 0xFFFFF000) != (m_EnterSection->m_EnterPC & 0xFFFFF000))
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case LIKELY_DELAY_SLOT:
|
case LIKELY_DELAY_SLOT:
|
||||||
|
@ -734,7 +734,7 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
m_NextInstruction = END_BLOCK;
|
m_NextInstruction = END_BLOCK;
|
||||||
break;
|
break;
|
||||||
case LIKELY_DELAY_SLOT_DONE:
|
case LIKELY_DELAY_SLOT_DONE:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
if (Section->m_CompiledLocation)
|
if (Section->m_CompiledLocation)
|
||||||
{
|
{
|
||||||
} else {
|
} else {
|
||||||
|
@ -755,9 +755,9 @@ bool LoopAnalysis::CheckLoopRegisterUsage( CCodeSection * Section)
|
||||||
if ((m_PC & 0xFFFFF000) != (m_EnterSection->m_EnterPC & 0xFFFFF000)) {
|
if ((m_PC & 0xFFFFF000) != (m_EnterSection->m_EnterPC & 0xFFFFF000)) {
|
||||||
if (m_NextInstruction != END_BLOCK && m_NextInstruction != NORMAL)
|
if (m_NextInstruction != END_BLOCK && m_NextInstruction != NORMAL)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
} while (m_NextInstruction != END_BLOCK);
|
} while (m_NextInstruction != END_BLOCK);
|
||||||
|
|
||||||
|
@ -783,7 +783,7 @@ bool LoopAnalysis::SyncRegState ( CRegInfo & RegSet, const CRegInfo& SyncReg )
|
||||||
RegSet.SetMipsRegState(x,CRegInfo::STATE_MODIFIED);
|
RegSet.SetMipsRegState(x,CRegInfo::STATE_MODIFIED);
|
||||||
bChanged = true;
|
bChanged = true;
|
||||||
} else if (RegSet.IsConst(x) && RegSet.Is64Bit(x) && RegSet.GetMipsReg_S(x) != SyncReg.GetMipsReg_S(x)) {
|
} else if (RegSet.IsConst(x) && RegSet.Is64Bit(x) && RegSet.GetMipsReg_S(x) != SyncReg.GetMipsReg_S(x)) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return bChanged;
|
return bChanged;
|
||||||
|
@ -875,7 +875,7 @@ void LoopAnalysis::SPECIAL_SRAV ( void )
|
||||||
|
|
||||||
void LoopAnalysis::SPECIAL_JR ( void )
|
void LoopAnalysis::SPECIAL_JR ( void )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
if (m_Reg.IsConst(m_Command.rs)) {
|
if (m_Reg.IsConst(m_Command.rs)) {
|
||||||
Section->m_Jump.TargetPC = m_Reg.GetMipsRegLo(m_Command.rs);
|
Section->m_Jump.TargetPC = m_Reg.GetMipsRegLo(m_Command.rs);
|
||||||
|
@ -888,7 +888,7 @@ void LoopAnalysis::SPECIAL_JR ( void )
|
||||||
|
|
||||||
void LoopAnalysis::SPECIAL_JALR ( void )
|
void LoopAnalysis::SPECIAL_JALR ( void )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
m_Reg.GetMipsRegLo(m_Command.rd) = m_PC + 8;
|
m_Reg.GetMipsRegLo(m_Command.rd) = m_PC + 8;
|
||||||
m_Reg.SetMipsRegState(m_Command.rd,CRegInfo::STATE_CONST_32);
|
m_Reg.SetMipsRegState(m_Command.rd,CRegInfo::STATE_CONST_32);
|
||||||
|
|
|
@ -72,7 +72,7 @@ void CRecompiler::Run()
|
||||||
}
|
}
|
||||||
__except( _MMU->MemoryFilter( GetExceptionCode(), GetExceptionInformation()) )
|
__except( _MMU->MemoryFilter( GetExceptionCode(), GetExceptionInformation()) )
|
||||||
{
|
{
|
||||||
_Notify->DisplayError(MSG_UNKNOWN_MEM_ACTION);
|
g_Notify->DisplayError(MSG_UNKNOWN_MEM_ACTION);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -88,7 +88,7 @@ void CRecompiler::RecompilerMain_VirtualTable ( void )
|
||||||
_Reg->DoTLBReadMiss(false,PC);
|
_Reg->DoTLBReadMiss(false,PC);
|
||||||
if (!_TransVaddr->ValidVaddr(PC))
|
if (!_TransVaddr->ValidVaddr(PC))
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("Failed to translate PC to a PAddr: %X\n\nEmulation stopped",PC);
|
g_Notify->DisplayError("Failed to translate PC to a PAddr: %X\n\nEmulation stopped",PC);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
|
@ -117,7 +117,7 @@ void CRecompiler::RecompilerMain_VirtualTable ( void )
|
||||||
if (table == NULL)
|
if (table == NULL)
|
||||||
{
|
{
|
||||||
WriteTrace(TraceError,"CRecompiler::RecompilerMain_VirtualTable: failed to allocate PCCompiledFunc");
|
WriteTrace(TraceError,"CRecompiler::RecompilerMain_VirtualTable: failed to allocate PCCompiledFunc");
|
||||||
_Notify->FatalError(MSG_MEM_ALLOC_ERROR);
|
g_Notify->FatalError(MSG_MEM_ALLOC_ERROR);
|
||||||
}
|
}
|
||||||
memset(table,0,sizeof(PCCompiledFunc) * (0x1000 >> 2));
|
memset(table,0,sizeof(PCCompiledFunc) * (0x1000 >> 2));
|
||||||
if (bSMM_Protect())
|
if (bSMM_Protect())
|
||||||
|
@ -134,7 +134,7 @@ void CRecompiler::RecompilerMain_VirtualTable ( void )
|
||||||
|
|
||||||
void CRecompiler::RecompilerMain_VirtualTable_validate ( void )
|
void CRecompiler::RecompilerMain_VirtualTable_validate ( void )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
/* PCCompiledFunc_TABLE * m_FunctionTable = m_Functions.GetFunctionTable();
|
/* PCCompiledFunc_TABLE * m_FunctionTable = m_Functions.GetFunctionTable();
|
||||||
|
|
||||||
while(!m_EndEmulation)
|
while(!m_EndEmulation)
|
||||||
|
@ -145,7 +145,7 @@ void CRecompiler::RecompilerMain_VirtualTable_validate ( void )
|
||||||
//Find Block on hash table
|
//Find Block on hash table
|
||||||
if (Info == NULL)
|
if (Info == NULL)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
if (!_TLB->ValidVaddr(PROGRAM_COUNTER))
|
if (!_TLB->ValidVaddr(PROGRAM_COUNTER))
|
||||||
{
|
{
|
||||||
|
@ -153,7 +153,7 @@ void CRecompiler::RecompilerMain_VirtualTable_validate ( void )
|
||||||
NextInstruction = NORMAL;
|
NextInstruction = NORMAL;
|
||||||
if (!_TLB->ValidVaddr(PROGRAM_COUNTER))
|
if (!_TLB->ValidVaddr(PROGRAM_COUNTER))
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("Failed to translate PC to a PAddr: %X\n\nEmulation stopped",PROGRAM_COUNTER);
|
g_Notify->DisplayError("Failed to translate PC to a PAddr: %X\n\nEmulation stopped",PROGRAM_COUNTER);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
|
@ -205,7 +205,7 @@ void CRecompiler::RecompilerMain_VirtualTable_validate ( void )
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
if (!_TLB->ValidVaddr(PROGRAM_COUNTER))
|
if (!_TLB->ValidVaddr(PROGRAM_COUNTER))
|
||||||
{
|
{
|
||||||
|
@ -213,7 +213,7 @@ void CRecompiler::RecompilerMain_VirtualTable_validate ( void )
|
||||||
NextInstruction = NORMAL;
|
NextInstruction = NORMAL;
|
||||||
if (!_TLB->ValidVaddr(PROGRAM_COUNTER))
|
if (!_TLB->ValidVaddr(PROGRAM_COUNTER))
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("Failed to translate PC to a PAddr: %X\n\nEmulation stopped",PROGRAM_COUNTER);
|
g_Notify->DisplayError("Failed to translate PC to a PAddr: %X\n\nEmulation stopped",PROGRAM_COUNTER);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -236,7 +236,7 @@ void CRecompiler::RecompilerMain_VirtualTable_validate ( void )
|
||||||
NextInstruction = NORMAL;
|
NextInstruction = NORMAL;
|
||||||
if (!_MMU->ValidVaddr(PROGRAM_COUNTER))
|
if (!_MMU->ValidVaddr(PROGRAM_COUNTER))
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("Failed to translate PC to a PAddr: %X\n\nEmulation stopped",PROGRAM_COUNTER);
|
g_Notify->DisplayError("Failed to translate PC to a PAddr: %X\n\nEmulation stopped",PROGRAM_COUNTER);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -353,14 +353,14 @@ void CRecompiler::RecompilerMain_Lookup( void )
|
||||||
{
|
{
|
||||||
/*if (bUseTlb())
|
/*if (bUseTlb())
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
if (!_TLB->TranslateVaddr(PROGRAM_COUNTER, Addr))
|
if (!_TLB->TranslateVaddr(PROGRAM_COUNTER, Addr))
|
||||||
{
|
{
|
||||||
DoTLBMiss(NextInstruction == DELAY_SLOT,PROGRAM_COUNTER);
|
DoTLBMiss(NextInstruction == DELAY_SLOT,PROGRAM_COUNTER);
|
||||||
NextInstruction = NORMAL;
|
NextInstruction = NORMAL;
|
||||||
if (!TranslateVaddr(PROGRAM_COUNTER, &Addr)) {
|
if (!TranslateVaddr(PROGRAM_COUNTER, &Addr)) {
|
||||||
_Notify->DisplayError("Failed to translate PC to a PAddr: %X\n\nEmulation stopped",PROGRAM_COUNTER);
|
g_Notify->DisplayError("Failed to translate PC to a PAddr: %X\n\nEmulation stopped",PROGRAM_COUNTER);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -410,7 +410,7 @@ void CRecompiler::RecompilerMain_Lookup( void )
|
||||||
if (Addr > 0x20000000)
|
if (Addr > 0x20000000)
|
||||||
{
|
{
|
||||||
WriteTraceF(TraceDebug,"Executing from non mapped space .1 PC: %X Addr: %X",PROGRAM_COUNTER, Addr);
|
WriteTraceF(TraceDebug,"Executing from non mapped space .1 PC: %X Addr: %X",PROGRAM_COUNTER, Addr);
|
||||||
_Notify->DisplayError(GS(MSG_NONMAPPED_SPACE));
|
g_Notify->DisplayError(GS(MSG_NONMAPPED_SPACE));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
Info = (CCompiledFunc *)*(JumpTable + (Addr >> 2));
|
Info = (CCompiledFunc *)*(JumpTable + (Addr >> 2));
|
||||||
|
@ -422,7 +422,7 @@ void CRecompiler::RecompilerMain_Lookup( void )
|
||||||
continue;
|
continue;
|
||||||
} else {
|
} else {
|
||||||
WriteTraceF(TraceDebug,"Executing from non mapped space .1 PC: %X Addr: %X",PROGRAM_COUNTER, Addr);
|
WriteTraceF(TraceDebug,"Executing from non mapped space .1 PC: %X Addr: %X",PROGRAM_COUNTER, Addr);
|
||||||
_Notify->DisplayError(GS(MSG_NONMAPPED_SPACE));
|
g_Notify->DisplayError(GS(MSG_NONMAPPED_SPACE));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -437,7 +437,7 @@ void CRecompiler::RecompilerMain_Lookup( void )
|
||||||
continue;
|
continue;
|
||||||
} else {
|
} else {
|
||||||
WriteTraceF(TraceDebug,"Executing from non mapped space .2 PC: %X Addr: %X",PROGRAM_COUNTER, Addr);
|
WriteTraceF(TraceDebug,"Executing from non mapped space .2 PC: %X Addr: %X",PROGRAM_COUNTER, Addr);
|
||||||
_Notify->DisplayError(GS(MSG_NONMAPPED_SPACE));
|
g_Notify->DisplayError(GS(MSG_NONMAPPED_SPACE));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -466,7 +466,7 @@ void CRecompiler::RecompilerMain_Lookup( void )
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
if (Profiling && IndvidualBlock) {
|
if (Profiling && IndvidualBlock) {
|
||||||
static DWORD ProfAddress = 0;
|
static DWORD ProfAddress = 0;
|
||||||
|
@ -507,7 +507,7 @@ void CRecompiler::RecompilerMain_Lookup_TLB( void )
|
||||||
_Reg->DoTLBReadMiss(false,PROGRAM_COUNTER);
|
_Reg->DoTLBReadMiss(false,PROGRAM_COUNTER);
|
||||||
if (!_TransVaddr->TranslateVaddr(PROGRAM_COUNTER, PhysicalAddr))
|
if (!_TransVaddr->TranslateVaddr(PROGRAM_COUNTER, PhysicalAddr))
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("Failed to translate PC to a PAddr: %X\n\nEmulation stopped",PROGRAM_COUNTER);
|
g_Notify->DisplayError("Failed to translate PC to a PAddr: %X\n\nEmulation stopped",PROGRAM_COUNTER);
|
||||||
m_EndEmulation = true;
|
m_EndEmulation = true;
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
|
@ -607,7 +607,7 @@ void CRecompiler::RecompilerMain_Lookup_validate_TLB( void )
|
||||||
_Reg->DoTLBReadMiss(false,PROGRAM_COUNTER);
|
_Reg->DoTLBReadMiss(false,PROGRAM_COUNTER);
|
||||||
if (!_TransVaddr->TranslateVaddr(PROGRAM_COUNTER, PhysicalAddr))
|
if (!_TransVaddr->TranslateVaddr(PROGRAM_COUNTER, PhysicalAddr))
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("Failed to translate PC to a PAddr: %X\n\nEmulation stopped",PROGRAM_COUNTER);
|
g_Notify->DisplayError("Failed to translate PC to a PAddr: %X\n\nEmulation stopped",PROGRAM_COUNTER);
|
||||||
m_EndEmulation = true;
|
m_EndEmulation = true;
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
|
@ -641,7 +641,7 @@ void CRecompiler::RecompilerMain_Lookup_validate_TLB( void )
|
||||||
info = JumpTable()[PhysicalAddr >> 2];
|
info = JumpTable()[PhysicalAddr >> 2];
|
||||||
if (info != NULL)
|
if (info != NULL)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
info = NULL;
|
info = NULL;
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
|
@ -693,7 +693,7 @@ void CRecompiler::ResetRecompCode()
|
||||||
|
|
||||||
void CRecompiler::RecompilerMain_ChangeMemory ( void )
|
void CRecompiler::RecompilerMain_ChangeMemory ( void )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
DWORD Value, Addr;
|
DWORD Value, Addr;
|
||||||
BYTE * Block;
|
BYTE * Block;
|
||||||
|
@ -705,7 +705,7 @@ void CRecompiler::RecompilerMain_ChangeMemory ( void )
|
||||||
NextInstruction = NORMAL;
|
NextInstruction = NORMAL;
|
||||||
if (!TranslateVaddr(PROGRAM_COUNTER, &Addr)) {
|
if (!TranslateVaddr(PROGRAM_COUNTER, &Addr)) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Failed to translate PC to a PAddr: %X\n\nEmulation stopped",PROGRAM_COUNTER);
|
g_Notify->DisplayError("Failed to translate PC to a PAddr: %X\n\nEmulation stopped",PROGRAM_COUNTER);
|
||||||
#endif
|
#endif
|
||||||
ExitThread(0);
|
ExitThread(0);
|
||||||
}
|
}
|
||||||
|
@ -719,7 +719,7 @@ void CRecompiler::RecompilerMain_ChangeMemory ( void )
|
||||||
Value = (DWORD)(*(DelaySlotTable + (Addr >> 12)));
|
Value = (DWORD)(*(DelaySlotTable + (Addr >> 12)));
|
||||||
} __except(EXCEPTION_EXECUTE_HANDLER) {
|
} __except(EXCEPTION_EXECUTE_HANDLER) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Executing Delay Slot from non maped space\nPROGRAM_COUNTER = 0x%X",PROGRAM_COUNTER);
|
g_Notify->DisplayError("Executing Delay Slot from non maped space\nPROGRAM_COUNTER = 0x%X",PROGRAM_COUNTER);
|
||||||
#endif
|
#endif
|
||||||
ExitThread(0);
|
ExitThread(0);
|
||||||
}
|
}
|
||||||
|
@ -770,7 +770,7 @@ void CRecompiler::RecompilerMain_ChangeMemory ( void )
|
||||||
Block = NULL;
|
Block = NULL;
|
||||||
}
|
}
|
||||||
} __except(EXCEPTION_EXECUTE_HANDLER) {
|
} __except(EXCEPTION_EXECUTE_HANDLER) {
|
||||||
_Notify->DisplayError(GS(MSG_NONMAPPED_SPACE));
|
g_Notify->DisplayError(GS(MSG_NONMAPPED_SPACE));
|
||||||
ExitThread(0);
|
ExitThread(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -912,7 +912,7 @@ void CRecompiler::ClearRecompCode_Phys(DWORD Address, int length, REMOVE_REASON
|
||||||
int ClearLen = ((length + 3) & ~3);
|
int ClearLen = ((length + 3) & ~3);
|
||||||
if (Address + ClearLen > RdramSize())
|
if (Address + ClearLen > RdramSize())
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
ClearLen = RdramSize() - Address;
|
ClearLen = RdramSize() - Address;
|
||||||
}
|
}
|
||||||
WriteTraceF(TraceRecompiler,"Reseting Jump Table, Addr: %X len: %d",Address,ClearLen);
|
WriteTraceF(TraceRecompiler,"Reseting Jump Table, Addr: %X len: %d",Address,ClearLen);
|
||||||
|
@ -954,7 +954,7 @@ void CRecompiler::ClearRecompCode_Virt(DWORD Address, int length,REMOVE_REASON R
|
||||||
|
|
||||||
if (DataLeft > 0)
|
if (DataLeft > 0)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -968,7 +968,7 @@ void CRecompiler::ClearRecompCode_Virt(DWORD Address, int length,REMOVE_REASON R
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -981,11 +981,11 @@ void CRecompiler::ResetMemoryStackPos( void )
|
||||||
}
|
}
|
||||||
if (_MMU == NULL || _Reg == NULL)
|
if (_MMU == NULL || _Reg == NULL)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (_Reg->m_GPR[29].UW[0] < 0x80000000 || _Reg->m_GPR[29].UW[0] >= 0xC0000000)
|
if (_Reg->m_GPR[29].UW[0] < 0x80000000 || _Reg->m_GPR[29].UW[0] >= 0xC0000000)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
m_MemoryStack = (DWORD)(_MMU->Rdram() + (_Reg->m_GPR[29].UW[0] & 0x1FFFFFFF));
|
m_MemoryStack = (DWORD)(_MMU->Rdram() + (_Reg->m_GPR[29].UW[0] & 0x1FFFFFFF));
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,7 +23,7 @@ bool CRecompMemory::AllocateMemory()
|
||||||
if (RecompCodeBase==NULL)
|
if (RecompCodeBase==NULL)
|
||||||
{
|
{
|
||||||
WriteTrace(TraceError,"CRecompMemory::AllocateMemory: failed to allocate RecompCodeBase");
|
WriteTrace(TraceError,"CRecompMemory::AllocateMemory: failed to allocate RecompCodeBase");
|
||||||
_Notify->DisplayError(MSG_MEM_ALLOC_ERROR);
|
g_Notify->DisplayError(MSG_MEM_ALLOC_ERROR);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -32,7 +32,7 @@ bool CRecompMemory::AllocateMemory()
|
||||||
{
|
{
|
||||||
WriteTrace(TraceError,"CRecompMemory::AllocateMemory: failed to commit initial buffer");
|
WriteTrace(TraceError,"CRecompMemory::AllocateMemory: failed to commit initial buffer");
|
||||||
VirtualFree( RecompCodeBase, 0 , MEM_RELEASE);
|
VirtualFree( RecompCodeBase, 0 , MEM_RELEASE);
|
||||||
_Notify->DisplayError(MSG_MEM_ALLOC_ERROR);
|
g_Notify->DisplayError(MSG_MEM_ALLOC_ERROR);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
m_RecompSize = InitialCompileBufferSize;
|
m_RecompSize = InitialCompileBufferSize;
|
||||||
|
@ -57,7 +57,7 @@ void CRecompMemory::CheckRecompMem ( void )
|
||||||
if (MemAddr == NULL)
|
if (MemAddr == NULL)
|
||||||
{
|
{
|
||||||
WriteTrace(TraceError,"CRecompMemory::CheckRecompMem: failed to increase buffer");
|
WriteTrace(TraceError,"CRecompMemory::CheckRecompMem: failed to increase buffer");
|
||||||
_Notify->FatalError(MSG_MEM_ALLOC_ERROR);
|
g_Notify->FatalError(MSG_MEM_ALLOC_ERROR);
|
||||||
}
|
}
|
||||||
m_RecompSize += IncreaseCompileBufferSize;
|
m_RecompSize += IncreaseCompileBufferSize;
|
||||||
|
|
||||||
|
@ -78,5 +78,5 @@ void CRecompMemory::ShowMemUsed()
|
||||||
|
|
||||||
DWORD TotalAvaliable = m_RecompSize / 0x100000;
|
DWORD TotalAvaliable = m_RecompSize / 0x100000;
|
||||||
|
|
||||||
_Notify->DisplayMessage(0,"Memory used: %d mb %-3d kb %-3d bytes Total Available: %d mb",MB,KB,Size, TotalAvaliable);
|
g_Notify->DisplayMessage(0,"Memory used: %d mb %-3d kb %-3d bytes Total Available: %d mb",MB,KB,Size, TotalAvaliable);
|
||||||
}
|
}
|
|
@ -54,7 +54,7 @@ void CRecompilerOps::Compile_Branch (CRecompilerOps::BranchFunction CompareFunc,
|
||||||
OPCODE Command;
|
OPCODE Command;
|
||||||
|
|
||||||
if (!_MMU->LW_VAddr(m_CompilePC + 4, Command.Hex)) {
|
if (!_MMU->LW_VAddr(m_CompilePC + 4, Command.Hex)) {
|
||||||
_Notify->DisplayError(GS(MSG_FAIL_LOAD_WORD));
|
g_Notify->DisplayError(GS(MSG_FAIL_LOAD_WORD));
|
||||||
ExitThread(0);
|
ExitThread(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -71,7 +71,7 @@ void CRecompilerOps::Compile_Branch (CRecompilerOps::BranchFunction CompareFunc,
|
||||||
break;
|
break;
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
default:
|
default:
|
||||||
_Notify->DisplayError("Unknown branch type");
|
g_Notify->DisplayError("Unknown branch type");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -153,7 +153,7 @@ void CRecompilerOps::Compile_Branch (CRecompilerOps::BranchFunction CompareFunc,
|
||||||
{
|
{
|
||||||
if (m_Section->m_Jump.LinkLocation != NULL || m_Section->m_Jump.LinkLocation2 != NULL)
|
if (m_Section->m_Jump.LinkLocation != NULL || m_Section->m_Jump.LinkLocation2 != NULL)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
MoveConstToVariable(m_Section->m_Jump.TargetPC,&R4300iOp::m_JumpToLocation,"R4300iOp::m_JumpToLocation");
|
MoveConstToVariable(m_Section->m_Jump.TargetPC,&R4300iOp::m_JumpToLocation,"R4300iOp::m_JumpToLocation");
|
||||||
}
|
}
|
||||||
|
@ -161,7 +161,7 @@ void CRecompilerOps::Compile_Branch (CRecompilerOps::BranchFunction CompareFunc,
|
||||||
{
|
{
|
||||||
if (m_Section->m_Cont.LinkLocation != NULL || m_Section->m_Cont.LinkLocation2 != NULL)
|
if (m_Section->m_Cont.LinkLocation != NULL || m_Section->m_Cont.LinkLocation2 != NULL)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
MoveConstToVariable(m_Section->m_Cont.TargetPC,&R4300iOp::m_JumpToLocation,"R4300iOp::m_JumpToLocation");
|
MoveConstToVariable(m_Section->m_Cont.TargetPC,&R4300iOp::m_JumpToLocation,"R4300iOp::m_JumpToLocation");
|
||||||
}
|
}
|
||||||
|
@ -169,7 +169,7 @@ void CRecompilerOps::Compile_Branch (CRecompilerOps::BranchFunction CompareFunc,
|
||||||
if (m_Section->m_Jump.LinkLocation != NULL || m_Section->m_Jump.LinkLocation2 != NULL)
|
if (m_Section->m_Jump.LinkLocation != NULL || m_Section->m_Jump.LinkLocation2 != NULL)
|
||||||
{
|
{
|
||||||
JmpLabel8("DoDelaySlot",0);
|
JmpLabel8("DoDelaySlot",0);
|
||||||
if (DelayLinkLocation != NULL) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (DelayLinkLocation != NULL) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
DelayLinkLocation = (BYTE *)(m_RecompPos - 1);
|
DelayLinkLocation = (BYTE *)(m_RecompPos - 1);
|
||||||
|
|
||||||
CPU_Message(" ");
|
CPU_Message(" ");
|
||||||
|
@ -185,7 +185,7 @@ void CRecompilerOps::Compile_Branch (CRecompilerOps::BranchFunction CompareFunc,
|
||||||
if (m_Section->m_Cont.LinkLocation != NULL || m_Section->m_Cont.LinkLocation2 != NULL)
|
if (m_Section->m_Cont.LinkLocation != NULL || m_Section->m_Cont.LinkLocation2 != NULL)
|
||||||
{
|
{
|
||||||
JmpLabel8("DoDelaySlot",0);
|
JmpLabel8("DoDelaySlot",0);
|
||||||
if (DelayLinkLocation != NULL) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (DelayLinkLocation != NULL) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
DelayLinkLocation = (BYTE *)(m_RecompPos - 1);
|
DelayLinkLocation = (BYTE *)(m_RecompPos - 1);
|
||||||
|
|
||||||
CPU_Message(" ");
|
CPU_Message(" ");
|
||||||
|
@ -287,7 +287,7 @@ void CRecompilerOps::Compile_Branch (CRecompilerOps::BranchFunction CompareFunc,
|
||||||
m_NextInstruction = END_BLOCK;
|
m_NextInstruction = END_BLOCK;
|
||||||
} else {
|
} else {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("WTF\n\nBranch\nNextInstruction = %X", m_NextInstruction);
|
g_Notify->DisplayError("WTF\n\nBranch\nNextInstruction = %X", m_NextInstruction);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -306,15 +306,15 @@ void CRecompilerOps::Compile_BranchLikely (BranchFunction CompareFunc, BOOL Link
|
||||||
} else {
|
} else {
|
||||||
if (m_Section->m_Jump.JumpPC != m_CompilePC)
|
if (m_Section->m_Jump.JumpPC != m_CompilePC)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (m_Section->m_Cont.JumpPC != m_CompilePC)
|
if (m_Section->m_Cont.JumpPC != m_CompilePC)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (m_Section->m_Cont.TargetPC != m_CompilePC + 8)
|
if (m_Section->m_Cont.TargetPC != m_CompilePC + 8)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (m_Section->m_JumpSection != NULL) {
|
if (m_Section->m_JumpSection != NULL) {
|
||||||
|
@ -345,7 +345,7 @@ 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) { _Notify->BreakPoint(__FILE__,__LINE__); }
|
if (m_Section->m_Cont.FallThrough) { g_Notify->BreakPoint(__FILE__,__LINE__); }
|
||||||
|
|
||||||
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);
|
||||||
|
@ -384,7 +384,7 @@ void CRecompilerOps::Compile_BranchLikely (BranchFunction CompareFunc, BOOL Link
|
||||||
{
|
{
|
||||||
if (m_Section->m_Jump.LinkLocation != NULL)
|
if (m_Section->m_Jump.LinkLocation != NULL)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
m_Section->GenerateSectionLinkage();
|
m_Section->GenerateSectionLinkage();
|
||||||
m_NextInstruction = END_BLOCK;
|
m_NextInstruction = END_BLOCK;
|
||||||
|
@ -397,7 +397,7 @@ void CRecompilerOps::Compile_BranchLikely (BranchFunction CompareFunc, BOOL Link
|
||||||
m_NextInstruction = END_BLOCK;
|
m_NextInstruction = END_BLOCK;
|
||||||
} else {
|
} else {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("WTF\n\nBranchLikely\nNextInstruction = %X", m_NextInstruction);
|
g_Notify->DisplayError("WTF\n\nBranchLikely\nNextInstruction = %X", m_NextInstruction);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1193,7 +1193,7 @@ void CRecompilerOps::BLTZ_Compare (void) {
|
||||||
void CRecompilerOps::BGEZ_Compare (void) {
|
void CRecompilerOps::BGEZ_Compare (void) {
|
||||||
if (IsConst(m_Opcode.rs)) {
|
if (IsConst(m_Opcode.rs)) {
|
||||||
if (Is64Bit(m_Opcode.rs)) {
|
if (Is64Bit(m_Opcode.rs)) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
CRecompilerOps::UnknownOpcode();
|
CRecompilerOps::UnknownOpcode();
|
||||||
} else if (IsSigned(m_Opcode.rs)) {
|
} else if (IsSigned(m_Opcode.rs)) {
|
||||||
if (GetMipsRegLo_S(m_Opcode.rs) >= 0) {
|
if (GetMipsRegLo_S(m_Opcode.rs) >= 0) {
|
||||||
|
@ -1322,7 +1322,7 @@ void CRecompilerOps::J (void) {
|
||||||
m_NextInstruction = END_BLOCK;
|
m_NextInstruction = END_BLOCK;
|
||||||
} else {
|
} else {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("WTF\n\nJ\nNextInstruction = %X", m_NextInstruction);
|
g_Notify->DisplayError("WTF\n\nJ\nNextInstruction = %X", m_NextInstruction);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1362,7 +1362,7 @@ void CRecompilerOps::JAL (void) {
|
||||||
m_NextInstruction = END_BLOCK;
|
m_NextInstruction = END_BLOCK;
|
||||||
} else {
|
} else {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("WTF\n\nBranch\nNextInstruction = %X", m_NextInstruction);
|
g_Notify->DisplayError("WTF\n\nBranch\nNextInstruction = %X", m_NextInstruction);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
|
@ -1715,13 +1715,13 @@ void CRecompilerOps::CACHE (void){
|
||||||
break;
|
break;
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
default:
|
default:
|
||||||
_Notify->DisplayError("cache: %d",m_Opcode.rt);
|
g_Notify->DisplayError("cache: %d",m_Opcode.rt);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CRecompilerOps::LL (void) {
|
void CRecompilerOps::LL (void) {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
x86Reg TempReg1, TempReg2;
|
x86Reg TempReg1, TempReg2;
|
||||||
|
|
||||||
|
@ -1735,7 +1735,7 @@ void CRecompilerOps::LL (void) {
|
||||||
_MMU->Compile_LW(m_Section, GetMipsRegLo(m_Opcode.rt),Address);
|
_MMU->Compile_LW(m_Section, GetMipsRegLo(m_Opcode.rt),Address);
|
||||||
MoveConstToVariable(1,_LLBit,"LLBit");
|
MoveConstToVariable(1,_LLBit,"LLBit");
|
||||||
|
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
TranslateVaddr(Address, &Address);
|
TranslateVaddr(Address, &Address);
|
||||||
#endif
|
#endif
|
||||||
|
@ -2057,7 +2057,7 @@ void CRecompilerOps::SPECIAL_JR (void) {
|
||||||
m_NextInstruction = END_BLOCK;
|
m_NextInstruction = END_BLOCK;
|
||||||
} else {
|
} else {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("WTF\n\nBranch\nNextInstruction = %X", m_NextInstruction);
|
g_Notify->DisplayError("WTF\n\nBranch\nNextInstruction = %X", m_NextInstruction);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2112,7 +2112,7 @@ void CRecompilerOps::SPECIAL_JALR (void)
|
||||||
m_NextInstruction = END_BLOCK;
|
m_NextInstruction = END_BLOCK;
|
||||||
} else {
|
} else {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("WTF\n\nBranch\nNextInstruction = %X", m_NextInstruction);
|
g_Notify->DisplayError("WTF\n\nBranch\nNextInstruction = %X", m_NextInstruction);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2983,7 +2983,7 @@ void CRecompilerOps::SPECIAL_XOR (void) {
|
||||||
if (IsMapped(m_Opcode.rd)) { UnMap_GPR(m_Opcode.rd, FALSE); }
|
if (IsMapped(m_Opcode.rd)) { UnMap_GPR(m_Opcode.rd, FALSE); }
|
||||||
if (Is64Bit(m_Opcode.rt) || Is64Bit(m_Opcode.rs)) {
|
if (Is64Bit(m_Opcode.rt) || Is64Bit(m_Opcode.rs)) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("XOR 1");
|
g_Notify->DisplayError("XOR 1");
|
||||||
#endif
|
#endif
|
||||||
CRecompilerOps::UnknownOpcode();
|
CRecompilerOps::UnknownOpcode();
|
||||||
} else {
|
} else {
|
||||||
|
@ -3208,7 +3208,7 @@ void CRecompilerOps::SPECIAL_SLT (void) {
|
||||||
if (IsKnown(m_Opcode.rt) && IsKnown(m_Opcode.rs)) {
|
if (IsKnown(m_Opcode.rt) && IsKnown(m_Opcode.rs)) {
|
||||||
if (IsConst(m_Opcode.rt) && IsConst(m_Opcode.rs)) {
|
if (IsConst(m_Opcode.rt) && IsConst(m_Opcode.rs)) {
|
||||||
if (Is64Bit(m_Opcode.rt) || Is64Bit(m_Opcode.rs)) {
|
if (Is64Bit(m_Opcode.rt) || Is64Bit(m_Opcode.rs)) {
|
||||||
_Notify->DisplayError("1");
|
g_Notify->DisplayError("1");
|
||||||
CRecompilerOps::UnknownOpcode();
|
CRecompilerOps::UnknownOpcode();
|
||||||
} else {
|
} else {
|
||||||
if (IsMapped(m_Opcode.rd)) { UnMap_GPR(m_Opcode.rd, FALSE); }
|
if (IsMapped(m_Opcode.rd)) { UnMap_GPR(m_Opcode.rd, FALSE); }
|
||||||
|
@ -3441,7 +3441,7 @@ void CRecompilerOps::SPECIAL_SLTU (void) {
|
||||||
if (IsKnown(m_Opcode.rt) && IsKnown(m_Opcode.rs)) {
|
if (IsKnown(m_Opcode.rt) && IsKnown(m_Opcode.rs)) {
|
||||||
if (IsConst(m_Opcode.rt) && IsConst(m_Opcode.rs)) {
|
if (IsConst(m_Opcode.rt) && IsConst(m_Opcode.rs)) {
|
||||||
if (Is64Bit(m_Opcode.rt) || Is64Bit(m_Opcode.rs)) {
|
if (Is64Bit(m_Opcode.rt) || Is64Bit(m_Opcode.rs)) {
|
||||||
_Notify->DisplayError("1");
|
g_Notify->DisplayError("1");
|
||||||
CRecompilerOps::UnknownOpcode();
|
CRecompilerOps::UnknownOpcode();
|
||||||
} else {
|
} else {
|
||||||
if (IsMapped(m_Opcode.rd)) { UnMap_GPR(m_Opcode.rd, FALSE); }
|
if (IsMapped(m_Opcode.rd)) { UnMap_GPR(m_Opcode.rd, FALSE); }
|
||||||
|
@ -4126,10 +4126,10 @@ void CRecompilerOps::COP0_MT (void) {
|
||||||
if (IsConst(m_Opcode.rt)) {
|
if (IsConst(m_Opcode.rt)) {
|
||||||
AndConstToVariable(0xFFFFCFF,&_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
AndConstToVariable(0xFFFFCFF,&_CP0[m_Opcode.rd], CRegName::Cop0[m_Opcode.rd]);
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
if ((GetMipsRegLo(m_Opcode.rt) & 0x300) != 0 ){ _Notify->DisplayError("Set IP0 or IP1"); }
|
if ((GetMipsRegLo(m_Opcode.rt) & 0x300) != 0 ){ g_Notify->DisplayError("Set IP0 or IP1"); }
|
||||||
#endif
|
#endif
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
CRecompilerOps::UnknownOpcode();
|
CRecompilerOps::UnknownOpcode();
|
||||||
#endif
|
#endif
|
||||||
|
@ -4140,7 +4140,7 @@ void CRecompilerOps::COP0_MT (void) {
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#ifdef tofix
|
#ifdef tofix
|
||||||
CRecompilerOps::UnknownOpcode();
|
CRecompilerOps::UnknownOpcode();
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -69,7 +69,7 @@ CRegInfo& CRegInfo::operator=(const CRegInfo& right)
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
if (*this != right)
|
if (*this != right)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
return *this;
|
return *this;
|
||||||
|
@ -151,7 +151,7 @@ void CRegInfo::FixRoundModel(FPU_ROUND RoundMethod )
|
||||||
case RoundDown: OrConstToX86Reg(0x0400, reg); break;
|
case RoundDown: OrConstToX86Reg(0x0400, reg); break;
|
||||||
case RoundUp: OrConstToX86Reg(0x0800, reg); break;
|
case RoundUp: OrConstToX86Reg(0x0800, reg); break;
|
||||||
default:
|
default:
|
||||||
_Notify->DisplayError("Unknown Rounding model");
|
g_Notify->DisplayError("Unknown Rounding model");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
MoveX86regToVariable(reg, &m_fpuControl, "m_fpuControl");
|
MoveX86regToVariable(reg, &m_fpuControl, "m_fpuControl");
|
||||||
|
@ -182,7 +182,7 @@ void CRegInfo::ChangeFPURegFormat (int Reg, FPU_STATE OldFormat, FPU_STATE NewFo
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("ChangeFormat: Register not on stack!!");
|
g_Notify->DisplayError("ChangeFormat: Register not on stack!!");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -195,8 +195,8 @@ void CRegInfo::Load_FPR_ToTop ( int Reg, int RegToLoad, FPU_STATE Format)
|
||||||
CPU_Message("CurrentRoundingModel: %s FpuRoundingModel(StackTopPos()): %s",RoundingModelName(GetRoundingModel()),RoundingModelName(FpuRoundingModel(StackTopPos())));
|
CPU_Message("CurrentRoundingModel: %s FpuRoundingModel(StackTopPos()): %s",RoundingModelName(GetRoundingModel()),RoundingModelName(FpuRoundingModel(StackTopPos())));
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (RegToLoad < 0) { _Notify->DisplayError("Load_FPR_ToTop\nRegToLoad < 0 ???"); return; }
|
if (RegToLoad < 0) { g_Notify->DisplayError("Load_FPR_ToTop\nRegToLoad < 0 ???"); return; }
|
||||||
if (Reg < 0) { _Notify->DisplayError("Load_FPR_ToTop\nReg < 0 ???"); return; }
|
if (Reg < 0) { g_Notify->DisplayError("Load_FPR_ToTop\nReg < 0 ???"); return; }
|
||||||
|
|
||||||
if (Format == FPU_Double || Format == FPU_Qword) {
|
if (Format == FPU_Double || Format == FPU_Qword) {
|
||||||
UnMap_FPR(Reg + 1,TRUE);
|
UnMap_FPR(Reg + 1,TRUE);
|
||||||
|
@ -327,7 +327,7 @@ void CRegInfo::Load_FPR_ToTop ( int Reg, int RegToLoad, FPU_STATE Format)
|
||||||
break;
|
break;
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
default:
|
default:
|
||||||
_Notify->DisplayError("Load_FPR_ToTop\nUnkown format to load %d",Format);
|
g_Notify->DisplayError("Load_FPR_ToTop\nUnkown format to load %d",Format);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
SetX86Protected(TempReg,FALSE);
|
SetX86Protected(TempReg,FALSE);
|
||||||
|
@ -507,8 +507,8 @@ CRegInfo::x86Reg CRegInfo::Map_MemoryStack ( x86Reg Reg, bool bMapRegister, bool
|
||||||
Reg = FreeX86Reg();
|
Reg = FreeX86Reg();
|
||||||
if (Reg == x86_Unknown)
|
if (Reg == x86_Unknown)
|
||||||
{
|
{
|
||||||
_Notify->DisplayError("Map_MemoryStack\n\nOut of registers");
|
g_Notify->DisplayError("Map_MemoryStack\n\nOut of registers");
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
SetX86Mapped(Reg,CRegInfo::Stack_Mapped);
|
SetX86Mapped(Reg,CRegInfo::Stack_Mapped);
|
||||||
CPU_Message(" regcache: allocate %s as Memory Stack",x86_Name(Reg));
|
CPU_Message(" regcache: allocate %s as Memory Stack",x86_Name(Reg));
|
||||||
|
@ -545,7 +545,7 @@ void CRegInfo::Map_GPR_32bit (int MipsReg, bool SignValue, int MipsRegToLoad)
|
||||||
x86Reg Reg;
|
x86Reg Reg;
|
||||||
if (MipsReg == 0)
|
if (MipsReg == 0)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -554,9 +554,9 @@ void CRegInfo::Map_GPR_32bit (int MipsReg, bool SignValue, int MipsRegToLoad)
|
||||||
Reg = FreeX86Reg();
|
Reg = FreeX86Reg();
|
||||||
if (Reg < 0) {
|
if (Reg < 0) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Map_GPR_32bit\n\nOut of registers");
|
g_Notify->DisplayError("Map_GPR_32bit\n\nOut of registers");
|
||||||
#endif
|
#endif
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
CPU_Message(" regcache: allocate %s to %s",x86_Name(Reg),CRegName::GPR[MipsReg]);
|
CPU_Message(" regcache: allocate %s to %s",x86_Name(Reg),CRegName::GPR[MipsReg]);
|
||||||
|
@ -610,7 +610,7 @@ void CRegInfo::Map_GPR_64bit ( int MipsReg, int MipsRegToLoad)
|
||||||
|
|
||||||
if (MipsReg == 0) {
|
if (MipsReg == 0) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("Map_GPR_32bit\n\nWhy are you trying to map reg 0");
|
g_Notify->DisplayError("Map_GPR_32bit\n\nWhy are you trying to map reg 0");
|
||||||
#endif
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -618,11 +618,11 @@ void CRegInfo::Map_GPR_64bit ( int MipsReg, int MipsRegToLoad)
|
||||||
ProtectGPR(MipsReg);
|
ProtectGPR(MipsReg);
|
||||||
if (IsUnknown(MipsReg) || IsConst(MipsReg)) {
|
if (IsUnknown(MipsReg) || IsConst(MipsReg)) {
|
||||||
x86Hi = FreeX86Reg();
|
x86Hi = FreeX86Reg();
|
||||||
if (x86Hi < 0) { _Notify->DisplayError("Map_GPR_64bit\n\nOut of registers"); return; }
|
if (x86Hi < 0) { g_Notify->DisplayError("Map_GPR_64bit\n\nOut of registers"); return; }
|
||||||
SetX86Protected(x86Hi,TRUE);
|
SetX86Protected(x86Hi,TRUE);
|
||||||
|
|
||||||
x86lo = FreeX86Reg();
|
x86lo = FreeX86Reg();
|
||||||
if (x86lo < 0) { _Notify->DisplayError("Map_GPR_64bit\n\nOut of registers"); return; }
|
if (x86lo < 0) { g_Notify->DisplayError("Map_GPR_64bit\n\nOut of registers"); return; }
|
||||||
SetX86Protected(x86lo,TRUE);
|
SetX86Protected(x86lo,TRUE);
|
||||||
|
|
||||||
CPU_Message(" regcache: allocate %s to hi word of %s",x86_Name(x86Hi),CRegName::GPR[MipsReg]);
|
CPU_Message(" regcache: allocate %s to hi word of %s",x86_Name(x86Hi),CRegName::GPR[MipsReg]);
|
||||||
|
@ -634,7 +634,7 @@ void CRegInfo::Map_GPR_64bit ( int MipsReg, int MipsRegToLoad)
|
||||||
x86Hi = FreeX86Reg();
|
x86Hi = FreeX86Reg();
|
||||||
if (x86Hi == x86_Unknown)
|
if (x86Hi == x86_Unknown)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
SetX86Protected(x86Hi,TRUE);
|
SetX86Protected(x86Hi,TRUE);
|
||||||
|
@ -721,7 +721,7 @@ CX86Ops::x86Reg CRegInfo::Map_TempReg (CX86Ops::x86Reg Reg, int MipsReg, BOOL Lo
|
||||||
if (Reg == x86_Unknown)
|
if (Reg == x86_Unknown)
|
||||||
{
|
{
|
||||||
WriteTrace(TraceError,"CRegInfo::Map_TempReg: Failed to find a free register");
|
WriteTrace(TraceError,"CRegInfo::Map_TempReg: Failed to find a free register");
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return x86_Unknown;
|
return x86_Unknown;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -738,7 +738,7 @@ CX86Ops::x86Reg CRegInfo::Map_TempReg (CX86Ops::x86Reg Reg, int MipsReg, BOOL Lo
|
||||||
Reg = Free8BitX86Reg();
|
Reg = Free8BitX86Reg();
|
||||||
if (Reg < 0) {
|
if (Reg < 0) {
|
||||||
WriteTrace(TraceError,"CRegInfo::Map_TempReg: Failed to find a free 8 bit register");
|
WriteTrace(TraceError,"CRegInfo::Map_TempReg: Failed to find a free 8 bit register");
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return x86_Unknown;
|
return x86_Unknown;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -746,7 +746,7 @@ CX86Ops::x86Reg CRegInfo::Map_TempReg (CX86Ops::x86Reg Reg, int MipsReg, BOOL Lo
|
||||||
if (GetX86Protected(Reg))
|
if (GetX86Protected(Reg))
|
||||||
{
|
{
|
||||||
WriteTrace(TraceError,"CRegInfo::Map_TempReg: Register is protected");
|
WriteTrace(TraceError,"CRegInfo::Map_TempReg: Register is protected");
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return x86_Unknown;
|
return x86_Unknown;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -963,7 +963,7 @@ void CRegInfo::UnMap_FPR (int Reg, int WriteBackValue )
|
||||||
break;
|
break;
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
default:
|
default:
|
||||||
_Notify->DisplayError("UnMap_FPR\nUnknown format to load %d",x86fpu_State[StackTopPos()]);
|
g_Notify->DisplayError("UnMap_FPR\nUnknown format to load %d",x86fpu_State[StackTopPos()]);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
SetX86Protected(TempReg,FALSE);
|
SetX86Protected(TempReg,FALSE);
|
||||||
|
@ -986,7 +986,7 @@ void CRegInfo::UnMap_GPR (DWORD Reg, bool WriteBackValue)
|
||||||
{
|
{
|
||||||
if (Reg == 0) {
|
if (Reg == 0) {
|
||||||
#ifndef EXTERNAL_RELEASE
|
#ifndef EXTERNAL_RELEASE
|
||||||
_Notify->DisplayError("UnMap_GPR\n\nWhy are you trying to unmap reg 0");
|
g_Notify->DisplayError("UnMap_GPR\n\nWhy are you trying to unmap reg 0");
|
||||||
#endif
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1209,7 +1209,7 @@ void CRegInfo::WriteBackRegisters ()
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
CPU_Message(__FUNCTION__ ": Unknown State: %d reg %d (%s)",GetMipsRegState(count),count,CRegName::GPR[count])
|
CPU_Message(__FUNCTION__ ": Unknown State: %d reg %d (%s)",GetMipsRegState(count),count,CRegName::GPR[count])
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,7 +56,7 @@ void CCodeSection::UnlinkParent( CCodeSection * Parent, bool AllowDelete, bool C
|
||||||
// {
|
// {
|
||||||
// if (!ContinueSection && Parent->ContinueSection == this)
|
// if (!ContinueSection && Parent->ContinueSection == this)
|
||||||
// {
|
// {
|
||||||
// _Notify->BreakPoint(__FILE__,__LINE__);
|
// g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
// }
|
// }
|
||||||
// }
|
// }
|
||||||
if (ContinueSection && Parent->ContinueSection == this)
|
if (ContinueSection && Parent->ContinueSection == this)
|
||||||
|
@ -67,7 +67,7 @@ void CCodeSection::UnlinkParent( CCodeSection * Parent, bool AllowDelete, bool C
|
||||||
// {
|
// {
|
||||||
// if (ContinueSection && Parent->JumpSection == this)
|
// if (ContinueSection && Parent->JumpSection == this)
|
||||||
// {
|
// {
|
||||||
// _Notify->BreakPoint(__FILE__,__LINE__);
|
// g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
// }
|
// }
|
||||||
// }
|
// }
|
||||||
if (!ContinueSection && Parent->JumpSection == this)
|
if (!ContinueSection && Parent->JumpSection == this)
|
||||||
|
@ -106,7 +106,7 @@ CCodeSection::~CCodeSection ( void )
|
||||||
ContinueSection->UnlinkParent(this, true, true);
|
ContinueSection->UnlinkParent(this, true, true);
|
||||||
if (ContinueSection)
|
if (ContinueSection)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
ContinueSection = NULL;
|
ContinueSection = NULL;
|
||||||
}
|
}
|
||||||
|
@ -115,7 +115,7 @@ CCodeSection::~CCodeSection ( void )
|
||||||
JumpSection->UnlinkParent(this, true, false);
|
JumpSection->UnlinkParent(this, true, false);
|
||||||
if (JumpSection)
|
if (JumpSection)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
JumpSection = NULL;
|
JumpSection = NULL;
|
||||||
}
|
}
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,8 +1,8 @@
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#pragma comment(lib, "winmm.lib")
|
#pragma comment(lib, "winmm.lib")
|
||||||
|
|
||||||
CSpeedLimitor::CSpeedLimitor(CNotification * const _Notify ) :
|
CSpeedLimitor::CSpeedLimitor(CNotification * const g_Notify ) :
|
||||||
_Notify(_Notify)
|
g_Notify(g_Notify)
|
||||||
{
|
{
|
||||||
m_Frames = 0;
|
m_Frames = 0;
|
||||||
m_LastTime = 0;
|
m_LastTime = 0;
|
||||||
|
@ -13,7 +13,7 @@ CSpeedLimitor::CSpeedLimitor(CNotification * const _Notify ) :
|
||||||
TIMECAPS Caps;
|
TIMECAPS Caps;
|
||||||
timeGetDevCaps(&Caps, sizeof(Caps));
|
timeGetDevCaps(&Caps, sizeof(Caps));
|
||||||
if (timeBeginPeriod(Caps.wPeriodMin) == TIMERR_NOCANDO) {
|
if (timeBeginPeriod(Caps.wPeriodMin) == TIMERR_NOCANDO) {
|
||||||
_Notify->DisplayError("Error during timer begin");
|
g_Notify->DisplayError("Error during timer begin");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,12 +1,12 @@
|
||||||
class CSpeedLimitor {
|
class CSpeedLimitor {
|
||||||
CNotification * const _Notify;
|
CNotification * const g_Notify;
|
||||||
DWORD m_Speed, m_BaseSpeed, m_Frames, m_LastTime;
|
DWORD m_Speed, m_BaseSpeed, m_Frames, m_LastTime;
|
||||||
double m_Ratio;
|
double m_Ratio;
|
||||||
|
|
||||||
void FixSpeedRatio ( void );
|
void FixSpeedRatio ( void );
|
||||||
|
|
||||||
public:
|
public:
|
||||||
CSpeedLimitor ( CNotification * const _Notify );
|
CSpeedLimitor ( CNotification * const g_Notify );
|
||||||
~CSpeedLimitor ( void );
|
~CSpeedLimitor ( void );
|
||||||
void SetHertz ( const DWORD Hertz );
|
void SetHertz ( const DWORD Hertz );
|
||||||
bool Timer_Process ( DWORD * const FrameRate );
|
bool Timer_Process ( DWORD * const FrameRate );
|
||||||
|
|
|
@ -7,7 +7,7 @@ CRecompiler * _Recompiler = NULL;
|
||||||
CMipsMemory * _MMU = NULL; //Memory of the n64
|
CMipsMemory * _MMU = NULL; //Memory of the n64
|
||||||
CTLB * _TLB = NULL; //TLB Unit
|
CTLB * _TLB = NULL; //TLB Unit
|
||||||
CRegisters * _Reg = NULL; //Current Register Set attacted to the _MMU
|
CRegisters * _Reg = NULL; //Current Register Set attacted to the _MMU
|
||||||
CNotification * _Notify = NULL;
|
CNotification * g_Notify = NULL;
|
||||||
CPlugins * _Plugins = NULL;
|
CPlugins * _Plugins = NULL;
|
||||||
CN64Rom * _Rom = NULL; //The current rom that this system is executing.. it can only execute one file at the time
|
CN64Rom * _Rom = NULL; //The current rom that this system is executing.. it can only execute one file at the time
|
||||||
CAudio * _Audio = NULL;
|
CAudio * _Audio = NULL;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
extern CNotification * _Notify;
|
extern CNotification * g_Notify;
|
||||||
extern CSettings * _Settings;
|
extern CSettings * _Settings;
|
||||||
|
|
||||||
extern CN64System * _System;
|
extern CN64System * _System;
|
||||||
|
|
|
@ -273,7 +273,7 @@ void CControl_Plugin::UpdateKeys (void) {
|
||||||
if (!m_Controllers[cont]->m_RawData) {
|
if (!m_Controllers[cont]->m_RawData) {
|
||||||
GetKeys(cont,&m_Controllers[cont]->m_Buttons);
|
GetKeys(cont,&m_Controllers[cont]->m_Buttons);
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (ReadController) { ReadController(-1,NULL); }
|
if (ReadController) { ReadController(-1,NULL); }
|
||||||
|
|
|
@ -47,7 +47,7 @@ void CPlugins::PluginChanged ( CPlugins * _this )
|
||||||
if (_BaseSystem) { _BaseSystem->ExternalEvent(SysEvent_ChangePlugins); }
|
if (_BaseSystem) { _BaseSystem->ExternalEvent(SysEvent_ChangePlugins); }
|
||||||
} else {
|
} else {
|
||||||
_this->Reset();
|
_this->Reset();
|
||||||
_Notify->RefreshMenu();
|
g_Notify->RefreshMenu();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -60,7 +60,7 @@ void CPlugins::CreatePlugins( void ) {
|
||||||
|
|
||||||
if (bHaveDebugger())
|
if (bHaveDebugger())
|
||||||
{
|
{
|
||||||
_Notify->RefreshMenu();
|
g_Notify->RefreshMenu();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -112,7 +112,7 @@ bool CSettingTypeApplication::Load ( int /*Index*/, bool & Value ) const
|
||||||
Value = dwValue != 0;
|
Value = dwValue != 0;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!bRes && m_DefaultSetting != Default_None)
|
if (!bRes && m_DefaultSetting != Default_None)
|
||||||
|
@ -134,7 +134,7 @@ bool CSettingTypeApplication::Load ( int /*Index*/, ULONG & Value ) const
|
||||||
{
|
{
|
||||||
bRes = m_SettingsIniFile->GetNumber(SectionName(),m_KeyNameIdex.c_str(),Value,Value);
|
bRes = m_SettingsIniFile->GetNumber(SectionName(),m_KeyNameIdex.c_str(),Value,Value);
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (!bRes && m_DefaultSetting != Default_None)
|
if (!bRes && m_DefaultSetting != Default_None)
|
||||||
{
|
{
|
||||||
|
@ -160,7 +160,7 @@ bool CSettingTypeApplication::Load ( int Index, stdstr & Value ) const
|
||||||
{
|
{
|
||||||
bRes = m_SettingsIniFile ? m_SettingsIniFile->GetString(SectionName(),m_KeyNameIdex.c_str(),m_DefaultStr,Value) : false;
|
bRes = m_SettingsIniFile ? m_SettingsIniFile->GetString(SectionName(),m_KeyNameIdex.c_str(),m_DefaultStr,Value) : false;
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (!bRes)
|
if (!bRes)
|
||||||
{
|
{
|
||||||
|
@ -216,7 +216,7 @@ void CSettingTypeApplication::Save ( int /*Index*/, bool Value )
|
||||||
{
|
{
|
||||||
m_SettingsIniFile->SaveNumber(SectionName(),m_KeyNameIdex.c_str(),Value);
|
m_SettingsIniFile->SaveNumber(SectionName(),m_KeyNameIdex.c_str(),Value);
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -226,7 +226,7 @@ void CSettingTypeApplication::Save ( int /*Index*/, ULONG Value )
|
||||||
{
|
{
|
||||||
m_SettingsIniFile->SaveNumber(SectionName(),m_KeyNameIdex.c_str(),Value);
|
m_SettingsIniFile->SaveNumber(SectionName(),m_KeyNameIdex.c_str(),Value);
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -236,7 +236,7 @@ void CSettingTypeApplication::Save ( int /*Index*/, const stdstr & Value )
|
||||||
{
|
{
|
||||||
m_SettingsIniFile->SaveString(SectionName(),m_KeyNameIdex.c_str(),Value.c_str());
|
m_SettingsIniFile->SaveString(SectionName(),m_KeyNameIdex.c_str(),Value.c_str());
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -246,7 +246,7 @@ void CSettingTypeApplication::Save ( int /*Index*/, const char * Value )
|
||||||
{
|
{
|
||||||
m_SettingsIniFile->SaveString(SectionName(),m_KeyNameIdex.c_str(),Value);
|
m_SettingsIniFile->SaveString(SectionName(),m_KeyNameIdex.c_str(),Value);
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -271,6 +271,6 @@ void CSettingTypeApplication::Delete( int /*Index*/ )
|
||||||
{
|
{
|
||||||
m_SettingsIniFile->SaveString(SectionName(),m_KeyNameIdex.c_str(),NULL);
|
m_SettingsIniFile->SaveString(SectionName(),m_KeyNameIdex.c_str(),NULL);
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -62,18 +62,18 @@ LPCSTR CSettingTypeCheats::SectionName ( void ) const
|
||||||
|
|
||||||
void CSettingTypeCheats::UpdateSettings ( void * )
|
void CSettingTypeCheats::UpdateSettings ( void * )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}*/
|
}*/
|
||||||
|
|
||||||
bool CSettingTypeCheats::Load ( int /*Index*/, bool & /*Value*/ ) const
|
bool CSettingTypeCheats::Load ( int /*Index*/, bool & /*Value*/ ) const
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CSettingTypeCheats::Load ( int /*Index*/, ULONG & /*Value*/ ) const
|
bool CSettingTypeCheats::Load ( int /*Index*/, ULONG & /*Value*/ ) const
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -90,28 +90,28 @@ bool CSettingTypeCheats::Load ( int Index, stdstr & Value ) const
|
||||||
//return the default values
|
//return the default values
|
||||||
void CSettingTypeCheats::LoadDefault ( int /*Index*/, bool & /*Value*/ ) const
|
void CSettingTypeCheats::LoadDefault ( int /*Index*/, bool & /*Value*/ ) const
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeCheats::LoadDefault ( int /*Index*/, ULONG & /*Value*/ ) const
|
void CSettingTypeCheats::LoadDefault ( int /*Index*/, ULONG & /*Value*/ ) const
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeCheats::LoadDefault ( int /*Index*/, stdstr & /*Value*/ ) const
|
void CSettingTypeCheats::LoadDefault ( int /*Index*/, stdstr & /*Value*/ ) const
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
//Update the settings
|
//Update the settings
|
||||||
void CSettingTypeCheats::Save ( int /*Index*/, bool /*Value*/ )
|
void CSettingTypeCheats::Save ( int /*Index*/, bool /*Value*/ )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeCheats::Save ( int /*Index*/, ULONG /*Value*/ )
|
void CSettingTypeCheats::Save ( int /*Index*/, ULONG /*Value*/ )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeCheats::Save ( int Index, const stdstr & Value )
|
void CSettingTypeCheats::Save ( int Index, const stdstr & Value )
|
||||||
|
|
|
@ -44,13 +44,13 @@ bool CSettingTypeRDBYesNo::Load ( int Index, bool & Value ) const
|
||||||
|
|
||||||
bool CSettingTypeRDBYesNo::Load ( int /*Index*/, ULONG & /*Value*/ ) const
|
bool CSettingTypeRDBYesNo::Load ( int /*Index*/, ULONG & /*Value*/ ) const
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CSettingTypeRDBYesNo::Load ( int /*Index*/, stdstr & /*Value*/ ) const
|
bool CSettingTypeRDBYesNo::Load ( int /*Index*/, stdstr & /*Value*/ ) const
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,12 +70,12 @@ void CSettingTypeRDBYesNo::LoadDefault ( int /*Index*/, bool & Value ) const
|
||||||
|
|
||||||
void CSettingTypeRDBYesNo::LoadDefault ( int /*Index*/, ULONG & /*Value*/ ) const
|
void CSettingTypeRDBYesNo::LoadDefault ( int /*Index*/, ULONG & /*Value*/ ) const
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeRDBYesNo::LoadDefault ( int /*Index*/, stdstr & /*Value*/ ) const
|
void CSettingTypeRDBYesNo::LoadDefault ( int /*Index*/, stdstr & /*Value*/ ) const
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -92,12 +92,12 @@ void CSettingTypeRDBYesNo::Save ( int /*Index*/, ULONG Value )
|
||||||
|
|
||||||
void CSettingTypeRDBYesNo::Save ( int /*Index*/, const stdstr & /*Value*/ )
|
void CSettingTypeRDBYesNo::Save ( int /*Index*/, const stdstr & /*Value*/ )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeRDBYesNo::Save ( int /*Index*/, const char * /*Value*/ )
|
void CSettingTypeRDBYesNo::Save ( int /*Index*/, const char * /*Value*/ )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeRDBYesNo::Delete( int /*Index*/ )
|
void CSettingTypeRDBYesNo::Delete( int /*Index*/ )
|
||||||
|
|
|
@ -356,7 +356,7 @@ void CSettings::RegisterSetting ( CSettings * _this, SettingID ID, SettingID Def
|
||||||
case SettingType_ConstValue:
|
case SettingType_ConstValue:
|
||||||
if (DataType != Data_DWORD)
|
if (DataType != Data_DWORD)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
_this->AddHandler(ID,new CSettingTypeTempNumber(Value));
|
_this->AddHandler(ID,new CSettingTypeTempNumber(Value));
|
||||||
|
@ -364,7 +364,7 @@ void CSettings::RegisterSetting ( CSettings * _this, SettingID ID, SettingID Def
|
||||||
case SettingType_ConstString:
|
case SettingType_ConstString:
|
||||||
if (DataType != Data_String)
|
if (DataType != Data_String)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
_this->AddHandler(ID,new CSettingTypeTempString(DefaultStr));
|
_this->AddHandler(ID,new CSettingTypeTempString(DefaultStr));
|
||||||
|
@ -390,7 +390,7 @@ void CSettings::RegisterSetting ( CSettings * _this, SettingID ID, SettingID Def
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case SettingType_GameSetting:
|
case SettingType_GameSetting:
|
||||||
|
@ -415,7 +415,7 @@ void CSettings::RegisterSetting ( CSettings * _this, SettingID ID, SettingID Def
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -439,11 +439,11 @@ void CSettings::RegisterSetting ( CSettings * _this, SettingID ID, SettingID Def
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -477,7 +477,7 @@ bool CSettings::LoadBool ( SettingID Type, bool & Value )
|
||||||
}
|
}
|
||||||
if (FindInfo->second->IndexBasedSetting())
|
if (FindInfo->second->IndexBasedSetting())
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
} else {
|
} else {
|
||||||
return FindInfo->second->Load(0,Value);
|
return FindInfo->second->Load(0,Value);
|
||||||
}
|
}
|
||||||
|
@ -504,7 +504,7 @@ bool CSettings::LoadBoolIndex( SettingID Type, int index , bool & Value )
|
||||||
{
|
{
|
||||||
return FindInfo->second->Load(index,Value);
|
return FindInfo->second->Load(index,Value);
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -527,7 +527,7 @@ bool CSettings::LoadDword ( SettingID Type, DWORD & Value)
|
||||||
}
|
}
|
||||||
if (FindInfo->second->IndexBasedSetting())
|
if (FindInfo->second->IndexBasedSetting())
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
} else {
|
} else {
|
||||||
return FindInfo->second->Load(0,Value);
|
return FindInfo->second->Load(0,Value);
|
||||||
}
|
}
|
||||||
|
@ -554,7 +554,7 @@ bool CSettings::LoadDwordIndex( SettingID Type, int index, DWORD & Value)
|
||||||
{
|
{
|
||||||
return FindInfo->second->Load(index,Value);
|
return FindInfo->second->Load(index,Value);
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -577,7 +577,7 @@ bool CSettings::LoadString ( SettingID Type, stdstr & Value )
|
||||||
}
|
}
|
||||||
if (FindInfo->second->IndexBasedSetting())
|
if (FindInfo->second->IndexBasedSetting())
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
} else {
|
} else {
|
||||||
return FindInfo->second->Load(0,Value);
|
return FindInfo->second->Load(0,Value);
|
||||||
}
|
}
|
||||||
|
@ -596,7 +596,7 @@ bool CSettings::LoadString ( SettingID Type, char * Buffer, int BufferSize )
|
||||||
bool bRes = false;
|
bool bRes = false;
|
||||||
if (FindInfo->second->IndexBasedSetting())
|
if (FindInfo->second->IndexBasedSetting())
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
} else {
|
} else {
|
||||||
stdstr Value;
|
stdstr Value;
|
||||||
bRes = FindInfo->second->Load(0,Value);
|
bRes = FindInfo->second->Load(0,Value);
|
||||||
|
@ -630,14 +630,14 @@ bool CSettings::LoadStringIndex ( SettingID Type, int index, stdstr & Value )
|
||||||
{
|
{
|
||||||
return FindInfo->second->Load(index,Value);
|
return FindInfo->second->Load(index,Value);
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CSettings::LoadStringIndex ( SettingID /*Type*/, int /*index*/, char * /*Buffer*/, int /*BufferSize*/ )
|
bool CSettings::LoadStringIndex ( SettingID /*Type*/, int /*index*/, char * /*Buffer*/, int /*BufferSize*/ )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -659,7 +659,7 @@ void CSettings::LoadDefaultBool ( SettingID Type, bool & Value )
|
||||||
} else {
|
} else {
|
||||||
if (FindInfo->second->IndexBasedSetting())
|
if (FindInfo->second->IndexBasedSetting())
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
} else {
|
} else {
|
||||||
FindInfo->second->LoadDefault(0,Value);
|
FindInfo->second->LoadDefault(0,Value);
|
||||||
}
|
}
|
||||||
|
@ -668,13 +668,13 @@ void CSettings::LoadDefaultBool ( SettingID Type, bool & Value )
|
||||||
|
|
||||||
bool CSettings::LoadDefaultBoolIndex ( SettingID /*Type*/, int /*index*/ )
|
bool CSettings::LoadDefaultBoolIndex ( SettingID /*Type*/, int /*index*/ )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettings::LoadDefaultBoolIndex ( SettingID /*Type*/, int /*index*/, bool & /*Value*/ )
|
void CSettings::LoadDefaultBoolIndex ( SettingID /*Type*/, int /*index*/, bool & /*Value*/ )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
DWORD CSettings::LoadDefaultDword ( SettingID Type )
|
DWORD CSettings::LoadDefaultDword ( SettingID Type )
|
||||||
|
@ -694,7 +694,7 @@ void CSettings::LoadDefaultDword ( SettingID Type, DWORD & Value)
|
||||||
} else {
|
} else {
|
||||||
if (FindInfo->second->IndexBasedSetting())
|
if (FindInfo->second->IndexBasedSetting())
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
} else {
|
} else {
|
||||||
FindInfo->second->LoadDefault(0,Value);
|
FindInfo->second->LoadDefault(0,Value);
|
||||||
}
|
}
|
||||||
|
@ -703,13 +703,13 @@ void CSettings::LoadDefaultDword ( SettingID Type, DWORD & Value)
|
||||||
|
|
||||||
DWORD CSettings::LoadDefaultDwordIndex ( SettingID /*Type*/, int /*index*/ )
|
DWORD CSettings::LoadDefaultDwordIndex ( SettingID /*Type*/, int /*index*/ )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettings::LoadDefaultDwordIndex ( SettingID /*Type*/, int /*index*/, DWORD & /*Value*/)
|
void CSettings::LoadDefaultDwordIndex ( SettingID /*Type*/, int /*index*/, DWORD & /*Value*/)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
stdstr CSettings::LoadDefaultString ( SettingID Type )
|
stdstr CSettings::LoadDefaultString ( SettingID Type )
|
||||||
|
@ -729,7 +729,7 @@ void CSettings::LoadDefaultString ( SettingID Type, stdstr & Value )
|
||||||
} else {
|
} else {
|
||||||
if (FindInfo->second->IndexBasedSetting())
|
if (FindInfo->second->IndexBasedSetting())
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
} else {
|
} else {
|
||||||
FindInfo->second->LoadDefault(0,Value);
|
FindInfo->second->LoadDefault(0,Value);
|
||||||
}
|
}
|
||||||
|
@ -738,23 +738,23 @@ void CSettings::LoadDefaultString ( SettingID Type, stdstr & Value )
|
||||||
|
|
||||||
void CSettings::LoadDefaultString ( SettingID /*Type*/, char * /*Buffer*/, int /*BufferSize*/ )
|
void CSettings::LoadDefaultString ( SettingID /*Type*/, char * /*Buffer*/, int /*BufferSize*/ )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
stdstr CSettings::LoadDefaultStringIndex ( SettingID /*Type*/, int /*index*/ )
|
stdstr CSettings::LoadDefaultStringIndex ( SettingID /*Type*/, int /*index*/ )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettings::LoadDefaultStringIndex ( SettingID /*Type*/, int /*index*/, stdstr & /*Value*/ )
|
void CSettings::LoadDefaultStringIndex ( SettingID /*Type*/, int /*index*/, stdstr & /*Value*/ )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettings::LoadDefaultStringIndex ( SettingID /*Type*/, int /*index*/, char * /*Buffer*/, int /*BufferSize*/ )
|
void CSettings::LoadDefaultStringIndex ( SettingID /*Type*/, int /*index*/, char * /*Buffer*/, int /*BufferSize*/ )
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettings::SaveBool ( SettingID Type, bool Value )
|
void CSettings::SaveBool ( SettingID Type, bool Value )
|
||||||
|
@ -768,7 +768,7 @@ void CSettings::SaveBool ( SettingID Type, bool Value )
|
||||||
}
|
}
|
||||||
if (FindInfo->second->IndexBasedSetting())
|
if (FindInfo->second->IndexBasedSetting())
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
} else {
|
} else {
|
||||||
FindInfo->second->Save(0,Value);
|
FindInfo->second->Save(0,Value);
|
||||||
}
|
}
|
||||||
|
@ -788,7 +788,7 @@ void CSettings::SaveBoolIndex( SettingID Type, int index, bool Value )
|
||||||
{
|
{
|
||||||
FindInfo->second->Save(index,Value);
|
FindInfo->second->Save(index,Value);
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
NotifyCallBacks(Type);
|
NotifyCallBacks(Type);
|
||||||
}
|
}
|
||||||
|
@ -804,7 +804,7 @@ void CSettings::SaveDword ( SettingID Type, DWORD Value )
|
||||||
}
|
}
|
||||||
if (FindInfo->second->IndexBasedSetting())
|
if (FindInfo->second->IndexBasedSetting())
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
} else {
|
} else {
|
||||||
FindInfo->second->Save(0,Value);
|
FindInfo->second->Save(0,Value);
|
||||||
}
|
}
|
||||||
|
@ -824,7 +824,7 @@ void CSettings::SaveDwordIndex ( SettingID Type, int index, DWORD Value )
|
||||||
{
|
{
|
||||||
FindInfo->second->Save(index,Value);
|
FindInfo->second->Save(index,Value);
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
NotifyCallBacks(Type);
|
NotifyCallBacks(Type);
|
||||||
}
|
}
|
||||||
|
@ -840,7 +840,7 @@ void CSettings::SaveString ( SettingID Type, const stdstr & Value )
|
||||||
}
|
}
|
||||||
if (FindInfo->second->IndexBasedSetting())
|
if (FindInfo->second->IndexBasedSetting())
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
} else {
|
} else {
|
||||||
FindInfo->second->Save(0,Value);
|
FindInfo->second->Save(0,Value);
|
||||||
}
|
}
|
||||||
|
@ -857,7 +857,7 @@ void CSettings::SaveString ( SettingID Type, const char * Buffer )
|
||||||
}
|
}
|
||||||
if (FindInfo->second->IndexBasedSetting())
|
if (FindInfo->second->IndexBasedSetting())
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
} else {
|
} else {
|
||||||
FindInfo->second->Save(0,Buffer);
|
FindInfo->second->Save(0,Buffer);
|
||||||
}
|
}
|
||||||
|
@ -876,7 +876,7 @@ void CSettings::SaveStringIndex( SettingID Type, int index, const char * Buffer
|
||||||
{
|
{
|
||||||
FindInfo->second->Save(index,Buffer);
|
FindInfo->second->Save(index,Buffer);
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
NotifyCallBacks(Type);
|
NotifyCallBacks(Type);
|
||||||
}
|
}
|
||||||
|
@ -896,7 +896,7 @@ void CSettings::DeleteSetting( SettingID Type )
|
||||||
}
|
}
|
||||||
if (FindInfo->second->IndexBasedSetting())
|
if (FindInfo->second->IndexBasedSetting())
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
} else {
|
} else {
|
||||||
FindInfo->second->Delete(0);
|
FindInfo->second->Delete(0);
|
||||||
}
|
}
|
||||||
|
@ -915,7 +915,7 @@ void CSettings::DeleteSettingIndex( SettingID Type, int index )
|
||||||
{
|
{
|
||||||
FindInfo->second->Delete(index);
|
FindInfo->second->Delete(index);
|
||||||
} else {
|
} else {
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
NotifyCallBacks(Type);
|
NotifyCallBacks(Type);
|
||||||
}
|
}
|
||||||
|
@ -960,7 +960,7 @@ void CSettings::SettingTypeChanged( SettingType Type )
|
||||||
void CSettings::UnknownSetting (SettingID /*Type*/)
|
void CSettings::UnknownSetting (SettingID /*Type*/)
|
||||||
{
|
{
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1044,6 +1044,6 @@ void CSettings::UnregisterChangeCB(SettingID Type,void * Data, SettingChangedFun
|
||||||
|
|
||||||
if (!bRemoved)
|
if (!bRemoved)
|
||||||
{
|
{
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
|
|
||||||
CFramePerSecond::CFramePerSecond (CNotification * Notification):
|
CFramePerSecond::CFramePerSecond (CNotification * Notification):
|
||||||
_Notify(Notification)
|
g_Notify(Notification)
|
||||||
{
|
{
|
||||||
m_iFrameRateType = _Settings->LoadDword(UserInterface_FrameDisplayType);
|
m_iFrameRateType = _Settings->LoadDword(UserInterface_FrameDisplayType);
|
||||||
m_ScreenHertz = _Settings->LoadDword(GameRunning_ScreenHertz);
|
m_ScreenHertz = _Settings->LoadDword(GameRunning_ScreenHertz);
|
||||||
|
@ -34,7 +34,7 @@ void CFramePerSecond::Reset (bool ClearDisplay) {
|
||||||
}
|
}
|
||||||
if (ClearDisplay)
|
if (ClearDisplay)
|
||||||
{
|
{
|
||||||
_Notify->DisplayMessage2("");
|
g_Notify->DisplayMessage2("");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -64,7 +64,7 @@ void CFramePerSecond::DisplayViCounter(DWORD FrameRate) {
|
||||||
if (m_iFrameRateType == FR_VIs)
|
if (m_iFrameRateType == FR_VIs)
|
||||||
{
|
{
|
||||||
if (FrameRate != 0) {
|
if (FrameRate != 0) {
|
||||||
_Notify->DisplayMessage2("VI/s: %d.00", FrameRate);
|
g_Notify->DisplayMessage2("VI/s: %d.00", FrameRate);
|
||||||
} else {
|
} else {
|
||||||
if (CurrentFrame > (NoOfFrames << 3)) {
|
if (CurrentFrame > (NoOfFrames << 3)) {
|
||||||
__int64 Total;
|
__int64 Total;
|
||||||
|
@ -73,9 +73,9 @@ void CFramePerSecond::DisplayViCounter(DWORD FrameRate) {
|
||||||
for (int count = 0; count < NoOfFrames; count ++) {
|
for (int count = 0; count < NoOfFrames; count ++) {
|
||||||
Total += Frames[count];
|
Total += Frames[count];
|
||||||
}
|
}
|
||||||
_Notify->DisplayMessage2("VI/s: %.2f", Frequency/ ((double)Total / (NoOfFrames << 3)));
|
g_Notify->DisplayMessage2("VI/s: %.2f", Frequency/ ((double)Total / (NoOfFrames << 3)));
|
||||||
} else {
|
} else {
|
||||||
_Notify->DisplayMessage2("VI/s: -.--");
|
g_Notify->DisplayMessage2("VI/s: -.--");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -94,11 +94,11 @@ void CFramePerSecond::DisplayViCounter(DWORD FrameRate) {
|
||||||
}
|
}
|
||||||
Percent = ((float)(Frequency/ ((double)Total / (NoOfFrames << 3)))) / m_ScreenHertz;
|
Percent = ((float)(Frequency/ ((double)Total / (NoOfFrames << 3)))) / m_ScreenHertz;
|
||||||
} else {
|
} else {
|
||||||
_Notify->DisplayMessage2("");
|
g_Notify->DisplayMessage2("");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_Notify->DisplayMessage2("%.1f %%",Percent * 100);
|
g_Notify->DisplayMessage2("%.1f %%",Percent * 100);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -136,7 +136,7 @@ void CFramePerSecond::DisplayDlCounter(DWORD FrameRate) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (FrameRate != 0) {
|
if (FrameRate != 0) {
|
||||||
_Notify->DisplayMessage2("DL/s: %d.00", FrameRate);
|
g_Notify->DisplayMessage2("DL/s: %d.00", FrameRate);
|
||||||
} else {
|
} else {
|
||||||
if (CurrentFrame > (NoOfFrames << 2)) {
|
if (CurrentFrame > (NoOfFrames << 2)) {
|
||||||
__int64 Total;
|
__int64 Total;
|
||||||
|
@ -145,9 +145,9 @@ void CFramePerSecond::DisplayDlCounter(DWORD FrameRate) {
|
||||||
for (int count = 0; count < NoOfFrames; count ++) {
|
for (int count = 0; count < NoOfFrames; count ++) {
|
||||||
Total += Frames[count];
|
Total += Frames[count];
|
||||||
}
|
}
|
||||||
_Notify->DisplayMessage2("DL/s: %.1f", Frequency/ ((double)Total / (NoOfFrames << 2)));
|
g_Notify->DisplayMessage2("DL/s: %.1f", Frequency/ ((double)Total / (NoOfFrames << 2)));
|
||||||
} else {
|
} else {
|
||||||
_Notify->DisplayMessage2("DL/s: -.--");
|
g_Notify->DisplayMessage2("DL/s: -.--");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
class CFramePerSecond {
|
class CFramePerSecond {
|
||||||
CNotification * const _Notify;
|
CNotification * const g_Notify;
|
||||||
int m_iFrameRateType, m_ScreenHertz;
|
int m_iFrameRateType, m_ScreenHertz;
|
||||||
|
|
||||||
enum { NoOfFrames = 7 };
|
enum { NoOfFrames = 7 };
|
||||||
|
|
|
@ -687,7 +687,7 @@ DWORD CALLBACK CMainGui::MainGui_Proc (WND_HANDLE hWnd, DWORD uMsg, DWORD wParam
|
||||||
{
|
{
|
||||||
if (!fActive && _Settings->LoadBool(UserInterface_InFullScreen))
|
if (!fActive && _Settings->LoadBool(UserInterface_InFullScreen))
|
||||||
{
|
{
|
||||||
_Notify->WindowMode();
|
g_Notify->WindowMode();
|
||||||
if (bAutoSleep() && _BaseSystem)
|
if (bAutoSleep() && _BaseSystem)
|
||||||
{
|
{
|
||||||
//System->ExternalEvent(PauseCPU_AppLostActiveDelayed );
|
//System->ExternalEvent(PauseCPU_AppLostActiveDelayed );
|
||||||
|
@ -792,7 +792,7 @@ DWORD CALLBACK CMainGui::MainGui_Proc (WND_HANDLE hWnd, DWORD uMsg, DWORD wParam
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
Rom.SaveRomSettingID();
|
Rom.SaveRomSettingID();
|
||||||
_Notify->DisplayMessage(0,"");
|
g_Notify->DisplayMessage(0,"");
|
||||||
BYTE * RomHeader = Rom.GetRomAddress();
|
BYTE * RomHeader = Rom.GetRomAddress();
|
||||||
WriteTrace(TraceGfxPlugin,"OnRomBrowserMenuItem: Starting");
|
WriteTrace(TraceGfxPlugin,"OnRomBrowserMenuItem: Starting");
|
||||||
_Plugins->Gfx()->OnRomBrowserMenuItem(LOWORD(wParam),hWnd,RomHeader);
|
_Plugins->Gfx()->OnRomBrowserMenuItem(LOWORD(wParam),hWnd,RomHeader);
|
||||||
|
@ -816,7 +816,7 @@ DWORD CALLBACK CMainGui::MainGui_Proc (WND_HANDLE hWnd, DWORD uMsg, DWORD wParam
|
||||||
CMainGui * _this = (CMainGui *)GetProp((HWND)hWnd,"Class");
|
CMainGui * _this = (CMainGui *)GetProp((HWND)hWnd,"Class");
|
||||||
if (_this->m_bMainWindow)
|
if (_this->m_bMainWindow)
|
||||||
{
|
{
|
||||||
_Notify->WindowMode();
|
g_Notify->WindowMode();
|
||||||
}
|
}
|
||||||
_this->m_hMainWindow = NULL;
|
_this->m_hMainWindow = NULL;
|
||||||
WriteTrace(TraceDebug,"WM_DESTROY - 1");
|
WriteTrace(TraceDebug,"WM_DESTROY - 1");
|
||||||
|
|
|
@ -295,7 +295,7 @@ bool CMainMenu::ProcessMessage(WND_HANDLE hWnd, DWORD /*FromAccelerator*/, DWORD
|
||||||
if (_Settings->LoadBool(UserInterface_ShowCPUPer))
|
if (_Settings->LoadBool(UserInterface_ShowCPUPer))
|
||||||
{
|
{
|
||||||
_Settings->SaveBool(UserInterface_ShowCPUPer,false);
|
_Settings->SaveBool(UserInterface_ShowCPUPer,false);
|
||||||
_Notify->DisplayMessage(0,"");
|
g_Notify->DisplayMessage(0,"");
|
||||||
} else {
|
} else {
|
||||||
_Settings->SaveBool(UserInterface_ShowCPUPer,true);
|
_Settings->SaveBool(UserInterface_ShowCPUPer,true);
|
||||||
}
|
}
|
||||||
|
@ -322,11 +322,11 @@ bool CMainMenu::ProcessMessage(WND_HANDLE hWnd, DWORD /*FromAccelerator*/, DWORD
|
||||||
_Settings->SaveBool(Debugger_ShowPifErrors,!_Settings->LoadBool(Debugger_ShowPifErrors));
|
_Settings->SaveBool(Debugger_ShowPifErrors,!_Settings->LoadBool(Debugger_ShowPifErrors));
|
||||||
break;
|
break;
|
||||||
case ID_DEBUG_SHOW_DLIST_COUNT:
|
case ID_DEBUG_SHOW_DLIST_COUNT:
|
||||||
_Notify->DisplayMessage(0,"");
|
g_Notify->DisplayMessage(0,"");
|
||||||
_Settings->SaveBool(Debugger_ShowDListAListCount,!_Settings->LoadBool(Debugger_ShowDListAListCount));
|
_Settings->SaveBool(Debugger_ShowDListAListCount,!_Settings->LoadBool(Debugger_ShowDListAListCount));
|
||||||
break;
|
break;
|
||||||
case ID_DEBUG_SHOW_RECOMP_MEM_SIZE:
|
case ID_DEBUG_SHOW_RECOMP_MEM_SIZE:
|
||||||
_Notify->DisplayMessage(0,"");
|
g_Notify->DisplayMessage(0,"");
|
||||||
_Settings->SaveBool(Debugger_ShowRecompMemSize,!_Settings->LoadBool(Debugger_ShowRecompMemSize));
|
_Settings->SaveBool(Debugger_ShowRecompMemSize,!_Settings->LoadBool(Debugger_ShowRecompMemSize));
|
||||||
break;
|
break;
|
||||||
case ID_DEBUG_SHOW_DIV_BY_ZERO:
|
case ID_DEBUG_SHOW_DIV_BY_ZERO:
|
||||||
|
@ -525,7 +525,7 @@ bool CMainMenu::ProcessMessage(WND_HANDLE hWnd, DWORD /*FromAccelerator*/, DWORD
|
||||||
stdstr Dir = _Settings->LoadStringIndex(Directory_RecentGameDirIndex,Offset);
|
stdstr Dir = _Settings->LoadStringIndex(Directory_RecentGameDirIndex,Offset);
|
||||||
if (Dir.length() > 0) {
|
if (Dir.length() > 0) {
|
||||||
_Settings->SaveString(Directory_Game,Dir.c_str());
|
_Settings->SaveString(Directory_Game,Dir.c_str());
|
||||||
_Notify->AddRecentDir(Dir.c_str());
|
g_Notify->AddRecentDir(Dir.c_str());
|
||||||
_Gui->RefreshMenu();
|
_Gui->RefreshMenu();
|
||||||
if (_Gui->RomBrowserVisible()) {
|
if (_Gui->RomBrowserVisible()) {
|
||||||
_Gui->RefreshRomBrowser();
|
_Gui->RefreshRomBrowser();
|
||||||
|
|
|
@ -3,8 +3,8 @@
|
||||||
|
|
||||||
CNotification & Notify ( void )
|
CNotification & Notify ( void )
|
||||||
{
|
{
|
||||||
static CNotification _Notify;
|
static CNotification g_Notify;
|
||||||
return _Notify;
|
return g_Notify;
|
||||||
}
|
}
|
||||||
|
|
||||||
CNotification::CNotification ( ) :
|
CNotification::CNotification ( ) :
|
||||||
|
|
|
@ -540,7 +540,7 @@ bool CRomBrowser::GetRomFileNames( strlist & FileList, const CPath & BaseDirecto
|
||||||
|
|
||||||
void CRomBrowser::NotificationCB ( LPCSTR Status, CRomBrowser * /*_this*/ )
|
void CRomBrowser::NotificationCB ( LPCSTR Status, CRomBrowser * /*_this*/ )
|
||||||
{
|
{
|
||||||
_Notify->DisplayMessage(5,"%s",Status);
|
g_Notify->DisplayMessage(5,"%s",Status);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1542,7 +1542,7 @@ void CRomBrowser::SelectRomDir(void)
|
||||||
WriteTrace(TraceDebug,"CRomBrowser::SelectRomDir 6");
|
WriteTrace(TraceDebug,"CRomBrowser::SelectRomDir 6");
|
||||||
_Settings->SaveString(Directory_Game,Directory);
|
_Settings->SaveString(Directory_Game,Directory);
|
||||||
WriteTrace(TraceDebug,"CRomBrowser::SelectRomDir 7");
|
WriteTrace(TraceDebug,"CRomBrowser::SelectRomDir 7");
|
||||||
_Notify->AddRecentDir(Directory);
|
g_Notify->AddRecentDir(Directory);
|
||||||
WriteTrace(TraceDebug,"CRomBrowser::SelectRomDir 8");
|
WriteTrace(TraceDebug,"CRomBrowser::SelectRomDir 8");
|
||||||
RefreshRomBrowser();
|
RefreshRomBrowser();
|
||||||
WriteTrace(TraceDebug,"CRomBrowser::SelectRomDir 9");
|
WriteTrace(TraceDebug,"CRomBrowser::SelectRomDir 9");
|
||||||
|
|
|
@ -120,13 +120,13 @@ void COptionsShortCutsPage::OnRemoveClicked ( UINT /*Code*/, int /*id*/, HWND /*
|
||||||
HTREEITEM hSelectedItem = m_MenuItems.GetSelectedItem();
|
HTREEITEM hSelectedItem = m_MenuItems.GetSelectedItem();
|
||||||
if (hSelectedItem == NULL)
|
if (hSelectedItem == NULL)
|
||||||
{
|
{
|
||||||
_Notify->DisplayError(GS(MSG_NO_SEL_SHORTCUT));
|
g_Notify->DisplayError(GS(MSG_NO_SEL_SHORTCUT));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
HTREEITEM hParent = m_MenuItems.GetParentItem(hSelectedItem);
|
HTREEITEM hParent = m_MenuItems.GetParentItem(hSelectedItem);
|
||||||
if (hParent == NULL)
|
if (hParent == NULL)
|
||||||
{
|
{
|
||||||
_Notify->DisplayError(GS(MSG_NO_SEL_SHORTCUT));
|
g_Notify->DisplayError(GS(MSG_NO_SEL_SHORTCUT));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -136,7 +136,7 @@ void COptionsShortCutsPage::OnRemoveClicked ( UINT /*Code*/, int /*id*/, HWND /*
|
||||||
int index = m_CurrentKeys.GetCurSel();
|
int index = m_CurrentKeys.GetCurSel();
|
||||||
if (index < 0)
|
if (index < 0)
|
||||||
{
|
{
|
||||||
_Notify->DisplayError(GS(MSG_NO_SEL_SHORTCUT));
|
g_Notify->DisplayError(GS(MSG_NO_SEL_SHORTCUT));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
ShortCut->RemoveItem((CMenuShortCutKey *)m_CurrentKeys.GetItemData(index));
|
ShortCut->RemoveItem((CMenuShortCutKey *)m_CurrentKeys.GetItemData(index));
|
||||||
|
@ -159,7 +159,7 @@ void COptionsShortCutsPage::OnAssignClicked ( UINT /*Code*/, int /*id*/, HWND /*
|
||||||
int index = m_VirtualKeyList.GetCurSel();
|
int index = m_VirtualKeyList.GetCurSel();
|
||||||
if (index < 0)
|
if (index < 0)
|
||||||
{
|
{
|
||||||
_Notify->DisplayError(GS(MSG_NO_SHORTCUT_SEL));
|
g_Notify->DisplayError(GS(MSG_NO_SHORTCUT_SEL));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -174,13 +174,13 @@ void COptionsShortCutsPage::OnAssignClicked ( UINT /*Code*/, int /*id*/, HWND /*
|
||||||
HTREEITEM hSelectedItem = m_MenuItems.GetSelectedItem();
|
HTREEITEM hSelectedItem = m_MenuItems.GetSelectedItem();
|
||||||
if (hSelectedItem == NULL)
|
if (hSelectedItem == NULL)
|
||||||
{
|
{
|
||||||
_Notify->DisplayError(GS(MSG_NO_MENUITEM_SEL));
|
g_Notify->DisplayError(GS(MSG_NO_MENUITEM_SEL));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
HTREEITEM hParent = m_MenuItems.GetParentItem(hSelectedItem);
|
HTREEITEM hParent = m_MenuItems.GetParentItem(hSelectedItem);
|
||||||
if (hParent == NULL)
|
if (hParent == NULL)
|
||||||
{
|
{
|
||||||
_Notify->DisplayError(GS(MSG_NO_MENUITEM_SEL));
|
g_Notify->DisplayError(GS(MSG_NO_MENUITEM_SEL));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -189,7 +189,7 @@ void COptionsShortCutsPage::OnAssignClicked ( UINT /*Code*/, int /*id*/, HWND /*
|
||||||
LanguageStringID strid = m_ShortCuts.GetMenuItemName(key,bCtrl,bAlt,bShift,AccessLevel);
|
LanguageStringID strid = m_ShortCuts.GetMenuItemName(key,bCtrl,bAlt,bShift,AccessLevel);
|
||||||
if (strid != EMPTY_STRING)
|
if (strid != EMPTY_STRING)
|
||||||
{
|
{
|
||||||
_Notify->DisplayError(GS(MSG_MENUITEM_ASSIGNED));
|
g_Notify->DisplayError(GS(MSG_MENUITEM_ASSIGNED));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
ShortCut->AddShortCut(key,bCtrl,bAlt,bShift,AccessLevel,true,false);
|
ShortCut->AddShortCut(key,bCtrl,bAlt,bShift,AccessLevel,true,false);
|
||||||
|
|
|
@ -244,7 +244,7 @@ void COptionPluginPage::ApplyComboBoxes ( void )
|
||||||
case PLUGIN_TYPE_AUDIO: _Settings->SaveBool(Plugin_AUDIO_Changed,true); break;
|
case PLUGIN_TYPE_AUDIO: _Settings->SaveBool(Plugin_AUDIO_Changed,true); break;
|
||||||
case PLUGIN_TYPE_CONTROLLER: _Settings->SaveBool(Plugin_CONT_Changed,true); break;
|
case PLUGIN_TYPE_CONTROLLER: _Settings->SaveBool(Plugin_CONT_Changed,true); break;
|
||||||
default:
|
default:
|
||||||
_Notify->BreakPoint(__FILE__,__LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (ComboBox->IsReset())
|
if (ComboBox->IsReset())
|
||||||
|
|
|
@ -263,7 +263,7 @@ int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE /*hPrevInstance*/, LPSTR /*lps
|
||||||
WriteTrace(TraceDebug,"WinMain - Application Starting");
|
WriteTrace(TraceDebug,"WinMain - Application Starting");
|
||||||
FixUPXIssue((BYTE *)hInstance);
|
FixUPXIssue((BYTE *)hInstance);
|
||||||
|
|
||||||
_Notify = &Notify();
|
g_Notify = &Notify();
|
||||||
|
|
||||||
//Create the plugin container
|
//Create the plugin container
|
||||||
WriteTrace(TraceDebug,"WinMain - Create Plugins");
|
WriteTrace(TraceDebug,"WinMain - Create Plugins");
|
||||||
|
@ -282,7 +282,7 @@ int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE /*hPrevInstance*/, LPSTR /*lps
|
||||||
CMainGui MainWindow(true,WinTitle.c_str()), HiddenWindow(false);
|
CMainGui MainWindow(true,WinTitle.c_str()), HiddenWindow(false);
|
||||||
CMainMenu MainMenu(&MainWindow);
|
CMainMenu MainMenu(&MainWindow);
|
||||||
_Plugins->SetRenderWindows(&MainWindow,&HiddenWindow);
|
_Plugins->SetRenderWindows(&MainWindow,&HiddenWindow);
|
||||||
_Notify->SetMainWindow(&MainWindow);
|
g_Notify->SetMainWindow(&MainWindow);
|
||||||
|
|
||||||
{
|
{
|
||||||
stdstr_f User("%s",_Settings->LoadString(Beta_UserName).c_str());
|
stdstr_f User("%s",_Settings->LoadString(Beta_UserName).c_str());
|
||||||
|
|
Loading…
Reference in New Issue