vgturtle127's Beautification 14 - Source\Project64-video directory and final cleanup

This commit is contained in:
zilmar 2021-05-18 21:21:36 +09:30
parent d6bf03bf20
commit ee864797ab
277 changed files with 5770 additions and 5859 deletions

View File

@ -40,7 +40,7 @@ void JavaBridge::GfxThreadDone()
JNIEnv *env = Android_JNI_GetEnv(); JNIEnv *env = Android_JNI_GetEnv();
if (g_GLThread != NULL && env != NULL) if (g_GLThread != NULL && env != NULL)
{ {
WriteTrace(TraceUserInterface, TraceDebug, "calling java GLThread::ThreadExiting"); WriteTrace(TraceUserInterface, TraceDebug, "Calling java GLThread::ThreadExiting");
jclass GLThreadClass = env->GetObjectClass(g_GLThread); jclass GLThreadClass = env->GetObjectClass(g_GLThread);
jmethodID midThreadExiting = env->GetMethodID(GLThreadClass, "ThreadExiting", "()V"); jmethodID midThreadExiting = env->GetMethodID(GLThreadClass, "ThreadExiting", "()V");
env->CallVoidMethod(g_GLThread, midThreadExiting); env->CallVoidMethod(g_GLThread, midThreadExiting);

View File

@ -16,7 +16,7 @@ public:
void GfxThreadDone(); void GfxThreadDone();
void SwapWindow(); void SwapWindow();
// ROM List // ROM list
void RomListReset(void); void RomListReset(void);
void RomListAddItem(const char * FullFileName, const char * FileName, const char * GoodName, uint32_t TextColor); void RomListAddItem(const char * FullFileName, const char * FileName, const char * GoodName, uint32_t TextColor);
void RomListLoaded(void); void RomListLoaded(void);

View File

@ -125,7 +125,7 @@ void CNotificationImp::BreakPoint(const char * FileName, int32_t LineNumber)
} }
else else
{ {
FatalError("Fatal Error: Emulation stopped"); FatalError("Fatal error: emulation stopped");
} }
} }

View File

@ -210,7 +210,7 @@ void AddRecentRom(const char * ImagePath)
if (g_JavaBridge) if (g_JavaBridge)
{ {
WriteTrace(TraceUserInterface, TraceDebug, "calling RecentRomsUpdated"); WriteTrace(TraceUserInterface, TraceDebug, "Calling RecentRomsUpdated");
g_JavaBridge->RecentRomsUpdated(); g_JavaBridge->RecentRomsUpdated();
} }
WriteTrace(TraceUserInterface, TraceDebug, "Done"); WriteTrace(TraceUserInterface, TraceDebug, "Done");
@ -220,7 +220,7 @@ void GameCpuRunning(void * /*NotUsed*/)
{ {
WriteTrace(TraceUserInterface, TraceDebug, "Start"); WriteTrace(TraceUserInterface, TraceDebug, "Start");
bool Running = g_Settings->LoadBool(GameRunning_CPU_Running); bool Running = g_Settings->LoadBool(GameRunning_CPU_Running);
WriteTrace(TraceUserInterface, TraceDebug, Running ? "Game Started" : "Game Stopped"); WriteTrace(TraceUserInterface, TraceDebug, Running ? "Game started" : "Game stopped");
JNIEnv *env = Android_JNI_GetEnv(); JNIEnv *env = Android_JNI_GetEnv();
if (Running) if (Running)
{ {
@ -232,7 +232,7 @@ void GameCpuRunning(void * /*NotUsed*/)
g_System->RefreshGameSettings(); g_System->RefreshGameSettings();
int RunCount = UISettingsLoadDword(Game_RunCount); int RunCount = UISettingsLoadDword(Game_RunCount);
WriteTrace(TraceUserInterface, TraceDebug, "Setting Run Count to %d", RunCount + 1); WriteTrace(TraceUserInterface, TraceDebug, "Setting run count to %d", RunCount + 1);
UISettingsSaveDword(Game_RunCount, RunCount + 1); UISettingsSaveDword(Game_RunCount, RunCount + 1);
if (env != NULL) if (env != NULL)
{ {
@ -265,12 +265,12 @@ void GameCpuRunning(void * /*NotUsed*/)
WriteTrace(TraceUserInterface, TraceError, "No Java bridge"); WriteTrace(TraceUserInterface, TraceError, "No Java bridge");
} }
// call in to java that emulation done // Call in to java that emulation done
WriteTrace(TraceUserInterface, TraceDebug, "Clean up global activity"); WriteTrace(TraceUserInterface, TraceDebug, "Clean up global activity");
env->DeleteGlobalRef(g_Activity); env->DeleteGlobalRef(g_Activity);
g_Activity = NULL; g_Activity = NULL;
WriteTrace(TraceUserInterface, TraceDebug, "Clean up global gl thread"); WriteTrace(TraceUserInterface, TraceDebug, "Clean up global GL thread");
if (g_JavaBridge) if (g_JavaBridge)
{ {
g_JavaBridge->GfxThreadDone(); g_JavaBridge->GfxThreadDone();
@ -300,7 +300,7 @@ EXPORT jboolean CALL Java_emu_project64_jni_NativeExports_appInit(JNIEnv* env, j
Notify().DisplayMessage(10, " / ____/ / / /_/ / / / __/ /__/ /_/ /_/ /__ __/"); Notify().DisplayMessage(10, " / ____/ / / /_/ / / / __/ /__/ /_/ /_/ /__ __/");
Notify().DisplayMessage(10, "/_/ /_/ \\____/_/ /\\___/\\___/\\__/\\____/ /_/"); Notify().DisplayMessage(10, "/_/ /_/ \\____/_/ /\\___/\\___/\\__/\\____/ /_/");
Notify().DisplayMessage(10, " /___/"); Notify().DisplayMessage(10, " /___/");
Notify().DisplayMessage(10, "http://www.pj64-emu.com/"); Notify().DisplayMessage(10, "https://www.pj64-emu.com/");
Notify().DisplayMessage(10, stdstr_f("%s Version %s", VER_FILE_DESCRIPTION_STR, VER_FILE_VERSION_STR).c_str()); Notify().DisplayMessage(10, stdstr_f("%s Version %s", VER_FILE_DESCRIPTION_STR, VER_FILE_VERSION_STR).c_str());
Notify().DisplayMessage(10, ""); Notify().DisplayMessage(10, "");

View File

@ -89,8 +89,8 @@ typedef struct
Function: CloseDLL Function: CloseDLL
Purpose: This function is called when the emulator is closing Purpose: This function is called when the emulator is closing
down allowing the DLL to de-initialize. down allowing the DLL to de-initialize.
input: none Input: None
output: none Output: None
*/ */
EXPORT void CALL CloseDLL(void); EXPORT void CALL CloseDLL(void);
@ -99,15 +99,15 @@ EXPORT void CALL CloseDLL(void);
Function: ControllerCommand Function: ControllerCommand
Purpose: To process the raw data that has just been sent to a Purpose: To process the raw data that has just been sent to a
specific controller. specific controller.
input: - Controller Number (0 to 3) and -1 signaling end of Input: Controller Number (0 to 3) and -1 signaling end of
processing the PIF RAM. processing the PIF RAM.
- Pointer of data to be processed. - Pointer of data to be processed.
output: none Output: None
note: This function is only needed if the DLL is allowing raw Note: This function is only needed if the DLL is allowing raw
data, or the plugin is set to raw data, or the plugin is set to raw
the data that is being processed looks like this: The data that is being processed looks like this:
initialize controller: 01 03 00 FF FF FF initialize controller: 01 03 00 FF FF FF
read controller: 01 04 01 FF FF FF FF read controller: 01 04 01 FF FF FF FF
*/ */
@ -118,8 +118,8 @@ EXPORT void CALL ControllerCommand(int Control, uint8_t * Command);
Function: DllAbout Function: DllAbout
Purpose: This function is optional function that is provided Purpose: This function is optional function that is provided
to give further information about the DLL. to give further information about the DLL.
input: a handle to the window that calls this function Input: A handle to the window that calls this function
output: none Output: None
*/ */
EXPORT void CALL DllAbout(void * hParent); EXPORT void CALL DllAbout(void * hParent);
@ -128,8 +128,8 @@ EXPORT void CALL DllAbout(void * hParent);
Function: DllConfig Function: DllConfig
Purpose: This function is optional function that is provided Purpose: This function is optional function that is provided
to allow the user to configure the DLL to allow the user to configure the DLL
input: a handle to the window that calls this function Input: A handle to the window that calls this function
output: none Output: None
*/ */
EXPORT void CALL DllConfig(void * hParent); EXPORT void CALL DllConfig(void * hParent);
@ -138,8 +138,8 @@ EXPORT void CALL DllConfig(void * hParent);
Function: DllTest Function: DllTest
Purpose: This function is optional function that is provided Purpose: This function is optional function that is provided
to allow the user to test the DLL to allow the user to test the DLL
input: a handle to the window that calls this function Input: A handle to the window that calls this function
output: none Output: None
*/ */
EXPORT void CALL DllTest(void * hParent); EXPORT void CALL DllTest(void * hParent);
@ -148,9 +148,9 @@ EXPORT void CALL DllTest(void * hParent);
Function: GetDllInfo Function: GetDllInfo
Purpose: This function allows the emulator to gather information Purpose: This function allows the emulator to gather information
about the DLL by filling in the PluginInfo structure. about the DLL by filling in the PluginInfo structure.
input: a pointer to a PLUGIN_INFO structure that needs to be Input: A pointer to a PLUGIN_INFO structure that needs to be
filled by the function. (see def above) filled by the function (see def above)
output: none Output: None
*/ */
EXPORT void CALL GetDllInfo(PLUGIN_INFO * PluginInfo); EXPORT void CALL GetDllInfo(PLUGIN_INFO * PluginInfo);
@ -158,10 +158,10 @@ EXPORT void CALL GetDllInfo(PLUGIN_INFO * PluginInfo);
/* /*
Function: GetKeys Function: GetKeys
Purpose: To get the current state of the controllers buttons. Purpose: To get the current state of the controllers buttons.
input: - Controller Number (0 to 3) Input: Controller Number (0 to 3)
- A pointer to a BUTTONS structure to be filled with - A pointer to a BUTTONS structure to be filled with
the controller state. the controller state.
output: none Output: None
*/ */
EXPORT void CALL GetKeys(int32_t Control, BUTTONS * Keys); EXPORT void CALL GetKeys(int32_t Control, BUTTONS * Keys);
@ -170,10 +170,10 @@ EXPORT void CALL GetKeys(int32_t Control, BUTTONS * Keys);
Function: InitiateControllers Function: InitiateControllers
Purpose: This function initializes how each of the controllers Purpose: This function initializes how each of the controllers
should be handled. should be handled.
input: - The handle to the main window. Input: - The handle to the main window.
- A controller structure that needs to be filled for - A controller structure that needs to be filled for
the emulator to know how to handle each controller. the emulator to know how to handle each controller.
output: none Output: None
*/ */
EXPORT void CALL InitiateControllers(CONTROL_INFO ControlInfo); EXPORT void CALL InitiateControllers(CONTROL_INFO ControlInfo);
@ -182,11 +182,11 @@ EXPORT void CALL InitiateControllers(CONTROL_INFO ControlInfo);
Function: ReadController Function: ReadController
Purpose: To process the raw data in the PIF RAM that is about to Purpose: To process the raw data in the PIF RAM that is about to
be read. be read.
input: - Controller Number (0 to 3) and -1 signaling end of Input: Controller Number (0 to 3) and -1 signaling end of
processing the PIF RAM. processing the PIF RAM.
- Pointer of data to be processed. - Pointer of data to be processed.
output: none Output: None
note: This function is only needed if the DLL is allowing raw Note: This function is only needed if the DLL is allowing raw
data. data.
*/ */
@ -195,18 +195,18 @@ EXPORT void CALL ReadController(int Control, uint8_t * Command);
/* /*
Function: RomClosed Function: RomClosed
Purpose: This function is called when a ROM is closed. Purpose: This function is called when a ROM is closed.
input: none Input: None
output: none Output: None
*/ */
EXPORT void CALL RomClosed(void); EXPORT void CALL RomClosed(void);
/* /*
Function: RomOpen Function: RomOpen
Purpose: This function is called when a ROM is open. (from the Purpose: This function is called when a ROM is open (from the
emulation thread) emulation thread)
input: none Input: None
output: none Output: None
*/ */
EXPORT void CALL RomOpen(void); EXPORT void CALL RomOpen(void);
@ -215,8 +215,8 @@ EXPORT void CALL RomOpen(void);
Function: WM_KeyDown Function: WM_KeyDown
Purpose: To pass the WM_KeyDown message from the emulator to the Purpose: To pass the WM_KeyDown message from the emulator to the
plugin. plugin.
input: wParam and lParam of the WM_KEYDOWN message. Input: wParam and lParam of the WM_KEYDOWN message.
output: none Output: None
*/ */
EXPORT void CALL WM_KeyDown(uint32_t wParam, uint32_t lParam); EXPORT void CALL WM_KeyDown(uint32_t wParam, uint32_t lParam);
@ -225,8 +225,8 @@ EXPORT void CALL WM_KeyDown(uint32_t wParam, uint32_t lParam);
Function: WM_KeyUp Function: WM_KeyUp
Purpose: To pass the WM_KEYUP message from the emulator to the Purpose: To pass the WM_KEYUP message from the emulator to the
plugin. plugin.
input: wParam and lParam of the WM_KEYDOWN message. Input: wParam and lParam of the WM_KEYDOWN message.
output: none Output: None
*/ */
EXPORT void CALL WM_KeyUp(uint32_t wParam, uint32_t lParam); EXPORT void CALL WM_KeyUp(uint32_t wParam, uint32_t lParam);

View File

@ -12,46 +12,46 @@ BUTTONS g_buttons;
void ShowAboutWindow (void * hParent); void ShowAboutWindow (void * hParent);
/****************************************************************** /*
Function: CloseDLL Function: CloseDLL
Purpose: This function is called when the emulator is closing Purpose: This function is called when the emulator is closing
down allowing the DLL to de-initialize. down allowing the DLL to de-initialize.
input: none Input: None
output: none Output: None
*******************************************************************/ */
EXPORT void CALL CloseDLL (void) EXPORT void CALL CloseDLL (void)
{ {
} }
/****************************************************************** /*
Function: ControllerCommand Function: ControllerCommand
Purpose: To process the raw data that has just been sent to a Purpose: To process the raw data that has just been sent to a
specific controller. specific controller.
input: - Controller Number (0 to 3) and -1 signaling end of Input: Controller Number (0 to 3) and -1 signaling end of
processing the PIF RAM. processing the PIF RAM.
- Pointer of data to be processed. - Pointer of data to be processed.
output: none Output: None
note: This function is only needed if the DLL is allowing raw Note: This function is only needed if the DLL is allowing raw
data, or the plugin is set to raw data, or the plugin is set to raw
the data that is being processed looks like this: The data that is being processed looks like this:
initialize controller: 01 03 00 FF FF FF Initialize controller: 01 03 00 FF FF FF
read controller: 01 04 01 FF FF FF FF Read controller: 01 04 01 FF FF FF FF
*******************************************************************/ */
EXPORT void CALL ControllerCommand ( int /*Control*/, uint8_t * /*Command*/) EXPORT void CALL ControllerCommand ( int /*Control*/, uint8_t * /*Command*/)
{ {
} }
/****************************************************************** /*
Function: DllAbout Function: DllAbout
Purpose: This function is optional function that is provided Purpose: This function is optional function that is provided
to give further information about the DLL. to give further information about the DLL.
input: a handle to the window that calls this function Input: A handle to the window that calls this function
output: none Output: None
*******************************************************************/ */
EXPORT void CALL DllAbout ( void * hParent ) EXPORT void CALL DllAbout ( void * hParent )
{ {
@ -60,38 +60,38 @@ EXPORT void CALL DllAbout ( void * hParent )
#endif #endif
} }
/****************************************************************** /*
Function: DllConfig Function: DllConfig
Purpose: This function is optional function that is provided Purpose: This function is optional function that is provided
to allow the user to configure the DLL to allow the user to configure the DLL
input: a handle to the window that calls this function Input: A handle to the window that calls this function
output: none Output: None
*******************************************************************/ */
EXPORT void CALL DllConfig ( void * /*hParent*/ ) EXPORT void CALL DllConfig ( void * /*hParent*/ )
{ {
} }
/****************************************************************** /*
Function: DllTest Function: DllTest
Purpose: This function is optional function that is provided Purpose: This function is optional function that is provided
to allow the user to test the DLL to allow the user to test the DLL
input: a handle to the window that calls this function Input: A handle to the window that calls this function
output: none Output: None
*******************************************************************/ */
EXPORT void CALL DllTest ( void * /*hParent*/ ) EXPORT void CALL DllTest ( void * /*hParent*/ )
{ {
} }
/****************************************************************** /*
Function: GetDllInfo Function: GetDllInfo
Purpose: This function allows the emulator to gather information Purpose: This function allows the emulator to gather information
about the DLL by filling in the PluginInfo structure. about the DLL by filling in the PluginInfo structure.
input: a pointer to a PLUGIN_INFO structure that needs to be Input: A pointer to a PLUGIN_INFO structure that needs to be
filled by the function. (see def above) filled by the function. (see def above)
output: none Output: None
*******************************************************************/ */
EXPORT void CALL GetDllInfo ( PLUGIN_INFO * PluginInfo ) EXPORT void CALL GetDllInfo ( PLUGIN_INFO * PluginInfo )
{ {
@ -104,14 +104,14 @@ EXPORT void CALL GetDllInfo ( PLUGIN_INFO * PluginInfo )
#endif #endif
} }
/****************************************************************** /*
Function: GetKeys Function: GetKeys
Purpose: To get the current state of the controllers buttons. Purpose: To get the current state of the controllers buttons.
input: - Controller Number (0 to 3) Input: Controller Number (0 to 3)
- A pointer to a BUTTONS structure to be filled with - A pointer to a BUTTONS structure to be filled with
the controller state. the controller state.
output: none Output: None
*******************************************************************/ */
EXPORT void CALL GetKeys(int Control, BUTTONS * Keys ) EXPORT void CALL GetKeys(int Control, BUTTONS * Keys )
{ {
@ -121,15 +121,15 @@ EXPORT void CALL GetKeys(int Control, BUTTONS * Keys )
} }
} }
/****************************************************************** /*
Function: InitiateControllers Function: InitiateControllers
Purpose: This function initializes how each of the controllers Purpose: This function initializes how each of the controllers
should be handled. should be handled.
input: - The handle to the main window. Input: The handle to the main window.
- A controller structure that needs to be filled for - A controller structure that needs to be filled for
the emulator to know how to handle each controller. the emulator to know how to handle each controller.
output: none Output: None
*******************************************************************/ */
EXPORT void CALL InitiateControllers (CONTROL_INFO ControlInfo) EXPORT void CALL InitiateControllers (CONTROL_INFO ControlInfo)
{ {
@ -138,65 +138,65 @@ EXPORT void CALL InitiateControllers (CONTROL_INFO ControlInfo)
g_control_info.Controls[0].Plugin = PLUGIN_MEMPAK; g_control_info.Controls[0].Plugin = PLUGIN_MEMPAK;
} }
/****************************************************************** /*
Function: ReadController Function: ReadController
Purpose: To process the raw data in the PIF RAM that is about to Purpose: To process the raw data in the PIF RAM that is about to
be read. be read.
input: - Controller Number (0 to 3) and -1 signaling end of Input: Controller Number (0 to 3) and -1 signaling end of
processing the PIF RAM. processing the PIF RAM.
- Pointer of data to be processed. - Pointer of data to be processed.
output: none Output: None
note: This function is only needed if the DLL is allowing raw Note: This function is only needed if the DLL is allowing raw
data. data.
*******************************************************************/ */
EXPORT void CALL ReadController ( int /*Control*/, uint8_t * /*Command*/ ) EXPORT void CALL ReadController ( int /*Control*/, uint8_t * /*Command*/ )
{ {
} }
/****************************************************************** /*
Function: RomClosed Function: RomClosed
Purpose: This function is called when a ROM is closed. Purpose: This function is called when a ROM is closed.
input: none Input: None
output: none Output: None
*******************************************************************/ */
EXPORT void CALL RomClosed (void) EXPORT void CALL RomClosed (void)
{ {
} }
/****************************************************************** /*
Function: RomOpen Function: RomOpen
Purpose: This function is called when a ROM is open. (from the Purpose: This function is called when a ROM is open (from the
emulation thread) emulation thread)
input: none Input: None
output: none Output: None
*******************************************************************/ */
EXPORT void CALL RomOpen (void) EXPORT void CALL RomOpen (void)
{ {
memset(&g_buttons, 0, sizeof(g_buttons)); memset(&g_buttons, 0, sizeof(g_buttons));
} }
/****************************************************************** /*
Function: WM_KeyDown Function: WM_KeyDown
Purpose: To pass the WM_KeyDown message from the emulator to the Purpose: To pass the WM_KeyDown message from the emulator to the
plugin. plugin.
input: wParam and lParam of the WM_KEYDOWN message. Input: wParam and lParam of the WM_KEYDOWN message.
output: none Output: None
*******************************************************************/ */
EXPORT void CALL WM_KeyDown( uint32_t /*wParam*/, uint32_t /*lParam*/ ) EXPORT void CALL WM_KeyDown( uint32_t /*wParam*/, uint32_t /*lParam*/ )
{ {
} }
/****************************************************************** /*
Function: WM_KeyUp Function: WM_KeyUp
Purpose: To pass the WM_KEYUP message from the emulator to the Purpose: To pass the WM_KEYUP message from the emulator to the
plugin. plugin.
input: wParam and lParam of the WM_KEYDOWN message. Input: wParam and lParam of the WM_KEYDOWN message.
output: none Output: None
*******************************************************************/ */
EXPORT void CALL WM_KeyUp( uint32_t /*wParam*/, uint32_t /*lParam*/ ) EXPORT void CALL WM_KeyUp( uint32_t /*wParam*/, uint32_t /*lParam*/ )
{ {

View File

@ -5,6 +5,6 @@
void ShowAboutWindow (void * hParent) void ShowAboutWindow (void * hParent)
{ {
#ifdef _WIN32 #ifdef _WIN32
MessageBox((HWND)hParent,L"Android Input Plugin",L"Dll About",MB_OK); MessageBox((HWND)hParent,L"Android input plugin",L"Dll About",MB_OK);
#endif #endif
} }

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2014 Bobby Smiles // Copyright(C) 2014 Bobby Smiles
// Copyright(C) 2009 Richard Goedeken // Copyright(C) 2009 Richard Goedeken
@ -286,7 +286,7 @@ void alist_envmix_exp( CHle * hle, bool init, bool aux, uint16_t dmem_dl, uint16
ramps[1].value = *(int32_t *)(save_buffer + 18); // 14-15 ramps[1].value = *(int32_t *)(save_buffer + 18); // 14-15
} }
// init which ensure ramp.step != 0 iff ramp.value == ramp.target // Initialize which ensure ramp.step != 0 iff ramp.value == ramp.target
ramps[0].step = ramps[0].target - ramps[0].value; ramps[0].step = ramps[0].target - ramps[0].value;
ramps[1].step = ramps[1].target - ramps[1].value; ramps[1].step = ramps[1].target - ramps[1].value;

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2014 Bobby Smiles // Copyright(C) 2014 Bobby Smiles
// GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html // GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2014 Bobby Smiles // Copyright(C) 2014 Bobby Smiles
// Copyright(C) 2009 Richard Goedeken // Copyright(C) 2009 Richard Goedeken

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2014 Bobby Smiles // Copyright(C) 2014 Bobby Smiles
// Copyright(C) 2009 Richard Goedeken // Copyright(C) 2009 Richard Goedeken

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2014 Bobby Smiles // Copyright(C) 2014 Bobby Smiles
// Copyright(C) 2009 Richard Goedeken // Copyright(C) 2009 Richard Goedeken
@ -284,12 +284,12 @@ static void FILTER(CHle * hle, uint32_t w1, uint32_t w2)
if (flags > 1) { if (flags > 1) {
hle->alist_nead().filter_count = w1; hle->alist_nead().filter_count = w1;
hle->alist_nead().filter_lut_address[0] = address; // t6 hle->alist_nead().filter_lut_address[0] = address; // T6
} }
else { else {
uint16_t dmem = w1; uint16_t dmem = w1;
hle->alist_nead().filter_lut_address[1] = address + 0x10; // t5 hle->alist_nead().filter_lut_address[1] = address + 0x10; // T5
alist_filter(hle, dmem, hle->alist_nead().filter_count, address, hle->alist_nead().filter_lut_address); alist_filter(hle, dmem, hle->alist_nead().filter_count, address, hle->alist_nead().filter_lut_address);
} }
} }

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2014 Bobby Smiles // Copyright(C) 2014 Bobby Smiles
// GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html // GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2014 Bobby Smiles // Copyright(C) 2014 Bobby Smiles
// GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html // GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2014 Bobby Smiles // Copyright(C) 2014 Bobby Smiles
// GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html // GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html
@ -14,7 +14,7 @@ static inline int16_t adpcm_predict_sample(uint8_t byte, uint8_t mask,
unsigned lshift, unsigned rshift) unsigned lshift, unsigned rshift)
{ {
int16_t sample = (uint16_t)(byte & mask) << lshift; int16_t sample = (uint16_t)(byte & mask) << lshift;
sample >>= rshift; // signed sample >>= rshift; // Signed
return sample; return sample;
} }

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2012 Bobby Smiles // Copyright(C) 2012 Bobby Smiles
// Copyright(C) 2009 Richard Goedeken // Copyright(C) 2009 Richard Goedeken

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2014 Bobby Smiles // Copyright(C) 2014 Bobby Smiles
// Copyright(C) 2009 Richard Goedeken // Copyright(C) 2009 Richard Goedeken

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2012 Bobby Smiles // Copyright(C) 2012 Bobby Smiles
// Copyright(C) 2009 Richard Goedeken // Copyright(C) 2009 Richard Goedeken
@ -294,7 +294,7 @@ void CHle::normal_task_dispatching(void)
return; return;
} }
WarnMessage("unknown OSTask: sum: %x PC:%x", sum, *m_sp_pc); WarnMessage("Unknown OSTask: sum: %x PC:%x", sum, *m_sp_pc);
#ifdef ENABLE_TASK_DUMP #ifdef ENABLE_TASK_DUMP
dump_unknown_task(this, sum); dump_unknown_task(this, sum);
#endif #endif
@ -311,7 +311,7 @@ void CHle::non_task_dispatching(void)
return; return;
} }
WarnMessage("unknown RSP code: sum: %x PC:%x", sum, *m_sp_pc); WarnMessage("Unknown RSP code: sum: %x PC:%x", sum, *m_sp_pc);
#ifdef ENABLE_TASK_DUMP #ifdef ENABLE_TASK_DUMP
dump_unknown_non_task(hle, sum); dump_unknown_non_task(hle, sum);
#endif #endif
@ -324,7 +324,7 @@ void CHle::non_task_dispatching(void)
void CHle::VerboseMessage(const char *message, ...) void CHle::VerboseMessage(const char *message, ...)
{ {
#if defined(_WIN32) && defined(_DEBUG) #if defined(_WIN32) && defined(_DEBUG)
// These can get annoying. // These can get annoying
#if 0 #if 0
MessageBox(NULL, message, "HLE verbose message", MB_OK); MessageBox(NULL, message, "HLE verbose message", MB_OK);
#endif #endif

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2014 Bobby Smiles // Copyright(C) 2014 Bobby Smiles
// GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html // GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html
@ -13,59 +13,59 @@
enum enum
{ {
SP_CLR_HALT = 0x00001, /* Bit 0: Clear halt */ SP_CLR_HALT = 0x00001, // Bit 0: Clear halt
SP_SET_HALT = 0x00002, /* Bit 1: Set halt */ SP_SET_HALT = 0x00002, // Bit 1: Set halt
SP_CLR_BROKE = 0x00004, /* Bit 2: Clear broke */ SP_CLR_BROKE = 0x00004, // Bit 2: Clear broke
SP_CLR_INTR = 0x00008, /* Bit 3: Clear INTR */ SP_CLR_INTR = 0x00008, // Bit 3: Clear INTR
SP_SET_INTR = 0x00010, /* Bit 4: Set INTR */ SP_SET_INTR = 0x00010, // Bit 4: Set INTR
SP_CLR_SSTEP = 0x00020, /* Bit 5: Clear SSTEP */ SP_CLR_SSTEP = 0x00020, // Bit 5: Clear SSTEP
SP_SET_SSTEP = 0x00040, /* Bit 6: Set SSTEP */ SP_SET_SSTEP = 0x00040, // Bit 6: Set SSTEP
SP_CLR_INTR_BREAK = 0x00080, /* Bit 7: Clear INTR on break */ SP_CLR_INTR_BREAK = 0x00080, // Bit 7: Clear INTR on break
SP_SET_INTR_BREAK = 0x00100, /* Bit 8: Set INTR on break */ SP_SET_INTR_BREAK = 0x00100, // Bit 8: Set INTR on break
SP_CLR_SIG0 = 0x00200, /* Bit 9: Clear signal 0 */ SP_CLR_SIG0 = 0x00200, // Bit 9: Clear signal 0
SP_SET_SIG0 = 0x00400, /* Bit 10: Set signal 0 */ SP_SET_SIG0 = 0x00400, // Bit 10: Set signal 0
SP_CLR_SIG1 = 0x00800, /* Bit 11: Clear signal 1 */ SP_CLR_SIG1 = 0x00800, // Bit 11: Clear signal 1
SP_SET_SIG1 = 0x01000, /* Bit 12: Set signal 1 */ SP_SET_SIG1 = 0x01000, // Bit 12: Set signal 1
SP_CLR_SIG2 = 0x02000, /* Bit 13: Clear signal 2 */ SP_CLR_SIG2 = 0x02000, // Bit 13: Clear signal 2
SP_SET_SIG2 = 0x04000, /* Bit 14: Set signal 2 */ SP_SET_SIG2 = 0x04000, // Bit 14: Set signal 2
SP_CLR_SIG3 = 0x08000, /* Bit 15: Clear signal 3 */ SP_CLR_SIG3 = 0x08000, // Bit 15: Clear signal 3
SP_SET_SIG3 = 0x10000, /* Bit 16: Set signal 3 */ SP_SET_SIG3 = 0x10000, // Bit 16: Set signal 3
SP_CLR_SIG4 = 0x20000, /* Bit 17: Clear signal 4 */ SP_CLR_SIG4 = 0x20000, // Bit 17: Clear signal 4
SP_SET_SIG4 = 0x40000, /* Bit 18: Set signal 4 */ SP_SET_SIG4 = 0x40000, // Bit 18: Set signal 4
SP_CLR_SIG5 = 0x80000, /* Bit 19: Clear signal 5 */ SP_CLR_SIG5 = 0x80000, // Bit 19: Clear signal 5
SP_SET_SIG5 = 0x100000, /* Bit 20: Set signal 5 */ SP_SET_SIG5 = 0x100000, // Bit 20: Set signal 5
SP_CLR_SIG6 = 0x200000, /* Bit 21: Clear signal 6 */ SP_CLR_SIG6 = 0x200000, // Bit 21: Clear signal 6
SP_SET_SIG6 = 0x400000, /* Bit 22: Set signal 6 */ SP_SET_SIG6 = 0x400000, // Bit 22: Set signal 6
SP_CLR_SIG7 = 0x800000, /* Bit 23: Clear signal 7 */ SP_CLR_SIG7 = 0x800000, // Bit 23: Clear signal 7
SP_SET_SIG7 = 0x1000000, /* Bit 24: Set signal 7 */ SP_SET_SIG7 = 0x1000000, // Bit 24: Set signal 7
SP_STATUS_HALT = 0x001, /* Bit 0: Halt */ SP_STATUS_HALT = 0x001, // Bit 0: Halt
SP_STATUS_BROKE = 0x002, /* Bit 1: Broke */ SP_STATUS_BROKE = 0x002, // Bit 1: Broke
SP_STATUS_DMA_BUSY = 0x004, /* Bit 2: DMA busy */ SP_STATUS_DMA_BUSY = 0x004, // Bit 2: DMA busy
SP_STATUS_DMA_FULL = 0x008, /* Bit 3: DMA full */ SP_STATUS_DMA_FULL = 0x008, // Bit 3: DMA full
SP_STATUS_IO_FULL = 0x010, /* Bit 4: IO full */ SP_STATUS_IO_FULL = 0x010, // Bit 4: IO full
SP_STATUS_SSTEP = 0x020, /* Bit 5: Single step */ SP_STATUS_SSTEP = 0x020, // Bit 5: Single step
SP_STATUS_INTR_BREAK = 0x040, /* Bit 6: Interrupt on break */ SP_STATUS_INTR_BREAK = 0x040, // Bit 6: Interrupt on break
SP_STATUS_SIG0 = 0x080, /* Bit 7: Signal 0 set */ SP_STATUS_SIG0 = 0x080, // Bit 7: Signal 0 set
SP_STATUS_SIG1 = 0x100, /* Bit 8: Signal 1 set */ SP_STATUS_SIG1 = 0x100, // Bit 8: Signal 1 set
SP_STATUS_SIG2 = 0x200, /* Bit 9: Signal 2 set */ SP_STATUS_SIG2 = 0x200, // Bit 9: Signal 2 set
SP_STATUS_SIG3 = 0x400, /* Bit 10: Signal 3 set */ SP_STATUS_SIG3 = 0x400, // Bit 10: Signal 3 set
SP_STATUS_SIG4 = 0x800, /* Bit 11: Signal 4 set */ SP_STATUS_SIG4 = 0x800, // Bit 11: Signal 4 set
SP_STATUS_SIG5 = 0x1000, /* Bit 12: Signal 5 set */ SP_STATUS_SIG5 = 0x1000, // Bit 12: Signal 5 set
SP_STATUS_SIG6 = 0x2000, /* Bit 13: Signal 6 set */ SP_STATUS_SIG6 = 0x2000, // Bit 13: Signal 6 set
SP_STATUS_SIG7 = 0x4000, /* Bit 14: Signal 7 set */ SP_STATUS_SIG7 = 0x4000, // Bit 14: Signal 7 set
}; };
// MIPS interface flags // MIPS interface flags
enum enum
{ {
MI_INTR_SP = 0x01, /* Bit 0: SP INTR */ MI_INTR_SP = 0x01, // Bit 0: SP INTR
MI_INTR_SI = 0x02, /* Bit 1: SI INTR */ MI_INTR_SI = 0x02, // Bit 1: SI INTR
MI_INTR_AI = 0x04, /* Bit 2: AI INTR */ MI_INTR_AI = 0x04, // Bit 2: AI INTR
MI_INTR_VI = 0x08, /* Bit 3: VI INTR */ MI_INTR_VI = 0x08, // Bit 3: VI INTR
MI_INTR_PI = 0x10, /* Bit 4: PI INTR */ MI_INTR_PI = 0x10, // Bit 4: PI INTR
MI_INTR_DP = 0x20, /* Bit 5: DP INTR */ MI_INTR_DP = 0x20, // Bit 5: DP INTR
}; };
class CHle class CHle

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2012 Bobby Smiles // Copyright(C) 2012 Bobby Smiles
// Copyright(C) 2009 Richard Goedeken // Copyright(C) 2009 Richard Goedeken
@ -373,7 +373,7 @@ static void decode_macroblock_ob(int16_t *macroblock, int32_t *y_dc, int32_t *u_
for (sb = 0; sb < 6; ++sb) { for (sb = 0; sb < 6; ++sb) {
int16_t tmp_sb[SUBBLOCK_SIZE]; int16_t tmp_sb[SUBBLOCK_SIZE];
// Update DC // Update decode
int32_t dc = (int32_t)macroblock[0]; int32_t dc = (int32_t)macroblock[0];
switch (sb) { switch (sb) {
case 0: case 0:

View File

@ -19,8 +19,8 @@ BOOL WINAPI DllMain(void * hinst, DWORD /*fdwReason*/, LPVOID /*lpvReserved*/)
Function: CloseDLL Function: CloseDLL
Purpose: This function is called when the emulator is closing Purpose: This function is called when the emulator is closing
down allowing the DLL to de-initialize. down allowing the DLL to de-initialize.
input: none Input: None
output: none Output: None
*/ */
void CloseDLL(void) void CloseDLL(void)
@ -36,8 +36,8 @@ void CloseDLL(void)
Function: DllAbout Function: DllAbout
Purpose: This function is optional function that is provided Purpose: This function is optional function that is provided
to give further information about the DLL. to give further information about the DLL.
input: a handle to the window that calls this function Input: A handle to the window that calls this function
output: none Output: None
*/ */
void DllAbout(void * hParent) void DllAbout(void * hParent)
@ -52,8 +52,8 @@ Function: DoRspCycles
Purpose: This function is to allow the RSP to run in parallel with Purpose: This function is to allow the RSP to run in parallel with
the r4300 switching control back to the r4300 once the the r4300 switching control back to the r4300 once the
function ends. function ends.
input: The number of cycles that is meant to be executed Input: The number of cycles that is meant to be executed
output: The number of cycles that was executed. This value can Output: The number of cycles that was executed. This value can
be greater than the number of cycles that the RSP be greater than the number of cycles that the RSP
should have performed. should have performed.
(this value is ignored if the RSP is stopped) (this value is ignored if the RSP is stopped)
@ -72,9 +72,9 @@ uint32_t DoRspCycles(uint32_t Cycles)
Function: GetDllInfo Function: GetDllInfo
Purpose: This function allows the emulator to gather information Purpose: This function allows the emulator to gather information
about the DLL by filling in the PluginInfo structure. about the DLL by filling in the PluginInfo structure.
input: a pointer to a PLUGIN_INFO structure that needs to be Input: A pointer to a PLUGIN_INFO structure that needs to be
filled by the function. (see def above) filled by the function. (see def above)
output: none Output: None
*/ */
void GetDllInfo(PLUGIN_INFO * PluginInfo) void GetDllInfo(PLUGIN_INFO * PluginInfo)
@ -95,11 +95,11 @@ Function: InitiateRSP
Purpose: This function is called when the DLL is started to give Purpose: This function is called when the DLL is started to give
information from the emulator that the N64 RSP information from the emulator that the N64 RSP
interface needs interface needs
input: Rsp_Info is passed to this function which is defined Input: Rsp_Info is passed to this function which is defined
above. above.
CycleCount is the number of cycles between switching CycleCount is the number of cycles between switching
control between the RSP and r4300i core. control between the RSP and r4300i core.
output: none Output: None
*/ */
void InitiateRSP(RSP_INFO Rsp_Info, uint32_t * /*CycleCount*/) void InitiateRSP(RSP_INFO Rsp_Info, uint32_t * /*CycleCount*/)
@ -114,9 +114,9 @@ void InitiateRSP(RSP_INFO Rsp_Info, uint32_t * /*CycleCount*/)
/* /*
Function: RomOpen Function: RomOpen
Purpose: This function is called when a ROM is opened. Purpose: This function is called when a ROM is opened
input: none Input: None
output: none Output: None
*/ */
void RomOpen(void) void RomOpen(void)
@ -125,9 +125,9 @@ void RomOpen(void)
/* /*
Function: RomClosed Function: RomClosed
Purpose: This function is called when a ROM is closed. Purpose: This function is called when a ROM is closed
input: none Input: None
output: none Output: None
*/ */
void RomClosed(void) void RomClosed(void)

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2012 Bobby Smiles // Copyright(C) 2012 Bobby Smiles
// GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html // GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2014 Bobby Smiles // Copyright(C) 2014 Bobby Smiles
// GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html // GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2014 Bobby Smiles // Copyright(C) 2014 Bobby Smiles
// Copyright(C) 2009 Richard Goedeken // Copyright(C) 2009 Richard Goedeken
@ -197,8 +197,8 @@ void mp3_task(CHle * hle, unsigned int index, uint32_t address)
uint32_t t4;// = (w1 & 0x1E); uint32_t t4;// = (w1 & 0x1E);
// Initialization code // Initialization code
uint32_t readPtr; // s5 uint32_t readPtr; // S5
uint32_t writePtr; // s6 uint32_t writePtr; // S6
uint32_t tmp; uint32_t tmp;
int cnt, cnt2; int cnt, cnt2;
@ -210,16 +210,16 @@ void mp3_task(CHle * hle, unsigned int index, uint32_t address)
writePtr = readPtr = address; writePtr = readPtr = address;
// TODO: Just do that for efficiency...may remove and use directly later anyway // TODO: Just do that for efficiency...may remove and use directly later anyway
memcpy(hle->mp3_buffer() + 0xCE8, hle->dram() + readPtr, 8); memcpy(hle->mp3_buffer() + 0xCE8, hle->dram() + readPtr, 8);
// This must be a header byte or whatnot // This must be a header byte or what not
readPtr += 8; readPtr += 8;
for (cnt = 0; cnt < 0x480; cnt += 0x180) for (cnt = 0; cnt < 0x480; cnt += 0x180)
{ {
// DMA: 0xCF0 <- RDRAM[s5] : 0x180 // DMA: 0xCF0 <- RDRAM[s5] : 0x180
memcpy(hle->mp3_buffer() + 0xCF0, hle->dram() + readPtr, 0x180); memcpy(hle->mp3_buffer() + 0xCF0, hle->dram() + readPtr, 0x180);
inPtr = 0xCF0; // s7 inPtr = 0xCF0; // S7
outPtr = 0xE70; // s3 outPtr = 0xE70; // S3
// --------------- Inner Loop Start -------------------- // Inner loop start
for (cnt2 = 0; cnt2 < 0x180; cnt2 += 0x40) for (cnt2 = 0; cnt2 < 0x180; cnt2 += 0x40)
{ {
t6 &= 0xFFE0; t6 &= 0xFFE0;
@ -234,7 +234,7 @@ void mp3_task(CHle * hle, unsigned int index, uint32_t address)
inPtr += 0x40; inPtr += 0x40;
outPtr += 0x40; outPtr += 0x40;
} }
// --------------- Inner Loop End -------------------- // Inner loop end
memcpy(hle->dram() + writePtr, hle->mp3_buffer() + 0xe70, 0x180); memcpy(hle->dram() + writePtr, hle->mp3_buffer() + 0xe70, 0x180);
writePtr += 0x180; writePtr += 0x180;
readPtr += 0x180; readPtr += 0x180;
@ -326,7 +326,7 @@ static void InnerLoop(CHle * hle, uint32_t outPtr, uint32_t inPtr, uint32_t t6,
MP3AB0(v); MP3AB0(v);
// Part 5 - 1-Wide Butterflies - 100% accurate but need SSVs! // Part 5 - 1-wide butterflies - 100% accurate but need SSVs!
t0 = t6 + 0x100; t0 = t6 + 0x100;
t1 = t6 + 0x200; t1 = t6 + 0x200;
@ -485,7 +485,7 @@ static void InnerLoop(CHle * hle, uint32_t outPtr, uint32_t inPtr, uint32_t t6,
MP3AB0(v); MP3AB0(v);
// Part 7: - 100% accurate + SSV - Unoptimized // Part 7: - 100% accurate + SSV - unoptimized (TODO: optimize?)
v[0] = (v[17] + v[16]) >> 1; v[0] = (v[17] + v[16]) >> 1;
v[1] = ((v[17] * (int)((short)0xA57E * 2)) + (v[16] * 0xB504)) >> 0x10; v[1] = ((v[17] * (int)((short)0xA57E * 2)) + (v[16] * 0xB504)) >> 0x10;
@ -582,7 +582,7 @@ static void InnerLoop(CHle * hle, uint32_t outPtr, uint32_t inPtr, uint32_t t6,
v18 = v6 + v8; v18 = v6 + v8;
// Clamp(v0); // Clamp(v0);
// Clamp(v18); // Clamp(v18);
// clamp??? // Clamp?
*(int16_t *)(hle->mp3_buffer() + (outPtr ^ S16)) = v0; *(int16_t *)(hle->mp3_buffer() + (outPtr ^ S16)) = v0;
*(int16_t *)(hle->mp3_buffer() + ((outPtr + 2)^S16)) = v18; *(int16_t *)(hle->mp3_buffer() + ((outPtr + 2)^S16)) = v18;
outPtr += 4; outPtr += 4;
@ -643,7 +643,7 @@ static void InnerLoop(CHle * hle, uint32_t outPtr, uint32_t inPtr, uint32_t t6,
v18 = v6 + v8; v18 = v6 + v8;
// Clamp(v0); // Clamp(v0);
// Clamp(v18); // Clamp(v18);
// clamp??? // Clamp?
*(int16_t *)(hle->mp3_buffer() + ((outPtr + 2)^S16)) = v0; *(int16_t *)(hle->mp3_buffer() + ((outPtr + 2)^S16)) = v0;
*(int16_t *)(hle->mp3_buffer() + ((outPtr + 4)^S16)) = v18; *(int16_t *)(hle->mp3_buffer() + ((outPtr + 4)^S16)) = v18;
outPtr += 4; outPtr += 4;

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2013 Bobby Smiles // Copyright(C) 2013 Bobby Smiles
// GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html // GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html
@ -252,7 +252,6 @@ void musyx_v2_task(CHle * hle)
if (ptr_10) if (ptr_10)
{ {
// TODO:
hle->WarnMessage("ptr_10=%08x mask_14=%02x ptr_24=%08x", ptr_10, mask_14, ptr_24); hle->WarnMessage("ptr_10=%08x mask_14=%02x ptr_24=%08x", ptr_10, mask_14, ptr_24);
} }
@ -320,7 +319,7 @@ static void update_base_vol(CHle * hle, int32_t *base_vol,
hle->VerboseMessage("base_vol voice_mask = %08x", voice_mask); hle->VerboseMessage("base_vol voice_mask = %08x", voice_mask);
hle->VerboseMessage("BEFORE: base_vol = %08x %08x %08x %08x", base_vol[0], base_vol[1], base_vol[2], base_vol[3]); hle->VerboseMessage("BEFORE: base_vol = %08x %08x %08x %08x", base_vol[0], base_vol[1], base_vol[2], base_vol[3]);
// optimization: skip voices contributions entirely if voice_mask is empty // Optimization: skip voices contributions entirely if voice_mask is empty
if (voice_mask != 0) if (voice_mask != 0)
{ {
for (i = 0, mask = 1; i < MAX_VOICES; ++i, mask <<= 1, last_sample_ptr += 8) for (i = 0, mask = 1; i < MAX_VOICES; ++i, mask <<= 1, last_sample_ptr += 8)
@ -337,7 +336,7 @@ static void update_base_vol(CHle * hle, int32_t *base_vol,
} }
} }
// optimization: skip contributions entirely if mask_15 is empty // Optimization: skip contributions entirely if mask_15 is empty
if (mask_15 != 0) if (mask_15 != 0)
{ {
for(i = 0, mask = 1; i < 4; ++i, mask <<= 1, ptr_24 += 8) for(i = 0, mask = 1; i < 4; ++i, mask <<= 1, ptr_24 += 8)
@ -846,7 +845,7 @@ static void interleave_stage_v1(CHle * hle, musyx_t *musyx, uint32_t output_ptr)
int16_t *right; int16_t *right;
uint32_t *dst; uint32_t *dst;
hle->VerboseMessage("interleave: %08x", output_ptr); hle->VerboseMessage("Interleave: %08x", output_ptr);
base_left = clamp_s16(musyx->base_vol[0]); base_left = clamp_s16(musyx->base_vol[0]);
base_right = clamp_s16(musyx->base_vol[1]); base_right = clamp_s16(musyx->base_vol[1]);

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2014 Bobby Smiles // Copyright(C) 2014 Bobby Smiles
// GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html // GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html

View File

@ -72,10 +72,10 @@ private:
std::string m_CurrentSection; std::string m_CurrentSection;
bool m_CurrentSectionDirty; bool m_CurrentSectionDirty;
int m_CurrentSectionFilePos; // Where in the file is the current section int m_CurrentSectionFilePos;
KeyValueList m_CurrentSectionData; KeyValueList m_CurrentSectionData;
long m_lastSectionSearch; // When scanning for a section, what was the last scanned POS long m_lastSectionSearch;
bool m_ReadOnly; bool m_ReadOnly;
bool m_InstantFlush; bool m_InstantFlush;

View File

@ -141,7 +141,7 @@ uint32_t CThread::GetCurrentThreadId(void)
#ifdef _WIN32 #ifdef _WIN32
return ::GetCurrentThreadId(); return ::GetCurrentThreadId();
#elif defined(SYS_gettid) || defined(__NR_gettid) #elif defined(SYS_gettid) || defined(__NR_gettid)
return syscall(__NR_gettid); /* GLIBC has no implementation of gettid(). */ return syscall(__NR_gettid); // GLIBC has no implementation of gettid()
#else #else
return gettid(); return gettid();
#endif #endif

View File

@ -207,7 +207,7 @@ CTraceFileLog::CTraceFileLog(const char * FileName, bool FlushFile, CLog::LOG_OP
m_hLogFile.SetTruncateFile(true); m_hLogFile.SetTruncateFile(true);
if (dwMaxFileSize < 3 || dwMaxFileSize > 2047) if (dwMaxFileSize < 3 || dwMaxFileSize > 2047)
{ /* Clamp file size to 5 MB if it exceeds 2047 or falls short of 3. */ { // Clamp file size to 5MB if it exceeds 2047 or falls short of 3
dwMaxFileSize = 5; dwMaxFileSize = 5;
} }
m_hLogFile.SetMaxFileSize((uint32_t)(dwMaxFileSize * MB)); m_hLogFile.SetMaxFileSize((uint32_t)(dwMaxFileSize * MB));

View File

@ -53,7 +53,7 @@ bool pjutil::TerminatedExistingExe()
} }
if (!AskedUser) if (!AskedUser)
{ {
stdstr_f Message("%s currently running\n\nTerminate pid %d now?", ModuleName.c_str(), lppe.th32ProcessID); stdstr_f Message("%s currently running\n\nTerminate PID %d now?", ModuleName.c_str(), lppe.th32ProcessID);
stdstr_f Caption("Terminate %s", ModuleName.c_str()); stdstr_f Caption("Terminate %s", ModuleName.c_str());
AskedUser = true; AskedUser = true;
@ -73,7 +73,7 @@ bool pjutil::TerminatedExistingExe()
} }
else else
{ {
stdstr_f Message("Failed to terminate pid %d", lppe.th32ProcessID); stdstr_f Message("Failed to terminate PID %d", lppe.th32ProcessID);
stdstr_f Caption("Terminate %s failed!", ModuleName.c_str()); stdstr_f Caption("Terminate %s failed!", ModuleName.c_str());
MessageBox(nullptr, Message.ToUTF16().c_str(), Caption.ToUTF16().c_str(), MB_YESNO | MB_ICONEXCLAMATION); MessageBox(nullptr, Message.ToUTF16().c_str(), Caption.ToUTF16().c_str(), MB_YESNO | MB_ICONEXCLAMATION);
} }

View File

@ -9,15 +9,15 @@ implied warranty of any kind.
The translator/ modifier does not claim (1) that MD5 will do what you think The translator/ modifier does not claim (1) that MD5 will do what you think
it does; (2) that this translation/ modification is accurate; or (3) that it does; (2) that this translation/ modification is accurate; or (3) that
this software is "merchantable." (Language for this disclaimer partially this software is "merchantable." (language for this disclaimer partially
copied from the disclaimer below). copied from the disclaimer below)
based on: based on:
MD5.H - header file for MD5C.C MD5.H - header file for MD5C.C
MDDRIVER.C - test driver for MD2, MD4 and MD5 MDDRIVER.C - test driver for MD2, MD4 and MD5
Copyright (C) 1991-2, RSA Data Security, Inc. Created 1991. All rights reserved. Copyright (C) 1991-1992, RSA Data Security, Inc. Created 1991. All rights reserved.
License to copy and use this software is granted provided that it License to copy and use this software is granted provided that it
is identified as the "RSA Data Security, Inc. MD5 Message-Digest is identified as the "RSA Data Security, Inc. MD5 Message-Digest
@ -59,7 +59,7 @@ MD5::~MD5()
void MD5::update(const uint1 *input, uint4 input_length) void MD5::update(const uint1 *input, uint4 input_length)
{ {
uint4 input_index, buffer_index; uint4 input_index, buffer_index;
uint4 buffer_space; // How much space is left in the buffer uint4 buffer_space;
if (finalized) // So we can't update! if (finalized) // So we can't update!
{ {
@ -78,7 +78,7 @@ void MD5::update(const uint1 *input, uint4 input_length)
count[1] += ((uint4)input_length >> 29); count[1] += ((uint4)input_length >> 29);
buffer_space = 64 - buffer_index; // How much space is left in the buffer buffer_space = 64 - buffer_index;
// Transform as many times as possible // Transform as many times as possible
if (input_length >= buffer_space) // i.e. we have enough to fill the buffer if (input_length >= buffer_space) // i.e. we have enough to fill the buffer
@ -93,11 +93,11 @@ void MD5::update(const uint1 *input, uint4 input_length)
transform((unsigned char *)(input + input_index)); transform((unsigned char *)(input + input_index));
} }
buffer_index = 0; // So we can buffer remaining buffer_index = 0;
} }
else else
{ {
input_index = 0; // So we can buffer the whole input input_index = 0;
} }
// Here we do the buffering: // Here we do the buffering:
@ -246,7 +246,7 @@ const char *MD5::hex_digest()
return m_hex_digest.c_str(); return m_hex_digest.c_str();
} }
// PRIVATE METHODS: // Private methods:
void MD5::init() void MD5::init()
{ {

View File

@ -9,15 +9,15 @@ implied warranty of any kind.
The translator/ modifier does not claim (1) that MD5 will do what you think The translator/ modifier does not claim (1) that MD5 will do what you think
it does; (2) that this translation/ modification is accurate; or (3) that it does; (2) that this translation/ modification is accurate; or (3) that
this software is "merchantable." (Language for this disclaimer partially this software is "merchantable." (language for this disclaimer partially
copied from the disclaimer below). copied from the disclaimer below)
based on: based on:
MD5.H - header file for MD5C.C MD5.H - header file for MD5C.C
MDDRIVER.C - test driver for MD2, MD4 and MD5 MDDRIVER.C - test driver for MD2, MD4 and MD5
Copyright (C) 1991-2, RSA Data Security, Inc. Created 1991. All rights reserved. Copyright (C) 1991-1992, RSA Data Security, Inc. Created 1991. All rights reserved.
License to copy and use this software is granted provided that it License to copy and use this software is granted provided that it
is identified as the "RSA Data Security, Inc. MD5 Message-Digest is identified as the "RSA Data Security, Inc. MD5 Message-Digest

View File

@ -233,7 +233,7 @@ CPath& CPath::operator =(const std::string& strPath)
/* /*
Post: Converts path to string Post: Converts path to string
Task: Convert path to string Task: Convert path to string
Warning: because this pointer to string point in the data Warning: Because this pointer to string point in the data
of this class, it is possible to cast the result of this of this class, it is possible to cast the result of this
function in any non-constant pointer and alter the data. function in any non-constant pointer and alter the data.
Very dangerous! Very dangerous!
@ -281,7 +281,7 @@ Task: Return the individual components of this path.
For any given argument, you can pass nullptr if you are not For any given argument, you can pass nullptr if you are not
interested in that component. interested in that component.
Do not rely on pNames being <= 8 characters, extensions Do not rely on pNames being <= 8 characters, extensions
being <= 3 characters, or drives being 1 character being <= 3 characters, or drives being 1 character.
*/ */
#ifdef _WIN32 #ifdef _WIN32
@ -922,7 +922,7 @@ Task: To determine if the directory exists, we need to
create a test path with a wildcard (*.*) extension create a test path with a wildcard (*.*) extension
and see if FindFirstFile returns anything. We don't and see if FindFirstFile returns anything. We don't
use CPath::FindFirst() because that routine parses out use CPath::FindFirst() because that routine parses out
'.' and '..', which fails for empty directories '.' and '..', which fails for empty directories.
*/ */
bool CPath::DirectoryExists() const bool CPath::DirectoryExists() const
@ -1041,10 +1041,10 @@ bool CPath::Delete(bool bEvenIfReadOnly) const
/* /*
Post: Return TRUE on success, false if there is such a target file Post: Return TRUE on success, false if there is such a target file
and we weren't granted permission to overwrite file or if we get an error and we weren't granted permission to overwrite file or if we get an error.
Task: Copy file Task: Copy file
Since ::CopyFile will not overwrite read-only files Since ::CopyFile will not overwrite read-only files
we will make sure the target file is writable first we will make sure the target file is writable first.
*/ */
bool CPath::CopyTo(const char * lpcszTargetFile, bool bOverwrite) bool CPath::CopyTo(const char * lpcszTargetFile, bool bOverwrite)
@ -1053,7 +1053,7 @@ bool CPath::CopyTo(const char * lpcszTargetFile, bool bOverwrite)
{ {
return false; return false;
} }
WriteTrace(TracePath, TraceDebug, "copy \"%s\" to \"%s\"",m_strPath.c_str(),lpcszTargetFile); WriteTrace(TracePath, TraceDebug, "Copy \"%s\" to \"%s\"",m_strPath.c_str(),lpcszTargetFile);
#ifdef _WIN32 #ifdef _WIN32
// Check if the target file exists // Check if the target file exists
CPath TargetFile(lpcszTargetFile); CPath TargetFile(lpcszTargetFile);
@ -1164,7 +1164,7 @@ bool CPath::CopyTo(const char * lpcszTargetFile, bool bOverwrite)
} }
// Post: Return TRUE on success, false if there is such a target file // Post: Return TRUE on success, false if there is such a target file
// and we weren't granted permission to overwrite file or get an error // and we weren't granted permission to overwrite file or get an error.
// Task: Move file // Task: Move file
bool CPath::MoveTo(const char * lpcszTargetFile, bool bOverwrite) bool CPath::MoveTo(const char * lpcszTargetFile, bool bOverwrite)
@ -1228,7 +1228,7 @@ These attributes do not follow a simple additive logic.
Note that FIND_ATTRIBUTE_FILES is 0x00, so it effectively cannot be Note that FIND_ATTRIBUTE_FILES is 0x00, so it effectively cannot be
removed from the attribute set. You will therefore always removed from the attribute set. You will therefore always
get normal files, and may also get Archive, Hidden, etc. get normal files, and may also get Archive, Hidden, etc.
if you specify those attributes if you specify those attributes.
See also: FindFirstFile, FindNextFile See also: FindFirstFile, FindNextFile
*/ */
@ -1287,8 +1287,8 @@ bool CPath::FindFirst(uint32_t dwAttributes /*= FIND_ATTRIBUTE_FILES*/)
return false; return false;
} }
// Post : Return TRUE if a new match found // Post: Return TRUE if a new match found
// Task : Find the next file that meets the conditions specified in the last FindFirst call // Task: Find the next file that meets the conditions specified in the last FindFirst call
bool CPath::FindNext() bool CPath::FindNext()
{ {
@ -1347,12 +1347,12 @@ bool CPath::FindNext()
strcmp(pEntry->d_name,"..") == 0 || strcmp(pEntry->d_name,"..") == 0 ||
!wildcmp(m_FindWildcard.c_str(),pEntry->d_name)) !wildcmp(m_FindWildcard.c_str(),pEntry->d_name))
{ {
WriteTrace(TracePath, TraceVerbose, "continue, d_name = %s",pEntry->d_name); WriteTrace(TracePath, TraceVerbose, "Continue, d_name = %s",pEntry->d_name);
continue; continue;
} }
if ((FIND_ATTRIBUTE_SUBDIR & dwFileAttributes) == FIND_ATTRIBUTE_SUBDIR) if ((FIND_ATTRIBUTE_SUBDIR & dwFileAttributes) == FIND_ATTRIBUTE_SUBDIR)
{ {
WriteTrace(TracePath, TraceVerbose, "is dir"); WriteTrace(TracePath, TraceVerbose, "is a directory");
if (IsDirectory()) if (IsDirectory())
{ {
// Found a directory // Found a directory
@ -1366,7 +1366,7 @@ bool CPath::FindNext()
} }
else else
{ {
WriteTrace(TracePath, TraceVerbose, "is file"); WriteTrace(TracePath, TraceVerbose, "is a file");
// Found a file // Found a file
if (IsDirectory()) if (IsDirectory())
{ {

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64. // Copyright(C) 2001-2021 Project64.
// Copyright(C) 2015 Gilles Siberlin // Copyright(C) 2015 Gilles Siberlin
// Copyright(C) 2007-2009 Richard Goedeken // Copyright(C) 2007-2009 Richard Goedeken

View File

@ -79,11 +79,11 @@ typedef struct
Function: AiDacrateChanged Function: AiDacrateChanged
Purpose: This function is called to notify the DLL that the Purpose: This function is called to notify the DLL that the
AiDacrate registers value has been changed. AiDacrate registers value has been changed.
input: The System type: Input: The system type:
SYSTEM_NTSC 0 SYSTEM_NTSC 0
SYSTEM_PAL 1 SYSTEM_PAL 1
SYSTEM_MPAL 2 SYSTEM_MPAL 2
output: none Output: None
*/ */
EXPORT void CALL AiDacrateChanged(int32_t SystemType); EXPORT void CALL AiDacrateChanged(int32_t SystemType);
@ -92,8 +92,8 @@ EXPORT void CALL AiDacrateChanged(int32_t SystemType);
Function: AiLenChanged Function: AiLenChanged
Purpose: This function is called to notify the DLL that the Purpose: This function is called to notify the DLL that the
AiLen registers value has been changed. AiLen registers value has been changed.
input: none Input: None
output: none Output: None
*/ */
EXPORT void CALL AiLenChanged(void); EXPORT void CALL AiLenChanged(void);
@ -102,8 +102,8 @@ EXPORT void CALL AiLenChanged(void);
Function: AiReadLength Function: AiReadLength
Purpose: This function is called to allow the DLL to return the Purpose: This function is called to allow the DLL to return the
value that AI_LEN_REG should equal value that AI_LEN_REG should equal
input: none Input: None
output: The amount of bytes still left to play. Output: The amount of bytes still left to play.
*/ */
EXPORT uint32_t CALL AiReadLength(void); EXPORT uint32_t CALL AiReadLength(void);
@ -116,9 +116,9 @@ go, copy more stuff to the buffer, anything you like).
The function is designed to go in to the message loop The function is designed to go in to the message loop
of the main window...but can be placed anywhere you of the main window...but can be placed anywhere you
like. like.
input: if Wait is set to true, then this function should wait Input: If wait is set to true, then this function should wait
till there is a message in its message queue. till there is a message in its message queue.
output: none Output: None
*/ */
EXPORT void CALL AiUpdate(int32_t Wait); EXPORT void CALL AiUpdate(int32_t Wait);
@ -127,8 +127,8 @@ EXPORT void CALL AiUpdate(int32_t Wait);
Function: CloseDLL Function: CloseDLL
Purpose: This function is called when the emulator is closing Purpose: This function is called when the emulator is closing
down allowing the DLL to de-initialize. down allowing the DLL to de-initialize.
input: none Input: None
output: none Output: None
*/ */
EXPORT void CALL CloseDLL(void); EXPORT void CALL CloseDLL(void);
@ -137,8 +137,8 @@ EXPORT void CALL CloseDLL(void);
Function: DllAbout Function: DllAbout
Purpose: This function is optional function that is provided Purpose: This function is optional function that is provided
to give further information about the DLL. to give further information about the DLL.
input: a handle to the window that calls this function Input: A handle to the window that calls this function.
output: none Output: None
*/ */
EXPORT void CALL DllAbout(void * hParent); EXPORT void CALL DllAbout(void * hParent);
@ -147,8 +147,8 @@ EXPORT void CALL DllAbout(void * hParent);
Function: DllConfig Function: DllConfig
Purpose: This function is optional function that is provided Purpose: This function is optional function that is provided
to allow the user to configure the DLL to allow the user to configure the DLL
input: a handle to the window that calls this function Input: A handle to the window that calls this function
output: none Output: None
*/ */
EXPORT void CALL DllConfig(void * hParent); EXPORT void CALL DllConfig(void * hParent);
@ -157,8 +157,8 @@ EXPORT void CALL DllConfig(void * hParent);
Function: DllTest Function: DllTest
Purpose: This function is optional function that is provided Purpose: This function is optional function that is provided
to allow the user to test the DLL to allow the user to test the DLL
input: a handle to the window that calls this function Input: A handle to the window that calls this function
output: none Output: None
*/ */
EXPORT void CALL DllTest(void * hParent); EXPORT void CALL DllTest(void * hParent);
@ -167,9 +167,9 @@ EXPORT void CALL DllTest(void * hParent);
Function: GetDllInfo Function: GetDllInfo
Purpose: This function allows the emulator to gather information Purpose: This function allows the emulator to gather information
about the DLL by filling in the PluginInfo structure. about the DLL by filling in the PluginInfo structure.
input: a pointer to a PLUGIN_INFO structure that needs to be Input: A pointer to a PLUGIN_INFO structure that needs to be
filled by the function. (see def above) filled by the function. (see def above)
output: none Output: None
*/ */
EXPORT void CALL GetDllInfo(PLUGIN_INFO * PluginInfo); EXPORT void CALL GetDllInfo(PLUGIN_INFO * PluginInfo);
@ -181,10 +181,9 @@ information from the emulator that the N64 audio
interface needs interface needs
Input: Audio_Info is passed to this function which is defined Input: Audio_Info is passed to this function which is defined
above. above.
Output: TRUE on success Output: True on success
FALSE on failure to initialize FALSE on failure to initialize
Note on interrupts:
** Note on interrupts **:
To generate an interrupt set the appropriate bit in MI_INTR_REG To generate an interrupt set the appropriate bit in MI_INTR_REG
and then call the function CheckInterrupts to tell the emulator and then call the function CheckInterrupts to tell the emulator
that there is a waiting interrupt. that there is a waiting interrupt.
@ -197,8 +196,8 @@ Function: ProcessAList
Purpose: This function is called when there is a Alist to be Purpose: This function is called when there is a Alist to be
processed. The DLL will have to work out all the info processed. The DLL will have to work out all the info
about the AList itself. about the AList itself.
input: none Input: None
output: none Output: None
*/ */
EXPORT void CALL ProcessAList(void); EXPORT void CALL ProcessAList(void);
@ -206,8 +205,8 @@ EXPORT void CALL ProcessAList(void);
/* /*
Function: RomClosed Function: RomClosed
Purpose: This function is called when a ROM is closed. Purpose: This function is called when a ROM is closed.
input: none Input: None
output: none Output: None
*/ */
EXPORT void CALL RomClosed(void); EXPORT void CALL RomClosed(void);

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64. // Copyright(C) 2001-2021 Project64.
// Copyright(C) 2000-2015 Azimer // Copyright(C) 2000-2015 Azimer
// GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html // GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html
@ -88,7 +88,7 @@ void DirectSoundDriver::StopAudio()
m_AudioIsDone = true; m_AudioIsDone = true;
if (WaitForSingleObject((HANDLE)m_handleAudioThread, 5000) == WAIT_TIMEOUT) if (WaitForSingleObject((HANDLE)m_handleAudioThread, 5000) == WAIT_TIMEOUT)
{ {
WriteTrace(TraceAudioDriver, TraceError, "Time out on close"); WriteTrace(TraceAudioDriver, TraceError, "Timeout on close");
TerminateThread((HANDLE)m_handleAudioThread, 1); TerminateThread((HANDLE)m_handleAudioThread, 1);
} }

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64. // Copyright(C) 2001-2021 Project64.
// Copyright(C) 2015 Gilles Siberlin // Copyright(C) 2015 Gilles Siberlin
// Copyright(C) 2007 - 2009 Richard Goedeken // Copyright(C) 2007 - 2009 Richard Goedeken
@ -45,7 +45,7 @@ enum { SECONDARY_BUFFER_NBR = 2 };
// This sets default frequency what is used if ROM doesn't want to change it. // This sets default frequency what is used if ROM doesn't want to change it.
// Probably only game that needs this is Zelda: Ocarina Of Time Master Quest // Probably only game that needs this is Zelda: Ocarina Of Time Master Quest
// TODO: We should try to find out why Demos' frequencies are always wrong // TODO: We should try to find out why Demos' frequencies are always wrong
// They tend to rely on a default frequency, but apparently never the same one ;) // They tend to rely on a default frequency, but apparently never the same one
enum { DEFAULT_FREQUENCY = 33600 }; enum { DEFAULT_FREQUENCY = 33600 };
@ -87,7 +87,7 @@ int g_OutputFreq = 44100;
bool g_critical_failure = false; bool g_critical_failure = false;
#ifdef ANDROID #ifdef ANDROID
// Thread Lock // Thread lock
threadLock g_lock; threadLock g_lock;
// Engine interfaces // Engine interfaces
@ -192,7 +192,7 @@ static void CloseAudio(void)
g_engineEngine = nullptr; g_engineEngine = nullptr;
} }
// Destroy thread Locks // Destroy thread locks
pthread_cond_signal(&(g_lock.cond)); pthread_cond_signal(&(g_lock.cond));
pthread_mutex_unlock(&(g_lock.mutex)); pthread_mutex_unlock(&(g_lock.mutex));
pthread_cond_destroy(&(g_lock.cond)); pthread_cond_destroy(&(g_lock.cond));
@ -379,7 +379,7 @@ void OpenSLESDriver::AI_SetFrequency(uint32_t freq, uint32_t BufferSize)
if (g_critical_failure) if (g_critical_failure)
{ {
WriteTrace(TraceAudioInitShutdown, TraceInfo, "Critical failure in setting up plugin, ignoring init..."); WriteTrace(TraceAudioInitShutdown, TraceInfo, "Critical failure in setting up plugin, ignoring initialization...");
WriteTrace(TraceAudioInitShutdown, TraceDebug, "Done"); WriteTrace(TraceAudioInitShutdown, TraceDebug, "Done");
return; return;
} }
@ -437,7 +437,7 @@ void OpenSLESDriver::AI_SetFrequency(uint32_t freq, uint32_t BufferSize)
} }
#ifdef ANDROID #ifdef ANDROID
// Create thread Locks to ensure synchronization between callback and processing code // Create thread locks to ensure synchronization between callback and processing code
if (pthread_mutex_init(&(g_lock.mutex), (pthread_mutexattr_t*)nullptr) != 0) if (pthread_mutex_init(&(g_lock.mutex), (pthread_mutexattr_t*)nullptr) != 0)
{ {
WriteTrace(TraceAudioInitShutdown, TraceError, "pthread_mutex_init failed"); WriteTrace(TraceAudioInitShutdown, TraceError, "pthread_mutex_init failed");

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64. // Copyright(C) 2001-2021 Project64.
// Copyright(C) 2015 Gilles Siberlin // Copyright(C) 2015 Gilles Siberlin
// Copyright(C) 2007 - 2009 Richard Goedeken // Copyright(C) 2007 - 2009 Richard Goedeken

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2000-2015 Azimer // Copyright(C) 2000-2015 Azimer
// GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html // GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html
@ -119,7 +119,7 @@ void SoundDriverBase::LoadAiBuffer(uint8_t *start, uint32_t length)
bool DMAEnabled = (*g_AudioInfo.AI_CONTROL_REG & AI_CONTROL_DMA_ON) == AI_CONTROL_DMA_ON; bool DMAEnabled = (*g_AudioInfo.AI_CONTROL_REG & AI_CONTROL_DMA_ON) == AI_CONTROL_DMA_ON;
if (!DMAEnabled) if (!DMAEnabled)
{ {
WriteTrace(TraceAudioDriver, TraceVerbose, "Return silence -- DMA is disabled"); WriteTrace(TraceAudioDriver, TraceVerbose, "Return silence - DMA is disabled");
memset(ptrStart, 0, bytesToMove); memset(ptrStart, 0, bytesToMove);
return; return;
} }

View File

@ -1,5 +1,5 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2000-2015 Azimer // Copyright(C) 2000-2015 Azimer
// GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html // GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html

View File

@ -196,7 +196,7 @@ static bool ParseCommand(int32_t argc, char **argv)
} }
else else
{ {
WriteTrace(TraceAppInit, TraceError, "not enough parameters for '%d: %s'", i, argv[i]); WriteTrace(TraceAppInit, TraceError, "Not enough parameters for '%d: %s'", i, argv[i]);
return false; return false;
} }
} }
@ -207,7 +207,7 @@ static bool ParseCommand(int32_t argc, char **argv)
} }
else else
{ {
WriteTrace(TraceAppInit, TraceError, "unrecognized command-line parameter '%d: %s'", i, argv[i]); WriteTrace(TraceAppInit, TraceError, "Unrecognized command-line parameter '%d: %s'", i, argv[i]);
} }
} }
return false; return false;
@ -222,17 +222,17 @@ bool AppInit(CNotification * Notify, const char * BaseDirectory, int argc, char
WriteTrace(TraceAppInit, TraceDebug, "Starting (BaseDirectory: %s)", BaseDirectory ? BaseDirectory : "null"); WriteTrace(TraceAppInit, TraceDebug, "Starting (BaseDirectory: %s)", BaseDirectory ? BaseDirectory : "null");
if (Notify == nullptr) if (Notify == nullptr)
{ {
WriteTrace(TraceAppInit, TraceError, "No Notification class passed"); WriteTrace(TraceAppInit, TraceError, "No notification class passed");
return false; return false;
} }
WriteTrace(TraceAppInit, TraceDebug, "Settings up settings"); WriteTrace(TraceAppInit, TraceDebug, "Setting up settings");
g_Settings = new CSettings; g_Settings = new CSettings;
g_Settings->Initialize(BaseDirectory, AppName()); g_Settings->Initialize(BaseDirectory, AppName());
WriteTrace(TraceAppInit, TraceDebug, "Parse Commands"); WriteTrace(TraceAppInit, TraceDebug, "Parse commands");
if (!ParseCommand(argc, argv)) if (!ParseCommand(argc, argv))
{ {
WriteTrace(TraceAppInit, TraceError, "Failed to Parse Commands, exiting now"); WriteTrace(TraceAppInit, TraceError, "Failed to parse commands, exiting now");
return false; return false;
} }
@ -254,33 +254,33 @@ bool AppInit(CNotification * Notify, const char * BaseDirectory, int argc, char
#else #else
if (!CMipsMemoryVM::SetupSegvHandler()) if (!CMipsMemoryVM::SetupSegvHandler())
{ {
WriteTrace(TraceAppInit, TraceDebug, "Setup Segv Handler Failed"); WriteTrace(TraceAppInit, TraceDebug, "Setup SEGV handler failed");
return false; return false;
} }
#endif #endif
g_Enhancements = new CEnhancements(); g_Enhancements = new CEnhancements();
//Create the plugin container //Create the plugin container
WriteTrace(TraceAppInit, TraceInfo, "Create Plugins"); WriteTrace(TraceAppInit, TraceInfo, "Create plugins");
g_Plugins = new CPlugins(Directory_Plugin, false); g_Plugins = new CPlugins(Directory_Plugin, false);
g_Lang = new CLanguage(); g_Lang = new CLanguage();
g_Lang->LoadCurrentStrings(); g_Lang->LoadCurrentStrings();
g_Notify->AppInitDone(); g_Notify->AppInitDone();
WriteTrace(TraceAppInit, TraceDebug, "Initialized Successfully"); WriteTrace(TraceAppInit, TraceDebug, "Initialized successfully");
return true; return true;
} }
catch (...) catch (...)
{ {
g_Notify->DisplayError(stdstr_f("Exception caught\nFile: %s\nLine: %d", __FILE__, __LINE__).c_str()); g_Notify->DisplayError(stdstr_f("Exception caught\nFile: %s\nLine: %d", __FILE__, __LINE__).c_str());
WriteTrace(TraceAppInit, TraceError, "Exception caught, Init was not successfull"); WriteTrace(TraceAppInit, TraceError, "Exception caught, initialization was not successful");
return false; return false;
} }
} }
void AppCleanup(void) void AppCleanup(void)
{ {
WriteTrace(TraceAppCleanup, TraceDebug, "cleaning up global objects"); WriteTrace(TraceAppCleanup, TraceDebug, "Cleaning up global objects");
CleanupTrace(); CleanupTrace();
if (g_Enhancements) { delete g_Enhancements; g_Enhancements = nullptr; } if (g_Enhancements) { delete g_Enhancements; g_Enhancements = nullptr; }

View File

@ -188,7 +188,7 @@ bool CMipsMemoryVM::FilterX86Exception(uint32_t MemAddress, X86_CONTEXT & contex
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to load byte\n\nMIPS Address: %08X\nX86 Address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str()); g_Notify->DisplayError(stdstr_f("Failed to load byte\n\nMIPS address: %08X\nX86 address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str());
} }
} }
*context.Eip = (uint32_t)ReadPos; *context.Eip = (uint32_t)ReadPos;
@ -198,7 +198,7 @@ bool CMipsMemoryVM::FilterX86Exception(uint32_t MemAddress, X86_CONTEXT & contex
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to load half word\n\nMIPS Address: %08X\nX86 Address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str()); g_Notify->DisplayError(stdstr_f("Failed to load half word\n\nMIPS address: %08X\nX86 address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str());
} }
} }
*context.Eip = (uint32_t)ReadPos; *context.Eip = (uint32_t)ReadPos;
@ -208,7 +208,7 @@ bool CMipsMemoryVM::FilterX86Exception(uint32_t MemAddress, X86_CONTEXT & contex
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to load byte\n\nMIPS Address: %08X\nX86 Address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str()); g_Notify->DisplayError(stdstr_f("Failed to load byte\n\nMIPS address: %08X\nX86 address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str());
} }
} }
*context.Eip = (uint32_t)ReadPos; *context.Eip = (uint32_t)ReadPos;
@ -218,7 +218,7 @@ bool CMipsMemoryVM::FilterX86Exception(uint32_t MemAddress, X86_CONTEXT & contex
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to load half word\n\nMIPS Address: %08X\nX86 Address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str()); g_Notify->DisplayError(stdstr_f("Failed to load half word\n\nMIPS address: %08X\nX86 address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str());
} }
} }
*context.Eip = (uint32_t)ReadPos; *context.Eip = (uint32_t)ReadPos;
@ -239,7 +239,7 @@ bool CMipsMemoryVM::FilterX86Exception(uint32_t MemAddress, X86_CONTEXT & contex
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to half word\n\nMIPS Address: %08X\nX86 Address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str()); g_Notify->DisplayError(stdstr_f("Failed to half word\n\nMIPS address: %08X\nX86 address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str());
} }
} }
*context.Eip = (uint32_t)ReadPos; *context.Eip = (uint32_t)ReadPos;
@ -249,7 +249,7 @@ bool CMipsMemoryVM::FilterX86Exception(uint32_t MemAddress, X86_CONTEXT & contex
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store half word\n\nMIPS Address: %08X\nX86 Address: %08X", MemAddress, g_Notify->DisplayError(stdstr_f("Failed to store half word\n\nMIPS address: %08X\nX86 address: %08X", MemAddress,
(uint8_t *)*context.Eip).c_str()); (uint8_t *)*context.Eip).c_str());
} }
} }
@ -268,7 +268,7 @@ bool CMipsMemoryVM::FilterX86Exception(uint32_t MemAddress, X86_CONTEXT & contex
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store half word\n\nMIPS Address: %08X\nX86 Address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store half word\n\nMIPS address: %08X\nX86 address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str());
} }
} }
*context.Eip = (uint32_t)(ReadPos + 2); *context.Eip = (uint32_t)(ReadPos + 2);
@ -286,7 +286,7 @@ bool CMipsMemoryVM::FilterX86Exception(uint32_t MemAddress, X86_CONTEXT & contex
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store byte\n\nMIPS Address: %08X\nX86 Address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store byte\n\nMIPS address: %08X\nX86 address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str());
} }
} }
*context.Eip = (uint32_t)ReadPos; *context.Eip = (uint32_t)ReadPos;
@ -296,7 +296,7 @@ bool CMipsMemoryVM::FilterX86Exception(uint32_t MemAddress, X86_CONTEXT & contex
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to load byte\n\nMIPS Address: %08X\nX86 Address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str()); g_Notify->DisplayError(stdstr_f("Failed to load byte\n\nMIPS address: %08X\nX86 address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str());
} }
} }
*context.Eip = (uint32_t)ReadPos; *context.Eip = (uint32_t)ReadPos;
@ -306,7 +306,7 @@ bool CMipsMemoryVM::FilterX86Exception(uint32_t MemAddress, X86_CONTEXT & contex
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to load word\n\nMIPS Address: %08X\nX86 Address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str()); g_Notify->DisplayError(stdstr_f("Failed to load word\n\nMIPS address: %08X\nX86 address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str());
} }
} }
*context.Eip = (uint32_t)ReadPos; *context.Eip = (uint32_t)ReadPos;
@ -316,7 +316,7 @@ bool CMipsMemoryVM::FilterX86Exception(uint32_t MemAddress, X86_CONTEXT & contex
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store word\n\nMIPS Address: %08X\nX86 Address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store word\n\nMIPS address: %08X\nX86 address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str());
} }
} }
*context.Eip = (uint32_t)ReadPos; *context.Eip = (uint32_t)ReadPos;
@ -334,7 +334,7 @@ bool CMipsMemoryVM::FilterX86Exception(uint32_t MemAddress, X86_CONTEXT & contex
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store byte\n\nMIPS Address: %08X\nX86 Address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store byte\n\nMIPS address: %08X\nX86 address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str());
} }
} }
*context.Eip = (uint32_t)(ReadPos + 1); *context.Eip = (uint32_t)(ReadPos + 1);
@ -352,7 +352,7 @@ bool CMipsMemoryVM::FilterX86Exception(uint32_t MemAddress, X86_CONTEXT & contex
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store word\n\nMIPS Address: %08X\nX86 Address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store word\n\nMIPS address: %08X\nX86 address: %08X", MemAddress, (uint8_t *)*context.Eip).c_str());
} }
} }
*context.Eip = (uint32_t)(ReadPos + 4); *context.Eip = (uint32_t)(ReadPos + 4);
@ -371,7 +371,7 @@ void CMipsMemoryVM::DumpArmExceptionInfo(uint32_t MemAddress, mcontext_t & conte
{ {
ArmThumbOpcode * OpCode = (ArmThumbOpcode *)context.arm_pc; ArmThumbOpcode * OpCode = (ArmThumbOpcode *)context.arm_pc;
Arm32Opcode * OpCode32 = (Arm32Opcode *)context.arm_pc; Arm32Opcode * OpCode32 = (Arm32Opcode *)context.arm_pc;
WriteTrace(TraceExceptionHandler, TraceError, "Program Counter 0x%lx", g_Reg->m_PROGRAM_COUNTER); WriteTrace(TraceExceptionHandler, TraceError, "Program counter 0x%lx", g_Reg->m_PROGRAM_COUNTER);
for (int i = 0, n = (sizeof(g_BaseSystem->m_LastSuccessSyncPC) / sizeof(g_BaseSystem->m_LastSuccessSyncPC[0])); i < n; i++) for (int i = 0, n = (sizeof(g_BaseSystem->m_LastSuccessSyncPC) / sizeof(g_BaseSystem->m_LastSuccessSyncPC[0])); i < n; i++)
{ {
WriteTrace(TraceExceptionHandler, TraceError, "m_LastSuccessSyncPC[%d] = 0x%lx", i, g_BaseSystem->m_LastSuccessSyncPC[i]); WriteTrace(TraceExceptionHandler, TraceError, "m_LastSuccessSyncPC[%d] = 0x%lx", i, g_BaseSystem->m_LastSuccessSyncPC[i]);
@ -467,7 +467,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to load word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to load word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 2; context.arm_pc = context.arm_pc + 2;
@ -479,7 +479,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 2; context.arm_pc = context.arm_pc + 2;
@ -493,7 +493,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 4; context.arm_pc = context.arm_pc + 4;
@ -507,7 +507,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 4; context.arm_pc = context.arm_pc + 4;
@ -521,7 +521,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to load word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to load word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 4; context.arm_pc = context.arm_pc + 4;
@ -536,7 +536,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 4; context.arm_pc = context.arm_pc + 4;
@ -549,7 +549,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store byte\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store byte\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 2; context.arm_pc = context.arm_pc + 2;
@ -563,7 +563,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store byte\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store byte\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 4; context.arm_pc = context.arm_pc + 4;
@ -577,7 +577,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store half word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store half word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 4; context.arm_pc = context.arm_pc + 4;
@ -591,7 +591,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store half word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store half word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 2; context.arm_pc = context.arm_pc + 2;
@ -605,7 +605,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store half word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store half word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 2; context.arm_pc = context.arm_pc + 2;
@ -619,7 +619,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 2; context.arm_pc = context.arm_pc + 2;
@ -633,7 +633,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to load word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to load word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 2; context.arm_pc = context.arm_pc + 2;
@ -647,7 +647,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store byte\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store byte\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 2; context.arm_pc = context.arm_pc + 2;
@ -661,7 +661,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store half word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store half word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 4; context.arm_pc = context.arm_pc + 4;
@ -675,7 +675,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to store word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to store word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 4; context.arm_pc = context.arm_pc + 4;
@ -689,7 +689,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to load half word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to load half word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 4; context.arm_pc = context.arm_pc + 4;
@ -703,7 +703,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to load half word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to load half word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 4; context.arm_pc = context.arm_pc + 4;
@ -718,7 +718,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to load half word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to load half word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 4; context.arm_pc = context.arm_pc + 4;
@ -732,7 +732,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to load word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to load word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 4; context.arm_pc = context.arm_pc + 4;
@ -746,7 +746,7 @@ bool CMipsMemoryVM::FilterArmException(uint32_t MemAddress, mcontext_t & context
{ {
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("Failed to load word\n\nMIPS Address: %08X\nPC Address: %08X", MemAddress, context.arm_pc).c_str()); g_Notify->DisplayError(stdstr_f("Failed to load word\n\nMIPS address: %08X\nPC address: %08X", MemAddress, context.arm_pc).c_str());
} }
} }
context.arm_pc = context.arm_pc + 4; context.arm_pc = context.arm_pc + 4;

View File

@ -4,7 +4,7 @@ enum LanguageStringID
{ {
EMPTY_STRING = 0, EMPTY_STRING = 0,
// Meta Information // Meta information
// About DLL // About DLL
LANGUAGE_NAME = 1, LANGUAGE_NAME = 1,
@ -110,7 +110,7 @@ enum LanguageStringID
MENU_SLOT_10 = 200, MENU_SLOT_10 = 200,
MENU_SLOT_SAVE = 201, MENU_SLOT_SAVE = 201,
// Pop up menu // Pop-up menu
POPUP_PLAY = 210, POPUP_PLAY = 210,
POPUP_INFO = 211, POPUP_INFO = 211,
POPUP_SETTINGS = 212, POPUP_SETTINGS = 212,
@ -171,7 +171,6 @@ enum LanguageStringID
MENUDES_GAME_SETTINGS = 285, MENUDES_GAME_SETTINGS = 285,
MENUDES_GAME_CHEATS = 286, MENUDES_GAME_CHEATS = 286,
// ROM browser // ROM browser
// ROM browser fields // ROM browser fields
@ -197,7 +196,6 @@ enum LanguageStringID
RB_FILE_FORMAT = 319, RB_FILE_FORMAT = 319,
RB_NAME = 321, RB_NAME = 321,
// Select ROM // Select ROM
SELECT_ROM_DIR = 320, SELECT_ROM_DIR = 320,

View File

@ -373,7 +373,7 @@ void CLanguage::LoadDefaultStrings(void)
DEF_STR(DISKSAVE_SHADOW, "Full Disk Copy"); DEF_STR(DISKSAVE_SHADOW, "Full Disk Copy");
DEF_STR(DISKSAVE_RAM, "Save Area Only"); DEF_STR(DISKSAVE_RAM, "Save Area Only");
// ROM Information // ROM information
// ROM info title // ROM info title
DEF_STR(INFO_TITLE, "ROM Information"); DEF_STR(INFO_TITLE, "ROM Information");
@ -434,7 +434,7 @@ void CLanguage::LoadDefaultStrings(void)
DEF_STR(CHEAT_CHANGED_MSG, "Cheat has been changed.\n\nDo you want to update?"); DEF_STR(CHEAT_CHANGED_MSG, "Cheat has been changed.\n\nDo you want to update?");
DEF_STR(CHEAT_CHANGED_TITLE, "Cheat updated"); DEF_STR(CHEAT_CHANGED_TITLE, "Cheat updated");
// Cheat Pop-up menu // Cheat pop-up menu
DEF_STR(CHEAT_ADDNEW, "Add New Cheat..."); DEF_STR(CHEAT_ADDNEW, "Add New Cheat...");
DEF_STR(CHEAT_EDIT, "Edit"); DEF_STR(CHEAT_EDIT, "Edit");
DEF_STR(CHEAT_DELETE, "Delete"); DEF_STR(CHEAT_DELETE, "Delete");

View File

@ -44,7 +44,7 @@ void CN64System::CloseCpu()
m_EndEmulation = true; m_EndEmulation = true;
if (g_Settings->LoadBool(GameRunning_CPU_Paused)) if (g_Settings->LoadBool(GameRunning_CPU_Paused))
{ {
WriteTrace(TraceN64System, TraceDebug, "Resume cpu"); WriteTrace(TraceN64System, TraceDebug, "Resume CPU");
m_hPauseEvent.Trigger(); m_hPauseEvent.Trigger();
} }

View File

@ -145,7 +145,7 @@ CEnhancement::CEnhancement(const char * Ident, const char * Entry) :
m_Name = &(Lines[0][CurrentLine]); m_Name = &(Lines[0][CurrentLine]);
m_NameAndExtension = m_Name; m_NameAndExtension = m_Name;
//key=value // Key=value
while (CurrentLine < Lines.size()) while (CurrentLine < Lines.size())
{ {
const char * Pos = strchr(Lines[CurrentLine].c_str(), '='); const char * Pos = strchr(Lines[CurrentLine].c_str(), '=');
@ -189,7 +189,7 @@ CEnhancement::CEnhancement(const char * Ident, const char * Entry) :
} }
} }
//Gameshark Code // Gameshark code
while (CurrentLine < Lines.size()) while (CurrentLine < Lines.size())
{ {
char TempFormat[128] = { 0 }; char TempFormat[128] = { 0 };
@ -231,7 +231,7 @@ CEnhancement::CEnhancement(const char * Ident, const char * Entry) :
m_Entries.push_back(GSEntry); m_Entries.push_back(GSEntry);
} }
//Options // Options
uint32_t OptionSize = 0; uint32_t OptionSize = 0;
while (CurrentLine < Lines.size()) while (CurrentLine < Lines.size())
{ {

View File

@ -164,7 +164,7 @@ bool CEnhancmentFile::MoveToSection(const char * Section, bool ChangeCurrentSect
} }
std::unique_ptr<char> Data; std::unique_ptr<char> Data;
char *Input = nullptr; char * Input = nullptr;
int MaxDataSize = 0, DataSize = 0, ReadPos = 0, result; int MaxDataSize = 0, DataSize = 0, ReadPos = 0, result;
FILELOC_ITR iter = m_SectionsPos.find(std::string(Section)); FILELOC_ITR iter = m_SectionsPos.find(std::string(Section));
@ -183,7 +183,7 @@ bool CEnhancmentFile::MoveToSection(const char * Section, bool ChangeCurrentSect
{ {
m_File.Seek(m_lastSectionSearch, CFileBase::begin); m_File.Seek(m_lastSectionSearch, CFileBase::begin);
//long Fpos; // Long Fpos;
uint8_t pUTF8[3]; uint8_t pUTF8[3];
pUTF8[0] = 0xef; pUTF8[0] = 0xef;
pUTF8[1] = 0xbb; pUTF8[1] = 0xbb;
@ -195,7 +195,7 @@ bool CEnhancmentFile::MoveToSection(const char * Section, bool ChangeCurrentSect
if (result <= 1) { continue; } if (result <= 1) { continue; }
if (strlen(CleanLine(Input)) <= 1) { continue; } if (strlen(CleanLine(Input)) <= 1) { continue; }
//We Only care about sections // We only care about sections
char * CurrentSection = Input; char * CurrentSection = Input;
if (m_lastSectionSearch == 0 && !memcmp(CurrentSection, pUTF8, 3)) if (m_lastSectionSearch == 0 && !memcmp(CurrentSection, pUTF8, 3))
@ -206,7 +206,7 @@ bool CEnhancmentFile::MoveToSection(const char * Section, bool ChangeCurrentSect
if (CurrentSection[0] != '[') { continue; } if (CurrentSection[0] != '[') { continue; }
int lineEndPos = (int)strlen(CurrentSection) - 1; int lineEndPos = (int)strlen(CurrentSection) - 1;
if (CurrentSection[lineEndPos] != ']') { continue; } if (CurrentSection[lineEndPos] != ']') { continue; }
//take off the ']' from the end of the string // Take off the ']' from the end of the string
CurrentSection[lineEndPos] = 0; CurrentSection[lineEndPos] = 0;
CurrentSection += 1; CurrentSection += 1;
m_lastSectionSearch = (m_File.GetPosition() - DataSize) + ReadPos; m_lastSectionSearch = (m_File.GetPosition() - DataSize) + ReadPos;
@ -385,9 +385,9 @@ void CEnhancmentFile::SaveCurrentSection(void)
int MaxDataSize = 0, DataSize = 0, ReadPos = 0, result; int MaxDataSize = 0, DataSize = 0, ReadPos = 0, result;
std::unique_ptr<char> Data; std::unique_ptr<char> Data;
char *Input = nullptr; char * Input = nullptr;
//Skip first line as it is the section name // Skip first line as it is the section name
int StartPos = m_CurrentSectionFilePos; int StartPos = m_CurrentSectionFilePos;
int EndPos = StartPos; int EndPos = StartPos;
do do
@ -457,7 +457,7 @@ int CEnhancmentFile::GetStringFromFile(char * & String, std::unique_ptr<char> &
} }
else else
{ {
//Increase buffer size // Increase buffer size
int NewMaxDataSize = MaxDataSize + BufferIncrease; int NewMaxDataSize = MaxDataSize + BufferIncrease;
char * NewBuffer = new char[NewMaxDataSize]; char * NewBuffer = new char[NewMaxDataSize];
if (NewBuffer == nullptr) if (NewBuffer == nullptr)
@ -491,7 +491,7 @@ const char * CEnhancmentFile::CleanLine(char * Line)
{ {
char * Pos = Line; char * Pos = Line;
//Remove any comment from the line // Remove any comment from the line
while (Pos != nullptr) while (Pos != nullptr)
{ {
Pos = strchr(Pos, '/'); Pos = strchr(Pos, '/');
@ -524,7 +524,7 @@ const char * CEnhancmentFile::CleanLine(char * Line)
} }
} }
//strip any spaces or line feeds from the end of the line // Strip any spaces or line feeds from the end of the line
for (int32_t i = (int32_t)strlen(&Line[0]) - 1; i >= 0; i--) for (int32_t i = (int32_t)strlen(&Line[0]) - 1; i >= 0; i--)
{ {
if (Line[i] != ' ' && Line[i] != '\r') if (Line[i] != ' ' && Line[i] != '\r')
@ -620,4 +620,3 @@ void CEnhancmentFile::ClearSectionPosList(long FilePos)
m_lastSectionSearch = FilePos; m_lastSectionSearch = FilePos;
} }
} }

View File

@ -411,7 +411,7 @@ void CEnhancements::ApplyGameSharkCodes(CMipsMemoryVM & MMU, CODES & CodeEntry,
switch (Code.Command() & 0xFF000000) switch (Code.Command() & 0xFF000000)
{ {
case 0x50000000: // Gameshark / AR case 0x50000000: // Gameshark / Action Replay
if ((CurrentEntry + 1) >= (int)CodeEntry.size()) if ((CurrentEntry + 1) >= (int)CodeEntry.size())
{ {
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
@ -532,7 +532,7 @@ void CEnhancements::ApplyGameSharkCodes(CMipsMemoryVM & MMU, CODES & CodeEntry,
case 0x89000000: case 0x89000000:
case 0xA8000000: case 0xA8000000:
case 0xA9000000: case 0xA9000000:
//Ignore - GS Button // Ignore - Gameshark (GS) button
break; break;
default: default:
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
@ -681,7 +681,7 @@ void CEnhancements::ScanFileThread(void)
{ {
do do
{ {
CEnhancmentFile EnhancmentFile(File, "Enhancment"); CEnhancmentFile EnhancmentFile(File, CEnhancement::EnhancementIdent);
CEnhancmentFile::SectionList Sections; CEnhancmentFile::SectionList Sections;
EnhancmentFile.GetSections(Sections); EnhancmentFile.GetSections(Sections);
for (CEnhancmentFile::SectionList::const_iterator itr = Sections.begin(); itr != Sections.end(); itr++) for (CEnhancmentFile::SectionList::const_iterator itr = Sections.begin(); itr != Sections.end(); itr++)
@ -699,7 +699,7 @@ void CEnhancements::ScanFileThread(void)
{ {
do do
{ {
CEnhancmentFile EnhancmentFile(File, "Enhancment"); CEnhancmentFile EnhancmentFile(File, CEnhancement::EnhancementIdent);
CEnhancmentFile::SectionList Sections; CEnhancmentFile::SectionList Sections;
EnhancmentFile.GetSections(Sections); EnhancmentFile.GetSections(Sections);
for (CEnhancmentFile::SectionList::const_iterator itr = Sections.begin(); itr != Sections.end(); itr++) for (CEnhancmentFile::SectionList::const_iterator itr = Sections.begin(); itr != Sections.end(); itr++)

View File

@ -32,7 +32,7 @@ private:
int32_t m_ViFrameRateWhole; int32_t m_ViFrameRateWhole;
uint32_t m_ViFrameRateFraction; uint32_t m_ViFrameRateFraction;
//Dlist // Dlist
HighResTimeStamp m_LastDlistFrame; HighResTimeStamp m_LastDlistFrame;
uint64_t m_FramesDlist[NoOfFrames]; uint64_t m_FramesDlist[NoOfFrames];
uint32_t m_CurrentDlistFrame; uint32_t m_CurrentDlistFrame;

View File

@ -88,7 +88,7 @@ bool DelaySlotEffectsCompare(uint32_t PC, uint32_t Reg1, uint32_t Reg2)
default: default:
if (CDebugSettings::HaveDebugger()) if (CDebugSettings::HaveDebugger())
{ {
g_Notify->DisplayError(stdstr_f("Does %s effect Delay slot at %X?", R4300iOpcodeName(Command.Hex, PC + 4), PC).c_str()); g_Notify->DisplayError(stdstr_f("Does %s effect delay slot at %X?", R4300iOpcodeName(Command.Hex, PC + 4), PC).c_str());
} }
return true; return true;
} }
@ -119,7 +119,7 @@ bool DelaySlotEffectsCompare(uint32_t PC, uint32_t Reg1, uint32_t Reg2)
default: default:
if (CDebugSettings::HaveDebugger()) if (CDebugSettings::HaveDebugger())
{ {
g_Notify->DisplayError(stdstr_f("Does %s effect Delay slot at %X?\n6", R4300iOpcodeName(Command.Hex, PC + 4), PC).c_str()); g_Notify->DisplayError(stdstr_f("Does %s effect delay slot at %X?\n6", R4300iOpcodeName(Command.Hex, PC + 4), PC).c_str());
} }
return true; return true;
} }
@ -128,7 +128,7 @@ bool DelaySlotEffectsCompare(uint32_t PC, uint32_t Reg1, uint32_t Reg2)
{ {
if (CDebugSettings::HaveDebugger()) if (CDebugSettings::HaveDebugger())
{ {
g_Notify->DisplayError(stdstr_f("Does %s effect Delay slot at %X?\n7", R4300iOpcodeName(Command.Hex, PC + 4), PC).c_str()); g_Notify->DisplayError(stdstr_f("Does %s effect delay slot at %X?\n7", R4300iOpcodeName(Command.Hex, PC + 4), PC).c_str());
} }
return true; return true;
} }
@ -157,7 +157,7 @@ bool DelaySlotEffectsCompare(uint32_t PC, uint32_t Reg1, uint32_t Reg2)
default: default:
if (CDebugSettings::HaveDebugger()) if (CDebugSettings::HaveDebugger())
{ {
g_Notify->DisplayError(stdstr_f("Does %s effect Delay slot at %X?", R4300iOpcodeName(Command.Hex, PC + 4), PC).c_str()); g_Notify->DisplayError(stdstr_f("Does %s effect delay slot at %X?", R4300iOpcodeName(Command.Hex, PC + 4), PC).c_str());
} }
return true; return true;
} }
@ -205,7 +205,7 @@ bool DelaySlotEffectsCompare(uint32_t PC, uint32_t Reg1, uint32_t Reg2)
default: default:
if (CDebugSettings::HaveDebugger()) if (CDebugSettings::HaveDebugger())
{ {
g_Notify->DisplayError(stdstr_f("Does %s effect Delay slot at %X?", R4300iOpcodeName(Command.Hex, PC + 4), PC).c_str()); g_Notify->DisplayError(stdstr_f("Does %s effect delay slot at %X?", R4300iOpcodeName(Command.Hex, PC + 4), PC).c_str());
} }
return true; return true;
} }
@ -230,13 +230,13 @@ void CInterpreterCPU::BuildCPU()
void CInterpreterCPU::InPermLoop() void CInterpreterCPU::InPermLoop()
{ {
// *** Changed ***/ // Changed
//if (CPU_Type == CPU_SyncCores) //if (CPU_Type == CPU_SyncCores)
//{ //{
// SyncRegisters.CP0[9] +=5; // SyncRegisters.CP0[9] +=5;
//} //}
/* Interrupts enabled */ // Interrupts enabled
if ((g_Reg->STATUS_REGISTER & STATUS_IE) == 0 || if ((g_Reg->STATUS_REGISTER & STATUS_IE) == 0 ||
(g_Reg->STATUS_REGISTER & STATUS_EXL) != 0 || (g_Reg->STATUS_REGISTER & STATUS_EXL) != 0 ||
(g_Reg->STATUS_REGISTER & STATUS_ERL) != 0 || (g_Reg->STATUS_REGISTER & STATUS_ERL) != 0 ||
@ -294,7 +294,7 @@ void CInterpreterCPU::ExecuteCPU()
g_Settings->SaveBool(Debugger_SteppingOps, true); g_Settings->SaveBool(Debugger_SteppingOps, true);
} }
g_Debugger->CPUStepStarted(); // may set stepping ops/skip op g_Debugger->CPUStepStarted(); // May set stepping ops/skip op
if (isStepping()) if (isStepping())
{ {
@ -320,7 +320,7 @@ void CInterpreterCPU::ExecuteCPU()
} */ } */
m_R4300i_Opcode[Opcode.op](); m_R4300i_Opcode[Opcode.op]();
_GPR[0].DW = 0; /* MIPS $zero hard-wired to 0 */ _GPR[0].DW = 0; // MIPS $zero hard-wired to 0
NextTimer -= CountPerOp; NextTimer -= CountPerOp;
if (CDebugSettings::HaveDebugger()) { g_Debugger->CPUStepEnded(); } if (CDebugSettings::HaveDebugger()) { g_Debugger->CPUStepEnded(); }

View File

@ -739,7 +739,8 @@ void TestInterpreterJump(uint32_t PC, uint32_t TargetPC, int32_t Reg1, int32_t R
R4300iOp::m_TestTimer = true; R4300iOp::m_TestTimer = true;
} }
/************************* Opcode functions *************************/ // Opcode functions
void R4300iOp::J() void R4300iOp::J()
{ {
m_NextInstruction = DELAY_SLOT; m_NextInstruction = DELAY_SLOT;
@ -1686,7 +1687,9 @@ void R4300iOp::SD()
TLB_WRITE_EXCEPTION(Address); TLB_WRITE_EXCEPTION(Address);
} }
} }
/********************** R4300i OpCodes: Special **********************/
// R4300i opcodes: Special
void R4300iOp::SPECIAL_SLL() void R4300iOp::SPECIAL_SLL()
{ {
_GPR[m_Opcode.rd].DW = (_GPR[m_Opcode.rt].W[0] << m_Opcode.sa); _GPR[m_Opcode.rd].DW = (_GPR[m_Opcode.rt].W[0] << m_Opcode.sa);
@ -1810,7 +1813,7 @@ void R4300iOp::SPECIAL_DIV()
{ {
if (bShowDivByZero()) if (bShowDivByZero())
{ {
g_Notify->DisplayError("DIV by 0 ???"); g_Notify->DisplayError("DIV by 0");
} }
_RegLO->DW = 0; _RegLO->DW = 0;
_RegHI->DW = 0; _RegHI->DW = 0;
@ -1828,7 +1831,7 @@ void R4300iOp::SPECIAL_DIVU()
{ {
if (bShowDivByZero()) if (bShowDivByZero())
{ {
g_Notify->DisplayError("DIVU by 0 ???"); g_Notify->DisplayError("DIVU by 0");
} }
_RegLO->DW = 0; _RegLO->DW = 0;
_RegHI->DW = 0; _RegHI->DW = 0;
@ -1874,7 +1877,7 @@ void R4300iOp::SPECIAL_DDIV()
{ {
if (HaveDebugger()) if (HaveDebugger())
{ {
g_Notify->DisplayError("DDIV by 0 ???"); g_Notify->DisplayError("DDIV by 0");
} }
} }
} }
@ -1890,7 +1893,7 @@ void R4300iOp::SPECIAL_DDIVU()
{ {
if (HaveDebugger()) if (HaveDebugger())
{ {
g_Notify->DisplayError("DDIVU by 0 ???"); g_Notify->DisplayError("DDIVU by 0");
} }
} }
} }
@ -2063,7 +2066,8 @@ void R4300iOp::SPECIAL_DSRA32()
_GPR[m_Opcode.rd].DW = (_GPR[m_Opcode.rt].DW >> (m_Opcode.sa + 32)); _GPR[m_Opcode.rd].DW = (_GPR[m_Opcode.rt].DW >> (m_Opcode.sa + 32));
} }
/********************** R4300i OpCodes: RegImm **********************/ // R4300i opcodes: RegImm
void R4300iOp::REGIMM_BLTZ() void R4300iOp::REGIMM_BLTZ()
{ {
m_NextInstruction = DELAY_SLOT; m_NextInstruction = DELAY_SLOT;
@ -2256,12 +2260,13 @@ void R4300iOp::REGIMM_TNEI()
} }
} }
/************************** COP0 functions **************************/ // COP0 functions
void R4300iOp::COP0_MF() void R4300iOp::COP0_MF()
{ {
if (LogCP0reads()) if (LogCP0reads())
{ {
LogMessage("%08X: R4300i Read from %s (0x%08X)", (*_PROGRAM_COUNTER), CRegName::Cop0[m_Opcode.rd], _CP0[m_Opcode.rd]); LogMessage("%08X: R4300i read from %s (0x%08X)", (*_PROGRAM_COUNTER), CRegName::Cop0[m_Opcode.rd], _CP0[m_Opcode.rd]);
} }
if (m_Opcode.rd == 9) if (m_Opcode.rd == 9)
@ -2275,8 +2280,8 @@ void R4300iOp::COP0_MT()
{ {
if (LogCP0changes()) if (LogCP0changes())
{ {
LogMessage("%08X: Writing 0x%X to %s register (Originally: 0x%08X)", (*_PROGRAM_COUNTER), _GPR[m_Opcode.rt].UW[0], CRegName::Cop0[m_Opcode.rd], _CP0[m_Opcode.rd]); LogMessage("%08X: Writing 0x%X to %s register (originally: 0x%08X)", (*_PROGRAM_COUNTER), _GPR[m_Opcode.rt].UW[0], CRegName::Cop0[m_Opcode.rd], _CP0[m_Opcode.rd]);
if (m_Opcode.rd == 11) //Compare if (m_Opcode.rd == 11) // Compare
{ {
LogMessage("%08X: Cause register changed from %08X to %08X", (*_PROGRAM_COUNTER), g_Reg->CAUSE_REGISTER, (g_Reg->CAUSE_REGISTER & ~CAUSE_IP7)); LogMessage("%08X: Cause register changed from %08X to %08X", (*_PROGRAM_COUNTER), g_Reg->CAUSE_REGISTER, (g_Reg->CAUSE_REGISTER & ~CAUSE_IP7));
} }
@ -2284,39 +2289,39 @@ void R4300iOp::COP0_MT()
switch (m_Opcode.rd) switch (m_Opcode.rd)
{ {
case 0: //Index case 0: // Index
case 2: //EntryLo0 case 2: // EntryLo0
case 3: //EntryLo1 case 3: // EntryLo1
case 5: //PageMask case 5: // PageMask
case 10: //Entry Hi case 10: // Entry Hi
case 14: //EPC case 14: // EPC
case 16: //Config case 16: // Config
case 18: //WatchLo case 18: // WatchLo
case 19: //WatchHi case 19: // WatchHi
case 28: //Tag lo case 28: // Tag lo
case 29: //Tag Hi case 29: // Tag Hi
case 30: //ErrEPC case 30: // ErrEPC
_CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0]; _CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0];
break; break;
case 6: //Wired case 6: // Wired
g_SystemTimer->UpdateTimers(); g_SystemTimer->UpdateTimers();
_CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0]; _CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0];
break; break;
case 4: //Context case 4: // Context
_CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0] & 0xFF800000; _CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0] & 0xFF800000;
break; break;
case 9: //Count case 9: // Count
g_SystemTimer->UpdateTimers(); g_SystemTimer->UpdateTimers();
_CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0]; _CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0];
g_SystemTimer->UpdateCompareTimer(); g_SystemTimer->UpdateCompareTimer();
break; break;
case 11: //Compare case 11: // Compare
g_SystemTimer->UpdateTimers(); g_SystemTimer->UpdateTimers();
_CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0]; _CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0];
g_Reg->FAKE_CAUSE_REGISTER &= ~CAUSE_IP7; g_Reg->FAKE_CAUSE_REGISTER &= ~CAUSE_IP7;
g_SystemTimer->UpdateCompareTimer(); g_SystemTimer->UpdateCompareTimer();
break; break;
case 12: //Status case 12: // Status
if ((_CP0[m_Opcode.rd] & STATUS_FR) != (_GPR[m_Opcode.rt].UW[0] & STATUS_FR)) if ((_CP0[m_Opcode.rd] & STATUS_FR) != (_GPR[m_Opcode.rt].UW[0] & STATUS_FR))
{ {
_CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0]; _CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0];
@ -2332,7 +2337,7 @@ void R4300iOp::COP0_MT()
} }
g_Reg->CheckInterrupts(); g_Reg->CheckInterrupts();
break; break;
case 13: //cause case 13: // Cause
_CP0[m_Opcode.rd] &= 0xFFFFCFF; _CP0[m_Opcode.rd] &= 0xFFFFCFF;
if ((_GPR[m_Opcode.rt].UW[0] & 0x300) != 0 && HaveDebugger()) if ((_GPR[m_Opcode.rt].UW[0] & 0x300) != 0 && HaveDebugger())
{ {
@ -2344,7 +2349,8 @@ void R4300iOp::COP0_MT()
} }
} }
/************************** COP0 CO functions ***********************/ // COP0 CO functions
void R4300iOp::COP0_CO_TLBR() void R4300iOp::COP0_CO_TLBR()
{ {
if (!g_System->bUseTlb()) if (!g_System->bUseTlb())
@ -2399,7 +2405,8 @@ void R4300iOp::COP0_CO_ERET()
m_TestTimer = true; m_TestTimer = true;
} }
/************************** COP1 functions **************************/ // COP1 functions
void R4300iOp::COP1_MF() void R4300iOp::COP1_MF()
{ {
TEST_COP1_USABLE_EXCEPTION(); TEST_COP1_USABLE_EXCEPTION();
@ -2419,7 +2426,7 @@ void R4300iOp::COP1_CF()
{ {
if (HaveDebugger()) if (HaveDebugger())
{ {
g_Notify->DisplayError("CFC1 what register are you writing to ?"); g_Notify->DisplayError("CFC1: what register are you writing to?");
} }
return; return;
} }
@ -2455,11 +2462,12 @@ void R4300iOp::COP1_CT()
} }
if (HaveDebugger()) if (HaveDebugger())
{ {
g_Notify->DisplayError("CTC1 what register are you writing to ?"); g_Notify->DisplayError("CTC1: what register are you writing to?");
} }
} }
/************************* COP1: BC1 functions ***********************/ // COP1: BC1 functions
void R4300iOp::COP1_BCF() void R4300iOp::COP1_BCF()
{ {
TEST_COP1_USABLE_EXCEPTION(); TEST_COP1_USABLE_EXCEPTION();
@ -2517,18 +2525,20 @@ void R4300iOp::COP1_BCTL()
m_JumpToLocation = (*_PROGRAM_COUNTER) + 8; m_JumpToLocation = (*_PROGRAM_COUNTER) + 8;
} }
} }
/************************** COP1: S functions ************************/
// COP1: S functions
__inline void Float_RoundToInteger32(int32_t * Dest, const float * Source, int RoundType) __inline void Float_RoundToInteger32(int32_t * Dest, const float * Source, int RoundType)
{ {
#pragma warning(push) #pragma warning(push)
#pragma warning(disable:4244) //warning C4244: disabe conversion from 'float' to 'int32_t', possible loss of data #pragma warning(disable:4244) // warning C4244: disable conversion from 'float' to 'int32_t', possible loss of data
if (RoundType == FE_TONEAREST) if (RoundType == FE_TONEAREST)
{ {
float reminder = *Source - floorf(*Source); float reminder = *Source - floorf(*Source);
if (reminder == 0.5) if (reminder == 0.5)
{ {
//make any decimal point in even to go to odd and any decimal point in odd stay as odd // Make any decimal point that is even odd, and any decimal point that is odd stay odd
if (*Source < 0) if (*Source < 0)
{ {
*Dest = (int)truncf(*Source) % 2 != 0 ? floorf(*Source) : ceilf(*Source); *Dest = (int)truncf(*Source) % 2 != 0 ? floorf(*Source) : ceilf(*Source);
@ -2553,14 +2563,14 @@ __inline void Float_RoundToInteger32(int32_t * Dest, const float * Source, int R
__inline void Float_RoundToInteger64(int64_t * Dest, const float * Source, int RoundType) __inline void Float_RoundToInteger64(int64_t * Dest, const float * Source, int RoundType)
{ {
#pragma warning(push) #pragma warning(push)
#pragma warning(disable:4244) //warning C4244: disabe conversion from 'float' to 'int64_t', possible loss of data #pragma warning(disable:4244) // warning C4244: disable conversion from 'float' to 'int64_t', possible loss of data
if (RoundType == FE_TONEAREST) if (RoundType == FE_TONEAREST)
{ {
float reminder = *Source - floorf(*Source); float reminder = *Source - floorf(*Source);
if (reminder == 0.5) if (reminder == 0.5)
{ {
//make any decimal point in even to go to odd and any decimal point in odd stay as odd // Make any decimal point that is even odd, and any decimal point that is odd stay odd
if (*Source < 0) if (*Source < 0)
{ {
*Dest = (int)truncf(*Source) % 2 != 0 ? floorf(*Source) : ceilf(*Source); *Dest = (int)truncf(*Source) % 2 != 0 ? floorf(*Source) : ceilf(*Source);
@ -2753,18 +2763,19 @@ void R4300iOp::COP1_S_CMP()
} }
} }
/************************** COP1: D functions ************************/ // COP1: D functions
__inline void Double_RoundToInteger32(int32_t * Dest, const double * Source, int RoundType) __inline void Double_RoundToInteger32(int32_t * Dest, const double * Source, int RoundType)
{ {
#pragma warning(push) #pragma warning(push)
#pragma warning(disable:4244) //warning C4244: disabe conversion from 'double' to 'uint32_t', possible loss of data #pragma warning(disable:4244) // warning C4244: disable conversion from 'double' to 'uint32_t', possible loss of data
if (RoundType == FE_TONEAREST) if (RoundType == FE_TONEAREST)
{ {
double reminder = *Source - floor(*Source); double reminder = *Source - floor(*Source);
if (reminder == 0.5) if (reminder == 0.5)
{ {
//make any decimal point in even to go to odd and any decimal point in odd stay as odd // Make any decimal point that is even odd, and any decimal point that is odd stay odd
if (*Source < 0) if (*Source < 0)
{ {
*Dest = (int)truncf(*Source) % 2 != 0 ? floor(*Source) : ceil(*Source); *Dest = (int)truncf(*Source) % 2 != 0 ? floor(*Source) : ceil(*Source);
@ -2793,14 +2804,14 @@ __inline void Double_RoundToInteger32(int32_t * Dest, const double * Source, int
__inline void Double_RoundToInteger64(int64_t * Dest, const double * Source, int RoundType) __inline void Double_RoundToInteger64(int64_t * Dest, const double * Source, int RoundType)
{ {
#pragma warning(push) #pragma warning(push)
#pragma warning(disable:4244) //warning C4244: disabe conversion from 'double' to 'uint64_t', possible loss of data #pragma warning(disable:4244) // warning C4244: disable conversion from 'double' to 'uint64_t', possible loss of data
if (RoundType == FE_TONEAREST) if (RoundType == FE_TONEAREST)
{ {
double reminder = *Source - floor(*Source); double reminder = *Source - floor(*Source);
if (reminder == 0.5) if (reminder == 0.5)
{ {
//make any decimal point in even to go to odd and any decimal point in odd stay as odd // Make any decimal point that is even odd, and any decimal point that is odd stay odd
if (*Source < 0) if (*Source < 0)
{ {
*Dest = (int)truncf(*Source) % 2 != 0 ? floor(*Source) : ceil(*Source); *Dest = (int)truncf(*Source) % 2 != 0 ? floor(*Source) : ceil(*Source);
@ -2997,7 +3008,8 @@ void R4300iOp::COP1_D_CMP()
} }
} }
/************************** COP1: W functions ************************/ // COP1: W functions
void R4300iOp::COP1_W_CVT_S() void R4300iOp::COP1_W_CVT_S()
{ {
TEST_COP1_USABLE_EXCEPTION(); TEST_COP1_USABLE_EXCEPTION();
@ -3012,7 +3024,8 @@ void R4300iOp::COP1_W_CVT_D()
*(double *)_FPR_D[m_Opcode.fd] = (double)*(int32_t *)_FPR_S[m_Opcode.fs]; *(double *)_FPR_D[m_Opcode.fd] = (double)*(int32_t *)_FPR_S[m_Opcode.fs];
} }
/************************** COP1: L functions ************************/ // COP1: L functions
void R4300iOp::COP1_L_CVT_S() void R4300iOp::COP1_L_CVT_S()
{ {
TEST_COP1_USABLE_EXCEPTION(); TEST_COP1_USABLE_EXCEPTION();
@ -3027,10 +3040,11 @@ void R4300iOp::COP1_L_CVT_D()
*(double *)_FPR_D[m_Opcode.fd] = (double)*(int64_t *)_FPR_D[m_Opcode.fs]; *(double *)_FPR_D[m_Opcode.fd] = (double)*(int64_t *)_FPR_D[m_Opcode.fs];
} }
/************************** Other functions **************************/ // Other functions
void R4300iOp::UnknownOpcode() void R4300iOp::UnknownOpcode()
{ {
g_Notify->DisplayError(stdstr_f("%s: %08X\n%s\n\nStopping Emulation !", GS(MSG_UNHANDLED_OP), (*_PROGRAM_COUNTER), g_Notify->DisplayError(stdstr_f("%s: %08X\n%s\n\nStopping emulation", GS(MSG_UNHANDLED_OP), (*_PROGRAM_COUNTER),
R4300iOpcodeName(m_Opcode.Hex, (*_PROGRAM_COUNTER))).c_str()); R4300iOpcodeName(m_Opcode.Hex, (*_PROGRAM_COUNTER))).c_str());
g_System->m_EndEmulation = true; g_System->m_EndEmulation = true;
@ -3040,7 +3054,7 @@ void R4300iOp::UnknownOpcode()
{ {
int32_t response; int32_t response;
strcat(Message, "\n\nDo you wish to enter the debugger ?"); strcat(Message, "\n\nDo you wish to enter the debugger?");
response = MessageBox(nullptr, Message, GS(MSG_MSGBOX_ERROR_TITLE), MB_YESNO | MB_ICONERROR); response = MessageBox(nullptr, Message, GS(MSG_MSGBOX_ERROR_TITLE), MB_YESNO | MB_ICONERROR);
if (response == IDYES) if (response == IDYES)

View File

@ -12,7 +12,7 @@ class R4300iOp :
public: public:
typedef void(*Func)(); typedef void(*Func)();
/************************* OpCode functions *************************/ // Opcode functions
static void J(); static void J();
static void JAL(); static void JAL();
static void BNE(); static void BNE();
@ -59,7 +59,7 @@ public:
static void SDC1(); static void SDC1();
static void SD(); static void SD();
/********************** R4300i OpCodes: Special **********************/ // R4300i opcodes: Special
static void SPECIAL_SLL(); static void SPECIAL_SLL();
static void SPECIAL_SRL(); static void SPECIAL_SRL();
static void SPECIAL_SRA(); static void SPECIAL_SRA();
@ -113,7 +113,7 @@ public:
static void SPECIAL_DSRL32(); static void SPECIAL_DSRL32();
static void SPECIAL_DSRA32(); static void SPECIAL_DSRA32();
/********************** R4300i OpCodes: RegImm **********************/ // R4300i opcodes: RegImm
static void REGIMM_BLTZ(); static void REGIMM_BLTZ();
static void REGIMM_BGEZ(); static void REGIMM_BGEZ();
static void REGIMM_BLTZL(); static void REGIMM_BLTZL();
@ -127,18 +127,18 @@ public:
static void REGIMM_TLTIU(); static void REGIMM_TLTIU();
static void REGIMM_TNEI(); static void REGIMM_TNEI();
/************************** COP0 functions **************************/ // COP0 functions
static void COP0_MF(); static void COP0_MF();
static void COP0_MT(); static void COP0_MT();
/************************** COP0 CO functions ***********************/ // COP0 CO functions
static void COP0_CO_TLBR(); static void COP0_CO_TLBR();
static void COP0_CO_TLBWI(); static void COP0_CO_TLBWI();
static void COP0_CO_TLBWR(); static void COP0_CO_TLBWR();
static void COP0_CO_TLBP(); static void COP0_CO_TLBP();
static void COP0_CO_ERET(); static void COP0_CO_ERET();
/************************** COP1 functions **************************/ // COP1 functions
static void COP1_MF(); static void COP1_MF();
static void COP1_DMF(); static void COP1_DMF();
static void COP1_CF(); static void COP1_CF();
@ -146,13 +146,13 @@ public:
static void COP1_DMT(); static void COP1_DMT();
static void COP1_CT(); static void COP1_CT();
/************************* COP1: BC1 functions ***********************/ // COP1: BC1 functions
static void COP1_BCF(); static void COP1_BCF();
static void COP1_BCT(); static void COP1_BCT();
static void COP1_BCFL(); static void COP1_BCFL();
static void COP1_BCTL(); static void COP1_BCTL();
/************************** COP1: S functions ************************/ // COP1: S functions
static void COP1_S_ADD(); static void COP1_S_ADD();
static void COP1_S_SUB(); static void COP1_S_SUB();
static void COP1_S_MUL(); static void COP1_S_MUL();
@ -174,7 +174,7 @@ public:
static void COP1_S_CVT_L(); static void COP1_S_CVT_L();
static void COP1_S_CMP(); static void COP1_S_CMP();
/************************** COP1: D functions ************************/ // COP1: D functions
static void COP1_D_ADD(); static void COP1_D_ADD();
static void COP1_D_SUB(); static void COP1_D_SUB();
static void COP1_D_MUL(); static void COP1_D_MUL();
@ -196,15 +196,15 @@ public:
static void COP1_D_CVT_L(); static void COP1_D_CVT_L();
static void COP1_D_CMP(); static void COP1_D_CMP();
/************************** COP1: W functions ************************/ // COP1: W functions
static void COP1_W_CVT_S(); static void COP1_W_CVT_S();
static void COP1_W_CVT_D(); static void COP1_W_CVT_D();
/************************** COP1: L functions ************************/ // COP1: L functions
static void COP1_L_CVT_S(); static void COP1_L_CVT_S();
static void COP1_L_CVT_D(); static void COP1_L_CVT_D();
/************************** Other functions **************************/ // Other functions
static void UnknownOpcode(); static void UnknownOpcode();
static Func* BuildInterpreter(); static Func* BuildInterpreter();

View File

@ -622,7 +622,8 @@ R4300iOp32::Func * R4300iOp32::BuildInterpreter()
return Jump_Opcode; return Jump_Opcode;
} }
/************************* Opcode functions *************************/ // Opcode functions
void R4300iOp32::JAL() void R4300iOp32::JAL()
{ {
m_NextInstruction = DELAY_SLOT; m_NextInstruction = DELAY_SLOT;
@ -1103,7 +1104,8 @@ void R4300iOp32::LL()
} }
} }
/********************** R4300i OpCodes: Special **********************/ // R4300i opcodes: Special
void R4300iOp32::SPECIAL_SLL() void R4300iOp32::SPECIAL_SLL()
{ {
_GPR[m_Opcode.rd].W[0] = (_GPR[m_Opcode.rt].W[0] << m_Opcode.sa); _GPR[m_Opcode.rd].W[0] = (_GPR[m_Opcode.rt].W[0] << m_Opcode.sa);
@ -1211,11 +1213,12 @@ void R4300iOp32::SPECIAL_TEQ()
{ {
if (_GPR[m_Opcode.rs].W[0] == _GPR[m_Opcode.rt].W[0] && CDebugSettings::HaveDebugger()) if (_GPR[m_Opcode.rs].W[0] == _GPR[m_Opcode.rt].W[0] && CDebugSettings::HaveDebugger())
{ {
g_Notify->DisplayError("Should trap this ???"); g_Notify->DisplayError("Should we trap this?");
} }
} }
/********************** R4300i OpCodes: RegImm **********************/ // R4300i opcodes: RegImm
void R4300iOp32::REGIMM_BLTZ() void R4300iOp32::REGIMM_BLTZ()
{ {
m_NextInstruction = DELAY_SLOT; m_NextInstruction = DELAY_SLOT;
@ -1352,12 +1355,13 @@ void R4300iOp32::REGIMM_BGEZAL()
_GPR[31].W[0] = (int32_t)((*_PROGRAM_COUNTER) + 8); _GPR[31].W[0] = (int32_t)((*_PROGRAM_COUNTER) + 8);
} }
/************************** COP0 functions **************************/ // COP0 functions
void R4300iOp32::COP0_MF() void R4300iOp32::COP0_MF()
{ {
if (LogCP0reads()) if (LogCP0reads())
{ {
LogMessage("%08X: R4300i Read from %s (0x%08X)", (*_PROGRAM_COUNTER), CRegName::Cop0[m_Opcode.rd], _CP0[m_Opcode.rd]); LogMessage("%08X: R4300i read from %s (0x%08X)", (*_PROGRAM_COUNTER), CRegName::Cop0[m_Opcode.rd], _CP0[m_Opcode.rd]);
} }
if (m_Opcode.rd == 9) if (m_Opcode.rd == 9)
@ -1372,7 +1376,7 @@ void R4300iOp32::COP0_MT()
if (LogCP0changes()) if (LogCP0changes())
{ {
LogMessage("%08X: Writing 0x%X to %s register (Originally: 0x%08X)", (*_PROGRAM_COUNTER), _GPR[m_Opcode.rt].UW[0], CRegName::Cop0[m_Opcode.rd], _CP0[m_Opcode.rd]); LogMessage("%08X: Writing 0x%X to %s register (Originally: 0x%08X)", (*_PROGRAM_COUNTER), _GPR[m_Opcode.rt].UW[0], CRegName::Cop0[m_Opcode.rd], _CP0[m_Opcode.rd]);
if (m_Opcode.rd == 11) //Compare if (m_Opcode.rd == 11) // Compare
{ {
LogMessage("%08X: Cause register changed from %08X to %08X", (*_PROGRAM_COUNTER), g_Reg->CAUSE_REGISTER, (g_Reg->CAUSE_REGISTER & ~CAUSE_IP7)); LogMessage("%08X: Cause register changed from %08X to %08X", (*_PROGRAM_COUNTER), g_Reg->CAUSE_REGISTER, (g_Reg->CAUSE_REGISTER & ~CAUSE_IP7));
} }
@ -1380,39 +1384,39 @@ void R4300iOp32::COP0_MT()
switch (m_Opcode.rd) switch (m_Opcode.rd)
{ {
case 0: //Index case 0: // Index
case 2: //EntryLo0 case 2: // EntryLo0
case 3: //EntryLo1 case 3: // EntryLo1
case 5: //PageMask case 5: // PageMask
case 10: //Entry Hi case 10: // Entry Hi
case 14: //EPC case 14: // EPC
case 16: //Config case 16: // Config
case 18: //WatchLo case 18: // WatchLo
case 19: //WatchHi case 19: // WatchHi
case 28: //Tag lo case 28: // Tag Lo
case 29: //Tag Hi case 29: // Tag Hi
case 30: //ErrEPC case 30: // ErrEPC
_CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0]; _CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0];
break; break;
case 6: //Wired case 6: // Wired
g_SystemTimer->UpdateTimers(); g_SystemTimer->UpdateTimers();
_CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0]; _CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0];
break; break;
case 4: //Context case 4: // Context
_CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0] & 0xFF800000; _CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0] & 0xFF800000;
break; break;
case 9: //Count case 9: // Count
g_SystemTimer->UpdateTimers(); g_SystemTimer->UpdateTimers();
_CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0]; _CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0];
g_SystemTimer->UpdateCompareTimer(); g_SystemTimer->UpdateCompareTimer();
break; break;
case 11: //Compare case 11: // Compare
g_SystemTimer->UpdateTimers(); g_SystemTimer->UpdateTimers();
_CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0]; _CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0];
g_Reg->FAKE_CAUSE_REGISTER &= ~CAUSE_IP7; g_Reg->FAKE_CAUSE_REGISTER &= ~CAUSE_IP7;
g_SystemTimer->UpdateCompareTimer(); g_SystemTimer->UpdateCompareTimer();
break; break;
case 12: //Status case 12: // Status
if ((_CP0[m_Opcode.rd] & STATUS_FR) != (_GPR[m_Opcode.rt].UW[0] & STATUS_FR)) if ((_CP0[m_Opcode.rd] & STATUS_FR) != (_GPR[m_Opcode.rt].UW[0] & STATUS_FR))
{ {
_CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0]; _CP0[m_Opcode.rd] = _GPR[m_Opcode.rt].UW[0];
@ -1424,11 +1428,11 @@ void R4300iOp32::COP0_MT()
} }
if ((_CP0[m_Opcode.rd] & 0x18) != 0 && CDebugSettings::HaveDebugger()) if ((_CP0[m_Opcode.rd] & 0x18) != 0 && CDebugSettings::HaveDebugger())
{ {
g_Notify->DisplayError("Left kernel mode ??"); g_Notify->DisplayError("Left kernel mode?");
} }
g_Reg->CheckInterrupts(); g_Reg->CheckInterrupts();
break; break;
case 13: //cause case 13: // Cause
_CP0[m_Opcode.rd] &= 0xFFFFCFF; _CP0[m_Opcode.rd] &= 0xFFFFCFF;
if ((_GPR[m_Opcode.rt].UW[0] & 0x300) != 0 && CDebugSettings::HaveDebugger()) if ((_GPR[m_Opcode.rt].UW[0] & 0x300) != 0 && CDebugSettings::HaveDebugger())
{ {
@ -1440,7 +1444,8 @@ void R4300iOp32::COP0_MT()
} }
} }
/************************** COP1 functions **************************/ // COP1 functions
void R4300iOp32::COP1_MF() void R4300iOp32::COP1_MF()
{ {
TEST_COP1_USABLE_EXCEPTION TEST_COP1_USABLE_EXCEPTION
@ -1452,7 +1457,7 @@ void R4300iOp32::COP1_CF()
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)
{ {
if (CDebugSettings::HaveDebugger()) { g_Notify->DisplayError("CFC1 what register are you writing to ?"); } if (CDebugSettings::HaveDebugger()) { g_Notify->DisplayError("CFC1: what register are you writing to?"); }
return; return;
} }
_GPR[m_Opcode.rt].W[0] = (int32_t)_FPCR[m_Opcode.fs]; _GPR[m_Opcode.rt].W[0] = (int32_t)_FPCR[m_Opcode.fs];

View File

@ -6,7 +6,7 @@ class R4300iOp32 :
public R4300iOp public R4300iOp
{ {
public: public:
/************************* OpCode functions *************************/ // Opcode functions
static void JAL(); static void JAL();
static void BEQ(); static void BEQ();
static void BNE(); static void BNE();
@ -34,7 +34,7 @@ public:
static void LWU(); static void LWU();
static void LL(); static void LL();
/********************** R4300i OpCodes: Special **********************/ // R4300i opcodes: Special
static void SPECIAL_SLL(); static void SPECIAL_SLL();
static void SPECIAL_SRL(); static void SPECIAL_SRL();
static void SPECIAL_SRA(); static void SPECIAL_SRA();
@ -53,7 +53,7 @@ public:
static void SPECIAL_SLTU(); static void SPECIAL_SLTU();
static void SPECIAL_TEQ(); static void SPECIAL_TEQ();
/********************** R4300i OpCodes: RegImm **********************/ // R4300i opcodes: RegImm
static void REGIMM_BLTZ(); static void REGIMM_BLTZ();
static void REGIMM_BGEZ(); static void REGIMM_BGEZ();
static void REGIMM_BLTZL(); static void REGIMM_BLTZL();
@ -61,11 +61,11 @@ public:
static void REGIMM_BLTZAL(); static void REGIMM_BLTZAL();
static void REGIMM_BGEZAL(); static void REGIMM_BGEZAL();
/************************** COP0 functions **************************/ // COP0 functions
static void COP0_MF(); static void COP0_MF();
static void COP0_MT(); static void COP0_MT();
/************************** COP1 functions **************************/ // COP1 functions
static void COP1_MF(); static void COP1_MF();
static void COP1_CF(); static void COP1_CF();
static void COP1_DMT(); static void COP1_DMT();

View File

@ -17,7 +17,7 @@ void CAudio::Reset()
m_SecondBuff = 0; m_SecondBuff = 0;
m_Status = 0; m_Status = 0;
m_BytesPerSecond = 0; m_BytesPerSecond = 0;
m_CountsPerByte = g_System->AiCountPerBytes(); // should be calculated ... see below, instead allow from user settings m_CountsPerByte = g_System->AiCountPerBytes(); // Should be calculated, see below, instead allow from user settings
if (m_CountsPerByte == 0) m_CountsPerByte = 500; // If the user has no defined value, grant a default and we will calculate if (m_CountsPerByte == 0) m_CountsPerByte = 500; // If the user has no defined value, grant a default and we will calculate
m_FramesPerSecond = 60; m_FramesPerSecond = 60;
} }
@ -47,7 +47,7 @@ void CAudio::LenChanged()
{ {
if (g_Reg->AI_LEN_REG >= 0x40000) if (g_Reg->AI_LEN_REG >= 0x40000)
{ {
WriteTrace(TraceAudio, TraceDebug, "*** Ignoring Write, To Large (%X)", g_Reg->AI_LEN_REG); WriteTrace(TraceAudio, TraceDebug, "Ignoring write, to large (%X)", g_Reg->AI_LEN_REG);
} }
else else
{ {
@ -57,12 +57,12 @@ void CAudio::LenChanged()
{ {
if (AudioLeft == 0) if (AudioLeft == 0)
{ {
WriteTrace(TraceAudio, TraceDebug, "Set Timer AI_LEN_REG: %d m_CountsPerByte: %d", g_Reg->AI_LEN_REG, m_CountsPerByte); WriteTrace(TraceAudio, TraceDebug, "Set timer AI_LEN_REG: %d m_CountsPerByte: %d", g_Reg->AI_LEN_REG, m_CountsPerByte);
g_SystemTimer->SetTimer(CSystemTimer::AiTimerInterrupt, g_Reg->AI_LEN_REG * m_CountsPerByte, false); g_SystemTimer->SetTimer(CSystemTimer::AiTimerInterrupt, g_Reg->AI_LEN_REG * m_CountsPerByte, false);
} }
else else
{ {
WriteTrace(TraceAudio, TraceDebug, "Increasing Second Buffer (m_SecondBuff %d Increase: %d)", m_SecondBuff, g_Reg->AI_LEN_REG); WriteTrace(TraceAudio, TraceDebug, "Increasing second buffer (m_SecondBuff %d Increase: %d)", m_SecondBuff, g_Reg->AI_LEN_REG);
m_SecondBuff += g_Reg->AI_LEN_REG; m_SecondBuff += g_Reg->AI_LEN_REG;
m_Status |= ai_full; m_Status |= ai_full;
} }
@ -75,7 +75,7 @@ void CAudio::LenChanged()
} }
else else
{ {
WriteTrace(TraceAudio, TraceDebug, "*** Reset Timer to 0"); WriteTrace(TraceAudio, TraceDebug, "Reset timer to 0");
g_SystemTimer->StopTimer(CSystemTimer::AiTimerBusy); g_SystemTimer->StopTimer(CSystemTimer::AiTimerBusy);
g_SystemTimer->StopTimer(CSystemTimer::AiTimerInterrupt); g_SystemTimer->StopTimer(CSystemTimer::AiTimerInterrupt);
m_SecondBuff = 0; m_SecondBuff = 0;
@ -86,7 +86,7 @@ void CAudio::LenChanged()
{ {
WriteTrace(TraceAudio, TraceDebug, "Calling plugin AiLenChanged"); WriteTrace(TraceAudio, TraceDebug, "Calling plugin AiLenChanged");
g_Plugins->Audio()->AiLenChanged(); g_Plugins->Audio()->AiLenChanged();
WriteTrace(TraceAudio, TraceDebug, "plugin AiLenChanged Done"); WriteTrace(TraceAudio, TraceDebug, "Plugin AiLenChanged Done");
} }
WriteTrace(TraceAudio, TraceDebug, "Done"); WriteTrace(TraceAudio, TraceDebug, "Done");
} }

View File

@ -1,4 +1,4 @@
// Based from MAME's N64DD driver code by Happy_ // Based on MAME's N64DD driver code by Happy_
#include "stdafx.h" #include "stdafx.h"
#include "Disk.h" #include "Disk.h"
#include <Project64-core/N64System/N64System.h> #include <Project64-core/N64System/N64System.h>
@ -24,13 +24,13 @@ void DiskCommand()
{ {
//ASIC_CMD_STATUS - Commands //ASIC_CMD_STATUS - Commands
uint32_t cmd = g_Reg->ASIC_CMD; uint32_t cmd = g_Reg->ASIC_CMD;
WriteTrace(TraceN64System, TraceDebug, "DD CMD %08X - DATA %08X", cmd, g_Reg->ASIC_DATA); WriteTrace(TraceN64System, TraceDebug, "N64DD CMD %08X - DATA %08X", cmd, g_Reg->ASIC_DATA);
#ifdef _WIN32 #ifdef _WIN32
SYSTEMTIME sysTime; SYSTEMTIME sysTime;
::GetLocalTime(&sysTime); ::GetLocalTime(&sysTime);
//BCD format needed for 64DD RTC // BCD format needed for 64DD RTC
uint8_t year = (uint8_t)(((sysTime.wYear / 10 % 10) << 4) | (sysTime.wYear % 10)); uint8_t year = (uint8_t)(((sysTime.wYear / 10 % 10) << 4) | (sysTime.wYear % 10));
uint8_t month = (uint8_t)(((sysTime.wMonth / 10) << 4) | (sysTime.wMonth % 10)); uint8_t month = (uint8_t)(((sysTime.wMonth / 10) << 4) | (sysTime.wMonth % 10));
uint8_t day = (uint8_t)(((sysTime.wDay / 10) << 4) | (sysTime.wDay % 10)); uint8_t day = (uint8_t)(((sysTime.wDay / 10) << 4) | (sysTime.wDay % 10));
@ -44,7 +44,7 @@ void DiskCommand()
struct tm result = { 0 }; struct tm result = { 0 };
localtime_r(&ltime, &result); localtime_r(&ltime, &result);
//BCD format needed for 64DD RTC // BCD format needed for 64DD RTC
uint8_t year = (uint8_t)(((result.tm_year / 10 % 10) << 4) | (result.tm_year % 10)); uint8_t year = (uint8_t)(((result.tm_year / 10 % 10) << 4) | (result.tm_year % 10));
uint8_t month = (uint8_t)((((result.tm_mon + 1) / 10) << 4) | ((result.tm_mon + 1) % 10)); uint8_t month = (uint8_t)((((result.tm_mon + 1) / 10) << 4) | ((result.tm_mon + 1) % 10));
uint8_t day = (uint8_t)(((result.tm_mday / 10) << 4) | (result.tm_mday % 10)); uint8_t day = (uint8_t)(((result.tm_mday / 10) << 4) | (result.tm_mday % 10));
@ -53,46 +53,46 @@ void DiskCommand()
uint8_t second = (uint8_t)(((result.tm_sec / 10) << 4) | (result.tm_sec % 10)); uint8_t second = (uint8_t)(((result.tm_sec / 10) << 4) | (result.tm_sec % 10));
#endif #endif
//Used for seek times // Used for seek times
bool isSeek = false; bool isSeek = false;
switch (cmd & 0xFFFF0000) switch (cmd & 0xFFFF0000)
{ {
case 0x00010000: case 0x00010000:
//Seek Read // Seek read
g_Reg->ASIC_CUR_TK = g_Reg->ASIC_DATA | 0x60000000; g_Reg->ASIC_CUR_TK = g_Reg->ASIC_DATA | 0x60000000;
dd_write = false; dd_write = false;
isSeek = true; isSeek = true;
break; break;
case 0x00020000: case 0x00020000:
//Seek Write // Seek write
g_Reg->ASIC_CUR_TK = g_Reg->ASIC_DATA | 0x60000000; g_Reg->ASIC_CUR_TK = g_Reg->ASIC_DATA | 0x60000000;
dd_write = true; dd_write = true;
isSeek = true; isSeek = true;
break; break;
case 0x00080000: case 0x00080000:
//Unset Disk Changed Bit // Unset disk changed bit
g_Reg->ASIC_STATUS &= ~DD_STATUS_DISK_CHNG; break; g_Reg->ASIC_STATUS &= ~DD_STATUS_DISK_CHNG; break;
case 0x00090000: case 0x00090000:
//Unset Reset & Disk Changed bit Bit // Unset reset and disk changed bit bit
g_Reg->ASIC_STATUS &= ~DD_STATUS_RST_STATE; g_Reg->ASIC_STATUS &= ~DD_STATUS_RST_STATE;
g_Reg->ASIC_STATUS &= ~DD_STATUS_DISK_CHNG; g_Reg->ASIC_STATUS &= ~DD_STATUS_DISK_CHNG;
//F-Zero X + Expansion Kit fix so it doesn't enable "swapping" at boot // F-Zero X + Expansion Kit fix so it doesn't enable "swapping" at boot
dd_swapdelay = 0; dd_swapdelay = 0;
if (g_Disk != nullptr) if (g_Disk != nullptr)
g_Reg->ASIC_STATUS |= DD_STATUS_DISK_PRES; g_Reg->ASIC_STATUS |= DD_STATUS_DISK_PRES;
break; break;
case 0x00120000: case 0x00120000:
//RTC Get Year & Month // RTC get year and month
g_Reg->ASIC_DATA = (year << 24) | (month << 16); break; g_Reg->ASIC_DATA = (year << 24) | (month << 16); break;
case 0x00130000: case 0x00130000:
//RTC Get Day & Hour // RTC get day and hour
g_Reg->ASIC_DATA = (day << 24) | (hour << 16); break; g_Reg->ASIC_DATA = (day << 24) | (hour << 16); break;
case 0x00140000: case 0x00140000:
//RTC Get Minute & Second // RTC get minute and second
g_Reg->ASIC_DATA = (minute << 24) | (second << 16); break; g_Reg->ASIC_DATA = (minute << 24) | (second << 16); break;
case 0x001B0000: case 0x001B0000:
//Disk Inquiry // Disk inquiry
g_Reg->ASIC_DATA = 0x00000000; break; g_Reg->ASIC_DATA = 0x00000000; break;
} }
@ -100,27 +100,27 @@ void DiskCommand()
{ {
if (g_System->DiskSeekTimingType() == DiskSeek_Turbo) if (g_System->DiskSeekTimingType() == DiskSeek_Turbo)
{ {
//Instant Response for Turbo // Instant response for turbo
//Set timer for seek response // Set timer for seek response
g_SystemTimer->SetTimer(g_SystemTimer->DDSeekTimer, 0, false); g_SystemTimer->SetTimer(g_SystemTimer->DDSeekTimer, 0, false);
//Set timer for motor // Set timer for motor
g_SystemTimer->SetTimer(g_SystemTimer->DDMotorTimer, 0, false); g_SystemTimer->SetTimer(g_SystemTimer->DDMotorTimer, 0, false);
} }
else /* if (g_System->DiskSeekTimingType() == DiskSeek_Slow) */ else /* if (g_System->DiskSeekTimingType() == DiskSeek_Slow) */
{ {
//Emulate Seek Times, send interrupt later // Emulate seek times, send interrupt later
uint32_t seektime = 0; uint32_t seektime = 0;
//Start Motor, can take half a second, delay the response // Start motor, can take half a second, delay the response
if (g_Reg->ASIC_STATUS & DD_STATUS_MTR_N_SPIN) if (g_Reg->ASIC_STATUS & DD_STATUS_MTR_N_SPIN)
{ {
seektime += (0x5A00000 / 2); seektime += (0x5A00000 / 2);
g_Reg->ASIC_STATUS &= ~DD_STATUS_MTR_N_SPIN; g_Reg->ASIC_STATUS &= ~DD_STATUS_MTR_N_SPIN;
} }
//Get Zone to calculate seek times // Get zone to calculate seek times
uint32_t track = g_Reg->ASIC_CUR_TK >> 16 & 0x0FFF; uint32_t track = g_Reg->ASIC_CUR_TK >> 16 & 0x0FFF;
uint32_t zone = 0; uint32_t zone = 0;
uint32_t zonebound = 0; uint32_t zonebound = 0;
@ -136,7 +136,7 @@ void DiskCommand()
} }
} }
//Add seek delay depending on the zone (this is inaccurate timing, but close enough) // Add seek delay depending on the zone (this is inaccurate timing, but close enough)
seektime += 0x179200; seektime += 0x179200;
switch (zone) switch (zone)
@ -159,16 +159,16 @@ void DiskCommand()
break; break;
} }
//Set timer for seek response // Set timer for seek response
g_SystemTimer->SetTimer(g_SystemTimer->DDSeekTimer, seektime, false); g_SystemTimer->SetTimer(g_SystemTimer->DDSeekTimer, seektime, false);
//Set timer for motor to shutdown in 5 seconds, reset the timer if other seek commands were sent // Set timer for motor to shutdown in 5 seconds, reset the timer if other seek commands were sent
g_SystemTimer->SetTimer(g_SystemTimer->DDMotorTimer, 0x5A00000 * 5, false); g_SystemTimer->SetTimer(g_SystemTimer->DDMotorTimer, 0x5A00000 * 5, false);
} }
} }
else else
{ {
//Other commands are basically instant // Other commands are basically instant
g_Reg->ASIC_STATUS |= DD_STATUS_MECHA_INT; g_Reg->ASIC_STATUS |= DD_STATUS_MECHA_INT;
g_Reg->FAKE_CAUSE_REGISTER |= CAUSE_IP3; g_Reg->FAKE_CAUSE_REGISTER |= CAUSE_IP3;
g_Reg->CheckInterrupts(); g_Reg->CheckInterrupts();
@ -178,7 +178,7 @@ void DiskCommand()
void DiskReset(void) void DiskReset(void)
{ {
//ASIC_HARD_RESET 0xAAAA0000 //ASIC_HARD_RESET 0xAAAA0000
WriteTrace(TraceN64System, TraceDebug, "DD RESET"); WriteTrace(TraceN64System, TraceDebug, "N64DD reset");
g_Reg->ASIC_STATUS |= DD_STATUS_RST_STATE; g_Reg->ASIC_STATUS |= DD_STATUS_RST_STATE;
dd_swapdelay = 0; dd_swapdelay = 0;
if (g_Disk != nullptr) if (g_Disk != nullptr)
@ -231,9 +231,9 @@ void DiskBMControl(void)
void DiskGapSectorCheck() void DiskGapSectorCheck()
{ {
//On 64DD Status Register Read // On 64DD status register read
//Buffer Manager Interrupt, Gap Sector Check // Buffer manager interrupt, gap sector check
if (g_Reg->ASIC_STATUS & DD_STATUS_BM_INT) if (g_Reg->ASIC_STATUS & DD_STATUS_BM_INT)
{ {
if (SECTORS_PER_BLOCK < dd_current) if (SECTORS_PER_BLOCK < dd_current)
@ -245,7 +245,7 @@ void DiskGapSectorCheck()
} }
} }
//Delay Disk Swapping by removing the disk for a certain amount of time, then insert the newly loaded disk (after 50 Status Register reads, here). // Delay disk swapping by removing the disk for a certain amount of time, then insert the newly loaded disk (after 50 status register reads, here)
if (!(g_Reg->ASIC_STATUS & DD_STATUS_DISK_PRES) && g_Disk != nullptr && g_Settings->LoadBool(GameRunning_LoadingInProgress) == false) if (!(g_Reg->ASIC_STATUS & DD_STATUS_DISK_PRES) && g_Disk != nullptr && g_Settings->LoadBool(GameRunning_LoadingInProgress) == false)
{ {
dd_swapdelay++; dd_swapdelay++;
@ -253,7 +253,7 @@ void DiskGapSectorCheck()
{ {
g_Reg->ASIC_STATUS |= (DD_STATUS_DISK_PRES | DD_STATUS_DISK_CHNG); g_Reg->ASIC_STATUS |= (DD_STATUS_DISK_PRES | DD_STATUS_DISK_CHNG);
dd_swapdelay = 0; dd_swapdelay = 0;
WriteTrace(TraceN64System, TraceDebug, "DD SWAP DONE"); WriteTrace(TraceN64System, TraceDebug, "N64DD swap done");
} }
} }
} }
@ -277,7 +277,7 @@ void DiskBMUpdate()
} }
else if (dd_current < SECTORS_PER_BLOCK + 1) else if (dd_current < SECTORS_PER_BLOCK + 1)
{ {
//C2 Sector // C2 sector
if (g_Reg->ASIC_BM_STATUS & DD_BM_STATUS_BLOCK) if (g_Reg->ASIC_BM_STATUS & DD_BM_STATUS_BLOCK)
{ {
dd_start_block = 1 - dd_start_block; dd_start_block = 1 - dd_start_block;
@ -303,16 +303,16 @@ void DiskBMUpdate()
} }
else else
{ {
//Read Data // Read data
if (((g_Reg->ASIC_CUR_TK >> 16) & 0x1FFF) == 6 && g_Reg->ASIC_CUR_SECTOR == 0 && g_Disk->GetCountry() != Country_Unknown) if (((g_Reg->ASIC_CUR_TK >> 16) & 0x1FFF) == 6 && g_Reg->ASIC_CUR_SECTOR == 0 && g_Disk->GetCountry() != Country_Unknown)
{ {
//Copy Protection if Retail Disk // Copy protection if retail disk
g_Reg->ASIC_STATUS &= ~DD_STATUS_DATA_RQ; g_Reg->ASIC_STATUS &= ~DD_STATUS_DATA_RQ;
g_Reg->ASIC_BM_STATUS |= DD_BM_STATUS_MICRO; g_Reg->ASIC_BM_STATUS |= DD_BM_STATUS_MICRO;
} }
else if (dd_current < SECTORS_PER_BLOCK) else if (dd_current < SECTORS_PER_BLOCK)
{ {
//User Sector // User sector
if (!DiskBMReadWrite(false)) if (!DiskBMReadWrite(false))
g_Reg->ASIC_STATUS |= DD_STATUS_DATA_RQ; g_Reg->ASIC_STATUS |= DD_STATUS_DATA_RQ;
else else
@ -321,14 +321,14 @@ void DiskBMUpdate()
} }
else if (dd_current < SECTORS_PER_BLOCK + 4) else if (dd_current < SECTORS_PER_BLOCK + 4)
{ {
//C2 sectors (All 00s) // C2 sectors (all 00s)
dd_current += 1; dd_current += 1;
if (dd_current == SECTORS_PER_BLOCK + 4) if (dd_current == SECTORS_PER_BLOCK + 4)
g_Reg->ASIC_STATUS |= DD_STATUS_C2_XFER; g_Reg->ASIC_STATUS |= DD_STATUS_C2_XFER;
} }
else if (dd_current == SECTORS_PER_BLOCK + 4) else if (dd_current == SECTORS_PER_BLOCK + 4)
{ {
//Gap Sector // Gap sector
if (g_Reg->ASIC_BM_STATUS & DD_BM_STATUS_BLOCK) if (g_Reg->ASIC_BM_STATUS & DD_BM_STATUS_BLOCK)
{ {
dd_start_block = 1 - dd_start_block; dd_start_block = 1 - dd_start_block;
@ -349,7 +349,7 @@ void DiskBMUpdate()
bool DiskBMReadWrite(bool /*write*/) bool DiskBMReadWrite(bool /*write*/)
{ {
//Returns true if error // Returns true if error
uint16_t head = ((g_Reg->ASIC_CUR_TK >> 16) / 0x1000) & 1; uint16_t head = ((g_Reg->ASIC_CUR_TK >> 16) / 0x1000) & 1;
uint16_t track = (g_Reg->ASIC_CUR_TK >> 16) & 0xFFF; uint16_t track = (g_Reg->ASIC_CUR_TK >> 16) & 0xFFF;
uint16_t block = (uint16_t)dd_start_block; uint16_t block = (uint16_t)dd_start_block;
@ -360,7 +360,7 @@ bool DiskBMReadWrite(bool /*write*/)
if (addr == 0xFFFFFFFF) if (addr == 0xFFFFFFFF)
{ {
//Error // Error
return true; return true;
} }
else else

View File

@ -1,4 +1,4 @@
// Based from MAME's N64DD driver code by Happy_ // Based on MAME's N64DD driver code by Happy_
#pragma once #pragma once
#include <stdint.h> #include <stdint.h>

View File

@ -63,17 +63,17 @@ void CDMA::PI_DMA_READ()
return; return;
} }
//64DD Buffers Write // 64DD buffers write
if (g_Reg->PI_CART_ADDR_REG >= 0x05000000 && g_Reg->PI_CART_ADDR_REG <= 0x050003FF) if (g_Reg->PI_CART_ADDR_REG >= 0x05000000 && g_Reg->PI_CART_ADDR_REG <= 0x050003FF)
{ {
//64DD C2 Sectors (don't care) // 64DD C2 sectors (don't care)
g_SystemTimer->SetTimer(g_SystemTimer->DDPiTimer, (PI_RD_LEN_REG * 63) / 25, false); g_SystemTimer->SetTimer(g_SystemTimer->DDPiTimer, (PI_RD_LEN_REG * 63) / 25, false);
return; return;
} }
if (g_Reg->PI_CART_ADDR_REG >= 0x05000400 && g_Reg->PI_CART_ADDR_REG <= 0x050004FF) if (g_Reg->PI_CART_ADDR_REG >= 0x05000400 && g_Reg->PI_CART_ADDR_REG <= 0x050004FF)
{ {
//64DD User Sector // 64DD user sector
uint32_t i; uint32_t i;
uint8_t * RDRAM = g_MMU->Rdram(); uint8_t * RDRAM = g_MMU->Rdram();
uint8_t * DISK = g_Disk->GetDiskAddressBuffer(); uint8_t * DISK = g_Disk->GetDiskAddressBuffer();
@ -87,14 +87,14 @@ void CDMA::PI_DMA_READ()
if (g_Reg->PI_CART_ADDR_REG >= 0x05000580 && g_Reg->PI_CART_ADDR_REG <= 0x050005BF) if (g_Reg->PI_CART_ADDR_REG >= 0x05000580 && g_Reg->PI_CART_ADDR_REG <= 0x050005BF)
{ {
//64DD MSEQ (don't care) // 64DD MSEQ (don't care)
g_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY; g_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY;
g_Reg->MI_INTR_REG |= MI_INTR_PI; g_Reg->MI_INTR_REG |= MI_INTR_PI;
g_Reg->CheckInterrupts(); g_Reg->CheckInterrupts();
return; return;
} }
//Write ROM Area (for 64DD Convert) // Write ROM area (for 64DD conversion)
if (g_Reg->PI_CART_ADDR_REG >= 0x10000000 && g_Reg->PI_CART_ADDR_REG <= 0x1FBFFFFF && g_Settings->LoadBool(Game_AllowROMWrites)) if (g_Reg->PI_CART_ADDR_REG >= 0x10000000 && g_Reg->PI_CART_ADDR_REG <= 0x1FBFFFFF && g_Settings->LoadBool(Game_AllowROMWrites))
{ {
uint32_t i; uint32_t i;
@ -172,7 +172,7 @@ void CDMA::PI_DMA_READ()
} }
if (g_System->m_SaveUsing == SaveChip_FlashRam) if (g_System->m_SaveUsing == SaveChip_FlashRam)
{ {
g_Notify->DisplayError(stdstr_f("**** FLashRam DMA Read address %08X *****", g_Reg->PI_CART_ADDR_REG).c_str()); g_Notify->DisplayError(stdstr_f("**** FlashRAM DMA read address %08X ****", g_Reg->PI_CART_ADDR_REG).c_str());
g_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY; g_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY;
g_Reg->MI_INTR_REG |= MI_INTR_PI; g_Reg->MI_INTR_REG |= MI_INTR_PI;
g_Reg->CheckInterrupts(); g_Reg->CheckInterrupts();
@ -180,7 +180,7 @@ void CDMA::PI_DMA_READ()
} }
if (HaveDebugger()) if (HaveDebugger())
{ {
g_Notify->DisplayError(stdstr_f("PI_DMA_READ where are you dmaing to ? : %08X", g_Reg->PI_CART_ADDR_REG).c_str()); g_Notify->DisplayError(stdstr_f("PI_DMA_READ where are you DMAing to? : %08X", g_Reg->PI_CART_ADDR_REG).c_str());
} }
g_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY; g_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY;
g_Reg->MI_INTR_REG |= MI_INTR_PI; g_Reg->MI_INTR_REG |= MI_INTR_PI;
@ -190,24 +190,24 @@ void CDMA::PI_DMA_READ()
void CDMA::PI_DMA_WRITE() void CDMA::PI_DMA_WRITE()
{ {
/* rounding PI_WR_LEN_REG up to the nearest even number fixes AI Shougi 3, Doraemon 3, etc. */ // Rounding PI_WR_LEN_REG up to the nearest even number fixes AI Shougi 3, Doraemon 3, etc.
uint32_t PI_WR_LEN_REG = ((g_Reg->PI_WR_LEN_REG) & 0x00FFFFFEul) + 2; uint32_t PI_WR_LEN_REG = ((g_Reg->PI_WR_LEN_REG) & 0x00FFFFFEul) + 2;
uint32_t PI_CART_ADDR_REG = !g_Settings->LoadBool(Game_UnalignedDMA) ? g_Reg->PI_CART_ADDR_REG & ~1 : g_Reg->PI_CART_ADDR_REG; uint32_t PI_CART_ADDR_REG = !g_Settings->LoadBool(Game_UnalignedDMA) ? g_Reg->PI_CART_ADDR_REG & ~1 : g_Reg->PI_CART_ADDR_REG;
g_Reg->PI_STATUS_REG |= PI_STATUS_DMA_BUSY; g_Reg->PI_STATUS_REG |= PI_STATUS_DMA_BUSY;
if (g_Reg->PI_DRAM_ADDR_REG + PI_WR_LEN_REG > g_MMU->RdramSize()) if (g_Reg->PI_DRAM_ADDR_REG + PI_WR_LEN_REG > g_MMU->RdramSize())
{ {
if (ShowUnhandledMemory()) { g_Notify->DisplayError(stdstr_f("PI_DMA_WRITE not in Memory: %08X", g_Reg->PI_DRAM_ADDR_REG + PI_WR_LEN_REG).c_str()); } if (ShowUnhandledMemory()) { g_Notify->DisplayError(stdstr_f("PI_DMA_WRITE not in memory: %08X", g_Reg->PI_DRAM_ADDR_REG + PI_WR_LEN_REG).c_str()); }
g_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY; g_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY;
g_Reg->MI_INTR_REG |= MI_INTR_PI; g_Reg->MI_INTR_REG |= MI_INTR_PI;
g_Reg->CheckInterrupts(); g_Reg->CheckInterrupts();
return; return;
} }
//64DD Buffers Read // 64DD buffers read
if (PI_CART_ADDR_REG >= 0x05000000 && PI_CART_ADDR_REG <= 0x050003FF) if (PI_CART_ADDR_REG >= 0x05000000 && PI_CART_ADDR_REG <= 0x050003FF)
{ {
//64DD C2 Sectors (just read 0) // 64DD C2 sectors (just read 0)
uint32_t i; uint32_t i;
uint8_t * RDRAM = g_MMU->Rdram(); uint8_t * RDRAM = g_MMU->Rdram();
for (i = 0; i < PI_WR_LEN_REG; i++) for (i = 0; i < PI_WR_LEN_REG; i++)
@ -215,14 +215,14 @@ void CDMA::PI_DMA_WRITE()
*(RDRAM + ((g_Reg->PI_DRAM_ADDR_REG + i) ^ 3)) = 0; *(RDRAM + ((g_Reg->PI_DRAM_ADDR_REG + i) ^ 3)) = 0;
} }
//Timer is needed for Track Read // Timer is needed for track read
g_SystemTimer->SetTimer(g_SystemTimer->DDPiTimer, (PI_WR_LEN_REG * 63) / 25, false); g_SystemTimer->SetTimer(g_SystemTimer->DDPiTimer, (PI_WR_LEN_REG * 63) / 25, false);
return; return;
} }
if (PI_CART_ADDR_REG >= 0x05000400 && PI_CART_ADDR_REG <= 0x050004FF) if (PI_CART_ADDR_REG >= 0x05000400 && PI_CART_ADDR_REG <= 0x050004FF)
{ {
//64DD User Sector // 64DD user sector
uint32_t i; uint32_t i;
uint8_t * RDRAM = g_MMU->Rdram(); uint8_t * RDRAM = g_MMU->Rdram();
uint8_t * DISK = g_Disk->GetDiskAddressBuffer(); uint8_t * DISK = g_Disk->GetDiskAddressBuffer();
@ -231,21 +231,21 @@ void CDMA::PI_DMA_WRITE()
*(RDRAM + ((g_Reg->PI_DRAM_ADDR_REG + i) ^ 3)) = *(DISK + (i ^ 3)); *(RDRAM + ((g_Reg->PI_DRAM_ADDR_REG + i) ^ 3)) = *(DISK + (i ^ 3));
} }
//Timer is needed for Track Read // Timer is needed for track read
g_SystemTimer->SetTimer(g_SystemTimer->DDPiTimer, (PI_WR_LEN_REG * 63) / 25, false); g_SystemTimer->SetTimer(g_SystemTimer->DDPiTimer, (PI_WR_LEN_REG * 63) / 25, false);
return; return;
} }
if (PI_CART_ADDR_REG >= 0x05000580 && PI_CART_ADDR_REG <= 0x050005BF) if (PI_CART_ADDR_REG >= 0x05000580 && PI_CART_ADDR_REG <= 0x050005BF)
{ {
//64DD MSEQ (don't care) // 64DD MSEQ (don't care)
g_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY; g_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY;
g_Reg->MI_INTR_REG |= MI_INTR_PI; g_Reg->MI_INTR_REG |= MI_INTR_PI;
g_Reg->CheckInterrupts(); g_Reg->CheckInterrupts();
return; return;
} }
//64DD IPL ROM // 64DD IPL ROM
if (PI_CART_ADDR_REG >= 0x06000000 && PI_CART_ADDR_REG <= 0x063FFFFF) if (PI_CART_ADDR_REG >= 0x06000000 && PI_CART_ADDR_REG <= 0x063FFFFF)
{ {
uint32_t i; uint32_t i;
@ -483,7 +483,7 @@ void CDMA::SP_DMA_READ()
{ {
if (HaveDebugger()) if (HaveDebugger())
{ {
g_Notify->DisplayError(stdstr_f("%s\nSP_DRAM_ADDR_REG not in RDRam space : % 08X", __FUNCTION__, g_Reg->SP_DRAM_ADDR_REG).c_str()); g_Notify->DisplayError(stdstr_f("%s\nSP_DRAM_ADDR_REG not in RDRAM space: % 08X", __FUNCTION__, g_Reg->SP_DRAM_ADDR_REG).c_str());
} }
g_Reg->SP_DMA_BUSY_REG = 0; g_Reg->SP_DMA_BUSY_REG = 0;
g_Reg->SP_STATUS_REG &= ~SP_STATUS_DMA_BUSY; g_Reg->SP_STATUS_REG &= ~SP_STATUS_DMA_BUSY;
@ -525,7 +525,7 @@ void CDMA::SP_DMA_WRITE()
{ {
if (HaveDebugger()) if (HaveDebugger())
{ {
g_Notify->DisplayError(stdstr_f("%s\nSP_DRAM_ADDR_REG not in RDRam space : %08X", __FUNCTION__, g_Reg->SP_DRAM_ADDR_REG).c_str()); g_Notify->DisplayError(stdstr_f("%s\nSP_DRAM_ADDR_REG not in RDRAM space: %08X", __FUNCTION__, g_Reg->SP_DRAM_ADDR_REG).c_str());
} }
return; return;
} }
@ -534,7 +534,7 @@ void CDMA::SP_DMA_WRITE()
{ {
if (HaveDebugger()) if (HaveDebugger())
{ {
g_Notify->DisplayError("SP DMA WRITE\ncould not fit copy in memory segement"); g_Notify->DisplayError("SP DMA WRITE\nCould not fit copy in memory segment");
} }
return; return;
} }

View File

@ -32,7 +32,7 @@ void CEeprom::EepromCommand(uint8_t * Command)
switch (Command[2]) switch (Command[2])
{ {
case 0: // check case 0: // Check
if (g_System->m_SaveUsing != SaveChip_Eeprom_4K && g_System->m_SaveUsing != SaveChip_Eeprom_16K) if (g_System->m_SaveUsing != SaveChip_Eeprom_4K && g_System->m_SaveUsing != SaveChip_Eeprom_16K)
{ {
Command[1] |= 0x80; Command[1] |= 0x80;
@ -61,7 +61,7 @@ void CEeprom::EepromCommand(uint8_t * Command)
Command[5] = 0x00; Command[5] = 0x00;
} }
break; break;
case 4: // Read from Eeprom case 4: // Read from EEPROM
if (Command[0] != 2 && HaveDebugger()) if (Command[0] != 2 && HaveDebugger())
{ {
ProcessingError(Command); ProcessingError(Command);
@ -72,7 +72,7 @@ void CEeprom::EepromCommand(uint8_t * Command)
} }
ReadFrom(&Command[4], Command[3]); ReadFrom(&Command[4], Command[3]);
break; break;
case 5: //Write to Eeprom case 5: // Write to EEPROM
if (Command[0] != 10 && HaveDebugger()) if (Command[0] != 10 && HaveDebugger())
{ {
ProcessingError(Command); ProcessingError(Command);
@ -83,25 +83,25 @@ void CEeprom::EepromCommand(uint8_t * Command)
} }
WriteTo(&Command[4], Command[3]); WriteTo(&Command[4], Command[3]);
break; break;
case 6: //RTC Status query case 6: // RTC status query
Command[3] = 0x00; Command[3] = 0x00;
Command[4] = 0x10; Command[4] = 0x10;
Command[5] = 0x00; Command[5] = 0x00;
break; break;
case 7: //Read RTC block case 7: // Read RTC block
switch (Command[3]) switch (Command[3])
{ {
case 0: //Block number case 0: // Block number
Command[4] = 0x00; Command[4] = 0x00;
Command[5] = 0x02; Command[5] = 0x02;
Command[12] = 0x00; Command[12] = 0x00;
break; break;
case 1: case 1:
//read block, Command[2], Unimplemented // Read block, Command[2], unimplemented
break; break;
case 2: //Set RTC Time case 2: // Set RTC time
time(&curtime_time); time(&curtime_time);
memcpy(&curtime, localtime(&curtime_time), sizeof(curtime)); // fd's fix memcpy(&curtime, localtime(&curtime_time), sizeof(curtime));
Command[4] = byte2bcd(curtime.tm_sec); Command[4] = byte2bcd(curtime.tm_sec);
Command[5] = byte2bcd(curtime.tm_min); Command[5] = byte2bcd(curtime.tm_min);
Command[6] = 0x80 + byte2bcd(curtime.tm_hour); Command[6] = 0x80 + byte2bcd(curtime.tm_hour);
@ -110,12 +110,12 @@ void CEeprom::EepromCommand(uint8_t * Command)
Command[9] = byte2bcd(curtime.tm_mon + 1); Command[9] = byte2bcd(curtime.tm_mon + 1);
Command[10] = byte2bcd(curtime.tm_year); Command[10] = byte2bcd(curtime.tm_year);
Command[11] = byte2bcd(curtime.tm_year / 100); Command[11] = byte2bcd(curtime.tm_year / 100);
Command[12] = 0x00; // status Command[12] = 0x00; // Status
break; break;
} }
break; break;
case 8: case 8:
//Write RTC, unimplemented // Write RTC, unimplemented
if (bShowPifRamErrors()) if (bShowPifRamErrors())
{ {
g_Notify->DisplayError("Write RTC, unimplemented"); g_Notify->DisplayError("Write RTC, unimplemented");
@ -199,6 +199,6 @@ void CEeprom::ProcessingError(uint8_t * /*Command*/)
{ {
if (bShowPifRamErrors()) if (bShowPifRamErrors())
{ {
g_Notify->DisplayError("What am I meant to do with this Eeprom Command"); g_Notify->DisplayError("What am I meant to do with this EEPROM command?");
} }
} }

View File

@ -40,7 +40,7 @@ void CFlashram::DmaFromFlashram(uint8_t * dest, int32_t StartOffset, int32_t len
{ {
if (HaveDebugger()) if (HaveDebugger())
{ {
g_Notify->DisplayError(stdstr_f("%s: Unaligned flash ram read ???", __FUNCTION__).c_str()); g_Notify->DisplayError(stdstr_f("%s: Unaligned flash RAM read?", __FUNCTION__).c_str());
} }
return; return;
} }
@ -178,7 +178,7 @@ void CFlashram::WriteToFlashCommand(uint32_t FlashRAM_Command)
} }
break; break;
default: default:
g_Notify->DisplayError(stdstr_f("Writing %X to flash ram command register\nm_FlashFlag: %d", FlashRAM_Command, m_FlashFlag).c_str()); g_Notify->DisplayError(stdstr_f("Writing %X to flash RAM command register\nm_FlashFlag: %d", FlashRAM_Command, m_FlashFlag).c_str());
} }
m_FlashFlag = FLASHRAM_MODE_NOPES; m_FlashFlag = FLASHRAM_MODE_NOPES;
break; break;
@ -199,7 +199,7 @@ void CFlashram::WriteToFlashCommand(uint32_t FlashRAM_Command)
m_FlashStatus = 0x1111800800C2001E; m_FlashStatus = 0x1111800800C2001E;
break; break;
case 0xB4000000: case 0xB4000000:
m_FlashFlag = FLASHRAM_MODE_WRITE; //???? m_FlashFlag = FLASHRAM_MODE_WRITE;
break; break;
case 0xA5000000: case 0xA5000000:
m_FlashRAM_Offset = (FlashRAM_Command & 0xFFFF) * sizeof(EmptyBlock); m_FlashRAM_Offset = (FlashRAM_Command & 0xFFFF) * sizeof(EmptyBlock);
@ -208,7 +208,7 @@ void CFlashram::WriteToFlashCommand(uint32_t FlashRAM_Command)
default: default:
if (HaveDebugger()) if (HaveDebugger())
{ {
g_Notify->DisplayError(stdstr_f("Writing %X to flash ram command register", FlashRAM_Command).c_str()); g_Notify->DisplayError(stdstr_f("Writing %X to flash RAM command register", FlashRAM_Command).c_str());
} }
} }
} }

View File

@ -1,8 +1,9 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2015 Bobby Smiles // Copyright(C) 2015 Bobby Smiles
// GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html // GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html
#include "stdafx.h" #include "stdafx.h"
#include "GBCart.h" #include "GBCart.h"
@ -15,27 +16,27 @@ static void read_gb_cart_normal(struct gb_cart* gb_cart, uint16_t address, uint8
if ((address >= 0x0000) && (address <= 0x7FFF)) if ((address >= 0x0000) && (address <= 0x7FFF))
{ {
//Read GB Cart // Read Game Boy cart
if (address >= gb_cart->rom_size) if (address >= gb_cart->rom_size)
{ {
//If address is larger then our rome size, bail out // If address is larger then our ROM size, bail out
return; return;
} }
memcpy(data, &gb_cart->rom[address], 0x20); memcpy(data, &gb_cart->rom[address], 0x20);
} }
else if ((address >= 0xA000) && (address <= 0xBFFF)) else if ((address >= 0xA000) && (address <= 0xBFFF))
{ {
//Read from RAM // Read from RAM
if (gb_cart->ram == nullptr) if (gb_cart->ram == nullptr)
{ {
//No RAM to write to // No RAM to write to
return; return;
} }
offset = address - 0xA000; offset = address - 0xA000;
if (offset >= gb_cart->ram_size) if (offset >= gb_cart->ram_size)
{ {
//Offset is larger then our ram size // Offset is larger then our RAM size
return; return;
} }
@ -49,17 +50,17 @@ static void write_gb_cart_normal(struct gb_cart* gb_cart, uint16_t address, cons
uint16_t offset; uint16_t offset;
if ((address >= 0xA000) && (address <= 0xBFFF)) if ((address >= 0xA000) && (address <= 0xBFFF))
{ {
//Write to RAM // Write to RAM
if (gb_cart->ram == nullptr) if (gb_cart->ram == nullptr)
{ {
//No RAM to write to // No RAM to write to
return; return;
} }
offset = address - 0xa000; offset = address - 0xa000;
if (offset >= gb_cart->ram_size) if (offset >= gb_cart->ram_size)
{ {
//Offset is larger then our ram size // Offset is larger then our RAM size
return; return;
} }
@ -71,11 +72,11 @@ static void read_gb_cart_mbc1(struct gb_cart* gb_cart, uint16_t address, uint8_t
{ {
size_t offset; size_t offset;
if ((address >= 0x0000) && (address <= 0x3FFF)) //No nbanked memory if ((address >= 0x0000) && (address <= 0x3FFF)) // No unbanked memory
{ {
memcpy(data, &gb_cart->rom[address], 0x20); memcpy(data, &gb_cart->rom[address], 0x20);
} }
else if ((address >= 0x4000) && (address <= 0x7FFF)) //Read from ROM else if ((address >= 0x4000) && (address <= 0x7FFF)) // Read from ROM
{ {
offset = (address - 0x4000) + (gb_cart->rom_bank * 0x4000); offset = (address - 0x4000) + (gb_cart->rom_bank * 0x4000);
if (offset < gb_cart->rom_size) if (offset < gb_cart->rom_size)
@ -83,7 +84,7 @@ static void read_gb_cart_mbc1(struct gb_cart* gb_cart, uint16_t address, uint8_t
memcpy(data, &gb_cart->rom[offset], 0x20); memcpy(data, &gb_cart->rom[offset], 0x20);
} }
} }
else if ((address >= 0xA000) && (address <= 0xBFFF)) //Read from RAM else if ((address >= 0xA000) && (address <= 0xBFFF)) // Read from RAM
{ {
if (gb_cart->ram != nullptr) if (gb_cart->ram != nullptr)
{ {
@ -102,15 +103,15 @@ static void write_gb_cart_mbc1(struct gb_cart* gb_cart, uint16_t address, const
if ((address >= 0x0000) && (address <= 0x1FFF)) // RAM enable if ((address >= 0x0000) && (address <= 0x1FFF)) // RAM enable
{ {
//Enable/disable RAM // Enable/disable RAM
gb_cart->ram_enabled = (data[0] & 0x0F) == 0x0A; gb_cart->ram_enabled = (data[0] & 0x0F) == 0x0A;
} }
else if ((address >= 0x2000) && (address <= 0x3FFF)) // ROM bank select else if ((address >= 0x2000) && (address <= 0x3FFF)) // ROM bank select
{ {
gb_cart->rom_bank &= 0x60; // keep MSB gb_cart->rom_bank &= 0x60; // Keep MSB
gb_cart->rom_bank |= data[0] & 0x1F; gb_cart->rom_bank |= data[0] & 0x1F;
// emulate quirk: 0x00 -> 0x01, 0x20 -> 0x21, 0x40->0x41, 0x60 -> 0x61 // Emulate quirk: 0x00 -> 0x01, 0x20 -> 0x21, 0x40->0x41, 0x60 -> 0x61
if ((gb_cart->rom_bank & 0x1F) == 0) if ((gb_cart->rom_bank & 0x1F) == 0)
{ {
gb_cart->rom_bank |= 0x01; gb_cart->rom_bank |= 0x01;
@ -125,27 +126,27 @@ static void write_gb_cart_mbc1(struct gb_cart* gb_cart, uint16_t address, const
else else
{ {
gb_cart->rom_bank &= 0x1F; gb_cart->rom_bank &= 0x1F;
gb_cart->rom_bank |= ((data[0] & 0x03) << 5); // set bits 5 and 6 of ROM bank gb_cart->rom_bank |= ((data[0] & 0x03) << 5); // Set bits 5 and 6 of ROM bank
} }
} }
else if ((address >= 0x6000) && (address <= 0x7FFF)) // MBC1 mode select else if ((address >= 0x6000) && (address <= 0x7FFF)) // MBC1 mode select
{ {
// this is overly complicated, but it keeps us from having to do bitwise math later // This is overly complicated, but it keeps us from having to do bitwise math later
// Basically we shuffle the 2 "magic bits" between rom_bank and ram_bank as necessary. // Basically we shuffle the 2 "magic bits" between rom_bank and ram_bank as necessary
if (gb_cart->ram_bank_mode != (data[0] & 0x01)) if (gb_cart->ram_bank_mode != (data[0] & 0x01))
{ {
// we should only alter the ROM and RAM bank numbers if we have changed modes // We should only alter the ROM and RAM bank numbers if we have changed modes
gb_cart->ram_bank_mode = data[0] & 0x01; gb_cart->ram_bank_mode = data[0] & 0x01;
if (gb_cart->ram_bank_mode) if (gb_cart->ram_bank_mode)
{ {
gb_cart->ram_bank = gb_cart->rom_bank >> 5; // set the ram bank to the "magic bits" gb_cart->ram_bank = gb_cart->rom_bank >> 5; // Set the RAM bank to the "magic bits"
gb_cart->rom_bank &= 0x1F; // zero out bits 5 and 6 to keep consistency gb_cart->rom_bank &= 0x1F; // Zero out bits 5 and 6 to keep consistency
} }
else else
{ {
gb_cart->rom_bank &= 0x1F; gb_cart->rom_bank &= 0x1F;
gb_cart->rom_bank |= (gb_cart->ram_bank << 5); gb_cart->rom_bank |= (gb_cart->ram_bank << 5);
gb_cart->ram_bank = 0x00; // we can only reach RAM page 0 gb_cart->ram_bank = 0x00; // We can only reach RAM page 0
} }
} }
} }
@ -166,11 +167,11 @@ static void read_gb_cart_mbc2(struct gb_cart* gb_cart, uint16_t address, uint8_t
{ {
size_t offset; size_t offset;
if ((address < 0x4000)) //Rom Bank 0 if ((address < 0x4000)) // ROM bank 0
{ {
memcpy(data, &gb_cart->rom[address], 0x20); memcpy(data, &gb_cart->rom[address], 0x20);
} }
else if ((address >= 0x4000) && (address < 0x8000)) //Switchable Rom Bank else if ((address >= 0x4000) && (address < 0x8000)) // Switchable ROM bank
{ {
offset = (address - 0x4000) + (gb_cart->rom_bank * 0x4000); offset = (address - 0x4000) + (gb_cart->rom_bank * 0x4000);
if (offset < gb_cart->rom_size) if (offset < gb_cart->rom_size)
@ -178,7 +179,7 @@ static void read_gb_cart_mbc2(struct gb_cart* gb_cart, uint16_t address, uint8_t
memcpy(data, &gb_cart->rom[offset], 0x20); memcpy(data, &gb_cart->rom[offset], 0x20);
} }
} }
else if ((address >= 0xA000) && (address <= 0xC000)) //Upper Bounds of memory map else if ((address >= 0xA000) && (address <= 0xC000)) // Upper bounds of memory map
{ {
if (gb_cart->ram != nullptr) if (gb_cart->ram != nullptr)
{ {
@ -232,7 +233,7 @@ void memoryUpdateMBC3Clock(struct gb_cart* gb_cart)
time_t now = time(nullptr); time_t now = time(nullptr);
time_t diff = now - gb_cart->rtc_last_time; time_t diff = now - gb_cart->rtc_last_time;
if (diff > 0) { if (diff > 0) {
// update the clock according to the last update time // Update the clock according to the last update time
gb_cart->rtc_data[0] += (int)(diff % 60); gb_cart->rtc_data[0] += (int)(diff % 60);
if (gb_cart->rtc_data[0] > 59) { if (gb_cart->rtc_data[0] > 59) {
gb_cart->rtc_data[0] -= 60; gb_cart->rtc_data[0] -= 60;
@ -270,11 +271,11 @@ static void read_gb_cart_mbc3(struct gb_cart* gb_cart, uint16_t address, uint8_t
{ {
size_t offset; size_t offset;
if ((address < 0x4000)) //Rom Bank 0 if ((address < 0x4000)) // ROM bank 0
{ {
memcpy(data, &gb_cart->rom[address], 0x20); memcpy(data, &gb_cart->rom[address], 0x20);
} }
else if ((address >= 0x4000) && (address < 0x8000)) //Switchable Rom Bank else if ((address >= 0x4000) && (address < 0x8000)) // Switchable ROM bank
{ {
offset = (address - 0x4000) + (gb_cart->rom_bank * 0x4000); offset = (address - 0x4000) + (gb_cart->rom_bank * 0x4000);
if (offset < gb_cart->rom_size) if (offset < gb_cart->rom_size)
@ -282,7 +283,7 @@ static void read_gb_cart_mbc3(struct gb_cart* gb_cart, uint16_t address, uint8_t
memcpy(data, &gb_cart->rom[offset], 0x20); memcpy(data, &gb_cart->rom[offset], 0x20);
} }
} }
else if ((address >= 0xA000) && (address <= 0xC000)) //Upper Bounds of memory map else if ((address >= 0xA000) && (address <= 0xC000)) // Upper bounds of memory map
{ {
if (gb_cart->ram != nullptr) if (gb_cart->ram != nullptr)
{ {
@ -323,7 +324,7 @@ static void write_gb_cart_mbc3(struct gb_cart* gb_cart, uint16_t address, const
if ((address >= 0x0000) && (address <= 0x1FFF)) // We shouldn't be able to read/write to RAM unless this is toggled on if ((address >= 0x0000) && (address <= 0x1FFF)) // We shouldn't be able to read/write to RAM unless this is toggled on
{ {
//Enable / Disable RAM -- NOT WORKING -- FIXME // Enable / Disable RAM -- NOT WORKING --
gb_cart->ram_enabled = (data[0] & 0x0F) == 0x0A; gb_cart->ram_enabled = (data[0] & 0x0F) == 0x0A;
} }
else if ((address >= 0x2000) && (address <= 0x3FFF)) // ROM bank select else if ((address >= 0x2000) && (address <= 0x3FFF)) // ROM bank select
@ -331,14 +332,14 @@ static void write_gb_cart_mbc3(struct gb_cart* gb_cart, uint16_t address, const
bank = data[0] & 0x7F; bank = data[0] & 0x7F;
gb_cart->rom_bank = (bank == 0) ? 1 : bank; gb_cart->rom_bank = (bank == 0) ? 1 : bank;
} }
else if ((address >= 0x4000) && (address <= 0x5FFF)) // RAM/Clock bank select else if ((address >= 0x4000) && (address <= 0x5FFF)) // RAM/clock bank select
{ {
if (gb_cart->ram != nullptr) if (gb_cart->ram != nullptr)
{ {
bank = data[0]; bank = data[0];
if (gb_cart->has_rtc && (bank >= 0x8 && bank <= 0xc)) if (gb_cart->has_rtc && (bank >= 0x8 && bank <= 0xc))
{ {
//Set the bank for the timer // Set the bank for the timer
gb_cart->ram_bank = bank; gb_cart->ram_bank = bank;
} }
else else
@ -349,10 +350,10 @@ static void write_gb_cart_mbc3(struct gb_cart* gb_cart, uint16_t address, const
} }
else if ((address >= 0x6000) && (address <= 0x7FFF)) // Latch timer data else if ((address >= 0x6000) && (address <= 0x7FFF)) // Latch timer data
{ {
//Implement RTC timer / latch // Implement RTC timer / latch
if (gb_cart->rtc_latch == 0 && data[0] == 1) if (gb_cart->rtc_latch == 0 && data[0] == 1)
{ {
//Update time // Update time
memoryUpdateMBC3Clock(gb_cart); memoryUpdateMBC3Clock(gb_cart);
for (int i = 0; i < 4; i++) for (int i = 0; i < 4; i++)
{ {
@ -375,7 +376,7 @@ static void write_gb_cart_mbc3(struct gb_cart* gb_cart, uint16_t address, const
} }
else if (gb_cart->has_rtc) else if (gb_cart->has_rtc)
{ {
/* RTC write */ // RTC write
gb_cart->rtc_data[gb_cart->ram_bank - 0x08] = data[0]; gb_cart->rtc_data[gb_cart->ram_bank - 0x08] = data[0];
} }
} }
@ -396,11 +397,11 @@ static void read_gb_cart_mbc5(struct gb_cart * gb_cart, uint16_t address, uint8_
{ {
size_t offset; size_t offset;
if ((address < 0x4000)) //Rom Bank 0 if ((address < 0x4000)) // ROM bank 0
{ {
memcpy(data, &gb_cart->rom[address], 0x20); memcpy(data, &gb_cart->rom[address], 0x20);
} }
else if ((address >= 0x4000) && (address < 0x8000)) //Switchable ROM BANK else if ((address >= 0x4000) && (address < 0x8000)) // Switchable ROM bank
{ {
offset = (address - 0x4000) + (gb_cart->rom_bank * 0x4000); offset = (address - 0x4000) + (gb_cart->rom_bank * 0x4000);
if (offset < gb_cart->rom_size) if (offset < gb_cart->rom_size)
@ -408,7 +409,7 @@ static void read_gb_cart_mbc5(struct gb_cart * gb_cart, uint16_t address, uint8_
memcpy(data, &gb_cart->rom[offset], 0x20); memcpy(data, &gb_cart->rom[offset], 0x20);
} }
} }
else if ((address >= 0xA000) && (address <= 0xC000)) //Upper bounds of memory map else if ((address >= 0xA000) && (address <= 0xC000)) // Upper bounds of memory map
{ {
if (gb_cart->ram != nullptr) if (gb_cart->ram != nullptr)
{ {
@ -427,7 +428,7 @@ static void write_gb_cart_mbc5(struct gb_cart* gb_cart, uint16_t address, const
if ((address >= 0x0000) && (address <= 0x1FFF)) // We shouldn't be able to read/write to RAM unless this is toggled on if ((address >= 0x0000) && (address <= 0x1FFF)) // We shouldn't be able to read/write to RAM unless this is toggled on
{ {
//Enable / Disable RAM -- NOT WORKING -- CHECK ME // Enable / Disable RAM -- NOT WORKING --
gb_cart->ram_enabled = (data[0] & 0x0F) == 0x0A; gb_cart->ram_enabled = (data[0] & 0x0F) == 0x0A;
} }
else if ((address >= 0x2000) && (address <= 0x2FFF)) // ROM bank select, low bits else if ((address >= 0x2000) && (address <= 0x2FFF)) // ROM bank select, low bits
@ -474,11 +475,11 @@ static void read_gb_cart_pocket_cam(struct gb_cart * gb_cart, uint16_t address,
{ {
size_t offset; size_t offset;
if ((address < 0x4000)) //Rom Bank 0 if ((address < 0x4000)) // ROM bank 0
{ {
memcpy(data, &gb_cart->rom[address], 0x20); memcpy(data, &gb_cart->rom[address], 0x20);
} }
else if ((address >= 0x4000) && (address < 0x8000)) //Switchable ROM BANK else if ((address >= 0x4000) && (address < 0x8000)) // Switchable ROM bank
{ {
offset = (address - 0x4000) + (gb_cart->rom_bank * 0x4000); offset = (address - 0x4000) + (gb_cart->rom_bank * 0x4000);
if (offset < gb_cart->rom_size) if (offset < gb_cart->rom_size)
@ -486,20 +487,20 @@ static void read_gb_cart_pocket_cam(struct gb_cart * gb_cart, uint16_t address,
memcpy(data, &gb_cart->rom[offset], 0x20); memcpy(data, &gb_cart->rom[offset], 0x20);
} }
} }
else if ((address >= 0xA000) && (address <= 0xC000)) //Upper bounds of memory map else if ((address >= 0xA000) && (address <= 0xC000)) // Upper bounds of memory map
{ {
//Check to see if where currently in register mode // Check to see if where currently in register mode
if (gb_cart->ram != nullptr) if (gb_cart->ram != nullptr)
{ {
if (gb_cart->ram_bank & 0x10) if (gb_cart->ram_bank & 0x10)
{ {
//Where in register mode, based off NRAGE we just fill the memory with Zeroes. // When in register mode, based off of N-Rage code we just fill the memory with zeroes
//Seems to be incorrect behaviour but need to find more doccumentation // Seems to be incorrect behavior, but need to find more documentation
memset(data, 0x00, 0x20); memset(data, 0x00, 0x20);
} }
else else
{ {
//Read RAM normally // Read RAM normally
offset = (address - 0xA000) + (gb_cart->ram_bank * 0x2000); offset = (address - 0xA000) + (gb_cart->ram_bank * 0x2000);
if (offset < gb_cart->ram_size) if (offset < gb_cart->ram_size)
{ {
@ -516,7 +517,7 @@ static void write_gb_cart_pocket_cam(struct gb_cart* gb_cart, uint16_t address,
if ((address >= 0x0000) && (address <= 0x1FFF)) // We shouldn't be able to read/write to RAM unless this is toggled on if ((address >= 0x0000) && (address <= 0x1FFF)) // We shouldn't be able to read/write to RAM unless this is toggled on
{ {
//Enable / Disable RAM // Enable / Disable RAM
gb_cart->ram_enabled = (data[0] & 0x0F) == 0x0A; gb_cart->ram_enabled = (data[0] & 0x0F) == 0x0A;
} }
else if ((address >= 0x2000) && (address <= 0x2FFF)) // ROM bank select, low bits else if ((address >= 0x2000) && (address <= 0x2FFF)) // ROM bank select, low bits
@ -524,18 +525,18 @@ static void write_gb_cart_pocket_cam(struct gb_cart* gb_cart, uint16_t address,
gb_cart->rom_bank &= 0xFF00; gb_cart->rom_bank &= 0xFF00;
gb_cart->rom_bank |= data[0]; gb_cart->rom_bank |= data[0];
} }
else if ((address >= 0x4000) && (address <= 0x4FFF)) // Camera Register & RAM bank select else if ((address >= 0x4000) && (address <= 0x4FFF)) // Camera register and RAM bank select
{ {
if (gb_cart->ram != nullptr) if (gb_cart->ram != nullptr)
{ {
if (data[0] & 0x10) if (data[0] & 0x10)
{ {
//REGISTER MODE // Register mode
gb_cart->ram_bank = data[0]; gb_cart->ram_bank = data[0];
} }
else else
{ {
//RAM MODE // RAM mode
gb_cart->ram_bank = data[0] & 0x0F; gb_cart->ram_bank = data[0] & 0x0F;
} }
} }
@ -546,11 +547,11 @@ static void write_gb_cart_pocket_cam(struct gb_cart* gb_cart, uint16_t address,
{ {
if (gb_cart->ram_bank & 0x10) if (gb_cart->ram_bank & 0x10)
{ {
//REGISTER MODE (DO NOTHING) // Register mode (do nothing)
} }
else else
{ {
//RAM MODE // RAM mode
offset = (address - 0xA000) + (gb_cart->ram_bank * 0x2000); offset = (address - 0xA000) + (gb_cart->ram_bank * 0x2000);
if (offset < gb_cart->ram_size) if (offset < gb_cart->ram_size)
{ {
@ -688,10 +689,10 @@ bool GBCart::init_gb_cart(struct gb_cart* gb_cart, const char* gb_file)
size_t ram_size = 0; size_t ram_size = 0;
CFile tempFile; CFile tempFile;
/* load GB cart ROM */ // Load Game Boy cart ROM
if (!tempFile.Open(gb_file, CFileBase::modeRead)) if (!tempFile.Open(gb_file, CFileBase::modeRead))
{ {
g_Notify->DisplayError("Failed to open Transferpak ROM"); g_Notify->DisplayError("Failed to open Transfer Pak ROM");
return false; return false;
} }
@ -706,7 +707,7 @@ bool GBCart::init_gb_cart(struct gb_cart* gb_cart, const char* gb_file)
return false; return false;
} }
/* get and parse cart type */ // Get and parse cart type
uint8_t cart_type = rom.get()[0x147]; uint8_t cart_type = rom.get()[0x147];
type = parse_cart_type(cart_type); type = parse_cart_type(cart_type);
if (type == nullptr) if (type == nullptr)
@ -714,7 +715,7 @@ bool GBCart::init_gb_cart(struct gb_cart* gb_cart, const char* gb_file)
return false; return false;
} }
/* load ram (if present) */ // Load RAM (if present)
if (type->extra_devices & GED_RAM) if (type->extra_devices & GED_RAM)
{ {
ram_size = 0; ram_size = 0;
@ -737,14 +738,14 @@ bool GBCart::init_gb_cart(struct gb_cart* gb_cart, const char* gb_file)
if (!tempFile.Open(g_Settings->LoadStringVal(Game_Transferpak_Sav).c_str(), CFileBase::modeRead)) if (!tempFile.Open(g_Settings->LoadStringVal(Game_Transferpak_Sav).c_str(), CFileBase::modeRead))
{ {
g_Notify->DisplayError("Failed to open Transferpak SAV File"); g_Notify->DisplayError("Failed to open Transfer Pak SAV file");
return false; return false;
} }
tempFile.Read(ram.get(), ram_size); tempFile.Read(ram.get(), ram_size);
} }
//If we have RTC we need to load in the data, we assume the save will use the VBA-M format // If we have RTC we need to load in the data, we assume the save will use the VBA-M format
if (type->extra_devices & GED_RTC) if (type->extra_devices & GED_RTC)
{ {
tempFile.Read(&gb_cart->rtc_data[0], 4); tempFile.Read(&gb_cart->rtc_data[0], 4);
@ -763,7 +764,7 @@ bool GBCart::init_gb_cart(struct gb_cart* gb_cart, const char* gb_file)
tempFile.Close(); tempFile.Close();
} }
/* update gb_cart */ // Update gb_cart
gb_cart->rom = rom.release(); gb_cart->rom = rom.release();
gb_cart->ram = ram.release(); gb_cart->ram = ram.release();
gb_cart->rom_size = rom_size; gb_cart->rom_size = rom_size;

View File

@ -38,6 +38,3 @@ public:
static void read_gb_cart(struct gb_cart* gb_cart, uint16_t address, uint8_t* data); static void read_gb_cart(struct gb_cart* gb_cart, uint16_t address, uint8_t* data);
static void write_gb_cart(struct gb_cart* gb_cart, uint16_t address, const uint8_t* data); static void write_gb_cart(struct gb_cart* gb_cart, uint16_t address, const uint8_t* data);
}; };

View File

@ -141,7 +141,7 @@ bool CMipsMemoryVM::Initialize(bool SyncSystem)
} }
if (m_RDRAM == nullptr) if (m_RDRAM == nullptr)
{ {
WriteTrace(TraceN64System, TraceError, "Failed to Reserve RDRAM (Size: 0x%X)", 0x20000000); WriteTrace(TraceN64System, TraceError, "Failed to reserve RDRAM (Size: 0x%X)", 0x20000000);
FreeMemory(); FreeMemory();
return false; return false;
} }
@ -149,14 +149,14 @@ bool CMipsMemoryVM::Initialize(bool SyncSystem)
m_AllocatedRdramSize = g_Settings->LoadDword(Game_RDRamSize); m_AllocatedRdramSize = g_Settings->LoadDword(Game_RDRamSize);
if (CommitMemory(m_RDRAM, m_AllocatedRdramSize, MEM_READWRITE) == nullptr) if (CommitMemory(m_RDRAM, m_AllocatedRdramSize, MEM_READWRITE) == nullptr)
{ {
WriteTrace(TraceN64System, TraceError, "Failed to Allocate RDRAM (Size: 0x%X)", m_AllocatedRdramSize); WriteTrace(TraceN64System, TraceError, "Failed to allocate RDRAM (Size: 0x%X)", m_AllocatedRdramSize);
FreeMemory(); FreeMemory();
return false; return false;
} }
if (CommitMemory(m_RDRAM + 0x04000000, 0x2000, MEM_READWRITE) == nullptr) if (CommitMemory(m_RDRAM + 0x04000000, 0x2000, MEM_READWRITE) == nullptr)
{ {
WriteTrace(TraceN64System, TraceError, "Failed to Allocate DMEM/IMEM (Size: 0x%X)", 0x2000); WriteTrace(TraceN64System, TraceError, "Failed to allocate DMEM/IMEM (Size: 0x%X)", 0x2000);
FreeMemory(); FreeMemory();
return false; return false;
} }
@ -171,7 +171,7 @@ bool CMipsMemoryVM::Initialize(bool SyncSystem)
m_RomSize = g_Rom->GetRomSize(); m_RomSize = g_Rom->GetRomSize();
if (CommitMemory(m_Rom, g_Rom->GetRomSize(), MEM_READWRITE) == nullptr) if (CommitMemory(m_Rom, g_Rom->GetRomSize(), MEM_READWRITE) == nullptr)
{ {
WriteTrace(TraceN64System, TraceError, "Failed to Allocate Rom (Size: 0x%X)", g_Rom->GetRomSize()); WriteTrace(TraceN64System, TraceError, "Failed to allocate ROM (Size: 0x%X)", g_Rom->GetRomSize());
FreeMemory(); FreeMemory();
return false; return false;
} }
@ -186,7 +186,7 @@ bool CMipsMemoryVM::Initialize(bool SyncSystem)
m_RomSize = g_Rom->GetRomSize(); m_RomSize = g_Rom->GetRomSize();
} }
//64DD IPL // 64DD IPL
if (g_DDRom != nullptr) if (g_DDRom != nullptr)
{ {
if (g_Settings->LoadBool(Game_LoadRomToMemory)) if (g_Settings->LoadBool(Game_LoadRomToMemory))
@ -196,7 +196,7 @@ bool CMipsMemoryVM::Initialize(bool SyncSystem)
m_DDRomSize = g_DDRom->GetRomSize(); m_DDRomSize = g_DDRom->GetRomSize();
if (CommitMemory(m_DDRom, g_DDRom->GetRomSize(), MEM_READWRITE) == nullptr) if (CommitMemory(m_DDRom, g_DDRom->GetRomSize(), MEM_READWRITE) == nullptr)
{ {
WriteTrace(TraceN64System, TraceError, "Failed to Allocate Rom (Size: 0x%X)", g_DDRom->GetRomSize()); WriteTrace(TraceN64System, TraceError, "Failed to allocate ROM (Size: 0x%X)", g_DDRom->GetRomSize());
FreeMemory(); FreeMemory();
return false; return false;
} }
@ -217,7 +217,7 @@ bool CMipsMemoryVM::Initialize(bool SyncSystem)
m_TLB_ReadMap = new size_t[0x100000]; m_TLB_ReadMap = new size_t[0x100000];
if (m_TLB_ReadMap == nullptr) if (m_TLB_ReadMap == nullptr)
{ {
WriteTrace(TraceN64System, TraceError, "Failed to Allocate m_TLB_ReadMap (Size: 0x%X)", 0x100000 * sizeof(size_t)); WriteTrace(TraceN64System, TraceError, "Failed to allocate m_TLB_ReadMap (Size: 0x%X)", 0x100000 * sizeof(size_t));
FreeMemory(); FreeMemory();
return false; return false;
} }
@ -225,7 +225,7 @@ bool CMipsMemoryVM::Initialize(bool SyncSystem)
m_TLB_WriteMap = new size_t[0x100000]; m_TLB_WriteMap = new size_t[0x100000];
if (m_TLB_WriteMap == nullptr) if (m_TLB_WriteMap == nullptr)
{ {
WriteTrace(TraceN64System, TraceError, "Failed to Allocate m_TLB_WriteMap (Size: 0x%X)", 0xFFFFF * sizeof(size_t)); WriteTrace(TraceN64System, TraceError, "Failed to allocate m_TLB_WriteMap (Size: 0x%X)", 0xFFFFF * sizeof(size_t));
FreeMemory(); FreeMemory();
return false; return false;
} }
@ -583,7 +583,7 @@ bool CMipsMemoryVM::VAddrToRealAddr(uint32_t VAddr, void * &RealAddress) const
bool CMipsMemoryVM::TranslateVaddr(uint32_t VAddr, uint32_t &PAddr) const bool CMipsMemoryVM::TranslateVaddr(uint32_t VAddr, uint32_t &PAddr) const
{ {
//Change the Virtual address to a Physical Address // Change the virtual address to a physical address
if (m_TLB_ReadMap[VAddr >> 12] == 0) if (m_TLB_ReadMap[VAddr >> 12] == 0)
{ {
return false; return false;
@ -807,7 +807,7 @@ bool CMipsMemoryVM::SW_NonMemory(uint32_t PAddr, uint32_t Value)
VirtualProtect(ROM, RomFileSize, PAGE_NOACCESS, &OldProtect); VirtualProtect(ROM, RomFileSize, PAGE_NOACCESS, &OldProtect);
} }
#endif #endif
//LogMessage("%X: Wrote To Rom %08X from %08X",PROGRAM_COUNTER,Value,PAddr); //LogMessage("%X: Wrote To ROM %08X from %08X",PROGRAM_COUNTER,Value,PAddr);
} }
else else
{ {
@ -916,7 +916,7 @@ void CMipsMemoryVM::ProtectMemory(uint32_t StartVaddr, uint32_t EndVaddr)
return; return;
} }
//Get Physical Addresses passed // Get physical addresses passed
uint32_t StartPAddr, EndPAddr; uint32_t StartPAddr, EndPAddr;
if (!TranslateVaddr(StartVaddr, StartPAddr)) if (!TranslateVaddr(StartVaddr, StartPAddr))
{ {
@ -927,14 +927,14 @@ void CMipsMemoryVM::ProtectMemory(uint32_t StartVaddr, uint32_t EndVaddr)
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
} }
//Get Length of memory being protected // Get length of memory being protected
int32_t Length = ((EndPAddr + 3) - StartPAddr) & ~3; int32_t Length = ((EndPAddr + 3) - StartPAddr) & ~3;
if (Length < 0) if (Length < 0)
{ {
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
} }
//Protect that memory address space // Protect that memory address space
uint8_t * MemLoc = Rdram() + StartPAddr; uint8_t * MemLoc = Rdram() + StartPAddr;
WriteTrace(TraceProtectedMem, TraceDebug, "Paddr: %08X Length: %X", StartPAddr, Length); WriteTrace(TraceProtectedMem, TraceDebug, "Paddr: %08X Length: %X", StartPAddr, Length);
@ -946,7 +946,7 @@ void CMipsMemoryVM::UnProtectMemory(uint32_t StartVaddr, uint32_t EndVaddr)
WriteTrace(TraceProtectedMem, TraceDebug, "StartVaddr: %08X EndVaddr: %08X", StartVaddr, EndVaddr); WriteTrace(TraceProtectedMem, TraceDebug, "StartVaddr: %08X EndVaddr: %08X", StartVaddr, EndVaddr);
if (!ValidVaddr(StartVaddr) || !ValidVaddr(EndVaddr)) { return; } if (!ValidVaddr(StartVaddr) || !ValidVaddr(EndVaddr)) { return; }
//Get Physical Addresses passed // Get physical addresses passed
uint32_t StartPAddr, EndPAddr; uint32_t StartPAddr, EndPAddr;
if (!TranslateVaddr(StartVaddr, StartPAddr)) if (!TranslateVaddr(StartVaddr, StartPAddr))
{ {
@ -957,7 +957,7 @@ void CMipsMemoryVM::UnProtectMemory(uint32_t StartVaddr, uint32_t EndVaddr)
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
} }
//Get Length of memory being protected // Get length of memory being protected
int32_t Length = ((EndPAddr + 3) - StartPAddr) & ~3; int32_t Length = ((EndPAddr + 3) - StartPAddr) & ~3;
if (Length < 0) if (Length < 0)
{ {
@ -1028,15 +1028,15 @@ void CMipsMemoryVM::RdramChanged(CMipsMemoryVM * _this)
void * result = CommitMemory(_this->m_RDRAM + old_size, new_size - old_size, MEM_READWRITE); void * result = CommitMemory(_this->m_RDRAM + old_size, new_size - old_size, MEM_READWRITE);
if (result == nullptr) if (result == nullptr)
{ {
WriteTrace(TraceN64System, TraceError, "failed to allocate extended memory"); WriteTrace(TraceN64System, TraceError, "Failed to allocate extended memory");
g_Notify->FatalError(GS(MSG_MEM_ALLOC_ERROR)); g_Notify->FatalError(GS(MSG_MEM_ALLOC_ERROR));
} }
} }
if (new_size > 0xFFFFFFFFul) if (new_size > 0xFFFFFFFFul)
{ // should be unreachable because: size_t new_size = g_Settings->(uint32_t) { // Should be unreachable because: size_t new_size = g_Settings->(uint32_t)
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
} // ...However, FFFFFFFF also is a limit to RCP addressing, so we care. } // However, FFFFFFFF also is a limit to RCP addressing, so we care
_this->m_AllocatedRdramSize = (uint32_t)new_size; _this->m_AllocatedRdramSize = (uint32_t)new_size;
} }
@ -1432,7 +1432,7 @@ void CMipsMemoryVM::Load32SerialInterface(void)
void CMipsMemoryVM::Load32CartridgeDomain1Address1(void) void CMipsMemoryVM::Load32CartridgeDomain1Address1(void)
{ {
//64DD IPL ROM // 64DD IPL ROM
if (g_DDRom != nullptr && (m_MemLookupAddress & 0xFFFFFF) < g_MMU->m_DDRomSize) if (g_DDRom != nullptr && (m_MemLookupAddress & 0xFFFFFF) < g_MMU->m_DDRomSize)
{ {
m_MemLookupValue.UW[0] = *(uint32_t *)&g_MMU->m_DDRom[(m_MemLookupAddress & 0xFFFFFF)]; m_MemLookupValue.UW[0] = *(uint32_t *)&g_MMU->m_DDRom[(m_MemLookupAddress & 0xFFFFFF)];
@ -1452,7 +1452,7 @@ void CMipsMemoryVM::Load32CartridgeDomain1Address3(void)
void CMipsMemoryVM::Load32CartridgeDomain2Address1(void) void CMipsMemoryVM::Load32CartridgeDomain2Address1(void)
{ {
//64DD REGISTERS // 64DD registers
if (g_Settings->LoadBool(Setting_EnableDisk)) if (g_Settings->LoadBool(Setting_EnableDisk))
{ {
switch (m_MemLookupAddress & 0x1FFFFFFF) switch (m_MemLookupAddress & 0x1FFFFFFF)
@ -1509,7 +1509,7 @@ void CMipsMemoryVM::Load32CartridgeDomain2Address2(void)
} }
if (g_System->m_SaveUsing == SaveChip_Sram) if (g_System->m_SaveUsing == SaveChip_Sram)
{ {
//Load Sram // Load SRAM
uint8_t tmp[4] = ""; uint8_t tmp[4] = "";
g_MMU->DmaFromSram(tmp, offset, 4); g_MMU->DmaFromSram(tmp, offset, 4);
m_MemLookupValue.UW[0] = tmp[3] << 24 | tmp[2] << 16 | tmp[1] << 8 | tmp[0]; m_MemLookupValue.UW[0] = tmp[3] << 24 | tmp[2] << 16 | tmp[1] << 8 | tmp[0];
@ -1561,7 +1561,7 @@ void CMipsMemoryVM::Load32Rom(void)
if (g_MMU->m_RomWrittenTo) if (g_MMU->m_RomWrittenTo)
{ {
m_MemLookupValue.UW[0] = g_MMU->m_RomWroteValue; m_MemLookupValue.UW[0] = g_MMU->m_RomWroteValue;
//LogMessage("%X: Read crap from Rom %08X from %08X",PROGRAM_COUNTER,*Value,PAddr); //LogMessage("%X: Read crap from ROM %08X from %08X",PROGRAM_COUNTER,*Value,PAddr);
g_MMU->m_RomWrittenTo = false; g_MMU->m_RomWrittenTo = false;
#ifdef ROM_IN_MAPSPACE #ifdef ROM_IN_MAPSPACE
{ {
@ -2021,7 +2021,7 @@ void CMipsMemoryVM::Write32AudioInterface(void)
break; break;
case 0x04500008: g_Reg->AI_CONTROL_REG = (m_MemLookupValue.UW[0] & 1); break; case 0x04500008: g_Reg->AI_CONTROL_REG = (m_MemLookupValue.UW[0] & 1); break;
case 0x0450000C: case 0x0450000C:
/* Clear Interrupt */; // Clear interrupt
g_Reg->MI_INTR_REG &= ~MI_INTR_AI; g_Reg->MI_INTR_REG &= ~MI_INTR_AI;
g_Reg->m_AudioIntrReg &= ~MI_INTR_AI; g_Reg->m_AudioIntrReg &= ~MI_INTR_AI;
g_Reg->CheckInterrupts(); g_Reg->CheckInterrupts();
@ -2138,7 +2138,7 @@ void CMipsMemoryVM::Write32SerialInterface(void)
void CMipsMemoryVM::Write32CartridgeDomain2Address1(void) void CMipsMemoryVM::Write32CartridgeDomain2Address1(void)
{ {
//64DD Registers // 64DD registers
if (g_Settings->LoadBool(Setting_EnableDisk)) if (g_Settings->LoadBool(Setting_EnableDisk))
{ {
switch (m_MemLookupAddress & 0xFFFFFFF) switch (m_MemLookupAddress & 0xFFFFFFF)
@ -2174,7 +2174,7 @@ void CMipsMemoryVM::Write32CartridgeDomain2Address2(void)
uint32_t offset = (m_MemLookupAddress & 0x1FFFFFFF) - 0x08000000; uint32_t offset = (m_MemLookupAddress & 0x1FFFFFFF) - 0x08000000;
if (g_System->m_SaveUsing == SaveChip_Sram && offset < 0x8000) if (g_System->m_SaveUsing == SaveChip_Sram && offset < 0x8000)
{ {
//Store Sram // Store SRAM
uint8_t tmp[4] = ""; uint8_t tmp[4] = "";
tmp[0] = 0xFF & (m_MemLookupValue.UW[0]); tmp[0] = 0xFF & (m_MemLookupValue.UW[0]);
tmp[1] = 0xFF & (m_MemLookupValue.UW[0] >> 8); tmp[1] = 0xFF & (m_MemLookupValue.UW[0] >> 8);

View File

@ -14,14 +14,14 @@
#ifndef _WIN32 #ifndef _WIN32
#include <signal.h> #include <signal.h>
/* siginfo_t */ // siginfo_t
#endif #endif
/* /*
* To do: Have address translation functions here? * TODO: Have address translation functions here?
* `return` either the translated address or the mask to XOR by? * `return` either the translated address or the mask to XOR by?
* *
* This will help us gradually be able to port Project64 for big-endian CPUs. * This will help us gradually be able to port Project64 to big-endian CPUs.
* Currently it is written to assume 32-bit little-endian, like so: * Currently it is written to assume 32-bit little-endian, like so:
* *
* 0xAABBCCDD EEFFGGHH --> 0xDDCCBBAA HHGGFFEE * 0xAABBCCDD EEFFGGHH --> 0xDDCCBBAA HHGGFFEE
@ -88,11 +88,11 @@ public:
static void segv_handler(int signal, siginfo_t *siginfo, void *sigcontext); static void segv_handler(int signal, siginfo_t *siginfo, void *sigcontext);
#endif #endif
//Protect the Memory from being written to // Protect the memory from being written to
void ProtectMemory(uint32_t StartVaddr, uint32_t EndVaddr); void ProtectMemory(uint32_t StartVaddr, uint32_t EndVaddr);
void UnProtectMemory(uint32_t StartVaddr, uint32_t EndVaddr); void UnProtectMemory(uint32_t StartVaddr, uint32_t EndVaddr);
//Functions for TLB notification // Functions for TLB notification
void TLB_Mapped(uint32_t VAddr, uint32_t Len, uint32_t PAddr, bool bReadOnly); void TLB_Mapped(uint32_t VAddr, uint32_t Len, uint32_t PAddr, bool bReadOnly);
void TLB_Unmaped(uint32_t Vaddr, uint32_t Len); void TLB_Unmaped(uint32_t Vaddr, uint32_t Len);
@ -179,35 +179,35 @@ private:
static bool FilterArmException(uint32_t MemAddress, mcontext_t & context); static bool FilterArmException(uint32_t MemAddress, mcontext_t & context);
#endif #endif
//Memory Locations // Memory locations
static uint8_t * m_Reserve1, *m_Reserve2; static uint8_t * m_Reserve1, *m_Reserve2;
uint8_t * m_RDRAM, *m_DMEM, *m_IMEM; uint8_t * m_RDRAM, *m_DMEM, *m_IMEM;
uint32_t m_AllocatedRdramSize; uint32_t m_AllocatedRdramSize;
//Rom Information // ROM information
bool m_RomMapped; bool m_RomMapped;
uint8_t * m_Rom; uint8_t * m_Rom;
uint32_t m_RomSize; uint32_t m_RomSize;
bool m_RomWrittenTo; bool m_RomWrittenTo;
uint32_t m_RomWroteValue; uint32_t m_RomWroteValue;
//DDRom Information // DDRom information
bool m_DDRomMapped; bool m_DDRomMapped;
uint8_t * m_DDRom; uint8_t * m_DDRom;
uint32_t m_DDRomSize; uint32_t m_DDRomSize;
//Current Half line //Current half line
void UpdateHalfLine(); void UpdateHalfLine();
uint32_t m_HalfLine; uint32_t m_HalfLine;
uint32_t m_HalfLineCheck; uint32_t m_HalfLineCheck;
uint32_t m_FieldSerration; uint32_t m_FieldSerration;
//Initializing and resetting information about the memory system // Initializing and resetting information about the memory system
void FreeMemory(); void FreeMemory();
mutable char m_strLabelName[100]; mutable char m_strLabelName[100];
//BIG look up table to quickly translate the tlb to real mem address // Big look up table to quickly translate the TLB to real memory addresses
size_t * m_TLB_ReadMap; size_t * m_TLB_ReadMap;
size_t * m_TLB_WriteMap; size_t * m_TLB_WriteMap;

View File

@ -165,7 +165,7 @@ void CMempak::ReadFrom(int32_t Control, uint32_t address, uint8_t * data)
else else
{ {
memset(data, 0x00, 0x20); memset(data, 0x00, 0x20);
/* Rumble pack area */ // Rumble pack area
} }
} }
@ -192,6 +192,6 @@ void CMempak::WriteTo(int32_t Control, uint32_t address, uint8_t * data)
} }
else else
{ {
/* Rumble pack area */ // Rumble pack area
} }
} }

View File

@ -557,7 +557,7 @@ const char * R4300iOpcodeName(uint32_t OpCode, uint32_t PC)
sprintf(CommandName, "ADDI\t%s, %s, 0x%04X", CRegName::GPR[command.rt], CRegName::GPR[command.rs], command.immediate); sprintf(CommandName, "ADDI\t%s, %s, 0x%04X", CRegName::GPR[command.rt], CRegName::GPR[command.rs], command.immediate);
break; break;
case R4300i_ADDIU: case R4300i_ADDIU:
// special case for stack // Special case for stack
if (command.rt == 29) if (command.rt == 29)
{ {
short imm = (short)command.immediate; short imm = (short)command.immediate;

View File

@ -84,7 +84,7 @@ void CPifRam::PifRamRead()
case 0xFD: CurPos = 0x40; break; case 0xFD: CurPos = 0x40; break;
case 0xFE: CurPos = 0x40; break; case 0xFE: CurPos = 0x40; break;
case 0xFF: break; case 0xFF: break;
case 0xB4: case 0x56: case 0xB8: break; /* ??? */ case 0xB4: case 0x56: case 0xB8: break;
default: default:
if ((m_PifRam[CurPos] & 0xC0) == 0) if ((m_PifRam[CurPos] & 0xC0) == 0)
{ {
@ -109,7 +109,7 @@ void CPifRam::PifRamRead()
{ {
if (CurPos != 0x27 && bShowPifRamErrors()) if (CurPos != 0x27 && bShowPifRamErrors())
{ {
g_Notify->DisplayError(stdstr_f("Unknown Command in PifRamRead(%X)", m_PifRam[CurPos]).c_str()); g_Notify->DisplayError(stdstr_f("Unknown command in PifRamRead(%X)", m_PifRam[CurPos]).c_str());
} }
CurPos = 0x40; CurPos = 0x40;
} }
@ -132,7 +132,7 @@ void CPifRam::PifRamWrite()
switch (m_PifRam[0x3F]) switch (m_PifRam[0x3F])
{ {
case 0x02: case 0x02:
// format the 'challenge' message into 30 nibbles for X-Scale's CIC code // Format the 'challenge' message into 30 nibbles for X-Scale's CIC code
{ {
char Challenge[30], Response[30]; char Challenge[30], Response[30];
for (int32_t i = 0; i < 15; i++) for (int32_t i = 0; i < 15; i++)
@ -174,7 +174,7 @@ void CPifRam::PifRamWrite()
default: default:
if (bShowPifRamErrors()) if (bShowPifRamErrors())
{ {
g_Notify->DisplayError(stdstr_f("Unkown PifRam control: %d", m_PifRam[0x3F]).c_str()); g_Notify->DisplayError(stdstr_f("Unknown PifRam control: %d", m_PifRam[0x3F]).c_str());
} }
} }
return; return;
@ -194,7 +194,7 @@ void CPifRam::PifRamWrite()
case 0xFD: CurPos = 0x40; break; case 0xFD: CurPos = 0x40; break;
case 0xFE: CurPos = 0x40; break; case 0xFE: CurPos = 0x40; break;
case 0xFF: break; case 0xFF: break;
case 0xB4: case 0x56: case 0xB8: break; /* ??? */ case 0xB4: case 0x56: case 0xB8: break; // ???
default: default:
if ((m_PifRam[CurPos] & 0xC0) == 0) if ((m_PifRam[CurPos] & 0xC0) == 0)
{ {
@ -254,7 +254,7 @@ void CPifRam::SI_DMA_READ()
{ {
if (bShowPifRamErrors()) if (bShowPifRamErrors())
{ {
g_Notify->DisplayError(stdstr_f("%s\nSI_DRAM_ADDR_REG not in RDRam space", __FUNCTION__).c_str()); g_Notify->DisplayError(stdstr_f("%s\nSI_DRAM_ADDR_REG not in RDRAM space", __FUNCTION__).c_str());
} }
return; return;
} }
@ -354,7 +354,7 @@ void CPifRam::SI_DMA_WRITE()
{ {
if (bShowPifRamErrors()) if (bShowPifRamErrors())
{ {
g_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;
} }
@ -388,7 +388,7 @@ void CPifRam::SI_DMA_WRITE()
int32_t count; int32_t count;
char HexData[100], AsciiData[100], Addon[20]; char HexData[100], AsciiData[100], Addon[20];
LogMessage(""); LogMessage("");
LogMessage("\tData DMAed to the Pif Ram:"); LogMessage("\tData DMAed to the PIF RAM:");
LogMessage("\t--------------------------"); LogMessage("\t--------------------------");
for (count = 0; count < 16; count++) for (count = 0; count < 16; count++)
{ {
@ -440,8 +440,8 @@ void CPifRam::ProcessControllerCommand(int32_t Control, uint8_t * Command)
switch (Command[2]) switch (Command[2])
{ {
case 0x00: // check case 0x00: // Check
case 0xFF: // reset & check ? case 0xFF: // Reset and check?
if ((Command[1] & 0x80) != 0) if ((Command[1] & 0x80) != 0)
{ {
break; break;
@ -450,7 +450,7 @@ void CPifRam::ProcessControllerCommand(int32_t Control, uint8_t * Command)
{ {
if (Command[0] != 1 || Command[1] != 3) if (Command[0] != 1 || Command[1] != 3)
{ {
g_Notify->DisplayError("What am I meant to do with this Controller Command"); g_Notify->DisplayError("What am I meant to do with this controller command?");
} }
} }
if (Controllers[Control].Present != 0) if (Controllers[Control].Present != 0)
@ -472,12 +472,12 @@ void CPifRam::ProcessControllerCommand(int32_t Control, uint8_t * Command)
Command[1] |= 0x80; Command[1] |= 0x80;
} }
break; break;
case 0x01: // read controller case 0x01: // Read controller
if (bShowPifRamErrors()) if (bShowPifRamErrors())
{ {
if (Command[0] != 1 || Command[1] != 4) if (Command[0] != 1 || Command[1] != 4)
{ {
g_Notify->DisplayError("What am I meant to do with this Controller Command"); g_Notify->DisplayError("What am I meant to do with this controller command?");
} }
} }
if (Controllers[Control].Present == false) if (Controllers[Control].Present == false)
@ -485,16 +485,16 @@ void CPifRam::ProcessControllerCommand(int32_t Control, uint8_t * Command)
Command[1] |= 0x80; Command[1] |= 0x80;
} }
break; break;
case 0x02: //read from controller pack case 0x02: // Read from controller pak
if (LogControllerPak()) if (LogControllerPak())
{ {
LogControllerPakData("Read: Before Gettting Results"); LogControllerPakData("Read: before getting results");
} }
if (bShowPifRamErrors()) if (bShowPifRamErrors())
{ {
if (Command[0] != 3 || Command[1] != 33) if (Command[0] != 3 || Command[1] != 33)
{ {
g_Notify->DisplayError("What am I meant to do with this Controller Command"); g_Notify->DisplayError("What am I meant to do with this controller command?");
} }
} }
if (Controllers[Control].Present != 0) if (Controllers[Control].Present != 0)
@ -523,19 +523,19 @@ void CPifRam::ProcessControllerCommand(int32_t Control, uint8_t * Command)
} }
if (LogControllerPak()) if (LogControllerPak())
{ {
LogControllerPakData("Read: After Gettting Results"); LogControllerPakData("Read: after getting results");
} }
break; break;
case 0x03: //write controller pak case 0x03: // Write controller pak
if (LogControllerPak()) if (LogControllerPak())
{ {
LogControllerPakData("Write: Before Processing"); LogControllerPakData("Write: before processing");
} }
if (bShowPifRamErrors()) if (bShowPifRamErrors())
{ {
if (Command[0] != 35 || Command[1] != 1) if (Command[0] != 35 || Command[1] != 1)
{ {
g_Notify->DisplayError("What am I meant to do with this Controller Command"); g_Notify->DisplayError("What am I meant to do with this controller command?");
} }
} }
if (Controllers[Control].Present != 0) if (Controllers[Control].Present != 0)
@ -562,7 +562,7 @@ void CPifRam::ProcessControllerCommand(int32_t Control, uint8_t * Command)
} }
if (LogControllerPak()) if (LogControllerPak())
{ {
LogControllerPakData("Write: After Processing"); LogControllerPakData("Write: after processing");
} }
break; break;
default: default:
@ -579,19 +579,19 @@ void CPifRam::ReadControllerCommand(int32_t Control, uint8_t * Command)
switch (Command[2]) switch (Command[2])
{ {
case 0x01: // read controller case 0x01: // Read controller
if (Controllers[Control].Present != 0) if (Controllers[Control].Present != 0)
{ {
if (bShowPifRamErrors()) if (bShowPifRamErrors())
{ {
if (Command[0] != 1 || Command[1] != 4) { g_Notify->DisplayError("What am I meant to do with this Controller Command"); } if (Command[0] != 1 || Command[1] != 4) { g_Notify->DisplayError("What am I meant to do with this controller command?"); }
} }
const uint32_t buttons = g_BaseSystem->GetButtons(Control); const uint32_t buttons = g_BaseSystem->GetButtons(Control);
memcpy(&Command[3], &buttons, sizeof(uint32_t)); memcpy(&Command[3], &buttons, sizeof(uint32_t));
} }
break; break;
case 0x02: //read from controller pack case 0x02: // Read from controller pak
if (Controllers[Control].Present != 0) if (Controllers[Control].Present != 0)
{ {
switch (Controllers[Control].Plugin) switch (Controllers[Control].Plugin)
@ -600,7 +600,7 @@ void CPifRam::ReadControllerCommand(int32_t Control, uint8_t * Command)
} }
} }
break; break;
case 0x03: //write controller pak case 0x03: // Write controller pak
if (Controllers[Control].Present != 0) if (Controllers[Control].Present != 0)
{ {
switch (Controllers[Control].Plugin) switch (Controllers[Control].Plugin)

View File

@ -261,7 +261,7 @@ void CRegisters::Reset()
m_LLBit = 0; m_LLBit = 0;
//Reset System Registers // Reset system registers
memset(m_RDRAM_Interface, 0, sizeof(m_RDRAM_Interface)); memset(m_RDRAM_Interface, 0, sizeof(m_RDRAM_Interface));
memset(m_RDRAM_Registers, 0, sizeof(m_RDRAM_Registers)); memset(m_RDRAM_Registers, 0, sizeof(m_RDRAM_Registers));
memset(m_Mips_Interface, 0, sizeof(m_Mips_Interface)); memset(m_Mips_Interface, 0, sizeof(m_Mips_Interface));
@ -350,11 +350,11 @@ void CRegisters::DoAddressError(bool DelaySlot, uint32_t BadVaddr, bool FromRead
g_Notify->DisplayError(stdstr_f("AddressError %s Vaddr: %X", FromRead ? "reading" : "writing", BadVaddr).c_str()); g_Notify->DisplayError(stdstr_f("AddressError %s Vaddr: %X", FromRead ? "reading" : "writing", BadVaddr).c_str());
if ((STATUS_REGISTER & STATUS_EXL) != 0) if ((STATUS_REGISTER & STATUS_EXL) != 0)
{ {
g_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)
{ {
g_Notify->DisplayError("ERL set in AddressError Exception"); g_Notify->DisplayError("ERL set in AddressError exception");
} }
} }
@ -406,11 +406,11 @@ void CRegisters::DoBreakException(bool DelaySlot)
{ {
if ((STATUS_REGISTER & STATUS_EXL) != 0) if ((STATUS_REGISTER & STATUS_EXL) != 0)
{ {
g_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)
{ {
g_Notify->DisplayError("ERL set in Break Exception"); g_Notify->DisplayError("ERL set in break exception");
} }
} }
@ -450,11 +450,11 @@ void CRegisters::DoCopUnusableException(bool DelaySlot, int32_t Coprocessor)
{ {
if ((STATUS_REGISTER & STATUS_EXL) != 0) if ((STATUS_REGISTER & STATUS_EXL) != 0)
{ {
g_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)
{ {
g_Notify->DisplayError("ERL set in Break Exception"); g_Notify->DisplayError("ERL set in break exception");
} }
} }
@ -495,7 +495,7 @@ bool CRegisters::DoIntrException(bool DelaySlot)
if (GenerateLog() && LogExceptions() && !LogNoInterrupts()) if (GenerateLog() && LogExceptions() && !LogNoInterrupts())
{ {
LogMessage("%08X: Interrupt Generated", m_PROGRAM_COUNTER); LogMessage("%08X: Interrupt generated", m_PROGRAM_COUNTER);
} }
CAUSE_REGISTER = FAKE_CAUSE_REGISTER; CAUSE_REGISTER = FAKE_CAUSE_REGISTER;
@ -548,7 +548,7 @@ void CRegisters::DoTLBReadMiss(bool DelaySlot, uint32_t BadVaddr)
{ {
if (HaveDebugger()) if (HaveDebugger())
{ {
g_Notify->DisplayError(stdstr_f("TLBMiss - EXL Set\nBadVaddr = %X\nAddress Defined: %s", BadVaddr, g_TLB->AddressDefined(BadVaddr) ? "true" : "false").c_str()); g_Notify->DisplayError(stdstr_f("TLBMiss - EXL set\nBadVaddr = %X\nAddress defined: %s", BadVaddr, g_TLB->AddressDefined(BadVaddr) ? "true" : "false").c_str());
} }
m_PROGRAM_COUNTER = 0x80000180; m_PROGRAM_COUNTER = 0x80000180;
} }
@ -586,7 +586,7 @@ void CRegisters::DoTLBWriteMiss(bool DelaySlot, uint32_t BadVaddr)
{ {
if (HaveDebugger()) if (HaveDebugger())
{ {
g_Notify->DisplayError(stdstr_f("TLBMiss - EXL Set\nBadVaddr = %X\nAddress Defined: %s", BadVaddr, g_TLB->AddressDefined(BadVaddr) ? "true" : "false").c_str()); g_Notify->DisplayError(stdstr_f("TLBMiss - EXL set\nBadVaddr = %X\nAddress defined: %s", BadVaddr, g_TLB->AddressDefined(BadVaddr) ? "true" : "false").c_str());
} }
m_PROGRAM_COUNTER = 0x80000180; m_PROGRAM_COUNTER = 0x80000180;
} }
@ -598,11 +598,11 @@ void CRegisters::DoSysCallException(bool DelaySlot)
{ {
if ((STATUS_REGISTER & STATUS_EXL) != 0) if ((STATUS_REGISTER & STATUS_EXL) != 0)
{ {
g_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)
{ {
g_Notify->DisplayError("ERL set in SysCall Exception"); g_Notify->DisplayError("ERL set in syscall exception");
} }
} }

View File

@ -6,7 +6,7 @@
#include <Project64-core/Settings/GameSettings.h> #include <Project64-core/Settings/GameSettings.h>
#include <Project64-core/Logging.h> #include <Project64-core/Logging.h>
//CPO registers by name // CPO registers by name
class CP0registers class CP0registers
{ {
protected: protected:
@ -39,17 +39,17 @@ private:
CP0registers& operator=(const CP0registers&); CP0registers& operator=(const CP0registers&);
}; };
//CPO register flags // CPO register flags
enum enum
{ {
//Status Register // Status register
STATUS_IE = 0x00000001, STATUS_EXL = 0x00000002, STATUS_ERL = 0x00000004, STATUS_IE = 0x00000001, STATUS_EXL = 0x00000002, STATUS_ERL = 0x00000004,
STATUS_IP0 = 0x00000100, STATUS_IP1 = 0x00000200, STATUS_IP2 = 0x00000400, STATUS_IP0 = 0x00000100, STATUS_IP1 = 0x00000200, STATUS_IP2 = 0x00000400,
STATUS_IP3 = 0x00000800, STATUS_IP4 = 0x00001000, STATUS_IP5 = 0x00002000, STATUS_IP3 = 0x00000800, STATUS_IP4 = 0x00001000, STATUS_IP5 = 0x00002000,
STATUS_IP6 = 0x00004000, STATUS_IP7 = 0x00008000, STATUS_BEV = 0x00400000, STATUS_IP6 = 0x00004000, STATUS_IP7 = 0x00008000, STATUS_BEV = 0x00400000,
STATUS_FR = 0x04000000, STATUS_CU0 = 0x10000000, STATUS_CU1 = 0x20000000, STATUS_FR = 0x04000000, STATUS_CU0 = 0x10000000, STATUS_CU1 = 0x20000000,
//Cause Flags // Cause flags
CAUSE_EXC_CODE = 0xFF, CAUSE_EXC_CODE = 0xFF,
CAUSE_IP0 = 0x100, CAUSE_IP0 = 0x100,
CAUSE_IP1 = 0x200, CAUSE_IP1 = 0x200,
@ -61,56 +61,56 @@ enum
CAUSE_IP7 = 0x8000, CAUSE_IP7 = 0x8000,
CAUSE_BD = 0x80000000, CAUSE_BD = 0x80000000,
//Cause exception ID's // Cause exception ID's
EXC_INT = 0, /* interrupt */ EXC_INT = 0, // Interrupt
EXC_MOD = 4, /* TLB mod */ EXC_MOD = 4, // TLB mod
EXC_RMISS = 8, /* Read TLB Miss */ EXC_RMISS = 8, // Read TLB miss
EXC_WMISS = 12, /* Write TLB Miss */ EXC_WMISS = 12, // Write TLB miss
EXC_RADE = 16, /* Read Address Error */ EXC_RADE = 16, // Read address error
EXC_WADE = 20, /* Write Address Error */ EXC_WADE = 20, // Write address error
EXC_IBE = 24, /* Instruction Bus Error */ EXC_IBE = 24, // Instruction bus error
EXC_DBE = 28, /* Data Bus Error */ EXC_DBE = 28, // Data bus error
EXC_SYSCALL = 32, /* SYSCALL */ EXC_SYSCALL = 32, // Syscall
EXC_BREAK = 36, /* BREAKpoint */ EXC_BREAK = 36, // Breakpoint
EXC_II = 40, /* Illegal Instruction */ EXC_II = 40, // Illegal instruction
EXC_CPU = 44, /* CoProcessor Unusable */ EXC_CPU = 44, // Co-processor unusable
EXC_OV = 48, /* OVerflow */ EXC_OV = 48, // Overflow
EXC_TRAP = 52, /* Trap exception */ EXC_TRAP = 52, // Trap exception
EXC_VCEI = 56, /* Virt. Coherency on Inst. fetch */ EXC_VCEI = 56, // Virtual coherency on instruction fetch
EXC_FPE = 60, /* Floating Point Exception */ EXC_FPE = 60, // Floating point exception
EXC_WATCH = 92, /* Watchpoint reference */ EXC_WATCH = 92, // Watchpoint reference
EXC_VCED = 124,/* Virt. Coherency on data read */ EXC_VCED = 124, // Virtual coherency on data read
}; };
//Float point control status register flags // Float point control status register flags
enum enum
{ {
FPCSR_FS = 0x01000000, /* flush denorm to zero */ FPCSR_FS = 0x01000000, // Flush denormalization to zero
FPCSR_C = 0x00800000, /* condition bit */ FPCSR_C = 0x00800000, // Condition bit
FPCSR_CE = 0x00020000, /* cause: unimplemented operation */ FPCSR_CE = 0x00020000, // Cause: unimplemented operation
FPCSR_CV = 0x00010000, /* cause: invalid operation */ FPCSR_CV = 0x00010000, // Cause: invalid operation
FPCSR_CZ = 0x00008000, /* cause: division by zero */ FPCSR_CZ = 0x00008000, // Cause: division by zero
FPCSR_CO = 0x00004000, /* cause: overflow */ FPCSR_CO = 0x00004000, // Cause: overflow
FPCSR_CU = 0x00002000, /* cause: underflow */ FPCSR_CU = 0x00002000, // Cause: underflow
FPCSR_CI = 0x00001000, /* cause: inexact operation */ FPCSR_CI = 0x00001000, // Cause: inexact operation
FPCSR_EV = 0x00000800, /* enable: invalid operation */ FPCSR_EV = 0x00000800, // Enable: invalid operation
FPCSR_EZ = 0x00000400, /* enable: division by zero */ FPCSR_EZ = 0x00000400, // Enable: division by zero
FPCSR_EO = 0x00000200, /* enable: overflow */ FPCSR_EO = 0x00000200, // Enable: overflow
FPCSR_EU = 0x00000100, /* enable: underflow */ FPCSR_EU = 0x00000100, // Enable: underflow
FPCSR_EI = 0x00000080, /* enable: inexact operation */ FPCSR_EI = 0x00000080, // Enable: inexact operation
FPCSR_FV = 0x00000040, /* flag: invalid operation */ FPCSR_FV = 0x00000040, // Flag: invalid operation
FPCSR_FZ = 0x00000020, /* flag: division by zero */ FPCSR_FZ = 0x00000020, // Flag: division by zero
FPCSR_FO = 0x00000010, /* flag: overflow */ FPCSR_FO = 0x00000010, // Flag: overflow
FPCSR_FU = 0x00000008, /* flag: underflow */ FPCSR_FU = 0x00000008, // Flag: underflow
FPCSR_FI = 0x00000004, /* flag: inexact operation */ FPCSR_FI = 0x00000004, // Flag: inexact operation
FPCSR_RM_MASK = 0x00000003, /* rounding mode mask */ FPCSR_RM_MASK = 0x00000003, // Rounding mode mask
FPCSR_RM_RN = 0x00000000, /* round to nearest */ FPCSR_RM_RN = 0x00000000, // Round to nearest
FPCSR_RM_RZ = 0x00000001, /* round to zero */ FPCSR_RM_RZ = 0x00000001, // Round to zero
FPCSR_RM_RP = 0x00000002, /* round to positive infinity */ FPCSR_RM_RP = 0x00000002, // Round to positive infinity
FPCSR_RM_RM = 0x00000003, /* round to negative infinity */ FPCSR_RM_RM = 0x00000003, // Round to negative infinity
}; };
//Rdram Registers // RDRAM registers
class Rdram_InterfaceReg class Rdram_InterfaceReg
{ {
protected: protected:
@ -135,7 +135,7 @@ private:
Rdram_InterfaceReg& operator=(const Rdram_InterfaceReg&); Rdram_InterfaceReg& operator=(const Rdram_InterfaceReg&);
}; };
//Mips interface registers // MIPS interface registers
class Mips_InterfaceReg class Mips_InterfaceReg
{ {
protected: protected:
@ -155,52 +155,52 @@ private:
Mips_InterfaceReg& operator=(const Mips_InterfaceReg&); Mips_InterfaceReg& operator=(const Mips_InterfaceReg&);
}; };
//Mips interface flags // MIPS interface flags
enum enum
{ {
MI_MODE_INIT = 0x0080, /* Bit 7: init mode */ MI_MODE_INIT = 0x0080, // Bit 7: Initialization mode
MI_MODE_EBUS = 0x0100, /* Bit 8: ebus test mode */ MI_MODE_EBUS = 0x0100, // Bit 8: EBUS test mode
MI_MODE_RDRAM = 0x0200, /* Bit 9: RDRAM reg mode */ MI_MODE_RDRAM = 0x0200, // Bit 9: RDRAM register mode
MI_CLR_INIT = 0x0080, /* Bit 7: clear init mode */ MI_CLR_INIT = 0x0080, // Bit 7: Clear initialization mode
MI_SET_INIT = 0x0100, /* Bit 8: set init mode */ MI_SET_INIT = 0x0100, // Bit 8: Set initialization mode
MI_CLR_EBUS = 0x0200, /* Bit 9: clear ebus test */ MI_CLR_EBUS = 0x0200, // Bit 9: Clear EBUS test
MI_SET_EBUS = 0x0400, /* Bit 10: set ebus test mode */ MI_SET_EBUS = 0x0400, // Bit 10: Set EBUS test mode
MI_CLR_DP_INTR = 0x0800, /* Bit 11: clear dp interrupt */ MI_CLR_DP_INTR = 0x0800, // Bit 11: Clear DP interrupt
MI_CLR_RDRAM = 0x1000, /* Bit 12: clear RDRAM reg */ MI_CLR_RDRAM = 0x1000, // Bit 12: Clear RDRAM register
MI_SET_RDRAM = 0x2000, /* Bit 13: set RDRAM reg mode */ MI_SET_RDRAM = 0x2000, // Bit 13: Set RDRAM register mode
//Flags for writing to MI_INTR_MASK_REG // Flags for writing to MI_INTR_MASK_REG
MI_INTR_MASK_CLR_SP = 0x0001, /* Bit 0: clear SP mask */ MI_INTR_MASK_CLR_SP = 0x0001, // Bit 0: Clear SP mask
MI_INTR_MASK_SET_SP = 0x0002, /* Bit 1: set SP mask */ MI_INTR_MASK_SET_SP = 0x0002, // Bit 1: Set SP mask
MI_INTR_MASK_CLR_SI = 0x0004, /* Bit 2: clear SI mask */ MI_INTR_MASK_CLR_SI = 0x0004, // Bit 2: Clear SI mask
MI_INTR_MASK_SET_SI = 0x0008, /* Bit 3: set SI mask */ MI_INTR_MASK_SET_SI = 0x0008, // Bit 3: Set SI mask
MI_INTR_MASK_CLR_AI = 0x0010, /* Bit 4: clear AI mask */ MI_INTR_MASK_CLR_AI = 0x0010, // Bit 4: Clear AI mask
MI_INTR_MASK_SET_AI = 0x0020, /* Bit 5: set AI mask */ MI_INTR_MASK_SET_AI = 0x0020, // Bit 5: Set AI mask
MI_INTR_MASK_CLR_VI = 0x0040, /* Bit 6: clear VI mask */ MI_INTR_MASK_CLR_VI = 0x0040, // Bit 6: Clear VI mask
MI_INTR_MASK_SET_VI = 0x0080, /* Bit 7: set VI mask */ MI_INTR_MASK_SET_VI = 0x0080, // Bit 7: Set VI mask
MI_INTR_MASK_CLR_PI = 0x0100, /* Bit 8: clear PI mask */ MI_INTR_MASK_CLR_PI = 0x0100, // Bit 8: Clear PI mask
MI_INTR_MASK_SET_PI = 0x0200, /* Bit 9: set PI mask */ MI_INTR_MASK_SET_PI = 0x0200, // Bit 9: Set PI mask
MI_INTR_MASK_CLR_DP = 0x0400, /* Bit 10: clear DP mask */ MI_INTR_MASK_CLR_DP = 0x0400, // Bit 10: Clear DP mask
MI_INTR_MASK_SET_DP = 0x0800, /* Bit 11: set DP mask */ MI_INTR_MASK_SET_DP = 0x0800, // Bit 11: Set DP mask
//Flags for reading from MI_INTR_MASK_REG // Flags for reading from MI_INTR_MASK_REG
MI_INTR_MASK_SP = 0x01, /* Bit 0: SP intr mask */ MI_INTR_MASK_SP = 0x01, // Bit 0: SP INTR mask
MI_INTR_MASK_SI = 0x02, /* Bit 1: SI intr mask */ MI_INTR_MASK_SI = 0x02, // Bit 1: SI INTR mask
MI_INTR_MASK_AI = 0x04, /* Bit 2: AI intr mask */ MI_INTR_MASK_AI = 0x04, // Bit 2: AI INTR mask
MI_INTR_MASK_VI = 0x08, /* Bit 3: VI intr mask */ MI_INTR_MASK_VI = 0x08, // Bit 3: VI INTR mask
MI_INTR_MASK_PI = 0x10, /* Bit 4: PI intr mask */ MI_INTR_MASK_PI = 0x10, // Bit 4: PI INTR mask
MI_INTR_MASK_DP = 0x20, /* Bit 5: DP intr mask */ MI_INTR_MASK_DP = 0x20, // Bit 5: DP INTR mask
MI_INTR_SP = 0x01, /* Bit 0: SP intr */ MI_INTR_SP = 0x01, // Bit 0: SP INTR
MI_INTR_SI = 0x02, /* Bit 1: SI intr */ MI_INTR_SI = 0x02, // Bit 1: SI INTR
MI_INTR_AI = 0x04, /* Bit 2: AI intr */ MI_INTR_AI = 0x04, // Bit 2: AI INTR
MI_INTR_VI = 0x08, /* Bit 3: VI intr */ MI_INTR_VI = 0x08, // Bit 3: VI INTR
MI_INTR_PI = 0x10, /* Bit 4: PI intr */ MI_INTR_PI = 0x10, // Bit 4: PI INTR
MI_INTR_DP = 0x20, /* Bit 5: DP intr */ MI_INTR_DP = 0x20, // Bit 5: DP INTR
}; };
//Mips interface registers // MIPS interface registers
class Video_InterfaceReg class Video_InterfaceReg
{ {
protected: protected:
@ -237,7 +237,7 @@ private:
Video_InterfaceReg& operator=(const Video_InterfaceReg&); Video_InterfaceReg& operator=(const Video_InterfaceReg&);
}; };
//Display Processor Control Registers // Display processor control registers
class DisplayControlReg class DisplayControlReg
{ {
protected: protected:
@ -261,33 +261,31 @@ private:
enum enum
{ {
DPC_CLR_XBUS_DMEM_DMA = 0x0001, /* Bit 0: clear xbus_dmem_dma */ DPC_CLR_XBUS_DMEM_DMA = 0x0001, // Bit 0: Clear xbus_dmem_dma
DPC_SET_XBUS_DMEM_DMA = 0x0002, /* Bit 1: set xbus_dmem_dma */ DPC_SET_XBUS_DMEM_DMA = 0x0002, // Bit 1: Set xbus_dmem_dma
DPC_CLR_FREEZE = 0x0004, /* Bit 2: clear freeze */ DPC_CLR_FREEZE = 0x0004, // Bit 2: Clear freeze
DPC_SET_FREEZE = 0x0008, /* Bit 3: set freeze */ DPC_SET_FREEZE = 0x0008, // Bit 3: Set freeze
DPC_CLR_FLUSH = 0x0010, /* Bit 4: clear flush */ DPC_CLR_FLUSH = 0x0010, // Bit 4: Clear flush
DPC_SET_FLUSH = 0x0020, /* Bit 5: set flush */ DPC_SET_FLUSH = 0x0020, // Bit 5: Set flush
DPC_CLR_TMEM_CTR = 0x0040, /* Bit 6: clear tmem ctr */ DPC_CLR_TMEM_CTR = 0x0040, // Bit 6: Clear TMEM CTR
DPC_CLR_PIPE_CTR = 0x0080, /* Bit 7: clear pipe ctr */ DPC_CLR_PIPE_CTR = 0x0080, // Bit 7: Clear pipe CTR
DPC_CLR_CMD_CTR = 0x0100, /* Bit 8: clear cmd ctr */ DPC_CLR_CMD_CTR = 0x0100, // Bit 8: Clear CMD CTR
DPC_CLR_CLOCK_CTR = 0x0200, /* Bit 9: clear clock ctr */ DPC_CLR_CLOCK_CTR = 0x0200, // Bit 9: Clear clock CTR
DPC_STATUS_XBUS_DMEM_DMA = 0x001, /* Bit 0: xbus_dmem_dma */ DPC_STATUS_XBUS_DMEM_DMA = 0x001, // Bit 0: xbus_dmem_dma
DPC_STATUS_FREEZE = 0x002, /* Bit 1: freeze */ DPC_STATUS_FREEZE = 0x002, // Bit 1: Freeze
DPC_STATUS_FLUSH = 0x004, /* Bit 2: flush */ DPC_STATUS_FLUSH = 0x004, // Bit 2: Flush
DPC_STATUS_START_GCLK = 0x008, /* Bit 3: start gclk */ DPC_STATUS_START_GCLK = 0x008, // Bit 3: Start GCLK
DPC_STATUS_TMEM_BUSY = 0x010, /* Bit 4: tmem busy */ DPC_STATUS_TMEM_BUSY = 0x010, // Bit 4: TMEM busy
DPC_STATUS_PIPE_BUSY = 0x020, /* Bit 5: pipe busy */ DPC_STATUS_PIPE_BUSY = 0x020, // Bit 5: Pipe busy
DPC_STATUS_CMD_BUSY = 0x040, /* Bit 6: cmd busy */ DPC_STATUS_CMD_BUSY = 0x040, // Bit 6: CMD busy
DPC_STATUS_CBUF_READY = 0x080, /* Bit 7: cbuf ready */ DPC_STATUS_CBUF_READY = 0x080, // Bit 7: CBUF ready
DPC_STATUS_DMA_BUSY = 0x100, /* Bit 8: dma busy */ DPC_STATUS_DMA_BUSY = 0x100, // Bit 8: DMA busy
DPC_STATUS_END_VALID = 0x200, /* Bit 9: end valid */ DPC_STATUS_END_VALID = 0x200, // Bit 9: End valid
DPC_STATUS_START_VALID = 0x400, /* Bit 10: start valid */ DPC_STATUS_START_VALID = 0x400, // Bit 10: Start valid
}; };
/* // Audio interface registers
//Audio Interface registers;
*/
class AudioInterfaceReg class AudioInterfaceReg
{ {
protected: protected:
@ -309,11 +307,11 @@ private:
enum enum
{ {
AI_STATUS_FIFO_FULL = 0x80000000, /* Bit 31: full */ AI_STATUS_FIFO_FULL = 0x80000000, // Bit 31: Full
AI_STATUS_DMA_BUSY = 0x40000000, /* Bit 30: busy */ AI_STATUS_DMA_BUSY = 0x40000000, // Bit 30: Busy
}; };
//Audio Interface registers; // Audio interface registers
class PeripheralInterfaceReg class PeripheralInterfaceReg
{ {
@ -365,7 +363,7 @@ private:
RDRAMInt_InterfaceReg& operator=(const RDRAMInt_InterfaceReg&); RDRAMInt_InterfaceReg& operator=(const RDRAMInt_InterfaceReg&);
}; };
//Signal Processor Interface; // Signal processor interface
class SigProcessor_InterfaceReg class SigProcessor_InterfaceReg
{ {
protected: protected:
@ -389,53 +387,53 @@ private:
SigProcessor_InterfaceReg& operator=(const SigProcessor_InterfaceReg&); SigProcessor_InterfaceReg& operator=(const SigProcessor_InterfaceReg&);
}; };
//Signal Processor interface flags // Signal processor interface flags
enum enum
{ {
SP_CLR_HALT = 0x00001, /* Bit 0: clear halt */ SP_CLR_HALT = 0x00001, // Bit 0: Clear halt
SP_SET_HALT = 0x00002, /* Bit 1: set halt */ SP_SET_HALT = 0x00002, // Bit 1: Set halt
SP_CLR_BROKE = 0x00004, /* Bit 2: clear broke */ SP_CLR_BROKE = 0x00004, // Bit 2: Clear broke
SP_CLR_INTR = 0x00008, /* Bit 3: clear intr */ SP_CLR_INTR = 0x00008, // Bit 3: Clear INTR
SP_SET_INTR = 0x00010, /* Bit 4: set intr */ SP_SET_INTR = 0x00010, // Bit 4: Set INTR
SP_CLR_SSTEP = 0x00020, /* Bit 5: clear sstep */ SP_CLR_SSTEP = 0x00020, // Bit 5: Clear SSTEP
SP_SET_SSTEP = 0x00040, /* Bit 6: set sstep */ SP_SET_SSTEP = 0x00040, // Bit 6: Set SSTEP
SP_CLR_INTR_BREAK = 0x00080, /* Bit 7: clear intr on break */ SP_CLR_INTR_BREAK = 0x00080, // Bit 7: Clear INTR on break
SP_SET_INTR_BREAK = 0x00100, /* Bit 8: set intr on break */ SP_SET_INTR_BREAK = 0x00100, // Bit 8: Set INTR on break
SP_CLR_SIG0 = 0x00200, /* Bit 9: clear signal 0 */ SP_CLR_SIG0 = 0x00200, // Bit 9: Clear signal 0
SP_SET_SIG0 = 0x00400, /* Bit 10: set signal 0 */ SP_SET_SIG0 = 0x00400, // Bit 10: Set signal 0
SP_CLR_SIG1 = 0x00800, /* Bit 11: clear signal 1 */ SP_CLR_SIG1 = 0x00800, // Bit 11: Clear signal 1
SP_SET_SIG1 = 0x01000, /* Bit 12: set signal 1 */ SP_SET_SIG1 = 0x01000, // Bit 12: Set signal 1
SP_CLR_SIG2 = 0x02000, /* Bit 13: clear signal 2 */ SP_CLR_SIG2 = 0x02000, // Bit 13: Clear signal 2
SP_SET_SIG2 = 0x04000, /* Bit 14: set signal 2 */ SP_SET_SIG2 = 0x04000, // Bit 14: Set signal 2
SP_CLR_SIG3 = 0x08000, /* Bit 15: clear signal 3 */ SP_CLR_SIG3 = 0x08000, // Bit 15: Clear signal 3
SP_SET_SIG3 = 0x10000, /* Bit 16: set signal 3 */ SP_SET_SIG3 = 0x10000, // Bit 16: Set signal 3
SP_CLR_SIG4 = 0x20000, /* Bit 17: clear signal 4 */ SP_CLR_SIG4 = 0x20000, // Bit 17: Clear signal 4
SP_SET_SIG4 = 0x40000, /* Bit 18: set signal 4 */ SP_SET_SIG4 = 0x40000, // Bit 18: Set signal 4
SP_CLR_SIG5 = 0x80000, /* Bit 19: clear signal 5 */ SP_CLR_SIG5 = 0x80000, // Bit 19: Clear signal 5
SP_SET_SIG5 = 0x100000, /* Bit 20: set signal 5 */ SP_SET_SIG5 = 0x100000, // Bit 20: Set signal 5
SP_CLR_SIG6 = 0x200000, /* Bit 21: clear signal 6 */ SP_CLR_SIG6 = 0x200000, // Bit 21: Clear signal 6
SP_SET_SIG6 = 0x400000, /* Bit 22: set signal 6 */ SP_SET_SIG6 = 0x400000, // Bit 22: Set signal 6
SP_CLR_SIG7 = 0x800000, /* Bit 23: clear signal 7 */ SP_CLR_SIG7 = 0x800000, // Bit 23: Clear signal 7
SP_SET_SIG7 = 0x1000000, /* Bit 24: set signal 7 */ SP_SET_SIG7 = 0x1000000, // Bit 24: Set signal 7
SP_STATUS_HALT = 0x001, /* Bit 0: halt */ SP_STATUS_HALT = 0x001, // Bit 0: Halt
SP_STATUS_BROKE = 0x002, /* Bit 1: broke */ SP_STATUS_BROKE = 0x002, // Bit 1: Broke
SP_STATUS_DMA_BUSY = 0x004, /* Bit 2: dma busy */ SP_STATUS_DMA_BUSY = 0x004, // Bit 2: DMA busy
SP_STATUS_DMA_FULL = 0x008, /* Bit 3: dma full */ SP_STATUS_DMA_FULL = 0x008, // Bit 3: DMA full
SP_STATUS_IO_FULL = 0x010, /* Bit 4: io full */ SP_STATUS_IO_FULL = 0x010, // Bit 4: IO full
SP_STATUS_SSTEP = 0x020, /* Bit 5: single step */ SP_STATUS_SSTEP = 0x020, // Bit 5: Single step
SP_STATUS_INTR_BREAK = 0x040, /* Bit 6: interrupt on break */ SP_STATUS_INTR_BREAK = 0x040, // Bit 6: Interrupt on break
SP_STATUS_SIG0 = 0x080, /* Bit 7: signal 0 set */ SP_STATUS_SIG0 = 0x080, // Bit 7: Signal 0 set
SP_STATUS_SIG1 = 0x100, /* Bit 8: signal 1 set */ SP_STATUS_SIG1 = 0x100, // Bit 8: Signal 1 set
SP_STATUS_SIG2 = 0x200, /* Bit 9: signal 2 set */ SP_STATUS_SIG2 = 0x200, // Bit 9: Signal 2 set
SP_STATUS_SIG3 = 0x400, /* Bit 10: signal 3 set */ SP_STATUS_SIG3 = 0x400, // Bit 10: Signal 3 set
SP_STATUS_SIG4 = 0x800, /* Bit 11: signal 4 set */ SP_STATUS_SIG4 = 0x800, // Bit 11: Signal 4 set
SP_STATUS_SIG5 = 0x1000, /* Bit 12: signal 5 set */ SP_STATUS_SIG5 = 0x1000, // Bit 12: Signal 5 set
SP_STATUS_SIG6 = 0x2000, /* Bit 13: signal 6 set */ SP_STATUS_SIG6 = 0x2000, // Bit 13: Signal 6 set
SP_STATUS_SIG7 = 0x4000, /* Bit 14: signal 7 set */ SP_STATUS_SIG7 = 0x4000, // Bit 14: Signal 7 set
}; };
//Peripheral Interface flags // Peripheral interface flags
enum enum
{ {
PI_STATUS_DMA_BUSY = 0x01, PI_STATUS_DMA_BUSY = 0x01,
@ -463,7 +461,7 @@ private:
Serial_InterfaceReg& operator=(const Serial_InterfaceReg&); Serial_InterfaceReg& operator=(const Serial_InterfaceReg&);
}; };
//Serial Interface flags // Serial interface flags
enum enum
{ {
SI_STATUS_DMA_BUSY = 0x0001, SI_STATUS_DMA_BUSY = 0x0001,
@ -472,7 +470,7 @@ enum
SI_STATUS_INTERRUPT = 0x1000, SI_STATUS_INTERRUPT = 0x1000,
}; };
//Disk Interface // Disk interface
class Disk_InterfaceReg class Disk_InterfaceReg
{ {
protected: protected:
@ -508,7 +506,7 @@ private:
Disk_InterfaceReg& operator=(const Disk_InterfaceReg&); Disk_InterfaceReg& operator=(const Disk_InterfaceReg&);
}; };
//Disk Interface Flags // Disk interface flags
enum enum
{ {
DD_STATUS_DATA_RQ = 0x40000000, DD_STATUS_DATA_RQ = 0x40000000,
@ -588,7 +586,7 @@ class CRegisters :
public: public:
CRegisters(CN64System * System, CSystemEvents * SystemEvents); CRegisters(CN64System * System, CSystemEvents * SystemEvents);
//General Registers // General registers
uint32_t m_PROGRAM_COUNTER; uint32_t m_PROGRAM_COUNTER;
MIPS_DWORD m_GPR[32]; MIPS_DWORD m_GPR[32];
uint32_t m_CP0[33]; uint32_t m_CP0[33];
@ -596,14 +594,14 @@ public:
MIPS_DWORD m_LO; MIPS_DWORD m_LO;
uint32_t m_LLBit; uint32_t m_LLBit;
//Floating point registers/information // Floating point registers/information
uint32_t m_FPCR[32]; uint32_t m_FPCR[32];
int32_t m_RoundingModel; int32_t m_RoundingModel;
MIPS_DWORD m_FPR[32]; MIPS_DWORD m_FPR[32];
float * m_FPR_S[32]; float * m_FPR_S[32];
double * m_FPR_D[32]; double * m_FPR_D[32];
//Memory Mapped N64 registers // Memory-mapped N64 registers
uint32_t m_RDRAM_Registers[10]; uint32_t m_RDRAM_Registers[10];
uint32_t m_SigProcessor_Interface[10]; uint32_t m_SigProcessor_Interface[10];
uint32_t m_Display_ControlReg[10]; uint32_t m_Display_ControlReg[10];

View File

@ -50,7 +50,7 @@ const char * SystemEventName(SystemEvent event)
case SysEvent_ResetRecompilerCode: return "SysEvent_ResetRecompilerCode"; case SysEvent_ResetRecompilerCode: return "SysEvent_ResetRecompilerCode";
} }
static char unknown[100]; static char unknown[100];
sprintf(unknown, "unknown(%d)", event); sprintf(unknown, "Unknown(%d)", event);
return unknown; return unknown;
} }

View File

@ -18,7 +18,7 @@ CSystemTimer::CSystemTimer(CRegisters &Reg, int32_t & NextTimer) :
void CSystemTimer::Reset() void CSystemTimer::Reset()
{ {
//initialise Structure // Initialize structure
for (int i = 0; i < MaxTimer; i++) for (int i = 0; i < MaxTimer; i++)
{ {
m_TimerDetatils[i].Active = false; m_TimerDetatils[i].Active = false;
@ -47,16 +47,16 @@ void CSystemTimer::SetTimer(TimerType Type, uint32_t Cycles, bool bRelative)
{ {
if (m_TimerDetatils[Type].Active) if (m_TimerDetatils[Type].Active)
{ {
m_TimerDetatils[Type].CyclesToTimer += Cycles; //Add to the timer m_TimerDetatils[Type].CyclesToTimer += Cycles; // Add to the timer
} }
else else
{ {
m_TimerDetatils[Type].CyclesToTimer = (int64_t)Cycles - (int64_t)m_NextTimer; //replace the new cycles m_TimerDetatils[Type].CyclesToTimer = (int64_t)Cycles - (int64_t)m_NextTimer; // Replace the new cycles
} }
} }
else else
{ {
m_TimerDetatils[Type].CyclesToTimer = (int64_t)Cycles - (int64_t)m_NextTimer; //replace the new cycles m_TimerDetatils[Type].CyclesToTimer = (int64_t)Cycles - (int64_t)m_NextTimer; // Replace the new cycles
} }
FixTimers(); FixTimers();
} }
@ -109,7 +109,7 @@ void CSystemTimer::FixTimers()
SetCompareTimer(); SetCompareTimer();
} }
//Update the cycles for the remaining number of cycles to timer // Update the cycles for the remaining number of cycles to timer
int count; int count;
for (count = 0; count < MaxTimer; count++) for (count = 0; count < MaxTimer; count++)
{ {
@ -120,10 +120,10 @@ void CSystemTimer::FixTimers()
m_TimerDetatils[count].CyclesToTimer += m_NextTimer; m_TimerDetatils[count].CyclesToTimer += m_NextTimer;
} }
//Set Max timer // Set max timer
m_NextTimer = 0x7FFFFFFF; m_NextTimer = 0x7FFFFFFF;
//Find the smallest timer left to go // Find the smallest timer left to go
for (count = 0; count < MaxTimer; count++) for (count = 0; count < MaxTimer; count++)
{ {
if (!m_TimerDetatils[count].Active) if (!m_TimerDetatils[count].Active)
@ -138,7 +138,7 @@ void CSystemTimer::FixTimers()
m_Current = (TimerType)count; m_Current = (TimerType)count;
} }
//Move the timer back this value // Move the timer back this value
for (count = 0; count < MaxTimer; count++) for (count = 0; count < MaxTimer; count++)
{ {
if (!m_TimerDetatils[count].Active) if (!m_TimerDetatils[count].Active)

View File

@ -85,8 +85,8 @@ void CTLB::Probe()
if (TlbValueMasked == EntryHiMasked) if (TlbValueMasked == EntryHiMasked)
{ {
if ((TlbEntryHiValue & 0x100) != 0 || //Global if ((TlbEntryHiValue & 0x100) != 0 || // Global
((TlbEntryHiValue & 0xFF) == (g_Reg->ENTRYHI_REGISTER & 0xFF))) //SameAsid ((TlbEntryHiValue & 0xFF) == (g_Reg->ENTRYHI_REGISTER & 0xFF))) // SameAsid
{ {
g_Reg->INDEX_REGISTER = Counter; g_Reg->INDEX_REGISTER = Counter;
int FastIndx = Counter << 1; int FastIndx = Counter << 1;
@ -115,7 +115,7 @@ void CTLB::WriteEntry(int index, bool Random)
WriteTrace(TraceTLB, TraceDebug, "%02d %d %08X %08X %08X %08X ", index, Random, g_Reg->PAGE_MASK_REGISTER, g_Reg->ENTRYHI_REGISTER, g_Reg->ENTRYLO0_REGISTER, g_Reg->ENTRYLO1_REGISTER); WriteTrace(TraceTLB, TraceDebug, "%02d %d %08X %08X %08X %08X ", index, Random, g_Reg->PAGE_MASK_REGISTER, g_Reg->ENTRYHI_REGISTER, g_Reg->ENTRYLO0_REGISTER, g_Reg->ENTRYLO1_REGISTER);
//Check to see if entry is unmapping it self // Check to see if entry is unmapping itself
if (m_tlb[index].EntryDefined) if (m_tlb[index].EntryDefined)
{ {
FastIndx = index << 1; FastIndx = index << 1;
@ -135,7 +135,7 @@ void CTLB::WriteEntry(int index, bool Random)
} }
} }
//Reset old addresses // Reset old addresses
if (m_tlb[index].EntryDefined) if (m_tlb[index].EntryDefined)
{ {
for (FastIndx = index << 1; FastIndx <= (index << 1) + 1; FastIndx++) for (FastIndx = index << 1; FastIndx <= (index << 1) + 1; FastIndx++)
@ -164,7 +164,7 @@ void CTLB::WriteEntry(int index, bool Random)
} }
} }
//fill in m_tlb entry // Fill in m_tlb entry
m_tlb[index].PageMask.Value = g_Reg->PAGE_MASK_REGISTER; m_tlb[index].PageMask.Value = g_Reg->PAGE_MASK_REGISTER;
m_tlb[index].EntryHi.Value = g_Reg->ENTRYHI_REGISTER; m_tlb[index].EntryHi.Value = g_Reg->ENTRYHI_REGISTER;
m_tlb[index].EntryLo0.Value = g_Reg->ENTRYLO0_REGISTER; m_tlb[index].EntryLo0.Value = g_Reg->ENTRYLO0_REGISTER;
@ -176,7 +176,7 @@ void CTLB::WriteEntry(int index, bool Random)
void CTLB::SetupTLB_Entry(int index, bool Random) void CTLB::SetupTLB_Entry(int index, bool Random)
{ {
//Fix up Fast TLB entries // Fix up fast TLB entries
if (!m_tlb[index].EntryDefined) if (!m_tlb[index].EntryDefined)
{ {
return; return;
@ -216,7 +216,7 @@ void CTLB::SetupTLB_Entry(int index, bool Random)
m_FastTlb[FastIndx].Random = Random; m_FastTlb[FastIndx].Random = Random;
m_FastTlb[FastIndx].Probed = false; m_FastTlb[FastIndx].Probed = false;
//Test both entries to see if they are valid // Test both entries to see if they are valid
for (FastIndx = index << 1; FastIndx <= (index << 1) + 1; FastIndx++) for (FastIndx = index << 1; FastIndx <= (index << 1) + 1; FastIndx++)
{ {
if (!m_FastTlb[FastIndx].VALID) if (!m_FastTlb[FastIndx].VALID)
@ -238,7 +238,7 @@ void CTLB::SetupTLB_Entry(int index, bool Random)
continue; continue;
} }
//MAP the new m_tlb entry for reading and writing // Map the new m_tlb entry for reading and writing
m_FastTlb[FastIndx].ValidEntry = true; m_FastTlb[FastIndx].ValidEntry = true;
m_CB->TLB_Mapped(m_FastTlb[FastIndx].VSTART, m_FastTlb[FastIndx].Length, m_FastTlb[FastIndx].PHYSSTART, !m_FastTlb[FastIndx].DIRTY); m_CB->TLB_Mapped(m_FastTlb[FastIndx].VSTART, m_FastTlb[FastIndx].Length, m_FastTlb[FastIndx].PHYSSTART, !m_FastTlb[FastIndx].DIRTY);
} }

View File

@ -88,12 +88,12 @@ public:
void Reset(bool InvalidateTLB); void Reset(bool InvalidateTLB);
//Used by opcodes of the same name to manipulate the tlb (reads the registers) // Used by opcodes of the same name to manipulate the TLB (reads the registers)
void Probe(); void Probe();
void ReadEntry(); void ReadEntry();
void WriteEntry(int32_t index, bool Random); void WriteEntry(int32_t index, bool Random);
//See if a VAddr has an entry to translate to a PAddr // See if a VAddr has an entry to translate to a PAddr
bool AddressDefined(uint32_t VAddr); bool AddressDefined(uint32_t VAddr);
const TLB_ENTRY & TlbEntry(int32_t Entry) const const TLB_ENTRY & TlbEntry(int32_t Entry) const
@ -124,7 +124,7 @@ private:
bool Probed; bool Probed;
}; };
friend class CDebugTlb; // enable debug window to read class friend class CDebugTlb; // Enable debug window to read class
CTLB_CB * const m_CB; CTLB_CB * const m_CB;

View File

@ -1,9 +1,9 @@
// Project64 - A Nintendo 64 emulator // Project64 - A Nintendo 64 emulator
// http://www.pj64-emu.com/ // https://www.pj64-emu.com/
// Copyright(C) 2001-2021 Project64 // Copyright(C) 2001-2021 Project64
// Copyright(C) 2015 Bobby Smiles // Copyright(C) 2015 Bobby Smiles
// GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html // GNU/GPLv2 licensed: https://gnu.org/licenses/gpl-2.0.html
#include "stdafx.h" #include "stdafx.h"
#include "GBCart.h" #include "GBCart.h"
#include "Transferpak.h" #include "Transferpak.h"
@ -17,7 +17,7 @@ uint16_t gb_cart_address(unsigned int bank, uint16_t address)
void Transferpak::Init() void Transferpak::Init()
{ {
//Quick check to ensure we dont have a ROM already // Quick check to ensure we don't have a ROM already
if (tpak.gb_cart.rom == nullptr) if (tpak.gb_cart.rom == nullptr)
{ {
memset(&tpak, 0, sizeof(tpak)); memset(&tpak, 0, sizeof(tpak));
@ -38,20 +38,20 @@ void Transferpak::ReadFrom(uint16_t address, uint8_t * data)
{ {
if ((address >= 0x8000) && (address <= 0x8FFF)) if ((address >= 0x8000) && (address <= 0x8FFF))
{ {
//Ensure we actually have a ROM loaded in first. // Ensure we actually have a ROM loaded in first
if (tpak.gb_cart.rom == nullptr) if (tpak.gb_cart.rom == nullptr)
{ {
Init(); Init();
} }
//Get whether the GB cart is enabled or disabled // Get whether the Game Boy cart is enabled or disabled
uint8_t value = (tpak.enabled) ? 0x84 : 0x00; uint8_t value = (tpak.enabled) ? 0x84 : 0x00;
memset(data, value, 0x20); memset(data, value, 0x20);
} }
else if ((address >= 0xB000) && (address <= 0xBFFF)) else if ((address >= 0xB000) && (address <= 0xBFFF))
{ {
// Get the GB Cart access mode // Get the Game Boy cart access mode
if (tpak.enabled) if (tpak.enabled)
{ {
memset(data, tpak.access_mode, 0x20); memset(data, tpak.access_mode, 0x20);
@ -65,7 +65,7 @@ void Transferpak::ReadFrom(uint16_t address, uint8_t * data)
} }
else if (address >= 0xC000) else if (address >= 0xC000)
{ {
// Read the GB Cart // Read the Game Boy cart
if (tpak.enabled) if (tpak.enabled)
{ {
GBCart::read_gb_cart(&tpak.gb_cart, gb_cart_address(tpak.bank, address), data); GBCart::read_gb_cart(&tpak.gb_cart, gb_cart_address(tpak.bank, address), data);
@ -79,13 +79,13 @@ void Transferpak::WriteTo(uint16_t address, uint8_t * data)
if ((address >= 0x8000) && (address <= 0x8FFF)) if ((address >= 0x8000) && (address <= 0x8FFF))
{ {
//Ensure we actually have a ROM loaded in first. // Ensure we actually have a ROM loaded in first
if (tpak.gb_cart.rom == nullptr) if (tpak.gb_cart.rom == nullptr)
{ {
Init(); Init();
} }
//Set whether the gb cart is enabled or disabled. // Set whether the Game Boy cart is enabled or disabled
switch (*data) switch (*data)
{ {
case 0xFE: case 0xFE:
@ -95,13 +95,13 @@ void Transferpak::WriteTo(uint16_t address, uint8_t * data)
tpak.enabled = true; tpak.enabled = true;
break; break;
default: default:
//Do nothing // Do nothing
break; break;
} }
} }
else if ((address >= 0xA000) && (address <= 0xAFFF)) else if ((address >= 0xA000) && (address <= 0xAFFF))
{ {
//Set the bank for the GB Cart // Set the bank for the Game Boy cart
if (tpak.enabled) if (tpak.enabled)
{ {
tpak.bank = *data; tpak.bank = *data;
@ -109,7 +109,7 @@ void Transferpak::WriteTo(uint16_t address, uint8_t * data)
} }
else if ((address >= 0xB000) && (address <= 0xBFFF)) else if ((address >= 0xB000) && (address <= 0xBFFF))
{ {
// Get the GB Cart access mode // Get the Game Boy cart access mode
if (tpak.enabled) if (tpak.enabled)
{ {
tpak.access_mode_changed = 0x04; tpak.access_mode_changed = 0x04;
@ -118,13 +118,13 @@ void Transferpak::WriteTo(uint16_t address, uint8_t * data)
if ((*data & 0xFE) != 0) if ((*data & 0xFE) != 0)
{ {
//Unkown tpak write // Unknown Transfer Pak write
} }
} }
} }
else if (address >= 0xC000) else if (address >= 0xC000)
{ {
// Write to the GB Cart // Write to the Game Boy cart
if (tpak.enabled) if (tpak.enabled)
{ {
GBCart::write_gb_cart(&tpak.gb_cart, gb_cart_address(tpak.bank, address), data); GBCart::write_gb_cart(&tpak.gb_cart, gb_cart_address(tpak.bank, address), data);

View File

@ -31,16 +31,16 @@ bool CN64Disk::LoadDiskImage(const char * FileLoc)
UnallocateDiskImage(); UnallocateDiskImage();
m_ErrorMsg = EMPTY_STRING; m_ErrorMsg = EMPTY_STRING;
//Assume the file extension is *.ndd or *.d64 // Assume the file extension is *.ndd or *.d64
stdstr ext = CPath(FileLoc).GetExtension(); stdstr ext = CPath(FileLoc).GetExtension();
stdstr ShadowFile = FileLoc; stdstr ShadowFile = FileLoc;
ShadowFile[ShadowFile.length() - 1] = 'r'; ShadowFile[ShadowFile.length() - 1] = 'r';
WriteTrace(TraceN64System, TraceDebug, "Attempt to load shadow file."); WriteTrace(TraceN64System, TraceDebug, "Attempting to load shadow file");
if (!AllocateAndLoadDiskImage(ShadowFile.c_str())) if (!AllocateAndLoadDiskImage(ShadowFile.c_str()))
{ {
m_isShadowDisk = false; m_isShadowDisk = false;
WriteTrace(TraceN64System, TraceDebug, "Loading Shadow file failed"); WriteTrace(TraceN64System, TraceDebug, "Loading shadow file failed");
UnallocateDiskImage(); UnallocateDiskImage();
if (!AllocateAndLoadDiskImage(FileLoc)) if (!AllocateAndLoadDiskImage(FileLoc))
{ {
@ -57,10 +57,10 @@ bool CN64Disk::LoadDiskImage(const char * FileLoc)
uint32_t crc1 = CalculateCrc(); uint32_t crc1 = CalculateCrc();
uint32_t crc2 = ~crc1; uint32_t crc2 = ~crc1;
m_DiskIdent.Format("%08X-%08X-C:%X", crc1, crc2, GetDiskAddressID()[0]); m_DiskIdent.Format("%08X-%08X-C:%X", crc1, crc2, GetDiskAddressID()[0]);
//Get the disk ID from the disk image // Get the disk ID from the disk image
if (*(uint32_t *)(&GetDiskAddressID()[0]) != 0) if (*(uint32_t *)(&GetDiskAddressID()[0]) != 0)
{ {
//if not 0x00000000 // If not 0x00000000
RomName[0] = (char)*(GetDiskAddressID() + 3); RomName[0] = (char)*(GetDiskAddressID() + 3);
RomName[1] = (char)*(GetDiskAddressID() + 2); RomName[1] = (char)*(GetDiskAddressID() + 2);
RomName[2] = (char)*(GetDiskAddressID() + 1); RomName[2] = (char)*(GetDiskAddressID() + 1);
@ -69,7 +69,7 @@ bool CN64Disk::LoadDiskImage(const char * FileLoc)
} }
else else
{ {
//if 0x00000000 then use a made up one // If 0x00000000 then use a made up one
RomName[0] = m_DiskIdent[12]; RomName[0] = m_DiskIdent[12];
RomName[1] = m_DiskIdent[11]; RomName[1] = m_DiskIdent[11];
RomName[2] = m_DiskIdent[10]; RomName[2] = m_DiskIdent[10];
@ -102,26 +102,26 @@ bool CN64Disk::SaveDiskImage()
{ {
DeinitSysDataD64(); DeinitSysDataD64();
//NO NEED TO SAVE IF DISK TYPE IS 6 // No need to save if disk type is 6
if (m_DiskType == 6) if (m_DiskType == 6)
{ {
m_DiskFile.Close(); m_DiskFile.Close();
WriteTrace(TraceN64System, TraceDebug, "Loaded Disk Type is 6. No RAM area. Shadow file is not needed."); WriteTrace(TraceN64System, TraceDebug, "Loaded disk type is 6. No RAM area. Shadow file is not needed.");
return true; return true;
} }
//Assume the file extension is *.ndd / *.d64 // Assume the file extension is *.ndd / *.d64
if (m_DiskFormat == DiskFormatMAME || m_isShadowDisk || g_Settings->LoadDword(Setting_DiskSaveType) == SaveDisk_ShadowFile) if (m_DiskFormat == DiskFormatMAME || m_isShadowDisk || g_Settings->LoadDword(Setting_DiskSaveType) == SaveDisk_ShadowFile)
{ {
//Shadow File // Shadow file
stdstr ShadowFile = m_FileName; stdstr ShadowFile = m_FileName;
ShadowFile[ShadowFile.length() - 1] = 'r'; ShadowFile[ShadowFile.length() - 1] = 'r';
WriteTrace(TraceN64System, TraceDebug, "Trying to open %s (Shadow File)", ShadowFile.c_str()); WriteTrace(TraceN64System, TraceDebug, "Trying to open %s (shadow file)", ShadowFile.c_str());
m_DiskFile.Close(); m_DiskFile.Close();
if (!m_DiskFile.Open(ShadowFile.c_str(), CFileBase::modeWrite | CFileBase::modeCreate | CFileBase::modeNoTruncate)) if (!m_DiskFile.Open(ShadowFile.c_str(), CFileBase::modeWrite | CFileBase::modeCreate | CFileBase::modeNoTruncate))
{ {
WriteTrace(TraceN64System, TraceError, "Failed to open %s (Shadow File)", ShadowFile.c_str()); WriteTrace(TraceN64System, TraceError, "Failed to open %s (shadow file)", ShadowFile.c_str());
return false; return false;
} }
@ -137,7 +137,7 @@ bool CN64Disk::SaveDiskImage()
} }
else else
{ {
//RAM File // RAM file
if (m_DiskFileSize <= m_DiskRamAddress || m_DiskRamAddress == 0) if (m_DiskFileSize <= m_DiskRamAddress || m_DiskRamAddress == 0)
{ {
m_DiskFile.Close(); m_DiskFile.Close();
@ -149,11 +149,11 @@ bool CN64Disk::SaveDiskImage()
ShadowFile[ShadowFile.length() - 2] = 'a'; ShadowFile[ShadowFile.length() - 2] = 'a';
ShadowFile[ShadowFile.length() - 3] = 'r'; ShadowFile[ShadowFile.length() - 3] = 'r';
WriteTrace(TraceN64System, TraceDebug, "Trying to open %s (RAM File)", ShadowFile.c_str()); WriteTrace(TraceN64System, TraceDebug, "Trying to open %s (RAM file)", ShadowFile.c_str());
m_DiskFile.Close(); m_DiskFile.Close();
if (!m_DiskFile.Open(ShadowFile.c_str(), CFileBase::modeWrite | CFileBase::modeCreate | CFileBase::modeNoTruncate)) if (!m_DiskFile.Open(ShadowFile.c_str(), CFileBase::modeWrite | CFileBase::modeCreate | CFileBase::modeNoTruncate))
{ {
WriteTrace(TraceN64System, TraceError, "Failed to open %s (RAM File)", ShadowFile.c_str()); WriteTrace(TraceN64System, TraceError, "Failed to open %s (RAM file)", ShadowFile.c_str());
return false; return false;
} }
@ -180,27 +180,27 @@ void CN64Disk::SwapDiskImage(const char * FileLoc)
bool CN64Disk::IsValidDiskImage(uint8_t Test[0x20]) bool CN64Disk::IsValidDiskImage(uint8_t Test[0x20])
{ {
//Basic System Data Check (first 0x20 bytes is enough) // Basic system data check (first 0x20 bytes is enough)
//Disk Type // Disk type
if ((Test[0x05] & 0xEF) > 6) return false; if ((Test[0x05] & 0xEF) > 6) return false;
//IPL Load Block // IPL load block
uint16_t ipl_load_blk = ((Test[0x06] << 8) | Test[0x07]); uint16_t ipl_load_blk = ((Test[0x06] << 8) | Test[0x07]);
if (ipl_load_blk > 0x10C3 || ipl_load_blk == 0x0000) return false; if (ipl_load_blk > 0x10C3 || ipl_load_blk == 0x0000) return false;
//IPL Load Address // IPL load address
uint32_t ipl_load_addr = (Test[0x1C] << 24) | (Test[0x1D] << 16) | (Test[0x1E] << 8) | Test[0x1F]; uint32_t ipl_load_addr = (Test[0x1C] << 24) | (Test[0x1D] << 16) | (Test[0x1E] << 8) | Test[0x1F];
if (ipl_load_addr < 0x80000000 && ipl_load_addr >= 0x80800000) return false; if (ipl_load_addr < 0x80000000 && ipl_load_addr >= 0x80800000) return false;
//Country Code // Country code
if (*((uint32_t *)&Test[0]) == 0x16D348E8) { return true; } if (*((uint32_t *)&Test[0]) == 0x16D348E8) { return true; }
else if (*((uint32_t *)&Test[0]) == 0x56EE6322) { return true; } else if (*((uint32_t *)&Test[0]) == 0x56EE6322) { return true; }
else if (*((uint32_t *)&Test[0]) == 0x00000000) { return true; } else if (*((uint32_t *)&Test[0]) == 0x00000000) { return true; }
return false; return false;
} }
//Save the settings of the loaded rom, so all loaded settings about rom will be identified with // Save the settings of the loaded ROM, so all loaded settings about ROM will be identified with this ROM
//this rom
void CN64Disk::SaveDiskSettingID(bool temp) void CN64Disk::SaveDiskSettingID(bool temp)
{ {
g_Settings->SaveBool(Game_TempLoaded, temp); g_Settings->SaveBool(Game_TempLoaded, temp);
@ -242,10 +242,10 @@ bool CN64Disk::AllocateDiskImage(uint32_t DiskFileSize)
WriteTrace(TraceN64System, TraceError, "Failed to allocate memory for disk (size: 0x%X)", DiskFileSize); WriteTrace(TraceN64System, TraceError, "Failed to allocate memory for disk (size: 0x%X)", DiskFileSize);
return false; return false;
} }
uint8_t * Image = (uint8_t *)(((uint64_t)ImageBase.get() + 0xFFF) & ~0xFFF); // start at begining of memory page uint8_t * Image = (uint8_t *)(((uint64_t)ImageBase.get() + 0xFFF) & ~0xFFF); // Start at beginning of memory page
WriteTrace(TraceN64System, TraceDebug, "Allocated disk memory (%p)", Image); WriteTrace(TraceN64System, TraceDebug, "Allocated disk memory (%p)", Image);
//save information about the disk loaded // Save information about the disk loaded
m_DiskImageBase = ImageBase.release(); m_DiskImageBase = ImageBase.release();
m_DiskImage = Image; m_DiskImage = Image;
m_DiskFileSize = DiskFileSize; m_DiskFileSize = DiskFileSize;
@ -262,10 +262,10 @@ bool CN64Disk::AllocateDiskHeader()
WriteTrace(TraceN64System, TraceError, "Failed to allocate memory for disk header forge (size: 0x40)"); WriteTrace(TraceN64System, TraceError, "Failed to allocate memory for disk header forge (size: 0x40)");
return false; return false;
} }
uint8_t * Header = (uint8_t *)(((uint64_t)HeaderBase.get() + 0xFFF) & ~0xFFF); // start at begining of memory page uint8_t * Header = (uint8_t *)(((uint64_t)HeaderBase.get() + 0xFFF) & ~0xFFF); // Start at beginning of memory page
WriteTrace(TraceN64System, TraceDebug, "Allocated disk memory (%p)", Header); WriteTrace(TraceN64System, TraceDebug, "Allocated disk memory (%p)", Header);
//save information about the disk loaded // Save information about the disk loaded
m_DiskHeaderBase = HeaderBase.release(); m_DiskHeaderBase = HeaderBase.release();
m_DiskHeader = Header; m_DiskHeader = Header;
return true; return true;
@ -280,7 +280,7 @@ bool CN64Disk::AllocateAndLoadDiskImage(const char * FileLoc)
return false; return false;
} }
//Make sure it is a valid disk image // Make sure it is a valid disk image
uint8_t Test[0x100]; uint8_t Test[0x100];
bool isValidDisk = false; bool isValidDisk = false;
@ -302,27 +302,27 @@ bool CN64Disk::AllocateAndLoadDiskImage(const char * FileLoc)
if (!isValidDisk) if (!isValidDisk)
{ {
m_DiskFile.Close(); m_DiskFile.Close();
WriteTrace(TraceN64System, TraceError, "invalid disk image file"); WriteTrace(TraceN64System, TraceError, "Invalid disk image file");
return false; return false;
} }
uint32_t DiskFileSize = m_DiskFile.GetLength(); uint32_t DiskFileSize = m_DiskFile.GetLength();
stdstr ext = CPath(FileLoc).GetExtension(); stdstr ext = CPath(FileLoc).GetExtension();
WriteTrace(TraceN64System, TraceDebug, "Successfully Opened, size: 0x%X", DiskFileSize); WriteTrace(TraceN64System, TraceDebug, "Successfully opened, size: 0x%X", DiskFileSize);
//Check Disk File Format // Check disk file format
if (((DiskFileSize == MameFormatSize) || (DiskFileSize == SDKFormatSize)) && (ext.compare("ndr") || ext.compare("ndd"))) if (((DiskFileSize == MameFormatSize) || (DiskFileSize == SDKFormatSize)) && (ext.compare("ndr") || ext.compare("ndd")))
{ {
if (DiskFileSize == MameFormatSize) if (DiskFileSize == MameFormatSize)
{ {
//If Disk is MAME Format (size is constant, it should be the same for every file), then continue // If disk is MAME Format (size is constant, it should be the same for every file), then continue
m_DiskFormat = DiskFormatMAME; m_DiskFormat = DiskFormatMAME;
WriteTrace(TraceN64System, TraceDebug, "Disk File is MAME Format"); WriteTrace(TraceN64System, TraceDebug, "Disk file is MAME format");
} }
else else
{ {
//If Disk is SDK format (made with SDK based dumpers like LuigiBlood's, or Nintendo's, size is also constant) // If disk is SDK format (made with SDK-based dumpers like LuigiBlood's, or Nintendo's, size is also constant)
m_DiskFormat = DiskFormatSDK; m_DiskFormat = DiskFormatSDK;
WriteTrace(TraceN64System, TraceDebug, "Disk File is SDK Format"); WriteTrace(TraceN64System, TraceDebug, "Disk file is SDK format");
} }
if (!AllocateDiskImage(DiskFileSize)) if (!AllocateDiskImage(DiskFileSize))
@ -331,7 +331,7 @@ bool CN64Disk::AllocateAndLoadDiskImage(const char * FileLoc)
return false; return false;
} }
//Load the n64 disk to the allocated memory // Load the N64 disk to the allocated memory
g_Notify->DisplayMessage(5, MSG_LOADING); g_Notify->DisplayMessage(5, MSG_LOADING);
m_DiskFile.SeekToBegin(); m_DiskFile.SeekToBegin();
@ -350,7 +350,7 @@ bool CN64Disk::AllocateAndLoadDiskImage(const char * FileLoc)
} }
TotalRead += dwToRead; TotalRead += dwToRead;
//Show Message of how much % wise of the rom has been loaded // Show message of how much of the ROM has been loaded (as a percentage)
g_Notify->DisplayMessage(0, stdstr_f("%s: %.2f%c", GS(MSG_LOADED), ((float)TotalRead / (float)DiskFileSize) * 100.0f, '%').c_str()); g_Notify->DisplayMessage(0, stdstr_f("%s: %.2f%c", GS(MSG_LOADED), ((float)TotalRead / (float)DiskFileSize) * 100.0f, '%').c_str());
} }
@ -370,7 +370,7 @@ bool CN64Disk::AllocateAndLoadDiskImage(const char * FileLoc)
else if ((DiskFileSize > 0x4F08) && (ext.compare("d6r") || ext.compare("d64"))) else if ((DiskFileSize > 0x4F08) && (ext.compare("d6r") || ext.compare("d64")))
{ {
m_DiskFormat = DiskFormatD64; m_DiskFormat = DiskFormatD64;
WriteTrace(TraceN64System, TraceDebug, "Disk File is D64 Format"); WriteTrace(TraceN64System, TraceDebug, "Disk file is D64 format");
m_DiskType = Test[5]; m_DiskType = Test[5];
uint16_t ROM_LBA_END = (Test[0xE0] << 8) | Test[0xE1]; uint16_t ROM_LBA_END = (Test[0xE0] << 8) | Test[0xE1];
@ -396,11 +396,11 @@ bool CN64Disk::AllocateAndLoadDiskImage(const char * FileLoc)
{ {
m_DiskFile.Close(); m_DiskFile.Close();
SetError(MSG_FAIL_IMAGE); SetError(MSG_FAIL_IMAGE);
WriteTrace(TraceN64System, TraceError, "Malformed D64 disk image, expected filesize of 0x200 + 0x%X + 0x%X = %08X, actual filesize: %08X", ROM_SIZE, RAM_SIZE, (0x200 + ROM_SIZE + RAM_SIZE), DiskFileSize); WriteTrace(TraceN64System, TraceError, "Malformed D64 disk image, expected file size of 0x200 + 0x%X + 0x%X = %08X, actual file size: %08X", ROM_SIZE, RAM_SIZE, (0x200 + ROM_SIZE + RAM_SIZE), DiskFileSize);
return false; return false;
} }
//Allocate File with Max RAM Area size // Allocate file with maximum size RAM area
WriteTrace(TraceN64System, TraceError, "Allocate D64 ROM %08X + RAM %08X", ROM_SIZE, FULL_RAM_SIZE); WriteTrace(TraceN64System, TraceError, "Allocate D64 ROM %08X + RAM %08X", ROM_SIZE, FULL_RAM_SIZE);
if (!AllocateDiskImage(0x200 + ROM_SIZE + FULL_RAM_SIZE)) if (!AllocateDiskImage(0x200 + ROM_SIZE + FULL_RAM_SIZE))
{ {
@ -408,7 +408,7 @@ bool CN64Disk::AllocateAndLoadDiskImage(const char * FileLoc)
return false; return false;
} }
//Load the n64 disk to the allocated memory // Load the N64 disk to the allocated memory
g_Notify->DisplayMessage(5, MSG_LOADING); g_Notify->DisplayMessage(5, MSG_LOADING);
m_DiskFile.SeekToBegin(); m_DiskFile.SeekToBegin();
@ -427,7 +427,7 @@ bool CN64Disk::AllocateAndLoadDiskImage(const char * FileLoc)
} }
TotalRead += dwToRead; TotalRead += dwToRead;
//Show Message of how much % wise of the rom has been loaded // Show message of how much of the ROM has been loaded (as a percentage)
g_Notify->DisplayMessage(0, stdstr_f("%s: %.2f%c", GS(MSG_LOADED), ((float)TotalRead / (float)DiskFileSize) * 100.0f, '%').c_str()); g_Notify->DisplayMessage(0, stdstr_f("%s: %.2f%c", GS(MSG_LOADED), ((float)TotalRead / (float)DiskFileSize) * 100.0f, '%').c_str());
} }
@ -446,9 +446,9 @@ bool CN64Disk::AllocateAndLoadDiskImage(const char * FileLoc)
} }
else else
{ {
//Else the disk file is invalid // Otherwise the disk file is invalid
m_DiskFile.Close(); m_DiskFile.Close();
WriteTrace(TraceN64System, TraceError, "Disk File is invalid, unexpected size"); WriteTrace(TraceN64System, TraceError, "Disk file is invalid, unexpected size");
return false; return false;
} }
@ -571,7 +571,7 @@ void CN64Disk::UnallocateDiskImage()
uint32_t CN64Disk::CalculateCrc() uint32_t CN64Disk::CalculateCrc()
{ {
//Custom CRC // Custom CRC
int crc = 0; int crc = 0;
for (int i = 0; i < 0x200; i += 4) for (int i = 0; i < 0x200; i += 4)
{ {
@ -585,7 +585,7 @@ uint32_t CN64Disk::GetDiskAddressBlock(uint16_t head, uint16_t track, uint16_t b
uint32_t offset = 0; uint32_t offset = 0;
if (m_DiskFormat == DiskFormatMAME) if (m_DiskFormat == DiskFormatMAME)
{ {
//MAME // MAME
uint32_t tr_off = 0; uint32_t tr_off = 0;
uint16_t dd_zone = 0; uint16_t dd_zone = 0;
@ -650,7 +650,7 @@ uint32_t CN64Disk::GetDiskAddressBlock(uint16_t head, uint16_t track, uint16_t b
} }
else if (m_DiskFormat == DiskFormatSDK) else if (m_DiskFormat == DiskFormatSDK)
{ {
//SDK // SDK
offset = LBAToByte(0, PhysToLBA(head, track, block)) + sector * sectorsize; offset = LBAToByte(0, PhysToLBA(head, track, block)) + sector * sectorsize;
if (offset < (BLOCKSIZE(0) * SYSTEM_LBAS) && sector == 0) if (offset < (BLOCKSIZE(0) * SYSTEM_LBAS) && sector == 0)
@ -671,7 +671,7 @@ uint32_t CN64Disk::GetDiskAddressBlock(uint16_t head, uint16_t track, uint16_t b
} }
else else
{ {
//D64 // D64
uint16_t ROM_LBA_END = *(uint16_t*)(&GetDiskAddressSys()[0xE2]); uint16_t ROM_LBA_END = *(uint16_t*)(&GetDiskAddressSys()[0xE2]);
uint16_t RAM_LBA_START = *(uint16_t*)(&GetDiskAddressSys()[0xE0]); uint16_t RAM_LBA_START = *(uint16_t*)(&GetDiskAddressSys()[0xE0]);
uint16_t RAM_LBA_END = *(uint16_t*)(&GetDiskAddressSys()[0xE6]); uint16_t RAM_LBA_END = *(uint16_t*)(&GetDiskAddressSys()[0xE6]);
@ -714,14 +714,14 @@ void CN64Disk::DetectSystemArea()
{ {
if ((m_DiskFormat == DiskFormatMAME) || (m_DiskFormat == DiskFormatSDK)) if ((m_DiskFormat == DiskFormatMAME) || (m_DiskFormat == DiskFormatSDK))
{ {
//MAME / SDK (System Area can be handled identically) // MAME / SDK (system area can be handled identically)
m_DiskSysAddress = 0; m_DiskSysAddress = 0;
m_DiskIDAddress = DISKID_LBA * 0x4D08; m_DiskIDAddress = DISKID_LBA * 0x4D08;
m_DiskRomAddress = SYSTEM_LBAS * 0x4D08; m_DiskRomAddress = SYSTEM_LBAS * 0x4D08;
//Handle System Data // Handle system data
const uint16_t sysblocks[4] = { 9, 8, 1, 0 }; const uint16_t sysblocks[4] = { 9, 8, 1, 0 };
//Check if Disk is development disk // Check if disk is development disk
bool isDevDisk = false; bool isDevDisk = false;
for (int i = 0; i < 4; i++) for (int i = 0; i < 4; i++)
@ -744,10 +744,10 @@ void CN64Disk::DetectSystemArea()
} }
} }
//Handle Disk ID // Handle disk ID
for (int i = 2; i > 0; i--) for (int i = 2; i > 0; i--)
{ {
//There are two Disk ID Blocks // There are two disk ID blocks
if (IsSysSectorGood(DISKID_LBA + i, 0xE8)) if (IsSysSectorGood(DISKID_LBA + i, 0xE8))
{ {
m_DiskIDAddress = ((DISKID_LBA + i) * 0x4D08); m_DiskIDAddress = ((DISKID_LBA + i) * 0x4D08);
@ -756,7 +756,7 @@ void CN64Disk::DetectSystemArea()
} }
else //if (m_DiskFormat == DiskFormatD64) else //if (m_DiskFormat == DiskFormatD64)
{ {
//D64 (uses fixed addresses) // D64 (uses fixed addresses)
m_DiskSysAddress = 0x000; m_DiskSysAddress = 0x000;
m_DiskIDAddress = 0x100; m_DiskIDAddress = 0x100;
m_DiskRomAddress = 0x200; m_DiskRomAddress = 0x200;
@ -765,7 +765,7 @@ void CN64Disk::DetectSystemArea()
bool CN64Disk::IsSysSectorGood(uint32_t block, uint32_t sectorsize) bool CN64Disk::IsSysSectorGood(uint32_t block, uint32_t sectorsize)
{ {
//Checks if all sectors are identical (meant only to be used for System Area for MAME and SDK formats) // Checks if all sectors are identical (meant only to be used for system area for MAME and SDK formats)
for (int j = 1; j < SECTORS_PER_BLOCK; j++) for (int j = 1; j < SECTORS_PER_BLOCK; j++)
{ {
for (uint32_t k = 0; k < sectorsize; k++) for (uint32_t k = 0; k < sectorsize; k++)
@ -779,25 +779,25 @@ bool CN64Disk::IsSysSectorGood(uint32_t block, uint32_t sectorsize)
if (block < DISKID_LBA) if (block < DISKID_LBA)
{ {
//Check System Data // Check system data
//System Format // System format
if (m_DiskImage[(block * 0x4D08) + 4] != 0x10) if (m_DiskImage[(block * 0x4D08) + 4] != 0x10)
return false; return false;
//Disk Format // Disk format
if ((m_DiskImage[(block * 0x4D08) + 5] & 0xF0) != 0x10) if ((m_DiskImage[(block * 0x4D08) + 5] & 0xF0) != 0x10)
return false; return false;
//Always 0xFFFFFFFF // Always 0xFFFFFFFF
if (*(uint32_t*)&m_DiskImage[(block * 0x4D08) + 0x18] != 0xFFFFFFFF) if (*(uint32_t*)&m_DiskImage[(block * 0x4D08) + 0x18] != 0xFFFFFFFF)
return false; return false;
uint8_t alt = 0xC; //Retail uint8_t alt = 0xC; // Retail
if ((block & 2) != 0) if ((block & 2) != 0)
alt = 0xA; //Development alt = 0xA; // Development
//Alternate Tracks Offsets (always the same) // Alternate tracks offsets (always the same)
for (int i = 0; i < 16; i++) for (int i = 0; i < 16; i++)
{ {
if (m_DiskImage[(block * 0x4D08) + 8 + i] != ((i + 1) * alt)) if (m_DiskImage[(block * 0x4D08) + 8 + i] != ((i + 1) * alt))
@ -824,14 +824,14 @@ Country CN64Disk::GetDiskCountryCode()
void CN64Disk::InitSysDataD64() void CN64Disk::InitSysDataD64()
{ {
//Else the disk will not work properly. // Otherwise the disk will not work properly
if (m_DiskFormat != DiskFormatD64) if (m_DiskFormat != DiskFormatD64)
return; return;
GetDiskAddressSys()[4 ^ 3] = 0x10; GetDiskAddressSys()[4 ^ 3] = 0x10;
GetDiskAddressSys()[5 ^ 3] |= 0x10; GetDiskAddressSys()[5 ^ 3] |= 0x10;
//Expand RAM Area for file format consistency // Expand RAM area for file format consistency
if (m_DiskType < 6) if (m_DiskType < 6)
{ {
*(uint16_t*)&GetDiskAddressSys()[0xE2 ^ 2] = RAM_START_LBA[m_DiskType] - SYSTEM_LBAS; *(uint16_t*)&GetDiskAddressSys()[0xE2 ^ 2] = RAM_START_LBA[m_DiskType] - SYSTEM_LBAS;
@ -846,7 +846,7 @@ void CN64Disk::InitSysDataD64()
void CN64Disk::DeinitSysDataD64() void CN64Disk::DeinitSysDataD64()
{ {
//Restore the data // Restore the data
if (m_DiskFormat != DiskFormatD64) if (m_DiskFormat != DiskFormatD64)
return; return;
@ -866,7 +866,7 @@ void CN64Disk::DetectRamAddress()
{ {
if (m_DiskFormat == DiskFormatMAME) if (m_DiskFormat == DiskFormatMAME)
{ {
//Not supported // Not supported
m_DiskRamAddress = 0; m_DiskRamAddress = 0;
} }
else if (m_DiskFormat == DiskFormatSDK) else if (m_DiskFormat == DiskFormatSDK)
@ -927,50 +927,50 @@ uint16_t CN64Disk::LBAToPhys(uint32_t lba)
{ {
uint8_t * sys_data = GetDiskAddressSys(); uint8_t * sys_data = GetDiskAddressSys();
//Get Block 0/1 on Disk Track // Get block 0/1 on disk track
uint8_t block = 1; uint8_t block = 1;
if (((lba & 3) == 0) || ((lba & 3) == 3)) if (((lba & 3) == 0) || ((lba & 3) == 3))
block = 0; block = 0;
//Get Virtual & Physical Disk Zones // Get virtual and physical disk zones
uint16_t vzone = (uint16_t)LBAToVZone(lba); uint16_t vzone = (uint16_t)LBAToVZone(lba);
uint16_t pzone = VZoneToPZone(vzone, m_DiskType); uint16_t pzone = VZoneToPZone(vzone, m_DiskType);
//Get Disk Head // Get disk head
uint16_t head = (7 < pzone); uint16_t head = (7 < pzone);
//Get Disk Zone // Get disk zone
uint16_t disk_zone = pzone; uint16_t disk_zone = pzone;
if (disk_zone != 0) if (disk_zone != 0)
disk_zone = pzone - 7; disk_zone = pzone - 7;
//Get Virtual Zone LBA start, if Zone 0, it's LBA 0 // Get virtual zone LBA start, if zone 0, it's LBA 0
uint16_t vzone_lba = 0; uint16_t vzone_lba = 0;
if (vzone != 0) if (vzone != 0)
vzone_lba = VZONE_LBA_TBL[m_DiskType][vzone - 1]; vzone_lba = VZONE_LBA_TBL[m_DiskType][vzone - 1];
//Calculate Physical Track // Calculate physical track
uint16_t track = (uint16_t)((lba - vzone_lba) >> 1); uint16_t track = (uint16_t)((lba - vzone_lba) >> 1);
//Get the start track from current zone // Get the start track from current zone
uint16_t track_zone_start = SCYL_ZONE_TBL[0][pzone]; uint16_t track_zone_start = SCYL_ZONE_TBL[0][pzone];
if (head != 0) if (head != 0)
{ {
//If Head 1, count from the other way around // If head 1, count from the other way around
track = -track; track = -track;
track_zone_start = OUTERCYL_TBL[disk_zone - 1]; track_zone_start = OUTERCYL_TBL[disk_zone - 1];
} }
track += SCYL_ZONE_TBL[0][pzone]; track += SCYL_ZONE_TBL[0][pzone];
//Get the relative offset to defect tracks for the current zone (if Zone 0, then it's 0) // Get the relative offset to defect tracks for the current zone (if zone 0, then it's 0)
uint16_t defect_offset = 0; uint16_t defect_offset = 0;
if (pzone != 0) if (pzone != 0)
defect_offset = sys_data[(8 + pzone - 1) ^ 3]; defect_offset = sys_data[(8 + pzone - 1) ^ 3];
//Get amount of defect tracks for the current zone // Get amount of defect tracks for the current zone
uint16_t defect_amount = sys_data[(8 + pzone) ^ 3] - defect_offset; uint16_t defect_amount = sys_data[(8 + pzone) ^ 3] - defect_offset;
//Skip defect tracks // Skip defect tracks
while ((defect_amount != 0) && ((sys_data[(0x20 + defect_offset) ^ 3] + track_zone_start) <= track)) while ((defect_amount != 0) && ((sys_data[(0x20 + defect_offset) ^ 3] + track_zone_start) <= track))
{ {
track++; track++;

View File

@ -54,11 +54,11 @@ private:
uint16_t LBAToPhys(uint32_t lba); uint16_t LBAToPhys(uint32_t lba);
uint16_t PhysToLBA(uint16_t head, uint16_t track, uint16_t block); uint16_t PhysToLBA(uint16_t head, uint16_t track, uint16_t block);
//constant values // Constant values
enum { ReadFromRomSection = 0x400000, MameFormatSize = 0x0435B0C0, SDKFormatSize = 0x03DEC800, enum { ReadFromRomSection = 0x400000, MameFormatSize = 0x0435B0C0, SDKFormatSize = 0x03DEC800,
DiskFormatMAME = 0x0, DiskFormatSDK = 0x1, DiskFormatD64 = 0x2 }; DiskFormatMAME = 0x0, DiskFormatSDK = 0x1, DiskFormatD64 = 0x2 };
//class variables // Class variables
CFile m_DiskFile; CFile m_DiskFile;
uint8_t * m_DiskImage; uint8_t * m_DiskImage;
uint8_t * m_DiskImageBase; uint8_t * m_DiskImageBase;
@ -73,11 +73,11 @@ private:
LanguageStringID m_ErrorMsg; LanguageStringID m_ErrorMsg;
Country m_Country; Country m_Country;
stdstr m_RomName, m_FileName, m_DiskIdent; stdstr m_RomName, m_FileName, m_DiskIdent;
uint8_t m_DiskFormat; //0 = MAME, 1 = SDK, 2 = D64 uint8_t m_DiskFormat; // 0 = MAME, 1 = SDK, 2 = D64
uint8_t m_DiskType; uint8_t m_DiskType;
bool m_isShadowDisk; bool m_isShadowDisk;
//Disk Defines // Disk defines
#define MAX_LBA 0x10DB #define MAX_LBA 0x10DB
#define SIZE_LBA MAX_LBA+1 #define SIZE_LBA MAX_LBA+1
#define SYSTEM_LBAS 24 #define SYSTEM_LBAS 24
@ -134,11 +134,11 @@ private:
#define VZoneToPZone(x, y) VZONE_PZONE_TBL[y][x] #define VZoneToPZone(x, y) VZONE_PZONE_TBL[y][x]
//Used for MAME format // Used for MAME format
const uint32_t MAMEStartOffset[16] = const uint32_t MAMEStartOffset[16] =
{ 0x0, 0x5F15E0, 0xB79D00, 0x10801A0, 0x1523720, 0x1963D80, 0x1D414C0, 0x20BBCE0, { 0x0, 0x5F15E0, 0xB79D00, 0x10801A0, 0x1523720, 0x1963D80, 0x1D414C0, 0x20BBCE0,
0x23196E0, 0x28A1E00, 0x2DF5DC0, 0x3299340, 0x36D99A0, 0x3AB70E0, 0x3E31900, 0x4149200 }; 0x23196E0, 0x28A1E00, 0x2DF5DC0, 0x3299340, 0x36D99A0, 0x3AB70E0, 0x3E31900, 0x4149200 };
//Used for SDK and D64 format // Used for SDK and D64 format
uint16_t LBAToPhysTable[SIZE_LBA]; uint16_t LBAToPhysTable[SIZE_LBA];
}; };

View File

@ -29,18 +29,18 @@ CN64Rom::~CN64Rom()
bool CN64Rom::AllocateRomImage(uint32_t RomFileSize) bool CN64Rom::AllocateRomImage(uint32_t RomFileSize)
{ {
WriteTrace(TraceN64System, TraceDebug, "Allocating memory for rom"); WriteTrace(TraceN64System, TraceDebug, "Allocating memory for ROM");
std::unique_ptr<uint8_t> ImageBase(new uint8_t[RomFileSize + 0x2000]); std::unique_ptr<uint8_t> ImageBase(new uint8_t[RomFileSize + 0x2000]);
if (ImageBase.get() == nullptr) if (ImageBase.get() == nullptr)
{ {
SetError(MSG_MEM_ALLOC_ERROR); SetError(MSG_MEM_ALLOC_ERROR);
WriteTrace(TraceN64System, TraceError, "Failed to allocate memory for rom (size: 0x%X)", RomFileSize); WriteTrace(TraceN64System, TraceError, "Failed to allocate memory for ROM (size: 0x%X)", RomFileSize);
return false; return false;
} }
uint8_t * Image = (uint8_t *)(((uint64_t)ImageBase.get() + 0xFFF) & ~0xFFF); // start at begining of memory page uint8_t * Image = (uint8_t *)(((uint64_t)ImageBase.get() + 0xFFF) & ~0xFFF); // Start at beginning of memory page
WriteTrace(TraceN64System, TraceDebug, "Allocated rom memory (%p)", Image); WriteTrace(TraceN64System, TraceDebug, "Allocated ROM memory (%p)", Image);
//save information about the rom loaded // Save information about the ROM loaded
m_ROMImageBase = ImageBase.release(); m_ROMImageBase = ImageBase.release();
m_ROMImage = Image; m_ROMImage = Image;
m_RomFileSize = RomFileSize; m_RomFileSize = RomFileSize;
@ -56,7 +56,7 @@ bool CN64Rom::AllocateAndLoadN64Image(const char * FileLoc, bool LoadBootCodeOnl
return false; return false;
} }
//Read the first 4 bytes and make sure it is a valid n64 image // Read the first 4 bytes and make sure it is a valid N64 image
uint8_t Test[4]; uint8_t Test[4];
m_RomFile.SeekToBegin(); m_RomFile.SeekToBegin();
if (m_RomFile.Read(Test, sizeof(Test)) != sizeof(Test)) if (m_RomFile.Read(Test, sizeof(Test)) != sizeof(Test))
@ -68,16 +68,16 @@ bool CN64Rom::AllocateAndLoadN64Image(const char * FileLoc, bool LoadBootCodeOnl
if (!IsValidRomImage(Test)) if (!IsValidRomImage(Test))
{ {
m_RomFile.Close(); m_RomFile.Close();
WriteTrace(TraceN64System, TraceError, "invalid image file %X %X %X %X", Test[0], Test[1], Test[2], Test[3]); WriteTrace(TraceN64System, TraceError, "Invalid image file %X %X %X %X", Test[0], Test[1], Test[2], Test[3]);
return false; return false;
} }
uint32_t RomFileSize = m_RomFile.GetLength(); uint32_t RomFileSize = m_RomFile.GetLength();
WriteTrace(TraceN64System, TraceDebug, "Successfully Opened, size: 0x%X", RomFileSize); WriteTrace(TraceN64System, TraceDebug, "Successfully opened, size: 0x%X", RomFileSize);
//if loading boot code then just load the first 0x1000 bytes // If loading boot code then just load the first 0x1000 bytes
if (LoadBootCodeOnly) if (LoadBootCodeOnly)
{ {
WriteTrace(TraceN64System, TraceDebug, "loading boot code, so loading the first 0x1000 bytes", RomFileSize); WriteTrace(TraceN64System, TraceDebug, "Loading boot code, so loading the first 0x1000 bytes", RomFileSize);
RomFileSize = 0x1000; RomFileSize = 0x1000;
} }
@ -87,7 +87,7 @@ bool CN64Rom::AllocateAndLoadN64Image(const char * FileLoc, bool LoadBootCodeOnl
return false; return false;
} }
//Load the n64 rom to the allocated memory // Load the N64 ROM into the allocated memory
g_Notify->DisplayMessage(5, MSG_LOADING); g_Notify->DisplayMessage(5, MSG_LOADING);
m_RomFile.SeekToBegin(); m_RomFile.SeekToBegin();
@ -106,7 +106,7 @@ bool CN64Rom::AllocateAndLoadN64Image(const char * FileLoc, bool LoadBootCodeOnl
} }
TotalRead += dwToRead; TotalRead += dwToRead;
//Show Message of how much % wise of the rom has been loaded // Show message of how much of the ROM has been loaded (as a percent)
g_Notify->DisplayMessage(0, stdstr_f("%s: %.2f%c", GS(MSG_LOADED), ((float)TotalRead / (float)RomFileSize) * 100.0f, '%').c_str()); g_Notify->DisplayMessage(0, stdstr_f("%s: %.2f%c", GS(MSG_LOADED), ((float)TotalRead / (float)RomFileSize) * 100.0f, '%').c_str());
} }
@ -121,7 +121,7 @@ bool CN64Rom::AllocateAndLoadN64Image(const char * FileLoc, bool LoadBootCodeOnl
g_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't be written to
ProtectMemory(m_ROMImage, m_RomFileSize, MEM_READONLY); ProtectMemory(m_ROMImage, m_RomFileSize, MEM_READONLY);
return true; return true;
} }
@ -137,7 +137,7 @@ bool CN64Rom::AllocateAndLoadZipImage(const char * FileLoc, bool LoadBootCodeOnl
int port = unzGoToFirstFile(file); int port = unzGoToFirstFile(file);
bool FoundRom = false; bool FoundRom = false;
//scan through all files in zip to a suitable file is found // Scan through all files in zip until a suitable file is found
while (port == UNZ_OK && !FoundRom) while (port == UNZ_OK && !FoundRom)
{ {
unz_file_info info; unz_file_info info;
@ -155,12 +155,12 @@ bool CN64Rom::AllocateAndLoadZipImage(const char * FileLoc, bool LoadBootCodeOnl
break; break;
} }
//Read the first 4 bytes to check magic number // Read the first 4 bytes to check magic number
uint8_t Test[4]; uint8_t Test[4];
unzReadCurrentFile(file, Test, sizeof(Test)); unzReadCurrentFile(file, Test, sizeof(Test));
if (IsValidRomImage(Test)) if (IsValidRomImage(Test))
{ {
//Get the size of the rom and try to allocate the memory needed. // Get the size of the ROM and try to allocate the memory needed
uint32_t RomFileSize = info.uncompressed_size; uint32_t RomFileSize = info.uncompressed_size;
if (LoadBootCodeOnly) if (LoadBootCodeOnly)
{ {
@ -173,7 +173,7 @@ bool CN64Rom::AllocateAndLoadZipImage(const char * FileLoc, bool LoadBootCodeOnl
return false; return false;
} }
//Load the n64 rom to the allocated memory // Load the N64 ROM into the allocated memory
g_Notify->DisplayMessage(5, MSG_LOADING); g_Notify->DisplayMessage(5, MSG_LOADING);
memcpy(m_ROMImage, Test, 4); memcpy(m_ROMImage, Test, 4);
@ -192,7 +192,7 @@ bool CN64Rom::AllocateAndLoadZipImage(const char * FileLoc, bool LoadBootCodeOnl
} }
TotalRead += dwRead; TotalRead += dwRead;
//Show Message of how much % wise of the rom has been loaded // Show message of how much of the ROM has been loaded (as a percent)
g_Notify->DisplayMessage(5, stdstr_f("%s: %.2f%c", GS(MSG_LOADED), ((float)TotalRead / (float)RomFileSize) * 100.0f, '%').c_str()); g_Notify->DisplayMessage(5, stdstr_f("%s: %.2f%c", GS(MSG_LOADED), ((float)TotalRead / (float)RomFileSize) * 100.0f, '%').c_str());
} }
dwRead = TotalRead + 4; dwRead = TotalRead + 4;
@ -209,7 +209,7 @@ bool CN64Rom::AllocateAndLoadZipImage(const char * FileLoc, bool LoadBootCodeOnl
g_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't be written to
ProtectMemory(m_ROMImage, m_RomFileSize, MEM_READONLY); ProtectMemory(m_ROMImage, m_RomFileSize, MEM_READONLY);
} }
unzCloseCurrentFile(file); unzCloseCurrentFile(file);
@ -241,7 +241,7 @@ void CN64Rom::ByteSwapRom()
m_ROMImage[count + 1] ^= m_ROMImage[count + 3]; m_ROMImage[count + 1] ^= m_ROMImage[count + 3];
} }
break; break;
case 0x40072780: //64DD IPL case 0x40072780: // 64DD IPL
case 0x40123780: case 0x40123780:
for (count = 0; count < m_RomFileSize; count += 4) for (count = 0; count < m_RomFileSize; count += 4)
{ {
@ -278,10 +278,10 @@ CICChip CN64Rom::GetCicChipID(uint8_t * RomData, uint64_t * CRC)
case 0x000000D6497E414B: return CIC_NUS_6103; case 0x000000D6497E414B: return CIC_NUS_6103;
case 0x0000011A49F60E96: return CIC_NUS_6105; case 0x0000011A49F60E96: return CIC_NUS_6105;
case 0x000000D6D5BE5580: return CIC_NUS_6106; case 0x000000D6D5BE5580: return CIC_NUS_6106;
case 0x000001053BC19870: return CIC_NUS_5167; //64DD CONVERSION CIC case 0x000001053BC19870: return CIC_NUS_5167; // 64DD conversion CIC
case 0x000000D2E53EF008: return CIC_NUS_8303; //64DD IPL case 0x000000D2E53EF008: return CIC_NUS_8303; // 64DD IPL
case 0x000000D2E53EF39F: return CIC_NUS_DDTL; //64DD IPL TOOL case 0x000000D2E53EF39F: return CIC_NUS_DDTL; // 64DD IPL tool
case 0x000000D2E53E5DDA: return CIC_NUS_DDUS; //64DD IPL US (different CIC) case 0x000000D2E53E5DDA: return CIC_NUS_DDUS; // 64DD IPL US (different CIC)
default: default:
return CIC_UNKNOWN; return CIC_UNKNOWN;
} }
@ -427,7 +427,7 @@ bool CN64Rom::IsValidRomImage(uint8_t Test[4])
if (*((uint32_t *)&Test[0]) == 0x40123780) { return true; } if (*((uint32_t *)&Test[0]) == 0x40123780) { return true; }
if (*((uint32_t *)&Test[0]) == 0x12408037) { return true; } if (*((uint32_t *)&Test[0]) == 0x12408037) { return true; }
if (*((uint32_t *)&Test[0]) == 0x80371240) { return true; } if (*((uint32_t *)&Test[0]) == 0x80371240) { return true; }
if (*((uint32_t *)&Test[0]) == 0x40072780) { return true; } //64DD IPL if (*((uint32_t *)&Test[0]) == 0x40072780) { return true; } // 64DD IPL
return false; return false;
} }
@ -459,7 +459,7 @@ void CN64Rom::CleanRomName(char * RomName, bool byteswap)
} }
} }
//truncate all the spaces at the end of the string // Truncate all the spaces at the end of the string
for (int count = 19; count >= 0; count--) for (int count = 19; count >= 0; count--)
{ {
if (RomName[count] == ' ') if (RomName[count] == ' ')
@ -476,7 +476,7 @@ void CN64Rom::CleanRomName(char * RomName, bool byteswap)
} }
RomName[20] = '\0'; RomName[20] = '\0';
//remove all /,\,: from the string // Remove all special characters from the string
for (int count = 0; count < (int)strlen(RomName); count++) for (int count = 0; count < (int)strlen(RomName); count++)
{ {
switch (RomName[count]) switch (RomName[count])
@ -507,7 +507,7 @@ bool CN64Rom::LoadN64Image(const char * FileLoc, bool LoadBootCodeOnly)
{ {
stdstr FullPath = FileLoc; stdstr FullPath = FileLoc;
//this should be a 7zip file // This should be a 7-zip file
char * SubFile = strstr(const_cast<char*>(FullPath.c_str()), "?"); char * SubFile = strstr(const_cast<char*>(FullPath.c_str()), "?");
if (SubFile != nullptr) if (SubFile != nullptr)
{ {
@ -516,8 +516,8 @@ bool CN64Rom::LoadN64Image(const char * FileLoc, bool LoadBootCodeOnly)
} }
//else load first found file until dialog is implemented //else load first found file until dialog is implemented
//{ //{
//Pop up a dialog and select file // Pop up a dialog and select file
//allocate memory for sub name and copy selected file name to var // Allocate memory for sub name and copy selected file name to variable
//} //}
C7zip ZipFile(FullPath.c_str()); C7zip ZipFile(FullPath.c_str());
@ -540,9 +540,9 @@ bool CN64Rom::LoadN64Image(const char * FileLoc, bool LoadBootCodeOnly)
} }
} }
//Get the size of the rom and try to allocate the memory needed. // Get the size of the ROM and try to allocate the memory needed
uint32_t RomFileSize = (uint32_t)f->Size; uint32_t RomFileSize = (uint32_t)f->Size;
//if loading boot code then just load the first 0x1000 bytes // If loading boot code then just load the first 0x1000 bytes
if (LoadBootCodeOnly) { RomFileSize = 0x1000; } if (LoadBootCodeOnly) { RomFileSize = 0x1000; }
if (!AllocateRomImage(RomFileSize)) if (!AllocateRomImage(RomFileSize))
@ -551,7 +551,7 @@ bool CN64Rom::LoadN64Image(const char * FileLoc, bool LoadBootCodeOnly)
return false; return false;
} }
//Load the n64 rom to the allocated memory // Load the N64 ROM to the allocated memory
g_Notify->DisplayMessage(5, MSG_LOADING); g_Notify->DisplayMessage(5, MSG_LOADING);
if (!ZipFile.GetFile(i, m_ROMImage, RomFileSize)) if (!ZipFile.GetFile(i, m_ROMImage, RomFileSize))
{ {
@ -574,7 +574,7 @@ bool CN64Rom::LoadN64Image(const char * FileLoc, bool LoadBootCodeOnly)
g_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't be written to
ProtectMemory(m_ROMImage, m_RomFileSize, MEM_READONLY); ProtectMemory(m_ROMImage, m_RomFileSize, MEM_READONLY);
Loaded7zFile = true; Loaded7zFile = true;
break; break;
@ -588,7 +588,7 @@ bool CN64Rom::LoadN64Image(const char * FileLoc, bool LoadBootCodeOnly)
} }
#endif #endif
//Try to open the file as a zip file // Try to open the file as a zip file
if (!Loaded7zFile) if (!Loaded7zFile)
{ {
if (!AllocateAndLoadZipImage(FileLoc, LoadBootCodeOnly)) if (!AllocateAndLoadZipImage(FileLoc, LoadBootCodeOnly))
@ -607,7 +607,7 @@ bool CN64Rom::LoadN64Image(const char * FileLoc, bool LoadBootCodeOnly)
} }
char RomName[260]; char RomName[260];
//Get the header from the rom image // Get the header from the ROM image
memcpy(&RomName[0], (void *)(m_ROMImage + 0x20), 20); memcpy(&RomName[0], (void *)(m_ROMImage + 0x20), 20);
CN64Rom::CleanRomName(RomName); CN64Rom::CleanRomName(RomName);
@ -625,7 +625,7 @@ bool CN64Rom::LoadN64Image(const char * FileLoc, bool LoadBootCodeOnly)
if (!LoadBootCodeOnly) if (!LoadBootCodeOnly)
{ {
//Calculate files MD5 // Calculate files MD5 checksum
m_MD5 = MD5((const unsigned char *)m_ROMImage, m_RomFileSize).hex_digest(); m_MD5 = MD5((const unsigned char *)m_ROMImage, m_RomFileSize).hex_digest();
WriteTrace(TraceN64System, TraceDebug, "MD5: %s", m_MD5.c_str()); WriteTrace(TraceN64System, TraceDebug, "MD5: %s", m_MD5.c_str());
} }
@ -636,7 +636,7 @@ bool CN64Rom::LoadN64Image(const char * FileLoc, bool LoadBootCodeOnly)
if (IsLoadedRomDDIPL()) if (IsLoadedRomDDIPL())
{ {
//Handle CRC differently if 64DD IPL // Handle CRC differently if it is a 64DD IPL
CRC1 = (*(uint16_t *)(&m_ROMImage[0x608]) << 16) | *(uint16_t *)(&m_ROMImage[0x60C]); CRC1 = (*(uint16_t *)(&m_ROMImage[0x608]) << 16) | *(uint16_t *)(&m_ROMImage[0x60C]);
CRC2 = (*(uint16_t *)(&m_ROMImage[0x638]) << 16) | *(uint16_t *)(&m_ROMImage[0x63C]); CRC2 = (*(uint16_t *)(&m_ROMImage[0x638]) << 16) | *(uint16_t *)(&m_ROMImage[0x63C]);
} }
@ -677,13 +677,13 @@ bool CN64Rom::LoadN64Image(const char * FileLoc, bool LoadBootCodeOnly)
} }
else if (!IsLoadedRomDDIPL()) else if (!IsLoadedRomDDIPL())
{ {
g_Settings->SaveString(Game_GameName, m_RomName.c_str()); //Use Base Game's Save File if loaded in combo g_Settings->SaveString(Game_GameName, m_RomName.c_str()); // Use base games save file if loaded in combo
} }
} }
if (g_Settings->LoadBool(Game_CRC_Recalc)) if (g_Settings->LoadBool(Game_CRC_Recalc))
{ {
//Calculate ROM Header CRC // Calculate ROM header CRC
CalculateRomCrc(); CalculateRomCrc();
} }
@ -703,7 +703,7 @@ bool CN64Rom::LoadN64ImageIPL(const char * FileLoc, bool LoadBootCodeOnly)
{ {
stdstr FullPath = FileLoc; stdstr FullPath = FileLoc;
//this should be a 7zip file // This should be a 7-zip file
char * SubFile = strstr(const_cast<char*>(FullPath.c_str()), "?"); char * SubFile = strstr(const_cast<char*>(FullPath.c_str()), "?");
if (SubFile != nullptr) if (SubFile != nullptr)
{ {
@ -712,8 +712,8 @@ bool CN64Rom::LoadN64ImageIPL(const char * FileLoc, bool LoadBootCodeOnly)
} }
//else load first found file until dialog is implemented //else load first found file until dialog is implemented
//{ //{
//Pop up a dialog and select file // Pop up a dialog and select file
//allocate memory for sub name and copy selected file name to var // Allocate memory for sub name and copy selected file name to variable
//} //}
C7zip ZipFile(FullPath.c_str()); C7zip ZipFile(FullPath.c_str());
@ -736,9 +736,9 @@ bool CN64Rom::LoadN64ImageIPL(const char * FileLoc, bool LoadBootCodeOnly)
} }
} }
//Get the size of the rom and try to allocate the memory needed. // Get the size of the ROM and try to allocate the memory needed
uint32_t RomFileSize = (uint32_t)f->Size; uint32_t RomFileSize = (uint32_t)f->Size;
//if loading boot code then just load the first 0x1000 bytes // If loading boot code then just load the first 0x1000 bytes
if (LoadBootCodeOnly) { RomFileSize = 0x1000; } if (LoadBootCodeOnly) { RomFileSize = 0x1000; }
if (!AllocateRomImage(RomFileSize)) if (!AllocateRomImage(RomFileSize))
@ -747,7 +747,7 @@ bool CN64Rom::LoadN64ImageIPL(const char * FileLoc, bool LoadBootCodeOnly)
return false; return false;
} }
//Load the n64 rom to the allocated memory // Load the N64 ROM to the allocated memory
g_Notify->DisplayMessage(5, MSG_LOADING); g_Notify->DisplayMessage(5, MSG_LOADING);
if (!ZipFile.GetFile(i, m_ROMImage, RomFileSize)) if (!ZipFile.GetFile(i, m_ROMImage, RomFileSize))
{ {
@ -770,7 +770,7 @@ bool CN64Rom::LoadN64ImageIPL(const char * FileLoc, bool LoadBootCodeOnly)
g_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't be written to
ProtectMemory(m_ROMImage, m_RomFileSize, MEM_READONLY); ProtectMemory(m_ROMImage, m_RomFileSize, MEM_READONLY);
Loaded7zFile = true; Loaded7zFile = true;
break; break;
@ -784,7 +784,7 @@ bool CN64Rom::LoadN64ImageIPL(const char * FileLoc, bool LoadBootCodeOnly)
} }
#endif #endif
//Try to open the file as a zip file // Try to open the file as a zip file
if (!Loaded7zFile) if (!Loaded7zFile)
{ {
if (!AllocateAndLoadZipImage(FileLoc, LoadBootCodeOnly)) if (!AllocateAndLoadZipImage(FileLoc, LoadBootCodeOnly))
@ -801,7 +801,7 @@ bool CN64Rom::LoadN64ImageIPL(const char * FileLoc, bool LoadBootCodeOnly)
} }
char RomName[260]; char RomName[260];
//Get the header from the rom image // Get the header from the ROM image
memcpy(&RomName[0], (void *)(m_ROMImage + 0x20), 20); memcpy(&RomName[0], (void *)(m_ROMImage + 0x20), 20);
CN64Rom::CleanRomName(RomName); CN64Rom::CleanRomName(RomName);
if (strlen(RomName) == 0) if (strlen(RomName) == 0)
@ -817,7 +817,7 @@ bool CN64Rom::LoadN64ImageIPL(const char * FileLoc, bool LoadBootCodeOnly)
if (!LoadBootCodeOnly) if (!LoadBootCodeOnly)
{ {
//Calculate files MD5 // Calculate files MD5 checksum
m_MD5 = MD5((const unsigned char *)m_ROMImage, m_RomFileSize).hex_digest(); m_MD5 = MD5((const unsigned char *)m_ROMImage, m_RomFileSize).hex_digest();
WriteTrace(TraceN64System, TraceDebug, "MD5: %s", m_MD5.c_str()); WriteTrace(TraceN64System, TraceDebug, "MD5: %s", m_MD5.c_str());
} }
@ -828,7 +828,7 @@ bool CN64Rom::LoadN64ImageIPL(const char * FileLoc, bool LoadBootCodeOnly)
if (IsLoadedRomDDIPL()) if (IsLoadedRomDDIPL())
{ {
//Handle CRC differently if 64DD IPL // Handle CRC differently if it is a 64DD IPL
CRC1 = (*(uint16_t *)(&m_ROMImage[0x608]) << 16) | *(uint16_t *)(&m_ROMImage[0x60C]); CRC1 = (*(uint16_t *)(&m_ROMImage[0x608]) << 16) | *(uint16_t *)(&m_ROMImage[0x60C]);
CRC2 = (*(uint16_t *)(&m_ROMImage[0x638]) << 16) | *(uint16_t *)(&m_ROMImage[0x63C]); CRC2 = (*(uint16_t *)(&m_ROMImage[0x638]) << 16) | *(uint16_t *)(&m_ROMImage[0x63C]);
} }
@ -854,15 +854,15 @@ bool CN64Rom::LoadN64ImageIPL(const char * FileLoc, bool LoadBootCodeOnly)
if (g_Settings->LoadBool(Game_CRC_Recalc)) if (g_Settings->LoadBool(Game_CRC_Recalc))
{ {
//Calculate ROM Header CRC // Calculate ROM header CRC
CalculateRomCrc(); CalculateRomCrc();
} }
return true; return true;
} }
//Save the settings of the loaded rom, so all loaded settings about rom will be identified with // Save the settings of the loaded ROM, so all loaded settings about ROM will be identified with this ROM
//this rom
void CN64Rom::SaveRomSettingID(bool temp) void CN64Rom::SaveRomSettingID(bool temp)
{ {
g_Settings->SaveBool(Game_TempLoaded, temp); g_Settings->SaveBool(Game_TempLoaded, temp);

View File

@ -27,7 +27,7 @@ public:
bool IsPal(); bool IsPal();
void UnallocateRomImage(); void UnallocateRomImage();
//Get a message id for the reason that you failed to load the rom // Get a message ID for the reason that you failed to load the ROM
LanguageStringID GetError() const { return m_ErrorMsg; } LanguageStringID GetError() const { return m_ErrorMsg; }
static CICChip GetCicChipID(uint8_t * RomData, uint64_t * CRC = nullptr); static CICChip GetCicChipID(uint8_t * RomData, uint64_t * CRC = nullptr);
static void CleanRomName(char * RomName, bool byteswap = true); static void CleanRomName(char * RomName, bool byteswap = true);
@ -43,10 +43,10 @@ private:
static void NotificationCB(const char * Status, CN64Rom * _this); static void NotificationCB(const char * Status, CN64Rom * _this);
//constant values // Constant values
enum { ReadFromRomSection = 0x400000 }; enum { ReadFromRomSection = 0x400000 };
//class variables // Class variables
CFile m_RomFile; CFile m_RomFile;
uint8_t * m_ROMImage; uint8_t * m_ROMImage;
uint8_t * m_ROMImageBase; uint8_t * m_ROMImageBase;

View File

@ -67,12 +67,12 @@ CN64System::CN64System(CPlugins * Plugins, uint32_t randomizer_seed, bool SavesR
if (!m_MMU_VM.Initialize(SyncSystem)) if (!m_MMU_VM.Initialize(SyncSystem))
{ {
WriteTrace(TraceN64System, TraceWarning, "MMU failed to Initialize"); WriteTrace(TraceN64System, TraceWarning, "MMU failed to initialize");
WriteTrace(TraceN64System, TraceDebug, "Done"); WriteTrace(TraceN64System, TraceDebug, "Done");
return; return;
} }
WriteTrace(TraceN64System, TraceDebug, "Reseting Plugins"); WriteTrace(TraceN64System, TraceDebug, "Resetting plugins");
g_Notify->DisplayMessage(5, MSG_PLUGIN_INIT); g_Notify->DisplayMessage(5, MSG_PLUGIN_INIT);
m_Plugins->CreatePlugins(); m_Plugins->CreatePlugins();
bool bRes = m_Plugins->Initiate(this); bool bRes = m_Plugins->Initiate(this);
@ -98,7 +98,7 @@ CN64System::CN64System(CPlugins * Plugins, uint32_t randomizer_seed, bool SavesR
{ {
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
} }
g_Notify->DisplayMessage(5, "Copy Plugins"); g_Notify->DisplayMessage(5, "Copy plugins");
g_Plugins->CopyPlugins(g_Settings->LoadStringVal(Directory_PluginSync)); g_Plugins->CopyPlugins(g_Settings->LoadStringVal(Directory_PluginSync));
m_SyncPlugins = new CPlugins(Directory_PluginSync, true); m_SyncPlugins = new CPlugins(Directory_PluginSync, true);
m_SyncPlugins->SetRenderWindows(g_Plugins->SyncWindow(), nullptr); m_SyncPlugins->SetRenderWindows(g_Plugins->SyncWindow(), nullptr);
@ -154,14 +154,14 @@ CN64System::~CN64System()
void CN64System::ExternalEvent(SystemEvent action) void CN64System::ExternalEvent(SystemEvent action)
{ {
WriteTrace(TraceN64System, TraceDebug, "action: %s", SystemEventName(action)); WriteTrace(TraceN64System, TraceDebug, "Action: %s", SystemEventName(action));
if (action == SysEvent_LoadMachineState && if (action == SysEvent_LoadMachineState &&
!g_Settings->LoadBool(GameRunning_CPU_Running) && !g_Settings->LoadBool(GameRunning_CPU_Running) &&
g_BaseSystem != nullptr && g_BaseSystem != nullptr &&
g_BaseSystem->LoadState()) g_BaseSystem->LoadState())
{ {
WriteTrace(TraceN64System, TraceDebug, "ignore event, manualy loaded save"); WriteTrace(TraceN64System, TraceDebug, "Ignore event, manually loaded save");
return; return;
} }
@ -170,7 +170,7 @@ void CN64System::ExternalEvent(SystemEvent action)
g_BaseSystem != nullptr && g_BaseSystem != nullptr &&
g_BaseSystem->SaveState()) g_BaseSystem->SaveState())
{ {
WriteTrace(TraceN64System, TraceDebug, "ignore event, manualy saved event"); WriteTrace(TraceN64System, TraceDebug, "Ignore event, manually saved event");
return; return;
} }
@ -228,7 +228,7 @@ void CN64System::ExternalEvent(SystemEvent action)
} }
break; break;
case SysEvent_ResumeCPU_FromMenu: case SysEvent_ResumeCPU_FromMenu:
// always resume if from menu // Always resume if from menu
m_hPauseEvent.Trigger(); m_hPauseEvent.Trigger();
break; break;
case SysEvent_ResumeCPU_AppGainedFocus: case SysEvent_ResumeCPU_AppGainedFocus:
@ -305,24 +305,24 @@ bool CN64System::LoadFileImage(const char * FileLoc)
g_Settings->SaveDword(Game_CurrentSaveState, g_Settings->LoadDefaultDword(Game_CurrentSaveState)); g_Settings->SaveDword(Game_CurrentSaveState, g_Settings->LoadDefaultDword(Game_CurrentSaveState));
if (g_Settings->LoadBool(GameRunning_LoadingInProgress)) if (g_Settings->LoadBool(GameRunning_LoadingInProgress))
{ {
WriteTrace(TraceN64System, TraceError, "game loading is in progress, can not load new file"); WriteTrace(TraceN64System, TraceError, "Game loading is in progress, cannot load new file");
return false; return false;
} }
//Mark the rom as loading // Mark the ROM as loading
WriteTrace(TraceN64System, TraceDebug, "Mark Rom as loading"); WriteTrace(TraceN64System, TraceDebug, "Mark ROM as loading");
g_Settings->SaveString(Game_File, ""); g_Settings->SaveString(Game_File, "");
g_Settings->SaveBool(GameRunning_LoadingInProgress, true); g_Settings->SaveBool(GameRunning_LoadingInProgress, true);
//Try to load the passed N64 rom // Try to load the passed N64 ROM
if (g_Rom == nullptr) if (g_Rom == nullptr)
{ {
WriteTrace(TraceN64System, TraceDebug, "Allocating global rom object"); WriteTrace(TraceN64System, TraceDebug, "Allocating global ROM object");
g_Rom = new CN64Rom(); g_Rom = new CN64Rom();
} }
else else
{ {
WriteTrace(TraceN64System, TraceDebug, "Use existing global rom object"); WriteTrace(TraceN64System, TraceDebug, "Use existing global ROM object");
} }
WriteTrace(TraceN64System, TraceDebug, "Loading \"%s\"", FileLoc); WriteTrace(TraceN64System, TraceDebug, "Loading \"%s\"", FileLoc);
@ -330,7 +330,7 @@ bool CN64System::LoadFileImage(const char * FileLoc)
{ {
if (g_Rom->IsLoadedRomDDIPL()) if (g_Rom->IsLoadedRomDDIPL())
{ {
//64DD IPL // 64DD IPL
if (g_DDRom == nullptr) if (g_DDRom == nullptr)
{ {
g_DDRom = new CN64Rom(); g_DDRom = new CN64Rom();
@ -351,7 +351,7 @@ bool CN64System::LoadFileImage(const char * FileLoc)
g_Settings->SaveString(Game_File, FileLoc); g_Settings->SaveString(Game_File, FileLoc);
} }
g_Settings->SaveBool(GameRunning_LoadingInProgress, false); g_Settings->SaveBool(GameRunning_LoadingInProgress, false);
WriteTrace(TraceN64System, TraceDebug, "Finished Loading (GoodName: %s)", g_Settings->LoadStringVal(Rdb_GoodName).c_str()); WriteTrace(TraceN64System, TraceDebug, "Finished loading (GoodName: %s)", g_Settings->LoadStringVal(Rdb_GoodName).c_str());
} }
else else
{ {
@ -375,20 +375,20 @@ bool CN64System::LoadFileImageIPL(const char * FileLoc)
return false; return false;
} }
//Mark the rom as loading // Mark the N64DD IPL as loading
WriteTrace(TraceN64System, TraceDebug, "Mark DDRom as loading"); WriteTrace(TraceN64System, TraceDebug, "Mark N64DD IPL as loading");
//g_Settings->SaveString(Game_File, ""); //g_Settings->SaveString(Game_File, "");
g_Settings->SaveBool(GameRunning_LoadingInProgress, true); g_Settings->SaveBool(GameRunning_LoadingInProgress, true);
//Try to load the passed N64 DDrom // Try to load the passed N64DD IPL
if (g_DDRom == nullptr) if (g_DDRom == nullptr)
{ {
WriteTrace(TraceN64System, TraceDebug, "Allocating global DDrom object"); WriteTrace(TraceN64System, TraceDebug, "Allocating global N64DD IPL object");
g_DDRom = new CN64Rom(); g_DDRom = new CN64Rom();
} }
else else
{ {
WriteTrace(TraceN64System, TraceDebug, "Use existing global DDrom object"); WriteTrace(TraceN64System, TraceDebug, "Use existing global N64DD IPL object");
} }
WriteTrace(TraceN64System, TraceDebug, "Loading \"%s\"", FileLoc); WriteTrace(TraceN64System, TraceDebug, "Loading \"%s\"", FileLoc);
@ -396,7 +396,7 @@ bool CN64System::LoadFileImageIPL(const char * FileLoc)
{ {
if (!g_DDRom->IsLoadedRomDDIPL()) if (!g_DDRom->IsLoadedRomDDIPL())
{ {
//If not 64DD IPL then it's wrong // If not 64DD IPL then it's wrong
WriteTrace(TraceN64System, TraceError, "LoadN64ImageIPL failed (\"%s\")", FileLoc); WriteTrace(TraceN64System, TraceError, "LoadN64ImageIPL failed (\"%s\")", FileLoc);
g_Notify->DisplayError(g_DDRom->GetError()); g_Notify->DisplayError(g_DDRom->GetError());
delete g_DDRom; delete g_DDRom;
@ -437,20 +437,20 @@ bool CN64System::LoadDiskImage(const char * FileLoc, const bool Expansion)
return false; return false;
} }
//Mark the rom as loading // Mark the disk as loading
WriteTrace(TraceN64System, TraceDebug, "Mark Disk as loading"); WriteTrace(TraceN64System, TraceDebug, "Mark disk as loading");
//g_Settings->SaveString(Game_File, ""); //g_Settings->SaveString(Game_File, "");
g_Settings->SaveBool(GameRunning_LoadingInProgress, true); g_Settings->SaveBool(GameRunning_LoadingInProgress, true);
//Try to load the passed N64 Disk // Try to load the passed N64 disk
if (g_Disk == nullptr) if (g_Disk == nullptr)
{ {
WriteTrace(TraceN64System, TraceDebug, "Allocating global Disk object"); WriteTrace(TraceN64System, TraceDebug, "Allocating global disk object");
g_Disk = new CN64Disk(); g_Disk = new CN64Disk();
} }
else else
{ {
WriteTrace(TraceN64System, TraceDebug, "Use existing global Disk object"); WriteTrace(TraceN64System, TraceDebug, "Use existing global disk object");
} }
WriteTrace(TraceN64System, TraceDebug, "Loading \"%s\"", FileLoc); WriteTrace(TraceN64System, TraceDebug, "Loading \"%s\"", FileLoc);
@ -478,7 +478,7 @@ bool CN64System::LoadDiskImage(const char * FileLoc, const bool Expansion)
bool CN64System::RunFileImage(const char * FileLoc) bool CN64System::RunFileImage(const char * FileLoc)
{ {
//Uninitialize g_Disk and g_DDRom to prevent exception when ending emulation of a regular ROM after playing 64DD content previously. // Uninitialize g_Disk and g_DDRom to prevent exception when ending emulation of a regular ROM after playing 64DD content previously
if (g_Disk != nullptr) if (g_Disk != nullptr)
{ {
g_Disk->UnallocateDiskImage(); g_Disk->UnallocateDiskImage();
@ -517,7 +517,7 @@ bool CN64System::RunDiskImage(const char * FileLoc)
return false; return false;
} }
//Select IPL ROM depending on Disk Country Code // Select IPL ROM depending on disk country code
if (!SelectAndLoadFileImageIPL(g_Disk->GetCountry(), false)) if (!SelectAndLoadFileImageIPL(g_Disk->GetCountry(), false))
{ {
return false; return false;
@ -539,7 +539,7 @@ bool CN64System::RunDiskComboImage(const char * FileLoc, const char * FileLocDis
return false; return false;
} }
//Select IPL ROM depending on Disk Country Code // Select IPL ROM depending on disk country code
if (!SelectAndLoadFileImageIPL(g_Disk->GetCountry(), true)) if (!SelectAndLoadFileImageIPL(g_Disk->GetCountry(), true))
{ {
return false; return false;
@ -558,7 +558,7 @@ void CN64System::RunLoadedImage(void)
{ {
if (g_Settings->LoadBool(Setting_AutoStart) != 0) if (g_Settings->LoadBool(Setting_AutoStart) != 0)
{ {
WriteTrace(TraceN64System, TraceDebug, "Automattically starting rom"); WriteTrace(TraceN64System, TraceDebug, "Automatically starting ROM");
g_BaseSystem->StartEmulation(true); g_BaseSystem->StartEmulation(true);
} }
} }
@ -605,7 +605,7 @@ bool CN64System::SelectAndLoadFileImageIPL(Country country, bool combo)
IPLROMError = MSG_TOOL_IPL_REQUIRED; IPLROMError = MSG_TOOL_IPL_REQUIRED;
if (combo && !CPath(g_Settings->LoadStringVal(File_DiskIPLTOOLPath).c_str()).Exists()) if (combo && !CPath(g_Settings->LoadStringVal(File_DiskIPLTOOLPath).c_str()).Exists())
{ {
//Development IPL is not needed for combo ROM + Disk loading // Development IPL is not needed for combo ROM + disk loading
if (CPath(g_Settings->LoadStringVal(File_DiskIPLPath).c_str()).Exists()) if (CPath(g_Settings->LoadStringVal(File_DiskIPLPath).c_str()).Exists())
IPLROMPathSetting = File_DiskIPLPath; IPLROMPathSetting = File_DiskIPLPath;
else if (CPath(g_Settings->LoadStringVal(File_DiskIPLUSAPath).c_str()).Exists()) else if (CPath(g_Settings->LoadStringVal(File_DiskIPLUSAPath).c_str()).Exists())
@ -660,14 +660,14 @@ bool CN64System::EmulationStarting(CThread * thread)
if (g_BaseSystem->SetActiveSystem(true)) if (g_BaseSystem->SetActiveSystem(true))
{ {
g_BaseSystem->m_thread = thread; g_BaseSystem->m_thread = thread;
WriteTrace(TraceN64System, TraceDebug, "Setting up N64 system done"); WriteTrace(TraceN64System, TraceDebug, "Setting up N64 system is done");
g_Settings->SaveBool(GameRunning_LoadingInProgress, false); g_Settings->SaveBool(GameRunning_LoadingInProgress, false);
try try
{ {
WriteTrace(TraceN64System, TraceDebug, "Game starting"); WriteTrace(TraceN64System, TraceDebug, "Game starting");
g_BaseSystem->StartEmulation2(false); g_BaseSystem->StartEmulation2(false);
WriteTrace(TraceN64System, TraceDebug, "Game Done"); WriteTrace(TraceN64System, TraceDebug, "Game done");
//PLACE TO ADD 64DD SAVING CODE // TODO: Add 64DD saving code?
if (g_Disk != nullptr) if (g_Disk != nullptr)
{ {
g_Disk->SaveDiskImage(); g_Disk->SaveDiskImage();
@ -715,7 +715,7 @@ void CN64System::StartEmulation2(bool NewThread)
WriteTrace(TraceN64System, TraceDebug, "Setting system as active"); WriteTrace(TraceN64System, TraceDebug, "Setting system as active");
if (!m_Plugins->Reset(this) || !m_Plugins->initilized()) if (!m_Plugins->Reset(this) || !m_Plugins->initilized())
{ {
WriteTrace(TraceN64System, TraceWarning, "can not run, plugins not initlized"); WriteTrace(TraceN64System, TraceWarning, "Can't run, plugins not initialized");
g_Settings->SaveBool(GameRunning_LoadingInProgress, false); g_Settings->SaveBool(GameRunning_LoadingInProgress, false);
g_Notify->DisplayError(MSG_PLUGIN_NOT_INIT); g_Notify->DisplayError(MSG_PLUGIN_NOT_INIT);
} }
@ -732,9 +732,9 @@ void CN64System::StartEmulation2(bool NewThread)
} }
else else
{ {
//mark the emulation as starting and fix up menus // Mark the emulation as starting and fix up menus
g_Notify->DisplayMessage(2, MSG_EMULATION_STARTED); g_Notify->DisplayMessage(2, MSG_EMULATION_STARTED);
WriteTrace(TraceN64System, TraceDebug, "Start Executing CPU"); WriteTrace(TraceN64System, TraceDebug, "Start executing CPU");
ExecuteCPU(); ExecuteCPU();
} }
WriteTrace(TraceN64System, TraceDebug, "Done"); WriteTrace(TraceN64System, TraceDebug, "Done");
@ -969,7 +969,7 @@ void CN64System::InitRegisters(bool bPostPif, CMipsMemoryVM & MMU)
{ {
m_Reg.Reset(); m_Reg.Reset();
//COP0 Registers // COP0 registers
m_Reg.RANDOM_REGISTER = 0x1F; m_Reg.RANDOM_REGISTER = 0x1F;
m_Reg.COUNT_REGISTER = 0x5000; m_Reg.COUNT_REGISTER = 0x5000;
m_Reg.MI_VERSION_REG = 0x02020102; m_Reg.MI_VERSION_REG = 0x02020102;
@ -982,9 +982,9 @@ void CN64System::InitRegisters(bool bPostPif, CMipsMemoryVM & MMU)
m_Reg.CONFIG_REGISTER = 0x0006E463; m_Reg.CONFIG_REGISTER = 0x0006E463;
m_Reg.STATUS_REGISTER = 0x34000000; m_Reg.STATUS_REGISTER = 0x34000000;
//64DD Registers // N64DD registers
//Start 64DD in Reset State and Motor Not Spinning // Start N64DD in reset state and motor not spinning
m_Reg.ASIC_STATUS = DD_STATUS_RST_STATE | DD_STATUS_MTR_N_SPIN; m_Reg.ASIC_STATUS = DD_STATUS_RST_STATE | DD_STATUS_MTR_N_SPIN;
m_Reg.ASIC_ID_REG = 0x00030000; m_Reg.ASIC_ID_REG = 0x00030000;
if (g_DDRom && (g_DDRom->CicChipID() == CIC_NUS_DDTL || (g_Disk && g_Disk->GetCountry() == Country_Unknown))) if (g_DDRom && (g_DDRom->CicChipID() == CIC_NUS_DDTL || (g_Disk && g_Disk->GetCountry() == Country_Unknown)))
@ -1074,7 +1074,7 @@ void CN64System::InitRegisters(bool bPostPif, CMipsMemoryVM & MMU)
case CIC_NUS_DDUS: case CIC_NUS_DDUS:
case CIC_NUS_DDTL: case CIC_NUS_DDTL:
default: default:
//no specific values // No specific values
break; break;
} }
m_Reg.m_GPR[20].DW = 0x0000000000000001; m_Reg.m_GPR[20].DW = 0x0000000000000001;
@ -1088,12 +1088,12 @@ void CN64System::InitRegisters(bool bPostPif, CMipsMemoryVM & MMU)
case CIC_NUS_6101: case CIC_NUS_6101:
m_Reg.m_GPR[22].DW = 0x000000000000003F; m_Reg.m_GPR[22].DW = 0x000000000000003F;
break; break;
case CIC_NUS_8303: //64DD IPL CIC case CIC_NUS_8303: // 64DD IPL CIC
case CIC_NUS_DDTL: //64DD IPL TOOL CIC case CIC_NUS_DDTL: // 64DD IPL tool CIC
case CIC_NUS_5167: //64DD CONVERSION CIC case CIC_NUS_5167: // 64DD conversion CIC
m_Reg.m_GPR[22].DW = 0x00000000000000DD; m_Reg.m_GPR[22].DW = 0x00000000000000DD;
break; break;
case CIC_NUS_DDUS: //64DD US IPL CIC case CIC_NUS_DDUS: // 64DD US IPL CIC
m_Reg.m_GPR[22].DW = 0x00000000000000DE; m_Reg.m_GPR[22].DW = 0x00000000000000DE;
break; break;
case CIC_UNKNOWN: case CIC_UNKNOWN:
@ -1153,7 +1153,7 @@ void CN64System::InitRegisters(bool bPostPif, CMipsMemoryVM & MMU)
else else
{ {
m_Reg.m_PROGRAM_COUNTER = 0xBFC00000; m_Reg.m_PROGRAM_COUNTER = 0xBFC00000;
/* PIF_Ram[36] = 0x00; PIF_Ram[39] = 0x3F; //common pif ram start values /* PIF_Ram[36] = 0x00; PIF_Ram[39] = 0x3F; // Common PIF RAM start values
switch (g_Rom->CicChipID()) { switch (g_Rom->CicChipID()) {
case CIC_NUS_6101: PIF_Ram[37] = 0x06; PIF_Ram[38] = 0x3F; break; case CIC_NUS_6101: PIF_Ram[37] = 0x06; PIF_Ram[38] = 0x3F; break;
@ -1170,7 +1170,7 @@ void CN64System::ExecuteCPU()
{ {
WriteTrace(TraceN64System, TraceDebug, "Start"); WriteTrace(TraceN64System, TraceDebug, "Start");
//reset code // Reset code
g_Settings->SaveBool(GameRunning_CPU_Paused, false); g_Settings->SaveBool(GameRunning_CPU_Paused, false);
g_Settings->SaveBool(GameRunning_CPU_Running, true); g_Settings->SaveBool(GameRunning_CPU_Running, true);
g_Notify->DisplayMessage(2, MSG_EMULATION_STARTED); g_Notify->DisplayMessage(2, MSG_EMULATION_STARTED);
@ -1205,7 +1205,7 @@ void CN64System::ExecuteCPU()
} }
WriteTrace(TraceN64System, TraceDebug, "CPU finished executing"); WriteTrace(TraceN64System, TraceDebug, "CPU finished executing");
CpuStopped(); CpuStopped();
WriteTrace(TraceN64System, TraceDebug, "Notifing plugins rom is done"); WriteTrace(TraceN64System, TraceDebug, "Notifying plugins ROM is done");
m_Plugins->RomClosed(); m_Plugins->RomClosed();
if (m_SyncCPU) if (m_SyncCPU)
{ {
@ -1249,11 +1249,11 @@ void CN64System::UpdateSyncCPU(CN64System * const SecondCPU, uint32_t const Cycl
{ {
int CyclesToExecute = Cycles - m_CyclesToSkip; int CyclesToExecute = Cycles - m_CyclesToSkip;
//Update the number of cycles to skip // Update the number of cycles to skip
m_CyclesToSkip -= Cycles; m_CyclesToSkip -= Cycles;
if (m_CyclesToSkip < 0) { m_CyclesToSkip = 0; } if (m_CyclesToSkip < 0) { m_CyclesToSkip = 0; }
//Run the other CPU For the same amount of cycles // Run the other CPU For the same amount of cycles
if (CyclesToExecute < 0) { return; } if (CyclesToExecute < 0) { return; }
SecondCPU->SetActiveSystem(true); SecondCPU->SetActiveSystem(true);
@ -1438,7 +1438,7 @@ void CN64System::DumpSyncErrors(CN64System * SecondCPU)
CLog Error; CLog Error;
Error.Open(ErrorFile); Error.Open(ErrorFile);
Error.Log("Errors:\r\n"); Error.Log("Errors:\r\n");
Error.Log("Register, Recompiler, Interpter\r\n"); Error.Log("Register, Recompiler, Interpreter\r\n");
#ifdef TEST_SP_TRACKING #ifdef TEST_SP_TRACKING
if (m_CurrentSP != GPR[29].UW[0]) if (m_CurrentSP != GPR[29].UW[0])
{ {
@ -1552,7 +1552,7 @@ void CN64System::DumpSyncErrors(CN64System * SecondCPU)
{ {
if (Rdram[z] != Rdram2[z]) if (Rdram[z] != Rdram2[z])
{ {
Error.LogF("Rdram[%X]: %X %X\r\n", z << 2, Rdram[z], Rdram2[z]); Error.LogF("RDRAM[%X]: %X %X\r\n", z << 2, Rdram[z], Rdram2[z]);
} }
} }
@ -1561,7 +1561,7 @@ void CN64System::DumpSyncErrors(CN64System * SecondCPU)
{ {
if (Imem[z] != Imem2[z]) if (Imem[z] != Imem2[z])
{ {
Error.LogF("Imem[%X]: %X %X\r\n", z << 2, Imem[z], Imem2[z]); Error.LogF("IMEM[%X]: %X %X\r\n", z << 2, Imem[z], Imem2[z]);
} }
} }
uint32_t * Dmem = (uint32_t *)m_MMU_VM.Dmem(), *Dmem2 = (uint32_t *)SecondCPU->m_MMU_VM.Dmem(); uint32_t * Dmem = (uint32_t *)m_MMU_VM.Dmem(), *Dmem2 = (uint32_t *)SecondCPU->m_MMU_VM.Dmem();
@ -1569,15 +1569,15 @@ void CN64System::DumpSyncErrors(CN64System * SecondCPU)
{ {
if (Dmem[z] != Dmem2[z]) if (Dmem[z] != Dmem2[z])
{ {
Error.LogF("Dmem[%X]: %X %X\r\n", z << 2, Dmem[z], Dmem2[z]); Error.LogF("DMEM[%X]: %X %X\r\n", z << 2, Dmem[z], Dmem2[z]);
} }
} }
Error.Log("\r\n"); Error.Log("\r\n");
Error.Log("Information:\r\n"); Error.Log("Information:\r\n");
Error.Log("\r\n"); Error.Log("\r\n");
Error.LogF("PROGRAM_COUNTER,0x%X\r\n", m_Reg.m_PROGRAM_COUNTER); Error.LogF("PROGRAM_COUNTER,0x%X\r\n", m_Reg.m_PROGRAM_COUNTER);
Error.LogF("Current Timer,0x%X\r\n", m_NextTimer); Error.LogF("Current timer,0x%X\r\n", m_NextTimer);
Error.LogF("Timer Type,0x%X\r\n", m_SystemTimer.CurrentType()); Error.LogF("Timer type,0x%X\r\n", m_SystemTimer.CurrentType());
Error.Log("\r\n"); Error.Log("\r\n");
for (int i = 0; i < (sizeof(m_LastSuccessSyncPC) / sizeof(m_LastSuccessSyncPC[0])); i++) for (int i = 0; i < (sizeof(m_LastSuccessSyncPC) / sizeof(m_LastSuccessSyncPC[0])); i++)
{ {
@ -1610,7 +1610,7 @@ void CN64System::DumpSyncErrors(CN64System * SecondCPU)
count < 10 ? 7 : 6, " ", *(m_Reg.m_FPR_D[count]), *(SecondCPU->m_Reg.m_FPR_D[count])); count < 10 ? 7 : 6, " ", *(m_Reg.m_FPR_D[count]), *(SecondCPU->m_Reg.m_FPR_D[count]));
} }
Error.Log("\r\n"); Error.Log("\r\n");
Error.LogF("Rounding Model, 0x%08X, 0x%08X\r\n", m_Reg.m_RoundingModel, SecondCPU->m_Reg.m_RoundingModel); Error.LogF("Rounding model, 0x%08X, 0x%08X\r\n", m_Reg.m_RoundingModel, SecondCPU->m_Reg.m_RoundingModel);
Error.Log("\r\n"); Error.Log("\r\n");
for (count = 0; count < 32; count++) for (count = 0; count < 32; count++)
{ {
@ -1661,7 +1661,7 @@ void CN64System::DumpSyncErrors(CN64System * SecondCPU)
} }
} }
Error.Log("\r\n"); Error.Log("\r\n");
Error.Log("Code at Last Sync PC:\r\n"); Error.Log("Code at last sync PC:\r\n");
for (count = 0; count < 50; count++) for (count = 0; count < 50; count++)
{ {
uint32_t OpcodeValue, Addr = m_LastSuccessSyncPC[0] + (count << 2); uint32_t OpcodeValue, Addr = m_LastSuccessSyncPC[0] + (count << 2);
@ -1672,7 +1672,7 @@ void CN64System::DumpSyncErrors(CN64System * SecondCPU)
} }
} }
g_Notify->DisplayError("Sync Error"); g_Notify->DisplayError("Sync error");
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
} }
@ -1683,7 +1683,7 @@ bool CN64System::SaveState()
// if (!m_SystemTimer.SaveAllowed()) { return false; } // if (!m_SystemTimer.SaveAllowed()) { return false; }
if ((m_Reg.STATUS_REGISTER & STATUS_EXL) != 0) if ((m_Reg.STATUS_REGISTER & STATUS_EXL) != 0)
{ {
WriteTrace(TraceN64System, TraceDebug, "Done - STATUS_EXL set, can not save"); WriteTrace(TraceN64System, TraceDebug, "Done - STATUS_EXL set, can't save");
return false; return false;
} }
@ -1715,13 +1715,13 @@ bool CN64System::SaveState()
CPath ZipFile(SaveFile); CPath ZipFile(SaveFile);
ZipFile.SetNameExtension(stdstr_f("%s.zip", ZipFile.GetNameExtension().c_str()).c_str()); ZipFile.SetNameExtension(stdstr_f("%s.zip", ZipFile.GetNameExtension().c_str()).c_str());
//Make sure the target dir exists // Make sure the target directory exists
if (!SaveFile.DirectoryExists()) if (!SaveFile.DirectoryExists())
{ {
SaveFile.DirectoryCreate(); SaveFile.DirectoryCreate();
} }
//Open the file // Open the file
if (g_Settings->LoadDword(Game_FuncLookupMode) == FuncFind_ChangeMemory) if (g_Settings->LoadDword(Game_FuncLookupMode) == FuncFind_ChangeMemory)
{ {
if (m_Recomp) if (m_Recomp)
@ -1742,7 +1742,7 @@ bool CN64System::SaveState()
zipWriteInFileInZip(file, &RdramSize, sizeof(uint32_t)); zipWriteInFileInZip(file, &RdramSize, sizeof(uint32_t));
if (g_Settings->LoadBool(Setting_EnableDisk) && g_Disk) if (g_Settings->LoadBool(Setting_EnableDisk) && g_Disk)
{ {
//Keep Base ROM Information (64DD IPL / Compatible Game ROM) // Keep base ROM information (64DD IPL / compatible game ROM)
zipWriteInFileInZip(file, &g_Rom->GetRomAddress()[0x10], 0x20); zipWriteInFileInZip(file, &g_Rom->GetRomAddress()[0x10], 0x20);
zipWriteInFileInZip(file, g_Disk->GetDiskAddressID(), 0x20); zipWriteInFileInZip(file, g_Disk->GetDiskAddressID(), 0x20);
} }
@ -1776,13 +1776,13 @@ bool CN64System::SaveState()
zipOpenNewFileInZip(file, ExtraInfo.GetNameExtension().c_str(), nullptr, nullptr, 0, nullptr, 0, nullptr, Z_DEFLATED, Z_DEFAULT_COMPRESSION); zipOpenNewFileInZip(file, ExtraInfo.GetNameExtension().c_str(), nullptr, nullptr, 0, nullptr, 0, nullptr, Z_DEFLATED, Z_DEFAULT_COMPRESSION);
//Extra Info v2 // Extra info v2
zipWriteInFileInZip(file, &SaveID_2, sizeof(SaveID_2)); zipWriteInFileInZip(file, &SaveID_2, sizeof(SaveID_2));
//Disk Interface Info // Disk interface info
zipWriteInFileInZip(file, m_Reg.m_DiskInterface, sizeof(uint32_t) * 22); zipWriteInFileInZip(file, m_Reg.m_DiskInterface, sizeof(uint32_t) * 22);
//System Timers Info // System timers info
m_SystemTimer.SaveData(file); m_SystemTimer.SaveData(file);
zipCloseFileInZip(file); zipCloseFileInZip(file);
@ -1806,13 +1806,13 @@ bool CN64System::SaveState()
return true; return true;
} }
//Write info to file // Write info to file
hSaveFile.SeekToBegin(); hSaveFile.SeekToBegin();
hSaveFile.Write(&SaveID_0, sizeof(uint32_t)); hSaveFile.Write(&SaveID_0, sizeof(uint32_t));
hSaveFile.Write(&RdramSize, sizeof(uint32_t)); hSaveFile.Write(&RdramSize, sizeof(uint32_t));
if (g_Settings->LoadBool(Setting_EnableDisk) && g_Disk) if (g_Settings->LoadBool(Setting_EnableDisk) && g_Disk)
{ {
//Keep Base ROM Information (64DD IPL / Compatible Game ROM) // Keep base ROM information (64DD IPL / compatible game ROM)
hSaveFile.Write(&g_Rom->GetRomAddress()[0x10], 0x20); hSaveFile.Write(&g_Rom->GetRomAddress()[0x10], 0x20);
hSaveFile.Write(g_Disk->GetDiskAddressID(), 0x20); hSaveFile.Write(g_Disk->GetDiskAddressID(), 0x20);
} }
@ -1847,13 +1847,13 @@ bool CN64System::SaveState()
CFile hExtraInfo(ExtraInfo, CFileBase::modeWrite | CFileBase::modeCreate); CFile hExtraInfo(ExtraInfo, CFileBase::modeWrite | CFileBase::modeCreate);
if (hExtraInfo.IsOpen()) if (hExtraInfo.IsOpen())
{ {
//Extra Info v2 // Extra info v2
hExtraInfo.Write(&SaveID_2, sizeof(uint32_t)); hExtraInfo.Write(&SaveID_2, sizeof(uint32_t));
//Disk Interface Info // Disk interface info
hExtraInfo.Write(m_Reg.m_DiskInterface, sizeof(uint32_t) * 22); hExtraInfo.Write(m_Reg.m_DiskInterface, sizeof(uint32_t) * 22);
//System Timers Info // System timers info
m_SystemTimer.SaveData(hExtraInfo); m_SystemTimer.SaveData(hExtraInfo);
hExtraInfo.Close(); hExtraInfo.Close();
} }
@ -1915,7 +1915,7 @@ bool CN64System::LoadState()
} }
CPath NewFileName = FileName; CPath NewFileName = FileName;
//Use old file Name // Use old file Name
if (g_Settings->LoadDword(Game_CurrentSaveState) != 0) if (g_Settings->LoadDword(Game_CurrentSaveState) != 0)
{ {
FileName.SetNameExtension(stdstr_f("%s.pj%d", g_Settings->LoadStringVal(Game_GameName).c_str(), g_Settings->LoadDword(Game_CurrentSaveState)).c_str()); FileName.SetNameExtension(stdstr_f("%s.pj%d", g_Settings->LoadStringVal(Game_GameName).c_str(), g_Settings->LoadDword(Game_CurrentSaveState)).c_str());
@ -1954,7 +1954,7 @@ bool CN64System::LoadState(const char * FileName)
if (g_Settings->LoadDword(Setting_AutoZipInstantSave) || _stricmp(SaveFile.GetExtension().c_str(), ".zip") == 0) if (g_Settings->LoadDword(Setting_AutoZipInstantSave) || _stricmp(SaveFile.GetExtension().c_str(), ".zip") == 0)
{ {
//If ziping save add .zip on the end // If zipping save add .zip on the end
if (!SaveFile.Exists() && _stricmp(SaveFile.GetExtension().c_str(), ".zip") != 0) if (!SaveFile.Exists() && _stricmp(SaveFile.GetExtension().c_str(), ".zip") != 0)
{ {
SaveFile.SetNameExtension(stdstr_f("%s.zip", SaveFile.GetNameExtension().c_str()).c_str()); SaveFile.SetNameExtension(stdstr_f("%s.zip", SaveFile.GetNameExtension().c_str()).c_str());
@ -1987,13 +1987,13 @@ bool CN64System::LoadState(const char * FileName)
if (!LoadedZipFile && Value == SaveID_0 && port == UNZ_OK) if (!LoadedZipFile && Value == SaveID_0 && port == UNZ_OK)
{ {
unzReadCurrentFile(file, &SaveRDRAMSize, sizeof(SaveRDRAMSize)); unzReadCurrentFile(file, &SaveRDRAMSize, sizeof(SaveRDRAMSize));
//Check header // Check header
uint8_t LoadHeader[64]; uint8_t LoadHeader[64];
unzReadCurrentFile(file, LoadHeader, 0x40); unzReadCurrentFile(file, LoadHeader, 0x40);
if (g_Settings->LoadBool(Setting_EnableDisk) && g_Disk) if (g_Settings->LoadBool(Setting_EnableDisk) && g_Disk)
{ {
//Base ROM Information (64DD IPL / Compatible Game ROM) & Disk Info Check // Base ROM information (64DD IPL / compatible game ROM) and disk info check
if ((memcmp(LoadHeader, &g_Rom->GetRomAddress()[0x10], 0x20) != 0 || if ((memcmp(LoadHeader, &g_Rom->GetRomAddress()[0x10], 0x20) != 0 ||
memcmp(&LoadHeader[0x20], g_Disk->GetDiskAddressID(), 0x20) != 0) && memcmp(&LoadHeader[0x20], g_Disk->GetDiskAddressID(), 0x20) != 0) &&
!g_Notify->AskYesNoQuestion(g_Lang->GetString(MSG_SAVE_STATE_HEADER).c_str())) !g_Notify->AskYesNoQuestion(g_Lang->GetString(MSG_SAVE_STATE_HEADER).c_str()))
@ -2043,21 +2043,21 @@ bool CN64System::LoadState(const char * FileName)
} }
if (LoadedZipFile && Value == SaveID_1 && port == UNZ_OK) if (LoadedZipFile && Value == SaveID_1 && port == UNZ_OK)
{ {
//Extra Info v1 // Extra info v1
//System Timers Info // System timers info
m_SystemTimer.LoadData(file); m_SystemTimer.LoadData(file);
} }
if (LoadedZipFile && Value == SaveID_2 && port == UNZ_OK) if (LoadedZipFile && Value == SaveID_2 && port == UNZ_OK)
{ {
//Extra Info v2 (Project64 2.4) // Extra info v2 (Project64 2.4)
//Disk Interface Info // Disk interface info
unzReadCurrentFile(file, m_Reg.m_DiskInterface, sizeof(uint32_t) * 22); unzReadCurrentFile(file, m_Reg.m_DiskInterface, sizeof(uint32_t) * 22);
//Recover Disk Seek Address (if the save state is done while loading/saving data) // Recover disk seek address (if the save state is done while loading/saving data)
if (g_Disk) if (g_Disk)
DiskBMReadWrite(false); DiskBMReadWrite(false);
//System Timers Info // System timers info
m_SystemTimer.LoadData(file); m_SystemTimer.LoadData(file);
} }
unzCloseCurrentFile(file); unzCloseCurrentFile(file);
@ -2083,12 +2083,12 @@ bool CN64System::LoadState(const char * FileName)
hSaveFile.Read(&SaveRDRAMSize, sizeof(SaveRDRAMSize)); hSaveFile.Read(&SaveRDRAMSize, sizeof(SaveRDRAMSize));
//Check header // Check header
uint8_t LoadHeader[64]; uint8_t LoadHeader[64];
hSaveFile.Read(LoadHeader, 0x40); hSaveFile.Read(LoadHeader, 0x40);
if (g_Settings->LoadBool(Setting_EnableDisk) && g_Disk) if (g_Settings->LoadBool(Setting_EnableDisk) && g_Disk)
{ {
//Base ROM Information (64DD IPL / Compatible Game ROM) & Disk Info Check // Base ROM information (64DD IPL / compatible game ROM) and disk info check
if ((memcmp(LoadHeader, &g_Rom->GetRomAddress()[0x10], 0x20) != 0 || if ((memcmp(LoadHeader, &g_Rom->GetRomAddress()[0x10], 0x20) != 0 ||
memcmp(&LoadHeader[0x20], g_Disk->GetDiskAddressID(), 0x20) != 0) && memcmp(&LoadHeader[0x20], g_Disk->GetDiskAddressID(), 0x20) != 0) &&
!g_Notify->AskYesNoQuestion(g_Lang->GetString(MSG_SAVE_STATE_HEADER).c_str())) !g_Notify->AskYesNoQuestion(g_Lang->GetString(MSG_SAVE_STATE_HEADER).c_str()))
@ -2138,29 +2138,29 @@ bool CN64System::LoadState(const char * FileName)
CFile hExtraInfo(ExtraInfo, CFileBase::modeRead); CFile hExtraInfo(ExtraInfo, CFileBase::modeRead);
if (hExtraInfo.IsOpen()) if (hExtraInfo.IsOpen())
{ {
//Extra Info version check // Extra info version check
hExtraInfo.Read(&Value, sizeof(Value)); hExtraInfo.Read(&Value, sizeof(Value));
if (Value != SaveID_1 && Value != SaveID_2) if (Value != SaveID_1 && Value != SaveID_2)
hExtraInfo.SeekToBegin(); hExtraInfo.SeekToBegin();
//Disk Interface Info // Disk interface info
if (Value == SaveID_2) if (Value == SaveID_2)
{ {
hExtraInfo.Read(m_Reg.m_DiskInterface, sizeof(uint32_t) * 22); hExtraInfo.Read(m_Reg.m_DiskInterface, sizeof(uint32_t) * 22);
//Recover Disk Seek Address (if the save state is done while loading/saving data) // Recover disk seek address (if the save state is done while loading/saving data)
if (g_Disk) if (g_Disk)
DiskBMReadWrite(false); DiskBMReadWrite(false);
} }
//System Timers Info // System timers info
m_SystemTimer.LoadData(hExtraInfo); m_SystemTimer.LoadData(hExtraInfo);
hExtraInfo.Close(); hExtraInfo.Close();
} }
} }
//Fix losing audio in certain games with certain plugins // Fix losing audio in certain games with certain plugins
AudioResetOnLoad = g_Settings->LoadBool(Game_AudioResetOnLoad); AudioResetOnLoad = g_Settings->LoadBool(Game_AudioResetOnLoad);
if (AudioResetOnLoad) if (AudioResetOnLoad)
{ {
@ -2185,12 +2185,12 @@ bool CN64System::LoadState(const char * FileName)
} }
g_Plugins->Audio()->DacrateChanged(SystemType()); g_Plugins->Audio()->DacrateChanged(SystemType());
//Fix Random Register // Fix random register
while ((int)m_Reg.RANDOM_REGISTER < (int)m_Reg.WIRED_REGISTER) while ((int)m_Reg.RANDOM_REGISTER < (int)m_Reg.WIRED_REGISTER)
{ {
m_Reg.RANDOM_REGISTER += 32 - m_Reg.WIRED_REGISTER; m_Reg.RANDOM_REGISTER += 32 - m_Reg.WIRED_REGISTER;
} }
//Fix up timer // Fix up timer
m_SystemTimer.SetTimer(CSystemTimer::CompareTimer, m_Reg.COMPARE_REGISTER - m_Reg.COUNT_REGISTER, false); m_SystemTimer.SetTimer(CSystemTimer::CompareTimer, m_Reg.COMPARE_REGISTER - m_Reg.COUNT_REGISTER, false);
m_SystemTimer.SetTimer(CSystemTimer::ViTimer, NextVITimer, false); m_SystemTimer.SetTimer(CSystemTimer::ViTimer, NextVITimer, false);
m_Reg.FixFpuLocations(); m_Reg.FixFpuLocations();
@ -2288,14 +2288,14 @@ void CN64System::RunRSP()
__except_try() __except_try()
{ {
WriteTrace(TraceRSP, TraceDebug, "do cycles - starting"); WriteTrace(TraceRSP, TraceDebug, "Do cycles - starting");
g_Plugins->RSP()->DoRspCycles(100); g_Plugins->RSP()->DoRspCycles(100);
WriteTrace(TraceRSP, TraceDebug, "do cycles - Done"); WriteTrace(TraceRSP, TraceDebug, "Do cycles - done");
} }
__except_catch() __except_catch()
{ {
WriteTrace(TraceRSP, TraceError, "exception generated"); WriteTrace(TraceRSP, TraceError, "Exception generated");
g_Notify->FatalError("CN64System::RunRSP()\nUnknown memory action\n\nEmulation stop"); g_Notify->FatalError("CN64System::RunRSP()\nUnknown memory action\n\nEmulation stopping");
} }
if (Task == 1 && bDelayDP() && ((m_Reg.m_GfxIntrReg & MI_INTR_DP) != 0)) if (Task == 1 && bDelayDP() && ((m_Reg.m_GfxIntrReg & MI_INTR_DP) != 0))
@ -2328,7 +2328,7 @@ void CN64System::RunRSP()
{ {
m_RspBroke = true; m_RspBroke = true;
} }
WriteTrace(TraceRSP, TraceDebug, "check interrupts"); WriteTrace(TraceRSP, TraceDebug, "Check interrupts");
g_Reg->CheckInterrupts(); g_Reg->CheckInterrupts();
} }
} }
@ -2347,7 +2347,7 @@ void CN64System::RefreshScreen()
if (bShowCPUPer()) { CPU_UsageAddr = m_CPU_Usage.StartTimer(Timer_RefreshScreen); } if (bShowCPUPer()) { CPU_UsageAddr = m_CPU_Usage.StartTimer(Timer_RefreshScreen); }
//Calculate how many cycles to next refresh // Calculate how many cycles to next refresh
if (m_Reg.VI_V_SYNC_REG == 0) if (m_Reg.VI_V_SYNC_REG == 0)
{ {
VI_INTR_TIME = 500000; VI_INTR_TIME = 500000;
@ -2381,13 +2381,13 @@ void CN64System::RefreshScreen()
__except_try() __except_try()
{ {
WriteTrace(TraceGFXPlugin, TraceDebug, "UpdateScreen Starting"); WriteTrace(TraceGFXPlugin, TraceDebug, "UpdateScreen starting");
g_Plugins->Gfx()->UpdateScreen(); g_Plugins->Gfx()->UpdateScreen();
if (g_Debugger != nullptr && HaveDebugger()) if (g_Debugger != nullptr && HaveDebugger())
{ {
g_Debugger->FrameDrawn(); g_Debugger->FrameDrawn();
} }
WriteTrace(TraceGFXPlugin, TraceDebug, "UpdateScreen Done"); WriteTrace(TraceGFXPlugin, TraceDebug, "UpdateScreen done");
} }
__except_catch() __except_catch()
{ {

View File

@ -27,7 +27,7 @@ class CPlugins;
class CRSP_Plugin; class CRSP_Plugin;
class CRecompiler; class CRecompiler;
//#define TEST_SP_TRACKING //track the SP to make sure all ops pick it up fine //#define TEST_SP_TRACKING // Track the SP to make sure all ops pick it up fine
class CN64System : class CN64System :
public CLogging, public CLogging,
@ -44,7 +44,7 @@ public:
bool m_EndEmulation; bool m_EndEmulation;
SAVE_CHIP_TYPE m_SaveUsing; SAVE_CHIP_TYPE m_SaveUsing;
//Methods // Methods
static bool LoadFileImage(const char * FileLoc); static bool LoadFileImage(const char * FileLoc);
static bool LoadFileImageIPL(const char * FileLoc); static bool LoadFileImageIPL(const char * FileLoc);
static bool LoadDiskImage(const char * FileLoc, const bool Expansion); static bool LoadDiskImage(const char * FileLoc, const bool Expansion);
@ -56,7 +56,7 @@ public:
static void CloseSystem(void); static void CloseSystem(void);
void CloseCpu(); void CloseCpu();
void ExternalEvent(SystemEvent action); //covers gui interacting and timers etc.. void ExternalEvent(SystemEvent action); // Covers GUI interactions and timers etc.
void StartEmulation(bool NewThread); void StartEmulation(bool NewThread);
void EndEmulation(); void EndEmulation();
void AlterSpeed(const CSpeedLimiter::ESpeedChange SpeedChange) { m_Limiter.AlterSpeed(SpeedChange); } void AlterSpeed(const CSpeedLimiter::ESpeedChange SpeedChange) { m_Limiter.AlterSpeed(SpeedChange); }
@ -79,29 +79,29 @@ public:
uint32_t GetButtons(int32_t Control) const { return m_Buttons[Control]; } uint32_t GetButtons(int32_t Control) const { return m_Buttons[Control]; }
CPlugins * GetPlugins() { return m_Plugins; } CPlugins * GetPlugins() { return m_Plugins; }
//Variable used to track that the SP is being handled and stays the same as the real SP in sync core // Variable used to track that the SP is being handled and stays the same as the real SP in sync core
#ifdef TEST_SP_TRACKING #ifdef TEST_SP_TRACKING
uint32_t m_CurrentSP; uint32_t m_CurrentSP;
#endif #endif
//For Sync CPU // For sync CPU
void UpdateSyncCPU(CN64System * const SecondCPU, uint32_t const Cycles); void UpdateSyncCPU(CN64System * const SecondCPU, uint32_t const Cycles);
void SyncCPU(CN64System * const SecondCPU); void SyncCPU(CN64System * const SecondCPU);
void SyncCPUPC(CN64System * const SecondCPU); void SyncCPUPC(CN64System * const SecondCPU);
void SyncSystem(); void SyncSystem();
void SyncSystemPC(); void SyncSystemPC();
private: private:
//Make sure plugins can directly access this information // Make sure plugins can directly access this information
friend class CGfxPlugin; friend class CGfxPlugin;
friend class CAudioPlugin; friend class CAudioPlugin;
friend class CRSP_Plugin; friend class CRSP_Plugin;
friend class CControl_Plugin; friend class CControl_Plugin;
//Recompiler has access to manipulate and call functions // Recompiler has access to manipulate and call functions
friend class CSystemTimer; friend class CSystemTimer;
friend class CRecompiler; friend class CRecompiler;
friend class CMipsMemoryVM; friend class CMipsMemoryVM;
//Used for loading and potentially executing the CPU in its own thread. // Used for loading and potentially executing the CPU in its own thread
static void StartEmulationThread(CThread * thread); static void StartEmulationThread(CThread * thread);
static bool EmulationStarting(CThread * thread); static bool EmulationStarting(CThread * thread);
static void StartEmulationThead(); static void StartEmulationThead();
@ -114,28 +114,28 @@ private:
void InitRegisters(bool bPostPif, CMipsMemoryVM & MMU); void InitRegisters(bool bPostPif, CMipsMemoryVM & MMU);
void DisplayRSPListCount(); void DisplayRSPListCount();
//CPU Methods // CPU methods
void ExecuteRecompiler(); void ExecuteRecompiler();
void ExecuteInterpret(); void ExecuteInterpret();
void ExecuteSyncCPU(); void ExecuteSyncCPU();
//Mark information saying that the CPU has stopped // Mark information saying that the CPU has stopped
void CpuStopped(); void CpuStopped();
//Functions in CTLB_CB // Functions in CTLB_CB
void TLB_Mapped(uint32_t VAddr, uint32_t Len, uint32_t PAddr, bool bReadOnly); void TLB_Mapped(uint32_t VAddr, uint32_t Len, uint32_t PAddr, bool bReadOnly);
void TLB_Unmaped(uint32_t VAddr, uint32_t Len); void TLB_Unmaped(uint32_t VAddr, uint32_t Len);
void TLB_Changed(); void TLB_Changed();
CPlugins * const m_Plugins; //The plugin container CPlugins * const m_Plugins; // The plugin container
CPlugins * m_SyncPlugins; CPlugins * m_SyncPlugins;
CN64System * m_SyncCPU; CN64System * m_SyncCPU;
CMipsMemoryVM m_MMU_VM; //Memory of the n64 CMipsMemoryVM m_MMU_VM; // Memory of the N64
CTLB m_TLB; CTLB m_TLB;
CRegisters m_Reg; CRegisters m_Reg;
CMempak m_Mempak; CMempak m_Mempak;
CFramePerSecond m_FPS; CFramePerSecond m_FPS;
CProfiling m_CPU_Usage; //used to track the cpu usage CProfiling m_CPU_Usage; // Used to track the CPU usage
CRecompiler * m_Recomp; CRecompiler * m_Recomp;
CAudio m_Audio; CAudio m_Audio;
CSpeedLimiter m_Limiter; CSpeedLimiter m_Limiter;
@ -155,24 +155,24 @@ private:
bool m_SyncSystem; bool m_SyncSystem;
CRandom m_Random; CRandom m_Random;
//When Syncing cores this is the PC where it last Sync'ed correctly // When syncing cores this is the PC where it last synced correctly
uint32_t m_LastSuccessSyncPC[10]; uint32_t m_LastSuccessSyncPC[10];
int32_t m_CyclesToSkip; int32_t m_CyclesToSkip;
//Handle to the cpu thread // Handle to the CPU thread
CThread * m_thread; CThread * m_thread;
//Handle to pause mutex // Handle to pause mutex
SyncEvent m_hPauseEvent; SyncEvent m_hPauseEvent;
//No of Alist and Dlist sent to the RSP // Number of Alist and Dlist sent to the RSP
uint32_t m_AlistCount, m_DlistCount, m_UnknownCount; uint32_t m_AlistCount, m_DlistCount, m_UnknownCount;
//list of function that have been called .. used in profiling // List of function that have been called (used in profiling)
FUNC_CALLS m_FunctionCalls; FUNC_CALLS m_FunctionCalls;
//list of Save State File IDs // List of save state file IDs
const uint32_t SaveID_0 = 0x23D8A6C8; //Main Save State Info (*.pj) const uint32_t SaveID_0 = 0x23D8A6C8; // Main save state info (*.pj)
const uint32_t SaveID_1 = 0x56D2CD23; //Extra Data v1 (System Timing) Info (*.dat) const uint32_t SaveID_1 = 0x56D2CD23; // Extra data v1 (system timing) info (*.dat)
const uint32_t SaveID_2 = 0x750A6BEB; //Extra Data v2 (Timing + Disk Registers) (*.dat) const uint32_t SaveID_2 = 0x750A6BEB; // Extra data v2 (timing + disk registers) (*.dat)
}; };

View File

@ -2,12 +2,13 @@
#include <stdint.h> #include <stdint.h>
/* /*
* The limits of COP1 extend to native SSE2 register capabilities, but for The limits of COP1 extend to native SSE2 register capabilities, but for
* now this is only being included to dodge the MSVC inline asm for x86. now this is only being included to dodge the MSVC inline assembler for x86.
*
* As better cross-platform methods of handling FP precision are implemented As better cross-platform methods of handling floating point precision are implemented
* for non-Intel-architecture builds, this #include may become obsolete. for non-Intel-architecture builds, this #include may become obsolete.
*/ */
#if defined(__i386) || defined(__x86_64__) || defined(_M_X64) #if defined(__i386) || defined(__x86_64__) || defined(_M_X64)
#include <emmintrin.h> #include <emmintrin.h>
#endif #endif

View File

@ -10,11 +10,11 @@ public:
void RecordTime(PROFILE_TIMERS timer, uint32_t time); void RecordTime(PROFILE_TIMERS timer, uint32_t time);
uint64_t NonCPUTime(void); uint64_t NonCPUTime(void);
//recording timing against current timer, returns the address of the timer stopped // Recording timing against the current timer, returns the address of the timer stopped
PROFILE_TIMERS StartTimer(PROFILE_TIMERS TimerType); PROFILE_TIMERS StartTimer(PROFILE_TIMERS TimerType);
PROFILE_TIMERS StopTimer(); PROFILE_TIMERS StopTimer();
//Display the CPU Usage // Display the CPU usage
void ShowCPU_Usage(); void ShowCPU_Usage();
void ResetTimers(void); void ResetTimers(void);

View File

@ -94,7 +94,7 @@ union Arm32Opcode
uint32_t Hex; uint32_t Hex;
uint8_t Ascii[4]; uint8_t Ascii[4];
// uint16 + uint16 type instuction // uint16 + uint16 type instruction
struct struct
{ {
unsigned rn : 4; unsigned rn : 4;

View File

@ -16,9 +16,8 @@ CArmOps::ArmReg CArmOps::m_LastStoreReg;
uint16_t CArmOps::m_PopRegisters = 0; uint16_t CArmOps::m_PopRegisters = 0;
uint16_t CArmOps::m_PushRegisters = 0; uint16_t CArmOps::m_PushRegisters = 0;
/************************************************************************** // Logging functions
* Logging Functions *
**************************************************************************/
void CArmOps::WriteArmComment(const char * Comment) void CArmOps::WriteArmComment(const char * Comment)
{ {
CPU_Message(""); CPU_Message("");
@ -126,7 +125,7 @@ void CArmOps::AddConstToArmReg(ArmReg DestReg, ArmReg SourceReg, uint32_t Const)
if (DestReg == SourceReg && Const == 0) if (DestReg == SourceReg && Const == 0)
{ {
//ignore // Ignore
} }
else if ((Const & 0xFFFFFFF8) == 0 && DestReg <= 7 && SourceReg <= 7) else if ((Const & 0xFFFFFFF8) == 0 && DestReg <= 7 && SourceReg <= 7)
{ {
@ -836,7 +835,7 @@ void CArmOps::PushArmReg(uint16_t Registers)
{ {
if (Registers == m_PopRegisters) if (Registers == m_PopRegisters)
{ {
CPU_Message("%s: Ignoring Push/Pop", __FUNCTION__); CPU_Message("%s: Ignoring push/pop", __FUNCTION__);
m_PopRegisters = 0; m_PopRegisters = 0;
PreOpCheck(Arm_Unknown, false, __FILE__, __LINE__); PreOpCheck(Arm_Unknown, false, __FILE__, __LINE__);
return; return;
@ -1373,7 +1372,7 @@ void CArmOps::XorConstToArmReg(ArmReg DestReg, uint32_t value)
if (value == 0) if (value == 0)
{ {
//ignore // Ignore
} }
else if (CanThumbCompressConst(value)) else if (CanThumbCompressConst(value))
{ {

View File

@ -115,13 +115,13 @@ public:
enum ArmCompareType enum ArmCompareType
{ {
ArmBranch_Equal = 0, //Code = 0000 ArmBranch_Equal = 0, // Code = 0000
ArmBranch_Notequal = 1, //Code = 0001 ArmBranch_Notequal = 1, // Code = 0001
ArmBranch_GreaterThanOrEqual = 10, //Code = 1010 ArmBranch_GreaterThanOrEqual = 10, // Code = 1010
ArmBranch_LessThan = 11, //Code = 1011 ArmBranch_LessThan = 11, // Code = 1011
ArmBranch_GreaterThan = 12, //Code = 1100 ArmBranch_GreaterThan = 12, // Code = 1100
ArmBranch_LessThanOrEqual = 13, //Code = 1101 ArmBranch_LessThanOrEqual = 13, // Code = 1101
ArmBranch_Always = 14, //Code = 1110 ArmBranch_Always = 14, // Code = 1110
}; };
enum ArmItMask enum ArmItMask
@ -144,7 +144,7 @@ public:
}; };
protected: protected:
//Logging Functions // Logging functions
static void WriteArmComment(const char * Comment); static void WriteArmComment(const char * Comment);
static void WriteArmLabel(const char * Label); static void WriteArmLabel(const char * Label);

View File

@ -166,7 +166,8 @@ void CArmRecompilerOps::Compile_TrapCompare(TRAP_COMPARE CompareType)
} }
} }
/************************** Branch functions ************************/ // Branch functions
void CArmRecompilerOps::Compile_BranchCompare(BRANCH_COMPARE CompareType) void CArmRecompilerOps::Compile_BranchCompare(BRANCH_COMPARE CompareType)
{ {
switch (CompareType) switch (CompareType)
@ -643,7 +644,7 @@ void CArmRecompilerOps::BNE_Compare()
if (m_Section->m_Jump.FallThrough) if (m_Section->m_Jump.FallThrough)
{ {
Jump = *g_RecompPos; Jump = *g_RecompPos;
BranchLabel8(ArmBranch_Notequal, "continue"); BranchLabel8(ArmBranch_Notequal, "Continue");
} }
else else
{ {
@ -721,7 +722,7 @@ void CArmRecompilerOps::BNE_Compare()
if (m_Section->m_Jump.FallThrough) if (m_Section->m_Jump.FallThrough)
{ {
Jump = *g_RecompPos; Jump = *g_RecompPos;
BranchLabel8(ArmBranch_Notequal, "continue"); BranchLabel8(ArmBranch_Notequal, "Continue");
} }
else else
{ {
@ -810,7 +811,7 @@ void CArmRecompilerOps::BNE_Compare()
if (m_Section->m_Jump.FallThrough) if (m_Section->m_Jump.FallThrough)
{ {
Jump = *g_RecompPos; Jump = *g_RecompPos;
BranchLabel8(ArmBranch_Notequal, "continue"); BranchLabel8(ArmBranch_Notequal, "Continue");
} }
else else
{ {
@ -885,7 +886,7 @@ void CArmRecompilerOps::BNE_Compare()
if (m_Section->m_Jump.FallThrough) if (m_Section->m_Jump.FallThrough)
{ {
Jump = *g_RecompPos; Jump = *g_RecompPos;
BranchLabel8(ArmBranch_Notequal, "continue"); BranchLabel8(ArmBranch_Notequal, "Continue");
} }
else else
{ {
@ -980,7 +981,7 @@ void CArmRecompilerOps::BEQ_Compare()
if (m_Section->m_Cont.FallThrough) if (m_Section->m_Cont.FallThrough)
{ {
Jump = *g_RecompPos; Jump = *g_RecompPos;
BranchLabel8(ArmBranch_Notequal, "continue"); BranchLabel8(ArmBranch_Notequal, "Continue");
} }
else else
{ {
@ -1057,7 +1058,7 @@ void CArmRecompilerOps::BEQ_Compare()
if (m_Section->m_Cont.FallThrough) if (m_Section->m_Cont.FallThrough)
{ {
Jump = *g_RecompPos; Jump = *g_RecompPos;
BranchLabel8(ArmBranch_Notequal, "continue"); BranchLabel8(ArmBranch_Notequal, "Continue");
} }
else else
{ {
@ -1141,7 +1142,7 @@ void CArmRecompilerOps::BEQ_Compare()
if (m_Section->m_Cont.FallThrough) if (m_Section->m_Cont.FallThrough)
{ {
Jump = *g_RecompPos; Jump = *g_RecompPos;
BranchLabel8(ArmBranch_Notequal, "continue"); BranchLabel8(ArmBranch_Notequal, "Continue");
} }
else else
{ {
@ -1204,7 +1205,7 @@ void CArmRecompilerOps::BEQ_Compare()
if (m_Section->m_Cont.FallThrough) if (m_Section->m_Cont.FallThrough)
{ {
Jump = *g_RecompPos; Jump = *g_RecompPos;
BranchLabel8(ArmBranch_Notequal, "continue"); BranchLabel8(ArmBranch_Notequal, "Continue");
} }
else else
{ {
@ -1328,12 +1329,12 @@ void CArmRecompilerOps::BGTZ_Compare()
BranchLabel20(ArmBranch_LessThan, m_Section->m_Cont.BranchLabel.c_str()); BranchLabel20(ArmBranch_LessThan, m_Section->m_Cont.BranchLabel.c_str());
m_Section->m_Cont.LinkLocation = (uint32_t *)(*g_RecompPos - 4); m_Section->m_Cont.LinkLocation = (uint32_t *)(*g_RecompPos - 4);
Jump = *g_RecompPos; Jump = *g_RecompPos;
BranchLabel8(ArmBranch_GreaterThan, "continue"); BranchLabel8(ArmBranch_GreaterThan, "Continue");
} }
else if (m_Section->m_Cont.FallThrough) else if (m_Section->m_Cont.FallThrough)
{ {
Jump = *g_RecompPos; Jump = *g_RecompPos;
BranchLabel8(ArmBranch_LessThan, "continue"); BranchLabel8(ArmBranch_LessThan, "Continue");
BranchLabel20(ArmBranch_GreaterThan, m_Section->m_Jump.BranchLabel.c_str()); BranchLabel20(ArmBranch_GreaterThan, m_Section->m_Jump.BranchLabel.c_str());
m_Section->m_Jump.LinkLocation = (uint32_t *)(*g_RecompPos - 4); m_Section->m_Jump.LinkLocation = (uint32_t *)(*g_RecompPos - 4);
} }
@ -1829,7 +1830,8 @@ void CArmRecompilerOps::COP1_BCT_Compare()
} }
} }
/************************* OpCode functions *************************/ // Opcode functions
void CArmRecompilerOps::J() void CArmRecompilerOps::J()
{ {
if (m_NextInstruction == NORMAL) if (m_NextInstruction == NORMAL)
@ -2335,8 +2337,8 @@ void CArmRecompilerOps::LW(bool ResultSigned, bool bRecordLLBit)
if (g_System->bFastSP() && m_Opcode.rt == 29) if (g_System->bFastSP() && m_Opcode.rt == 29)
{ {
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
/*ResetX86Protection(); //ResetX86Protection();
ResetMemoryStack();*/ //ResetMemoryStack();
} }
} }
@ -3671,7 +3673,7 @@ void CArmRecompilerOps::SPECIAL_SLT()
MoveConstToArmReg(useRdReg ? GetMipsRegMapLo(m_Opcode.rd) : UnknownArmReg, (uint16_t)0); MoveConstToArmReg(useRdReg ? GetMipsRegMapLo(m_Opcode.rd) : UnknownArmReg, (uint16_t)0);
CPU_Message(""); CPU_Message("");
CPU_Message(" Continue:"); CPU_Message(" continue:");
SetJump8(JumpContinue, *g_RecompPos); SetJump8(JumpContinue, *g_RecompPos);
if (!useRdReg) if (!useRdReg)
{ {
@ -3754,7 +3756,7 @@ void CArmRecompilerOps::SPECIAL_SLT()
MoveConstToArmReg(useRdReg ? GetMipsRegMapLo(m_Opcode.rd) : TempRegRt, (uint16_t)1); MoveConstToArmReg(useRdReg ? GetMipsRegMapLo(m_Opcode.rd) : TempRegRt, (uint16_t)1);
MoveConstToArmReg(useRdReg ? GetMipsRegMapLo(m_Opcode.rd) : TempRegRt, (uint16_t)0); MoveConstToArmReg(useRdReg ? GetMipsRegMapLo(m_Opcode.rd) : TempRegRt, (uint16_t)0);
CPU_Message(""); CPU_Message("");
CPU_Message(" Continue:"); CPU_Message(" continue:");
SetJump8(JumpContinue, *g_RecompPos); SetJump8(JumpContinue, *g_RecompPos);
if (!useRdReg) if (!useRdReg)
{ {
@ -3923,14 +3925,15 @@ void CArmRecompilerOps::SPECIAL_DSRA32()
} }
} }
/************************** COP0 functions **************************/ // COP0 functions
void CArmRecompilerOps::COP0_MF() void CArmRecompilerOps::COP0_MF()
{ {
if (m_Opcode.rt != 0) { UnMap_GPR(m_Opcode.rt, true); } if (m_Opcode.rt != 0) { UnMap_GPR(m_Opcode.rt, true); }
switch (m_Opcode.rd) switch (m_Opcode.rd)
{ {
case 9: //Count case 9: // Count
m_RegWorkingSet.SetBlockCycleCount(m_RegWorkingSet.GetBlockCycleCount() - g_System->CountPerOp()); m_RegWorkingSet.SetBlockCycleCount(m_RegWorkingSet.GetBlockCycleCount() - g_System->CountPerOp());
UpdateCounters(m_RegWorkingSet, false, true); UpdateCounters(m_RegWorkingSet, false, true);
m_RegWorkingSet.SetBlockCycleCount(m_RegWorkingSet.GetBlockCycleCount() + g_System->CountPerOp()); m_RegWorkingSet.SetBlockCycleCount(m_RegWorkingSet.GetBlockCycleCount() + g_System->CountPerOp());
@ -3952,21 +3955,21 @@ void CArmRecompilerOps::COP0_MT()
switch (m_Opcode.rd) switch (m_Opcode.rd)
{ {
case 0: //Index case 0: // Index
case 2: //EntryLo0 case 2: // EntryLo0
case 3: //EntryLo1 case 3: // EntryLo1
case 4: //Context case 4: // Context
case 5: //PageMask case 5: // PageMask
case 10: //Entry Hi case 10: // Entry Hi
case 12: //Status case 12: // Status
case 13: //cause case 13: // Cause
case 14: //EPC case 14: // EPC
case 16: //Config case 16: // Config
case 18: //WatchLo case 18: // WatchLo
case 19: //WatchHi case 19: // WatchHi
case 28: //Tag lo case 28: // Tag Lo
case 29: //Tag Hi case 29: // Tag Hi
case 30: //ErrEPC case 30: // ErrEPC
if (g_Settings->LoadBool(Game_32Bit)) if (g_Settings->LoadBool(Game_32Bit))
{ {
CompileInterpterCall((void *)R4300iOp32::COP0_MT, "R4300iOp32::COP0_MT"); CompileInterpterCall((void *)R4300iOp32::COP0_MT, "R4300iOp32::COP0_MT");
@ -3976,9 +3979,9 @@ void CArmRecompilerOps::COP0_MT()
CompileInterpterCall((void *)R4300iOp::COP0_MT, "R4300iOp::COP0_MT"); CompileInterpterCall((void *)R4300iOp::COP0_MT, "R4300iOp::COP0_MT");
} }
break; break;
case 6: //Wired case 6: // Wired
case 9: //Count case 9: // Count
case 11: //Compare case 11: // Compare
m_RegWorkingSet.SetBlockCycleCount(m_RegWorkingSet.GetBlockCycleCount() - g_System->CountPerOp()); m_RegWorkingSet.SetBlockCycleCount(m_RegWorkingSet.GetBlockCycleCount() - g_System->CountPerOp());
UpdateCounters(m_RegWorkingSet, false, true); UpdateCounters(m_RegWorkingSet, false, true);
m_RegWorkingSet.SetBlockCycleCount(m_RegWorkingSet.GetBlockCycleCount() + g_System->CountPerOp()); m_RegWorkingSet.SetBlockCycleCount(m_RegWorkingSet.GetBlockCycleCount() + g_System->CountPerOp());
@ -4080,7 +4083,8 @@ void CArmRecompilerOps::COP0_CO_ERET()
m_NextInstruction = END_BLOCK; m_NextInstruction = END_BLOCK;
} }
/************************** COP1 functions **************************/ // COP1 functions
void CArmRecompilerOps::COP1_MF() void CArmRecompilerOps::COP1_MF()
{ {
CompileCop1Test(); CompileCop1Test();
@ -4952,7 +4956,7 @@ void CArmRecompilerOps::SyncRegState(const CRegInfo & SyncTo)
if (m_RegWorkingSet.GetArmRegMapped((ArmReg)i) == CArmRegInfo::GPR_Mapped) if (m_RegWorkingSet.GetArmRegMapped((ArmReg)i) == CArmRegInfo::GPR_Mapped)
{ {
bool moved_gpr_mapping = false; bool moved_gpr_mapping = false;
//See if mapped, if so move it // See if mapped, if so move it
for (uint32_t z = 0; z < 16; z++) for (uint32_t z = 0; z < 16; z++)
{ {
if (SyncTo.GetArmRegMapped((ArmReg)z) != CArmRegInfo::GPR_Mapped) if (SyncTo.GetArmRegMapped((ArmReg)z) != CArmRegInfo::GPR_Mapped)
@ -4984,7 +4988,7 @@ void CArmRecompilerOps::SyncRegState(const CRegInfo & SyncTo)
} }
} }
bool moved = false; bool moved = false;
//See if mapped, if so move it // See if mapped, if so move it
for (uint32_t z = i + 1; z < 16; z++) for (uint32_t z = i + 1; z < 16; z++)
{ {
if (m_RegWorkingSet.GetArmRegMapped((ArmReg)z) == CArmRegInfo::Variable_Mapped && if (m_RegWorkingSet.GetArmRegMapped((ArmReg)z) == CArmRegInfo::Variable_Mapped &&
@ -5010,7 +5014,7 @@ void CArmRecompilerOps::SyncRegState(const CRegInfo & SyncTo)
if (m_RegWorkingSet.GetArmRegMapped((ArmReg)i) == CArmRegInfo::Variable_Mapped && if (m_RegWorkingSet.GetArmRegMapped((ArmReg)i) == CArmRegInfo::Variable_Mapped &&
m_RegWorkingSet.GetVariableMappedTo((ArmReg)i) != SyncTo.GetVariableMappedTo((ArmReg)i)) m_RegWorkingSet.GetVariableMappedTo((ArmReg)i) != SyncTo.GetVariableMappedTo((ArmReg)i))
{ {
//See if mapped, if so move it // See if mapped, if so move it
for (uint32_t z = i + 1; z < 16; z++) for (uint32_t z = i + 1; z < 16; z++)
{ {
if (SyncTo.GetArmRegMapped((ArmReg)z) != CArmRegInfo::Variable_Mapped || if (SyncTo.GetArmRegMapped((ArmReg)z) != CArmRegInfo::Variable_Mapped ||
@ -5053,14 +5057,14 @@ void CArmRecompilerOps::SyncRegState(const CRegInfo & SyncTo)
else if (MemStackReg == x86_Unknown) else if (MemStackReg == x86_Unknown)
{ {
UnMap_X86reg(TargetStackReg); UnMap_X86reg(TargetStackReg);
CPU_Message(" regcache: allocate %s as Memory Stack", x86_Name(TargetStackReg)); CPU_Message(" regcache: allocate %s as memory stack", x86_Name(TargetStackReg));
m_RegWorkingSet.SetX86Mapped(TargetStackReg, CRegInfo::Stack_Mapped); m_RegWorkingSet.SetX86Mapped(TargetStackReg, CRegInfo::Stack_Mapped);
MoveVariableToX86reg(&g_Recompiler->MemoryStackPos(), "MemoryStack", TargetStackReg); MoveVariableToX86reg(&g_Recompiler->MemoryStackPos(), "MemoryStack", TargetStackReg);
} }
else else
{ {
UnMap_X86reg(TargetStackReg); UnMap_X86reg(TargetStackReg);
CPU_Message(" regcache: change allocation of Memory Stack from %s to %s", x86_Name(MemStackReg), x86_Name(TargetStackReg)); CPU_Message(" regcache: change allocation of memory stack from %s to %s", x86_Name(MemStackReg), x86_Name(TargetStackReg));
m_RegWorkingSet.SetX86Mapped(TargetStackReg, CRegInfo::Stack_Mapped); m_RegWorkingSet.SetX86Mapped(TargetStackReg, CRegInfo::Stack_Mapped);
m_RegWorkingSet.SetX86Mapped(MemStackReg, CRegInfo::NotMapped); m_RegWorkingSet.SetX86Mapped(MemStackReg, CRegInfo::NotMapped);
MoveX86RegToX86Reg(MemStackReg, TargetStackReg); MoveX86RegToX86Reg(MemStackReg, TargetStackReg);
@ -5103,12 +5107,12 @@ void CArmRecompilerOps::SyncRegState(const CRegInfo & SyncTo)
case CRegInfo::STATE_CONST_32_SIGN: case CRegInfo::STATE_CONST_32_SIGN:
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 constant is different register %d (%s) Value: 0x%08X to 0x%08X", i, CRegName::GPR[i], GetMipsRegLo(i), SyncTo.GetMipsRegLo(i));
g_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 register state %d\nin SyncRegState", GetMipsRegState(i));
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
} }
} }
@ -5258,7 +5262,7 @@ void CArmRecompilerOps::SyncRegState(const CRegInfo & SyncTo)
case CRegInfo::STATE_CONST_32_SIGN: case CRegInfo::STATE_CONST_32_SIGN:
if (!g_System->b32BitCore() && GetMipsRegLo_S(i) < 0) if (!g_System->b32BitCore() && GetMipsRegLo_S(i) < 0)
{ {
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));
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
} }
@ -5503,7 +5507,7 @@ bool CArmRecompilerOps::InheritParentInfo()
return true; return true;
} }
//Multiple Parents // Multiple parents
BLOCK_PARENT_LIST ParentList; BLOCK_PARENT_LIST ParentList;
CCodeSection::SECTION_LIST::iterator iter; CCodeSection::SECTION_LIST::iterator iter;
for (iter = m_Section->m_ParentSection.begin(); iter != m_Section->m_ParentSection.end(); iter++) for (iter = m_Section->m_ParentSection.begin(); iter != m_Section->m_ParentSection.end(); iter++)
@ -5576,7 +5580,7 @@ bool CArmRecompilerOps::InheritParentInfo()
FirstParent = 0; FirstParent = 0;
} }
//Link First Parent to start // Link first parent to start
CCodeSection * Parent = ParentList[FirstParent].Parent; CCodeSection * Parent = ParentList[FirstParent].Parent;
CJumpInfo * JumpInfo = ParentList[FirstParent].JumpInfo; CJumpInfo * JumpInfo = ParentList[FirstParent].JumpInfo;
@ -5610,7 +5614,7 @@ bool CArmRecompilerOps::InheritParentInfo()
} }
JumpInfo->FallThrough = false; JumpInfo->FallThrough = false;
//determine loop reg usage // Determine loop register usage
if (m_Section->m_InLoop && ParentList.size() > 1) if (m_Section->m_InLoop && ParentList.size() > 1)
{ {
if (!SetupRegisterForLoop(m_Section->m_BlockInfo, m_Section->m_RegEnter)) { return false; } if (!SetupRegisterForLoop(m_Section->m_BlockInfo, m_Section->m_RegEnter)) { return false; }
@ -5632,7 +5636,7 @@ bool CArmRecompilerOps::InheritParentInfo()
if (m_RegWorkingSet.GetRoundingModel() != RegSet->GetRoundingModel()) { m_RegWorkingSet.SetRoundingModel(CRegInfo::RoundUnknown); } if (m_RegWorkingSet.GetRoundingModel() != RegSet->GetRoundingModel()) { m_RegWorkingSet.SetRoundingModel(CRegInfo::RoundUnknown); }
//Find Parent MapRegState // Find parent MapRegState
/*MemoryStackPos = x86_Unknown; /*MemoryStackPos = x86_Unknown;
for (i2 = 0; i2 < sizeof(x86_Registers) / sizeof(x86_Registers[0]); i2++) for (i2 = 0; i2 < sizeof(x86_Registers) / sizeof(x86_Registers[0]); i2++)
{ {
@ -5644,7 +5648,7 @@ bool CArmRecompilerOps::InheritParentInfo()
} }
if (MemoryStackPos == x86_Unknown) if (MemoryStackPos == x86_Unknown)
{ {
// if the memory stack position is not mapped then unmap it // If the memory stack position is not mapped then unmap it
x86Reg MemStackReg = Get_MemoryStack(); x86Reg MemStackReg = Get_MemoryStack();
if (MemStackReg != x86_Unknown) if (MemStackReg != x86_Unknown)
{ {
@ -5686,7 +5690,7 @@ bool CArmRecompilerOps::InheritParentInfo()
} }
break; break;
default: default:
CPU_Message("Unknown CPU State(%d) in InheritParentInfo", GetMipsRegState(i2)); CPU_Message("Unknown CPU state(%d) in InheritParentInfo", GetMipsRegState(i2));
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
} }
} }
@ -5729,7 +5733,7 @@ bool CArmRecompilerOps::InheritParentInfo()
} }
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));
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
break; break;
} }
@ -5755,7 +5759,7 @@ bool CArmRecompilerOps::InheritParentInfo()
} }
m_Section->m_RegEnter = m_RegWorkingSet; m_Section->m_RegEnter = m_RegWorkingSet;
//Sync registers for different blocks // Sync registers for different blocks
stdstr_f Label("Section_%d", m_Section->m_SectionID); stdstr_f Label("Section_%d", m_Section->m_SectionID);
int CurrentParent = FirstParent; int CurrentParent = FirstParent;
bool NeedSync = false; bool NeedSync = false;
@ -5828,7 +5832,7 @@ bool CArmRecompilerOps::InheritParentInfo()
} }
break; break;
default: default:
WriteTrace(TraceRecompiler, TraceError, "Unhandled Reg state %d\nin InheritParentInfo", GetMipsRegState(i2)); WriteTrace(TraceRecompiler, TraceError, "Unhandled register state %d\nin InheritParentInfo", GetMipsRegState(i2));
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
} }
} }
@ -5865,7 +5869,7 @@ bool CArmRecompilerOps::InheritParentInfo()
{ {
UpdateCounters(m_RegWorkingSet, false, true); UpdateCounters(m_RegWorkingSet, false, true);
} }
SyncRegState(m_Section->m_RegEnter); //Sync SyncRegState(m_Section->m_RegEnter); // Sync
m_Section->m_RegEnter = m_RegWorkingSet; m_Section->m_RegEnter = m_RegWorkingSet;
} }
@ -5966,7 +5970,7 @@ void CArmRecompilerOps::UpdateSyncCPU(CRegInfo & RegSet, uint32_t Cycles)
{ {
return; return;
} }
WriteArmComment("Updating Sync CPU"); WriteArmComment("Updating sync CPU");
RegSet.BeforeCallDirect(); RegSet.BeforeCallDirect();
MoveConstToArmReg(Arm_R2, Cycles); MoveConstToArmReg(Arm_R2, Cycles);
MoveConstToArmReg(Arm_R1, (uint32_t)g_SyncSystem, "g_SyncSystem"); MoveConstToArmReg(Arm_R1, (uint32_t)g_SyncSystem, "g_SyncSystem");
@ -5980,7 +5984,7 @@ void CArmRecompilerOps::UpdateCounters(CRegInfo & RegSet, bool CheckTimer, bool
if (RegSet.GetBlockCycleCount() != 0) if (RegSet.GetBlockCycleCount() != 0)
{ {
UpdateSyncCPU(RegSet, RegSet.GetBlockCycleCount()); UpdateSyncCPU(RegSet, RegSet.GetBlockCycleCount());
WriteArmComment("Update Counter"); WriteArmComment("Update counter");
ArmReg NextTimerReg = RegSet.Map_Variable(CArmRegInfo::VARIABLE_NEXT_TIMER); ArmReg NextTimerReg = RegSet.Map_Variable(CArmRegInfo::VARIABLE_NEXT_TIMER);
ArmReg TempReg = RegSet.Map_TempReg(Arm_Any, -1, false); ArmReg TempReg = RegSet.Map_TempReg(Arm_Any, -1, false);
@ -6133,7 +6137,7 @@ void CArmRecompilerOps::SW_Const(uint32_t Value, uint32_t VAddr)
default: default:
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str());
} }
} }
break; break;
@ -6169,10 +6173,10 @@ void CArmRecompilerOps::SW_Const(uint32_t Value, uint32_t VAddr)
case 0x0404001C: MoveConstToVariable(0, &g_Reg->SP_SEMAPHORE_REG, "SP_SEMAPHORE_REG"); break; case 0x0404001C: MoveConstToVariable(0, &g_Reg->SP_SEMAPHORE_REG, "SP_SEMAPHORE_REG"); break;
case 0x04080000: MoveConstToVariable(Value & 0xFFC, &g_Reg->SP_PC_REG, "SP_PC_REG"); break; case 0x04080000: MoveConstToVariable(Value & 0xFFC, &g_Reg->SP_PC_REG, "SP_PC_REG"); break;
default: default:
CPU_Message(" Should be moving %X in to %08X ?!?", Value, VAddr); CPU_Message(" should be moving %X in to %08X ?", Value, VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
@ -6191,7 +6195,7 @@ void CArmRecompilerOps::SW_Const(uint32_t Value, uint32_t VAddr)
default: default:
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
@ -6303,10 +6307,10 @@ void CArmRecompilerOps::SW_Const(uint32_t Value, uint32_t VAddr)
} }
break; break;
default: default:
CPU_Message(" Should be moving %X in to %08X ?!?", Value, VAddr); CPU_Message(" should be moving %X in to %08X ?", Value, VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
@ -6324,7 +6328,7 @@ void CArmRecompilerOps::SW_Const(uint32_t Value, uint32_t VAddr)
CompareArmRegToArmReg(TempReg, TempValueReg); CompareArmRegToArmReg(TempReg, TempValueReg);
uint8_t * Jump = *g_RecompPos; uint8_t * Jump = *g_RecompPos;
BranchLabel8(ArmBranch_Equal, "continue"); BranchLabel8(ArmBranch_Equal, "Continue");
m_RegWorkingSet.BeforeCallDirect(); m_RegWorkingSet.BeforeCallDirect();
ArmReg VariableReg = TempValueReg != Arm_R1 ? Arm_R1 : Arm_R2; ArmReg VariableReg = TempValueReg != Arm_R1 ? Arm_R1 : Arm_R2;
@ -6349,7 +6353,7 @@ void CArmRecompilerOps::SW_Const(uint32_t Value, uint32_t VAddr)
CompareArmRegToArmReg(TempReg, TempValueReg); CompareArmRegToArmReg(TempReg, TempValueReg);
uint8_t * Jump = *g_RecompPos; uint8_t * Jump = *g_RecompPos;
BranchLabel8(ArmBranch_Equal, "continue"); BranchLabel8(ArmBranch_Equal, "Continue");
MoveArmRegToVariable(TempValueReg, &g_Reg->VI_WIDTH_REG, "VI_WIDTH_REG"); MoveArmRegToVariable(TempValueReg, &g_Reg->VI_WIDTH_REG, "VI_WIDTH_REG");
m_RegWorkingSet.BeforeCallDirect(); m_RegWorkingSet.BeforeCallDirect();
@ -6357,7 +6361,7 @@ void CArmRecompilerOps::SW_Const(uint32_t Value, uint32_t VAddr)
m_RegWorkingSet.AfterCallDirect(); m_RegWorkingSet.AfterCallDirect();
FlushPopArmReg(); FlushPopArmReg();
CPU_Message(""); CPU_Message("");
CPU_Message(" Continue:"); CPU_Message(" continue:");
SetJump8(Jump, *g_RecompPos); SetJump8(Jump, *g_RecompPos);
} }
break; break;
@ -6379,15 +6383,15 @@ void CArmRecompilerOps::SW_Const(uint32_t Value, uint32_t VAddr)
case 0x04400030: MoveConstToVariable(Value, &g_Reg->VI_X_SCALE_REG, "VI_X_SCALE_REG"); break; case 0x04400030: MoveConstToVariable(Value, &g_Reg->VI_X_SCALE_REG, "VI_X_SCALE_REG"); break;
case 0x04400034: MoveConstToVariable(Value, &g_Reg->VI_Y_SCALE_REG, "VI_Y_SCALE_REG"); break; case 0x04400034: MoveConstToVariable(Value, &g_Reg->VI_Y_SCALE_REG, "VI_Y_SCALE_REG"); break;
default: default:
CPU_Message(" Should be moving %X in to %08X ?!?", Value, VAddr); CPU_Message(" should be moving %X in to %08X ?", Value, VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
break; break;
case 0x04500000: /* AI registers */ case 0x04500000: // AI registers
switch (PAddr) switch (PAddr)
{ {
case 0x04500000: MoveConstToVariable(Value, &g_Reg->AI_DRAM_ADDR_REG, "AI_DRAM_ADDR_REG"); break; case 0x04500000: MoveConstToVariable(Value, &g_Reg->AI_DRAM_ADDR_REG, "AI_DRAM_ADDR_REG"); break;
@ -6408,7 +6412,7 @@ void CArmRecompilerOps::SW_Const(uint32_t Value, uint32_t VAddr)
break; break;
case 0x04500008: MoveConstToVariable((Value & 1), &g_Reg->AI_CONTROL_REG, "AI_CONTROL_REG"); break; case 0x04500008: MoveConstToVariable((Value & 1), &g_Reg->AI_CONTROL_REG, "AI_CONTROL_REG"); break;
case 0x0450000C: case 0x0450000C:
/* Clear Interrupt */; // Clear interrupt
AndConstToVariable(&g_Reg->MI_INTR_REG, "MI_INTR_REG", (uint32_t)~MI_INTR_AI); AndConstToVariable(&g_Reg->MI_INTR_REG, "MI_INTR_REG", (uint32_t)~MI_INTR_AI);
AndConstToVariable(&g_Reg->m_AudioIntrReg, "m_AudioIntrReg", (uint32_t)~MI_INTR_AI); AndConstToVariable(&g_Reg->m_AudioIntrReg, "m_AudioIntrReg", (uint32_t)~MI_INTR_AI);
m_RegWorkingSet.BeforeCallDirect(); m_RegWorkingSet.BeforeCallDirect();
@ -6426,10 +6430,10 @@ void CArmRecompilerOps::SW_Const(uint32_t Value, uint32_t VAddr)
break; break;
case 0x04500014: MoveConstToVariable(Value, &g_Reg->AI_BITRATE_REG, "AI_BITRATE_REG"); break; case 0x04500014: MoveConstToVariable(Value, &g_Reg->AI_BITRATE_REG, "AI_BITRATE_REG"); break;
default: default:
CPU_Message(" Should be moving %X in to %08X ?!?", Value, VAddr); CPU_Message(" should be moving %X in to %08X ?", Value, VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
@ -6475,10 +6479,10 @@ void CArmRecompilerOps::SW_Const(uint32_t Value, uint32_t VAddr)
case 0x0460002C: MoveConstToVariable((Value & 0xFF), &g_Reg->PI_BSD_DOM2_PGS_REG, "PI_BSD_DOM2_PGS_REG"); break; case 0x0460002C: MoveConstToVariable((Value & 0xFF), &g_Reg->PI_BSD_DOM2_PGS_REG, "PI_BSD_DOM2_PGS_REG"); break;
case 0x04600030: MoveConstToVariable((Value & 0xFF), &g_Reg->PI_BSD_DOM2_RLS_REG, "PI_BSD_DOM2_RLS_REG"); break; case 0x04600030: MoveConstToVariable((Value & 0xFF), &g_Reg->PI_BSD_DOM2_RLS_REG, "PI_BSD_DOM2_RLS_REG"); break;
default: default:
CPU_Message(" Should be moving %X in to %08X ?!?", Value, VAddr); CPU_Message(" should be moving %X in to %08X ?", Value, VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
@ -6491,10 +6495,10 @@ void CArmRecompilerOps::SW_Const(uint32_t Value, uint32_t VAddr)
case 0x04700008: MoveConstToVariable(Value, &g_Reg->RI_CURRENT_LOAD_REG, "RI_CURRENT_LOAD_REG"); break; case 0x04700008: MoveConstToVariable(Value, &g_Reg->RI_CURRENT_LOAD_REG, "RI_CURRENT_LOAD_REG"); break;
case 0x0470000C: MoveConstToVariable(Value, &g_Reg->RI_SELECT_REG, "RI_SELECT_REG"); break; case 0x0470000C: MoveConstToVariable(Value, &g_Reg->RI_SELECT_REG, "RI_SELECT_REG"); break;
default: default:
CPU_Message(" Should be moving %X in to %08X ?!?", Value, VAddr); CPU_Message(" should be moving %X in to %08X ?", Value, VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
@ -6532,16 +6536,16 @@ void CArmRecompilerOps::SW_Const(uint32_t Value, uint32_t VAddr)
m_RegWorkingSet.AfterCallDirect(); m_RegWorkingSet.AfterCallDirect();
break; break;
default: default:
CPU_Message(" Should be moving %X in to %08X ?!?", Value, VAddr); CPU_Message(" should be moving %X in to %08X ?", Value, VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
break; break;
case 0x05000000: case 0x05000000:
//64DD Registers // 64DD registers
if (g_Settings->LoadBool(Setting_EnableDisk)) if (g_Settings->LoadBool(Setting_EnableDisk))
{ {
switch (PAddr) switch (PAddr)
@ -6552,10 +6556,10 @@ void CArmRecompilerOps::SW_Const(uint32_t Value, uint32_t VAddr)
m_RegWorkingSet.AfterCallDirect(); m_RegWorkingSet.AfterCallDirect();
break; break;
default: default:
CPU_Message(" Should be moving %X in to %08X ?!?", Value, VAddr); CPU_Message(" should be moving %X in to %08X ?", Value, VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
@ -6574,10 +6578,10 @@ void CArmRecompilerOps::SW_Const(uint32_t Value, uint32_t VAddr)
m_RegWorkingSet.AfterCallDirect(); m_RegWorkingSet.AfterCallDirect();
break; break;
default: default:
CPU_Message(" Should be moving %X in to %08X ?!?", Value, VAddr); CPU_Message(" should be moving %X in to %08X ?", Value, VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store %08X in %08X?", __FUNCTION__, Value, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
@ -6641,10 +6645,10 @@ void CArmRecompilerOps::SW_Register(ArmReg Reg, uint32_t VAddr)
case 0x03F8000C: break; case 0x03F8000C: break;
case 0x03F80014: break; case 0x03F80014: break;
default: default:
CPU_Message(" Should be moving %s in to %08X ?!?", ArmRegName(Reg), VAddr); CPU_Message(" should be moving %s in to %08X ?", ArmRegName(Reg), VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store in %08X?", __FUNCTION__, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store in %08X?", __FUNCTION__, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
@ -6689,10 +6693,10 @@ void CArmRecompilerOps::SW_Register(ArmReg Reg, uint32_t VAddr)
} }
else else
{ {
CPU_Message(" Should be moving %s in to %08X ?!?", ArmRegName(Reg), VAddr); CPU_Message(" should be moving %s in to %08X ?", ArmRegName(Reg), VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store in %08X?", __FUNCTION__, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store in %08X?", __FUNCTION__, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
@ -6732,10 +6736,10 @@ void CArmRecompilerOps::SW_Register(ArmReg Reg, uint32_t VAddr)
m_RegWorkingSet.AfterCallDirect(); m_RegWorkingSet.AfterCallDirect();
break; break;
default: default:
CPU_Message(" Should be moving %s in to %08X ?!?", ArmRegName(Reg), VAddr); CPU_Message(" should be moving %s in to %08X ?", ArmRegName(Reg), VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store in %08X?", __FUNCTION__, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store in %08X?", __FUNCTION__, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
@ -6750,7 +6754,7 @@ void CArmRecompilerOps::SW_Register(ArmReg Reg, uint32_t VAddr)
CompareArmRegToArmReg(TempReg, Reg); CompareArmRegToArmReg(TempReg, Reg);
uint8_t * Jump = *g_RecompPos; uint8_t * Jump = *g_RecompPos;
BranchLabel8(ArmBranch_Equal, "continue"); BranchLabel8(ArmBranch_Equal, "Continue");
MoveArmRegToVariable(Reg, &g_Reg->VI_STATUS_REG, "VI_STATUS_REG"); MoveArmRegToVariable(Reg, &g_Reg->VI_STATUS_REG, "VI_STATUS_REG");
m_RegWorkingSet.BeforeCallDirect(); m_RegWorkingSet.BeforeCallDirect();
@ -6758,7 +6762,7 @@ void CArmRecompilerOps::SW_Register(ArmReg Reg, uint32_t VAddr)
m_RegWorkingSet.AfterCallDirect(); m_RegWorkingSet.AfterCallDirect();
FlushPopArmReg(); FlushPopArmReg();
CPU_Message(""); CPU_Message("");
CPU_Message(" Continue:"); CPU_Message(" continue:");
SetJump8(Jump, *g_RecompPos); SetJump8(Jump, *g_RecompPos);
} }
break; break;
@ -6782,7 +6786,7 @@ void CArmRecompilerOps::SW_Register(ArmReg Reg, uint32_t VAddr)
m_RegWorkingSet.AfterCallDirect(); m_RegWorkingSet.AfterCallDirect();
FlushPopArmReg(); FlushPopArmReg();
CPU_Message(""); CPU_Message("");
CPU_Message(" Continue:"); CPU_Message(" continue:");
SetJump8(Jump, *g_RecompPos); SetJump8(Jump, *g_RecompPos);
} }
break; break;
@ -6804,14 +6808,14 @@ void CArmRecompilerOps::SW_Register(ArmReg Reg, uint32_t VAddr)
case 0x04400030: MoveArmRegToVariable(Reg, &g_Reg->VI_X_SCALE_REG, "VI_X_SCALE_REG"); break; case 0x04400030: MoveArmRegToVariable(Reg, &g_Reg->VI_X_SCALE_REG, "VI_X_SCALE_REG"); break;
case 0x04400034: MoveArmRegToVariable(Reg, &g_Reg->VI_Y_SCALE_REG, "VI_Y_SCALE_REG"); break; case 0x04400034: MoveArmRegToVariable(Reg, &g_Reg->VI_Y_SCALE_REG, "VI_Y_SCALE_REG"); break;
default: default:
CPU_Message(" Should be moving %s in to %08X ?!?", ArmRegName(Reg), VAddr); CPU_Message(" should be moving %s in to %08X ?", ArmRegName(Reg), VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store in %08X?", __FUNCTION__, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store in %08X?", __FUNCTION__, VAddr).c_str());
} }
} }
break; break;
case 0x04500000: /* AI registers */ case 0x04500000: // AI registers
switch (PAddr) { switch (PAddr) {
case 0x04500000: MoveArmRegToVariable(Reg, &g_Reg->AI_DRAM_ADDR_REG, "AI_DRAM_ADDR_REG"); break; case 0x04500000: MoveArmRegToVariable(Reg, &g_Reg->AI_DRAM_ADDR_REG, "AI_DRAM_ADDR_REG"); break;
case 0x04500004: case 0x04500004:
@ -6835,7 +6839,7 @@ void CArmRecompilerOps::SW_Register(ArmReg Reg, uint32_t VAddr)
MoveArmRegToVariable(Reg, &g_Reg->AI_CONTROL_REG, "AI_CONTROL_REG"); MoveArmRegToVariable(Reg, &g_Reg->AI_CONTROL_REG, "AI_CONTROL_REG");
AndConstToVariable(&g_Reg->AI_CONTROL_REG, "AI_CONTROL_REG", 1); AndConstToVariable(&g_Reg->AI_CONTROL_REG, "AI_CONTROL_REG", 1);
case 0x0450000C: case 0x0450000C:
/* Clear Interrupt */; // Clear interrupt
AndConstToVariable(&g_Reg->MI_INTR_REG, "MI_INTR_REG", (uint32_t)~MI_INTR_AI); AndConstToVariable(&g_Reg->MI_INTR_REG, "MI_INTR_REG", (uint32_t)~MI_INTR_AI);
AndConstToVariable(&g_Reg->m_AudioIntrReg, "m_AudioIntrReg", (uint32_t)~MI_INTR_AI); AndConstToVariable(&g_Reg->m_AudioIntrReg, "m_AudioIntrReg", (uint32_t)~MI_INTR_AI);
m_RegWorkingSet.BeforeCallDirect(); m_RegWorkingSet.BeforeCallDirect();
@ -6859,7 +6863,7 @@ void CArmRecompilerOps::SW_Register(ArmReg Reg, uint32_t VAddr)
MoveArmRegToVariable(Reg, PAddr + g_MMU->Rdram(), stdstr_f("RDRAM + %X", PAddr).c_str()); MoveArmRegToVariable(Reg, PAddr + g_MMU->Rdram(), stdstr_f("RDRAM + %X", PAddr).c_str());
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store in %08X?", __FUNCTION__, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store in %08X?", __FUNCTION__, VAddr).c_str());
} }
} }
break; break;
@ -6896,7 +6900,7 @@ void CArmRecompilerOps::SW_Register(ArmReg Reg, uint32_t VAddr)
case 0x04600010: case 0x04600010:
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store in %08X?", __FUNCTION__, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store in %08X?", __FUNCTION__, VAddr).c_str());
} }
AndConstToVariable(&g_Reg->MI_INTR_REG, "MI_INTR_REG", (uint32_t)~MI_INTR_PI); AndConstToVariable(&g_Reg->MI_INTR_REG, "MI_INTR_REG", (uint32_t)~MI_INTR_PI);
m_RegWorkingSet.BeforeCallDirect(); m_RegWorkingSet.BeforeCallDirect();
@ -6937,10 +6941,10 @@ void CArmRecompilerOps::SW_Register(ArmReg Reg, uint32_t VAddr)
AndConstToVariable(&g_Reg->PI_BSD_DOM2_RLS_REG, "PI_BSD_DOM2_RLS_REG", 0xFF); AndConstToVariable(&g_Reg->PI_BSD_DOM2_RLS_REG, "PI_BSD_DOM2_RLS_REG", 0xFF);
break; break;
default: default:
CPU_Message(" Should be moving %s in to %08X ?!?", ArmRegName(Reg), VAddr); CPU_Message(" should be moving %s in to %08X ?", ArmRegName(Reg), VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store in %08X?", __FUNCTION__, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store in %08X?", __FUNCTION__, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
@ -6953,10 +6957,10 @@ void CArmRecompilerOps::SW_Register(ArmReg Reg, uint32_t VAddr)
case 0x0470000C: MoveArmRegToVariable(Reg, &g_Reg->RI_SELECT_REG, "RI_SELECT_REG"); break; case 0x0470000C: MoveArmRegToVariable(Reg, &g_Reg->RI_SELECT_REG, "RI_SELECT_REG"); break;
case 0x04700010: MoveArmRegToVariable(Reg, &g_Reg->RI_REFRESH_REG, "RI_REFRESH_REG"); break; case 0x04700010: MoveArmRegToVariable(Reg, &g_Reg->RI_REFRESH_REG, "RI_REFRESH_REG"); break;
default: default:
CPU_Message(" Should be moving %s in to %08X ?!?", ArmRegName(Reg), VAddr); CPU_Message(" should be moving %s in to %08X ?", ArmRegName(Reg), VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store in %08X?", __FUNCTION__, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store in %08X?", __FUNCTION__, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
@ -6988,23 +6992,23 @@ void CArmRecompilerOps::SW_Register(ArmReg Reg, uint32_t VAddr)
m_RegWorkingSet.AfterCallDirect(); m_RegWorkingSet.AfterCallDirect();
break; break;
default: default:
CPU_Message(" Should be moving %s in to %08X ?!?", ArmRegName(Reg), VAddr); CPU_Message(" should be moving %s in to %08X ?", ArmRegName(Reg), VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store in %08X?", __FUNCTION__, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store in %08X?", __FUNCTION__, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
break; break;
case 0x05000000: case 0x05000000:
//64DD Registers // 64DD registers
if (g_Settings->LoadBool(Setting_EnableDisk)) if (g_Settings->LoadBool(Setting_EnableDisk))
{ {
switch (PAddr) switch (PAddr)
{ {
case 0x05000500: MoveArmRegToVariable(Reg, &g_Reg->ASIC_DATA, "ASIC_DATA"); break; case 0x05000500: MoveArmRegToVariable(Reg, &g_Reg->ASIC_DATA, "ASIC_DATA"); break;
case 0x05000508: case 0x05000508:
//ASIC_CMD // ASIC_CMD
MoveArmRegToVariable(Reg, &g_Reg->ASIC_CMD, "ASIC_CMD"); MoveArmRegToVariable(Reg, &g_Reg->ASIC_CMD, "ASIC_CMD");
m_RegWorkingSet.BeforeCallDirect(); m_RegWorkingSet.BeforeCallDirect();
CallFunction(AddressOf(&DiskCommand), "DiskCommand"); CallFunction(AddressOf(&DiskCommand), "DiskCommand");
@ -7017,7 +7021,7 @@ void CArmRecompilerOps::SW_Register(ArmReg Reg, uint32_t VAddr)
m_RegWorkingSet.AfterCallDirect(); m_RegWorkingSet.AfterCallDirect();
break; break;
case 0x05000510: case 0x05000510:
//ASIC_BM_CTL // ASIC_BM_CTL
MoveArmRegToVariable(Reg, &g_Reg->ASIC_BM_CTL, "ASIC_BM_CTL"); MoveArmRegToVariable(Reg, &g_Reg->ASIC_BM_CTL, "ASIC_BM_CTL");
m_RegWorkingSet.BeforeCallDirect(); m_RegWorkingSet.BeforeCallDirect();
CallFunction(AddressOf(&DiskBMControl), "DiskBMControl"); CallFunction(AddressOf(&DiskBMControl), "DiskBMControl");
@ -7040,10 +7044,10 @@ void CArmRecompilerOps::SW_Register(ArmReg Reg, uint32_t VAddr)
MoveArmRegToVariable(Reg, PAddr + g_MMU->Rdram(), stdstr_f("RDRAM + %X", PAddr).c_str()); MoveArmRegToVariable(Reg, PAddr + g_MMU->Rdram(), stdstr_f("RDRAM + %X", PAddr).c_str());
break; break;
default: default:
CPU_Message(" Should be moving %s in to %08X ?!?", ArmRegName(Reg), VAddr); CPU_Message(" should be moving %s in to %08X ?", ArmRegName(Reg), VAddr);
if (ShowUnhandledMemory()) if (ShowUnhandledMemory())
{ {
g_Notify->DisplayError(stdstr_f("%s\ntrying to store in %08X?", __FUNCTION__, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nTrying to store in %08X?", __FUNCTION__, VAddr).c_str());
} }
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
@ -7084,7 +7088,7 @@ void CArmRecompilerOps::LB_KnownAddress(ArmReg Reg, uint32_t VAddr, bool SignExt
SignExtendByte(Reg); SignExtendByte(Reg);
break; break;
default: default:
CPU_Message(" Should be loading from %08X ?!?", VAddr); CPU_Message(" should be loading from %08X ?", VAddr);
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
} }
@ -7157,7 +7161,7 @@ void CArmRecompilerOps::LW_KnownAddress(ArmReg Reg, uint32_t VAddr)
{ {
g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str());
} }
CPU_Message(" Should be loading from %08X ?!?", VAddr); CPU_Message(" should be loading from %08X ?", VAddr);
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
break; break;
@ -7180,7 +7184,7 @@ void CArmRecompilerOps::LW_KnownAddress(ArmReg Reg, uint32_t VAddr)
default: default:
MoveConstToArmReg(Reg, (uint32_t)0); MoveConstToArmReg(Reg, (uint32_t)0);
if (ShowUnhandledMemory()) { g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str()); } if (ShowUnhandledMemory()) { g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str()); }
CPU_Message(" Should be loading from %08X ?!?", VAddr); CPU_Message(" should be loading from %08X ?", VAddr);
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
break; break;
@ -7200,11 +7204,11 @@ void CArmRecompilerOps::LW_KnownAddress(ArmReg Reg, uint32_t VAddr)
default: default:
MoveConstToArmReg(Reg, (uint32_t)0); MoveConstToArmReg(Reg, (uint32_t)0);
if (ShowUnhandledMemory()) { g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str()); } if (ShowUnhandledMemory()) { g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str()); }
CPU_Message(" Should be loading from %08X ?!?", VAddr); CPU_Message(" should be loading from %08X ?", VAddr);
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
break; break;
case 0x04500000: /* AI registers */ case 0x04500000: // AI registers
switch (PAddr) switch (PAddr)
{ {
case 0x04500004: case 0x04500004:
@ -7257,7 +7261,7 @@ void CArmRecompilerOps::LW_KnownAddress(ArmReg Reg, uint32_t VAddr)
default: default:
MoveConstToArmReg(Reg, (uint32_t)0); MoveConstToArmReg(Reg, (uint32_t)0);
if (ShowUnhandledMemory()) { g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str()); } if (ShowUnhandledMemory()) { g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str()); }
CPU_Message(" Should be loading from %08X ?!?", VAddr); CPU_Message(" should be loading from %08X ?", VAddr);
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
break; break;
@ -7283,7 +7287,7 @@ void CArmRecompilerOps::LW_KnownAddress(ArmReg Reg, uint32_t VAddr)
{ {
g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str());
} }
CPU_Message(" Should be loading from %08X ?!?", VAddr); CPU_Message(" should be loading from %08X ?", VAddr);
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
break; break;
@ -7298,7 +7302,7 @@ void CArmRecompilerOps::LW_KnownAddress(ArmReg Reg, uint32_t VAddr)
{ {
g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str());
} }
CPU_Message(" Should be loading from %08X ?!?", VAddr); CPU_Message(" should be loading from %08X ?", VAddr);
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
break; break;
@ -7313,12 +7317,12 @@ void CArmRecompilerOps::LW_KnownAddress(ArmReg Reg, uint32_t VAddr)
{ {
g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str());
} }
CPU_Message(" Should be loading from %08X ?!?", VAddr); CPU_Message(" should be loading from %08X ?", VAddr);
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
break; break;
case 0x05000000: case 0x05000000:
//64DD Registers // 64DD registers
if (g_Settings->LoadBool(Setting_EnableDisk)) if (g_Settings->LoadBool(Setting_EnableDisk))
{ {
switch (PAddr) switch (PAddr)
@ -7353,7 +7357,7 @@ void CArmRecompilerOps::LW_KnownAddress(ArmReg Reg, uint32_t VAddr)
{ {
g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str()); g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str());
} }
CPU_Message(" Should be loading from %08X ?!?", VAddr); CPU_Message(" should be loading from %08X ?", VAddr);
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
} }
@ -7375,11 +7379,11 @@ void CArmRecompilerOps::LW_KnownAddress(ArmReg Reg, uint32_t VAddr)
if ((PAddr & 0xF0000000) == 0x10000000 && (PAddr - 0x10000000) < g_Rom->GetRomSize()) if ((PAddr & 0xF0000000) == 0x10000000 && (PAddr - 0x10000000) < g_Rom->GetRomSize())
{ {
uint32_t RomOffset = PAddr - 0x10000000; uint32_t RomOffset = PAddr - 0x10000000;
MoveVariableToArmReg(RomOffset + g_Rom->GetRomAddress(), stdstr_f("ROM + %X", RomOffset).c_str(), Reg); // read from rom MoveVariableToArmReg(RomOffset + g_Rom->GetRomAddress(), stdstr_f("ROM + %X", RomOffset).c_str(), Reg); // Read from ROM
} }
else else
{ {
CPU_Message(" Should be loading from %08X ?!?", VAddr); CPU_Message(" should be loading from %08X ?", VAddr);
if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); } if (HaveDebugger()) { g_Notify->BreakPoint(__FILE__, __LINE__); }
} }
} }

View File

@ -12,10 +12,10 @@ class CArmRecompilerOps :
public: public:
CArmRecompilerOps(); CArmRecompilerOps();
/*************************** Trap functions *************************/ // Trap functions
void Compile_TrapCompare(TRAP_COMPARE CompareType); void Compile_TrapCompare(TRAP_COMPARE CompareType);
/************************** Branch functions ************************/ // Branch functions
void Compile_BranchCompare(BRANCH_COMPARE CompareType); void Compile_BranchCompare(BRANCH_COMPARE CompareType);
void Compile_Branch(BRANCH_COMPARE CompareType, BRANCH_TYPE BranchType, bool Link); void Compile_Branch(BRANCH_COMPARE CompareType, BRANCH_TYPE BranchType, bool Link);
void Compile_BranchLikely(BRANCH_COMPARE CompareType, bool Link); void Compile_BranchLikely(BRANCH_COMPARE CompareType, bool Link);
@ -28,7 +28,7 @@ public:
void COP1_BCF_Compare(); void COP1_BCF_Compare();
void COP1_BCT_Compare(); void COP1_BCT_Compare();
/************************* OpCode functions *************************/ // Opcode functions
void J (); void J ();
void JAL (); void JAL ();
void ADDI (); void ADDI ();
@ -67,7 +67,7 @@ public:
void SDC1 (); void SDC1 ();
void SD (); void SD ();
/********************** R4300i OpCodes: Special **********************/ // R4300i opcodes: Special
void SPECIAL_SLL (); void SPECIAL_SLL ();
void SPECIAL_SRL (); void SPECIAL_SRL ();
void SPECIAL_SRA (); void SPECIAL_SRA ();
@ -113,18 +113,18 @@ public:
void SPECIAL_DSRL32 (); void SPECIAL_DSRL32 ();
void SPECIAL_DSRA32 (); void SPECIAL_DSRA32 ();
/************************** COP0 functions **************************/ // COP0 functions
void COP0_MF (); void COP0_MF ();
void COP0_MT (); void COP0_MT ();
/************************** COP0 CO functions ***********************/ // COP0 CO functions
void COP0_CO_TLBR (); void COP0_CO_TLBR ();
void COP0_CO_TLBWI (); void COP0_CO_TLBWI ();
void COP0_CO_TLBWR (); void COP0_CO_TLBWR ();
void COP0_CO_TLBP (); void COP0_CO_TLBP ();
void COP0_CO_ERET (); void COP0_CO_ERET ();
/************************** COP1 functions **************************/ // COP1 functions
void COP1_MF (); void COP1_MF ();
void COP1_DMF (); void COP1_DMF ();
void COP1_CF (); void COP1_CF ();
@ -132,7 +132,7 @@ public:
void COP1_DMT (); void COP1_DMT ();
void COP1_CT (); void COP1_CT ();
/************************** COP1: S functions ************************/ // COP1: S functions
void COP1_S_ADD (); void COP1_S_ADD ();
void COP1_S_SUB (); void COP1_S_SUB ();
void COP1_S_MUL (); void COP1_S_MUL ();
@ -154,7 +154,7 @@ public:
void COP1_S_CVT_L (); void COP1_S_CVT_L ();
void COP1_S_CMP (); void COP1_S_CMP ();
/************************** COP1: D functions ************************/ // COP1: D functions
void COP1_D_ADD (); void COP1_D_ADD ();
void COP1_D_SUB (); void COP1_D_SUB ();
void COP1_D_MUL (); void COP1_D_MUL ();
@ -176,15 +176,15 @@ public:
void COP1_D_CVT_L (); void COP1_D_CVT_L ();
void COP1_D_CMP (); void COP1_D_CMP ();
/************************** COP1: W functions ************************/ // COP1: W functions
void COP1_W_CVT_S (); void COP1_W_CVT_S ();
void COP1_W_CVT_D (); void COP1_W_CVT_D ();
/************************** COP1: L functions ************************/ // COP1: L functions
void COP1_L_CVT_S (); void COP1_L_CVT_S ();
void COP1_L_CVT_D (); void COP1_L_CVT_D ();
/************************** Other functions **************************/ // Other functions
void UnknownOpcode (); void UnknownOpcode ();
private: private:
@ -220,7 +220,7 @@ private:
void CompileExecuteBP(void); void CompileExecuteBP(void);
void CompileExecuteDelaySlotBP(void); void CompileExecuteDelaySlotBP(void);
/********* Helper Functions *********/ // Helper functions
typedef CRegInfo::REG_STATE REG_STATE; typedef CRegInfo::REG_STATE REG_STATE;
static inline REG_STATE GetMipsRegState(int32_t Reg) { return m_RegWorkingSet.GetMipsRegState(Reg); } static inline REG_STATE GetMipsRegState(int32_t Reg) { return m_RegWorkingSet.GetMipsRegState(Reg); }

View File

@ -265,7 +265,7 @@ void CArmRegInfo::Map_GPR_32bit(int32_t MipsReg, bool SignValue, int32_t MipsReg
{ {
if (Is64Bit(MipsReg)) if (Is64Bit(MipsReg))
{ {
CPU_Message(" regcache: unallocate %s from high 32bit of %s", ArmRegName(GetMipsRegMapHi(MipsReg)), CRegName::GPR_Hi[MipsReg]); CPU_Message(" regcache: unallocate %s from high 32-bit of %s", ArmRegName(GetMipsRegMapHi(MipsReg)), CRegName::GPR_Hi[MipsReg]);
SetArmRegMapOrder(GetMipsRegMapHi(MipsReg), 0); SetArmRegMapOrder(GetMipsRegMapHi(MipsReg), 0);
SetArmRegMapped(GetMipsRegMapHi(MipsReg), NotMapped); SetArmRegMapped(GetMipsRegMapHi(MipsReg), NotMapped);
SetArmRegProtected(GetMipsRegMapHi(MipsReg), false); SetArmRegProtected(GetMipsRegMapHi(MipsReg), false);
@ -327,7 +327,7 @@ void CArmRegInfo::Map_GPR_64bit(int32_t MipsReg, int32_t MipsRegToLoad)
if (MipsReg == 0) if (MipsReg == 0)
{ {
if (HaveDebugger()) { g_Notify->DisplayError("Map_GPR_64bit\n\nWhy are you trying to map reg 0"); } if (HaveDebugger()) { g_Notify->DisplayError("Map_GPR_64bit\n\nWhy are you trying to map register 0?"); }
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
return; return;
} }
@ -466,7 +466,7 @@ void CArmRegInfo::UnMap_GPR(uint32_t MipsReg, bool WriteBackValue)
{ {
if (HaveDebugger()) if (HaveDebugger())
{ {
g_Notify->DisplayError(stdstr_f("%s\n\nWhy are you trying to unmap reg 0", __FUNCTION__).c_str()); g_Notify->DisplayError(stdstr_f("%s\n\nWhy are you trying to unmap register 0?", __FUNCTION__).c_str());
} }
return; return;
} }
@ -502,7 +502,7 @@ void CArmRegInfo::WriteBack_GPR(uint32_t MipsReg, bool Unmapping)
{ {
if (HaveDebugger()) if (HaveDebugger())
{ {
g_Notify->DisplayError(stdstr_f("%s\n\nWhy are you trying to unmap reg 0", __FUNCTION__).c_str()); g_Notify->DisplayError(stdstr_f("%s\n\nWhy are you trying to unmap register 0?", __FUNCTION__).c_str());
} }
return; return;
} }
@ -597,7 +597,7 @@ void CArmRegInfo::WriteBackRegisters()
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
break; break;
default: default:
CPU_Message("%s: Unknown State: %d reg %d (%s)", __FUNCTION__, GetMipsRegState(count), count, CRegName::GPR[count]); CPU_Message("%s: Unknown state: %d reg %d (%s)", __FUNCTION__, GetMipsRegState(count), count, CRegName::GPR[count]);
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
} }
} }
@ -701,7 +701,7 @@ bool CArmRegInfo::UnMap_ArmReg(ArmReg Reg)
} }
else if (GetArmRegMapped(Reg) == Temp_Mapped) else if (GetArmRegMapped(Reg) == Temp_Mapped)
{ {
CPU_Message(" regcache: unallocate %s from temp storage", ArmRegName(Reg)); CPU_Message(" regcache: unallocate %s from temporary storage", ArmRegName(Reg));
SetArmRegMapped(Reg, NotMapped); SetArmRegMapped(Reg, NotMapped);
return true; return true;
} }
@ -901,11 +901,11 @@ CArmOps::ArmReg CArmRegInfo::Map_TempReg(ArmReg Reg, int32_t MipsReg, bool LoadH
} }
if (MipsReg < 0) if (MipsReg < 0)
{ {
CPU_Message(" regcache: allocate %s as temp storage", ArmRegName(Reg)); CPU_Message(" regcache: allocate %s as temporary storage", ArmRegName(Reg));
} }
else else
{ {
CPU_Message(" regcache: allocate %s as temp storage (%s)", ArmRegName(Reg), LoadHiWord ? CRegName::GPR_Hi[MipsReg] : CRegName::GPR_Lo[MipsReg]); CPU_Message(" regcache: allocate %s as temporary storage (%s)", ArmRegName(Reg), LoadHiWord ? CRegName::GPR_Hi[MipsReg] : CRegName::GPR_Lo[MipsReg]);
if (GprReg == Arm_Unknown) if (GprReg == Arm_Unknown)
{ {
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);

View File

@ -10,7 +10,7 @@ class CArmRegInfo :
private CSystemRegisters private CSystemRegisters
{ {
public: public:
//enums // Enums
enum REG_MAPPED enum REG_MAPPED
{ {
NotMapped = 0, NotMapped = 0,

View File

@ -1,17 +1,14 @@
/**************************************************************************** /*
* * Project64 - A Nintendo 64 emulator
* Project64 - A Nintendo 64 emulator. * https://www.pj64-emu.com/
* http://www.pj64-emu.com/ * Copyright (C) 2012-2021 Project64. All rights reserved.
* Copyright (C) 2012 Project64. All rights reserved. * License:
* * GNU/GPLv2 http://www.gnu.org/licenses/gpl-2.0.html
* License: * */
* GNU/GPLv2 http://www.gnu.org/licenses/gpl-2.0.html *
* *
****************************************************************************/
#define GLOBAL_FUNCTION(name) \ #define GLOBAL_FUNCTION(name) \
.align 2; \ .align 2; \
.globl name; \ .global name; \
.hidden name; \ .hidden name; \
.type name, %function; \ .type name, %function; \
name name

View File

@ -26,7 +26,7 @@ m_RecompilerOps(nullptr),
m_Test(1) m_Test(1)
{ {
#if defined(__arm__) || defined(_M_ARM) #if defined(__arm__) || defined(_M_ARM)
// make sure function starts at odd address so that the system knows it is thumb mode // Make sure function starts at an odd address so that the system knows it is in thumb mode
if (((uint32_t)m_CompiledLocation % 2) == 0) if (((uint32_t)m_CompiledLocation % 2) == 0)
{ {
m_CompiledLocation+=1; m_CompiledLocation+=1;
@ -264,7 +264,7 @@ bool CCodeBlock::CreateBlockLinkage(CCodeSection * EnterSection)
{ {
CPU_Message("%s: End Block", __FUNCTION__); CPU_Message("%s: End Block", __FUNCTION__);
CurrentSection->m_EndSection = true; CurrentSection->m_EndSection = true;
// find other sections that need compiling // Find other sections that need compiling
break; break;
} }
@ -334,7 +334,7 @@ bool CCodeBlock::CreateBlockLinkage(CCodeSection * EnterSection)
TestPC += IncludeDelaySlot ? 8 : 4; TestPC += IncludeDelaySlot ? 8 : 4;
//Find the next section // Find the next section
CCodeSection * NewSection = nullptr; CCodeSection * NewSection = nullptr;
for (SectionMap::const_iterator itr = m_SectionMap.begin(); itr != m_SectionMap.end(); itr++) for (SectionMap::const_iterator itr = m_SectionMap.begin(); itr != m_SectionMap.end(); itr++)
{ {
@ -745,11 +745,11 @@ bool CCodeBlock::AnalyzeInstruction(uint32_t PC, uint32_t & TargetPC, uint32_t &
bool CCodeBlock::Compile() bool CCodeBlock::Compile()
{ {
CPU_Message("====== Code Block ======"); CPU_Message("====== Code block ======");
CPU_Message("Native entry point: %X", CompiledLocation()); CPU_Message("Native entry point: %X", CompiledLocation());
CPU_Message("Start of Block: %X", VAddrEnter()); CPU_Message("Start of block: %X", VAddrEnter());
CPU_Message("No of Sections: %d", NoOfSections()); CPU_Message("Number of sections: %d", NoOfSections());
CPU_Message("====== recompiled code ======"); CPU_Message("====== Recompiled code ======");
m_RecompilerOps->EnterCodeBlock(); m_RecompilerOps->EnterCodeBlock();
if (g_System->bLinkBlocks()) if (g_System->bLinkBlocks())

View File

@ -46,10 +46,10 @@ private:
bool & EndBlock, bool & PermLoop); bool & EndBlock, bool & PermLoop);
uint32_t m_VAddrEnter; uint32_t m_VAddrEnter;
uint32_t m_VAddrFirst; // the address of the first opcode in the block uint32_t m_VAddrFirst; // The address of the first opcode in the block
uint32_t m_VAddrLast; // the address of the first opcode in the block uint32_t m_VAddrLast; // The address of the first opcode in the block
uint8_t* m_CompiledLocation; // What address is this compiled at uint8_t* m_CompiledLocation; // What address is this compiled at?
uint8_t* m_CompiledLocationEnd; // What address is this compiled at uint8_t* m_CompiledLocationEnd; // What address is this compiled at?
typedef std::map<uint32_t, CCodeSection *> SectionMap; typedef std::map<uint32_t, CCodeSection *> SectionMap;
typedef std::list<CCodeSection *> SectionList; typedef std::list<CCodeSection *> SectionList;

View File

@ -187,7 +187,7 @@ void CCodeSection::GenerateSectionLinkage()
{ {
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
#ifdef legacycode #ifdef legacycode
//Handle Fall througth // Handle fall-through
uint8_t * Jump = nullptr; uint8_t * Jump = nullptr;
for (i = 0; i < 2; i ++) for (i = 0; i < 2; i ++)
{ {
@ -243,7 +243,7 @@ void CCodeSection::GenerateSectionLinkage()
// MoveConstToVariable(DELAY_SLOT,&m_NextInstruction,"m_NextInstruction"); // MoveConstToVariable(DELAY_SLOT,&m_NextInstruction,"m_NextInstruction");
PushImm32(stdstr_f("0x%08X",m_RecompilerOps->GetCurrentPC() + 4).c_str(),m_RecompilerOps->GetCurrentPC() + 4); PushImm32(stdstr_f("0x%08X",m_RecompilerOps->GetCurrentPC() + 4).c_str(),m_RecompilerOps->GetCurrentPC() + 4);
// check if there is an existing section // Check if there is an existing section
MoveConstToX86reg((uint32_t)g_Recompiler,x86_ECX); MoveConstToX86reg((uint32_t)g_Recompiler,x86_ECX);
Call_Direct(AddressOf(&CRecompiler::CompileDelaySlot), "CRecompiler::CompileDelaySlot"); Call_Direct(AddressOf(&CRecompiler::CompileDelaySlot), "CRecompiler::CompileDelaySlot");
@ -253,7 +253,7 @@ void CCodeSection::GenerateSectionLinkage()
#endif #endif
} }
// Handle Perm Loop // Handle permanent loop
if (m_RecompilerOps->GetCurrentPC() == m_Jump.TargetPC && (m_Cont.FallThrough == false)) if (m_RecompilerOps->GetCurrentPC() == m_Jump.TargetPC && (m_Cont.FallThrough == false))
{ {
if (!DelaySlotEffectsJump(m_RecompilerOps->GetCurrentPC())) if (!DelaySlotEffectsJump(m_RecompilerOps->GetCurrentPC()))
@ -826,7 +826,7 @@ bool CCodeSection::GenerateNativeCode(uint32_t Test)
break; break;
case JUMP: case JUMP:
case END_BLOCK: case END_BLOCK:
// Do nothing, block will end // Do nothing, the block will end
break; break;
default: default:
CPU_Message("m_RecompilerOps->GetNextStepType() = %d", m_RecompilerOps->GetNextStepType()); CPU_Message("m_RecompilerOps->GetNextStepType() = %d", m_RecompilerOps->GetNextStepType());
@ -874,7 +874,7 @@ void CCodeSection::AddParent(CCodeSection * Parent)
return; return;
} }
// check to see if we already have the parent in the list // Check to see if we already have the parent in the list
for (SECTION_LIST::iterator iter = m_ParentSection.begin(); iter != m_ParentSection.end(); iter++) for (SECTION_LIST::iterator iter = m_ParentSection.begin(); iter != m_ParentSection.end(); iter++)
{ {
if (*iter == Parent) if (*iter == Parent)
@ -896,7 +896,7 @@ void CCodeSection::AddParent(CCodeSection * Parent)
} }
else else
{ {
g_Notify->DisplayError("How are these sections joined?????"); g_Notify->DisplayError("How are these sections joined?");
} }
} }
else else
@ -1192,26 +1192,27 @@ void CCodeSection::DisplaySectionInformation()
if (g_System->bLinkBlocks()) if (g_System->bLinkBlocks())
{ {
CPU_Message("Jump Address: 0x%08X", m_Jump.JumpPC); CPU_Message("Jump address: 0x%08X", m_Jump.JumpPC);
CPU_Message("Jump Target Address: 0x%08X", m_Jump.TargetPC); CPU_Message("Jump target address: 0x%08X", m_Jump.TargetPC);
if (m_JumpSection != nullptr) if (m_JumpSection != nullptr)
{ {
CPU_Message("Jump Section: %d", m_JumpSection->m_SectionID); CPU_Message("Jump section: %d", m_JumpSection->m_SectionID);
} }
else else
{ {
CPU_Message("Jump Section: None"); CPU_Message("Jump section: None");
} }
CPU_Message("Continue Address: 0x%08X", m_Cont.JumpPC); CPU_Message("Continue address: 0x%08X", m_Cont.JumpPC);
CPU_Message("Continue Target Address: 0x%08X", m_Cont.TargetPC); CPU_Message("Continue target address: 0x%08X", m_Cont.TargetPC);
if (m_ContinueSection != nullptr) { if (m_ContinueSection != nullptr)
CPU_Message("Continue Section: %d", m_ContinueSection->m_SectionID); {
CPU_Message("Continue section: %d", m_ContinueSection->m_SectionID);
} }
else else
{ {
CPU_Message("Continue Section: None"); CPU_Message("Continue section: None");
} }
CPU_Message("In Loop: %s", m_InLoop ? "Yes" : "No"); CPU_Message("In loop: %s", m_InLoop ? "Yes" : "No");
} }
CPU_Message("======================="); CPU_Message("=======================");
} }

View File

@ -27,7 +27,7 @@ public:
void AddParent(CCodeSection * Parent); void AddParent(CCodeSection * Parent);
void SwitchParent(CCodeSection * OldParent, CCodeSection * NewParent); void SwitchParent(CCodeSection * OldParent, CCodeSection * NewParent);
/* Block Connection info */ // Block connection info
SECTION_LIST m_ParentSection; SECTION_LIST m_ParentSection;
CCodeBlock * const m_BlockInfo; CCodeBlock * const m_BlockInfo;
const uint32_t m_SectionID; const uint32_t m_SectionID;
@ -35,8 +35,8 @@ public:
uint32_t m_EndPC; uint32_t m_EndPC;
CCodeSection * m_ContinueSection; CCodeSection * m_ContinueSection;
CCodeSection * m_JumpSection; CCodeSection * m_JumpSection;
bool m_EndSection; // if this section does not link bool m_EndSection; // If this section does not link, are other sections allowed to find block to link to it?
bool m_LinkAllowed; // are other sections allowed to find block to link to it bool m_LinkAllowed;
uint32_t m_Test; uint32_t m_Test;
uint32_t m_Test2; uint32_t m_Test2;
uint8_t * m_CompiledLocation; uint8_t * m_CompiledLocation;
@ -44,10 +44,10 @@ public:
bool m_DelaySlot; bool m_DelaySlot;
CRecompilerOps * & m_RecompilerOps; CRecompilerOps * & m_RecompilerOps;
/* Register Info */ // Register info
CRegInfo m_RegEnter; CRegInfo m_RegEnter;
/* Jump Info */ // Jump info
CJumpInfo m_Jump; CJumpInfo m_Jump;
CJumpInfo m_Cont; CJumpInfo m_Cont;

View File

@ -23,7 +23,7 @@ struct CExitInfo
CRegInfo ExitRegSet; CRegInfo ExitRegSet;
EXIT_REASON reason; EXIT_REASON reason;
STEP_TYPE NextInstruction; STEP_TYPE NextInstruction;
uint32_t * JumpLoc; //32bit jump uint32_t * JumpLoc; // 32-bit jump
}; };
typedef std::list<CExitInfo> EXIT_LIST; typedef std::list<CExitInfo> EXIT_LIST;

View File

@ -16,7 +16,7 @@ CCompiledFunc::CCompiledFunc( const CCodeBlock & CodeBlock ) :
m_MemLocation[1] = CodeBlock.MemLocation(1); m_MemLocation[1] = CodeBlock.MemLocation(1);
#if defined(__arm__) || defined(_M_ARM) #if defined(__arm__) || defined(_M_ARM)
// make sure function starts at odd address so that the system knows it is thumb mode // Make sure function starts at an odd address so that the system knows it is in thumb mode
if ((((uint32_t)m_Function) % 2) == 0) if ((((uint32_t)m_Function) % 2) == 0)
{ {
m_Function = (Func)(((uint32_t)m_Function) + 1); m_Function = (Func)(((uint32_t)m_Function) + 1);

View File

@ -8,7 +8,6 @@ public:
typedef void (*Func)(); typedef void (*Func)();
//Get Private Information
const uint32_t EnterPC () const { return m_EnterPC; } const uint32_t EnterPC () const { return m_EnterPC; }
const uint32_t MinPC () const { return m_MinPC; } const uint32_t MinPC () const { return m_MinPC; }
const uint32_t MaxPC () const { return m_MaxPC; } const uint32_t MaxPC () const { return m_MaxPC; }

View File

@ -16,13 +16,13 @@ CFunctionMap::~CFunctionMap()
bool CFunctionMap::AllocateMemory() bool CFunctionMap::AllocateMemory()
{ {
WriteTrace(TraceRecompiler, TraceDebug, "start"); WriteTrace(TraceRecompiler, TraceDebug, "Start");
if (LookUpMode() == FuncFind_VirtualLookup && m_FunctionTable == nullptr) if (LookUpMode() == FuncFind_VirtualLookup && m_FunctionTable == nullptr)
{ {
m_FunctionTable = new PCCompiledFunc_TABLE[0x100000]; m_FunctionTable = new PCCompiledFunc_TABLE[0x100000];
if (m_FunctionTable == nullptr) if (m_FunctionTable == nullptr)
{ {
WriteTrace(TraceRecompiler, TraceError, "failed to allocate function table"); WriteTrace(TraceRecompiler, TraceError, "Failed to allocate function table");
g_Notify->FatalError(MSG_MEM_ALLOC_ERROR); g_Notify->FatalError(MSG_MEM_ALLOC_ERROR);
return false; return false;
} }
@ -33,7 +33,7 @@ bool CFunctionMap::AllocateMemory()
m_JumpTable = new PCCompiledFunc[RdramSize() >> 2]; m_JumpTable = new PCCompiledFunc[RdramSize() >> 2];
if (m_JumpTable == nullptr) if (m_JumpTable == nullptr)
{ {
WriteTrace(TraceRecompiler, TraceError, "failed to allocate jump table"); WriteTrace(TraceRecompiler, TraceError, "Failed to allocate jump table");
g_Notify->FatalError(MSG_MEM_ALLOC_ERROR); g_Notify->FatalError(MSG_MEM_ALLOC_ERROR);
return false; return false;
} }
@ -66,7 +66,7 @@ void CFunctionMap::CleanBuffers()
void CFunctionMap::Reset(bool bAllocate) void CFunctionMap::Reset(bool bAllocate)
{ {
WriteTrace(TraceRecompiler, TraceDebug, "start (bAllocate: %s)", bAllocate ? "true" : "false"); WriteTrace(TraceRecompiler, TraceDebug, "Start (bAllocate: %s)", bAllocate ? "true" : "false");
CleanBuffers(); CleanBuffers();
if (bAllocate && (g_System->LookUpMode() == FuncFind_VirtualLookup || g_System->LookUpMode() == FuncFind_PhysicalLookup)) if (bAllocate && (g_System->LookUpMode() == FuncFind_VirtualLookup || g_System->LookUpMode() == FuncFind_PhysicalLookup))
{ {

View File

@ -14,7 +14,7 @@ struct CJumpInfo
uint32_t * LinkLocation2; uint32_t * LinkLocation2;
bool FallThrough; bool FallThrough;
bool PermLoop; bool PermLoop;
bool DoneDelaySlot; //maybe deletable bool DoneDelaySlot;
CRegInfo RegSet; CRegInfo RegSet;
EXIT_REASON ExitReason; EXIT_REASON ExitReason;
}; };

View File

@ -235,7 +235,7 @@ bool LoopAnalysis::CheckLoopRegisterUsage(CCodeSection * Section)
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
#ifdef legacycode #ifdef legacycode
if (m_Command.Hex == 0x00000001) { break; } if (m_Command.Hex == 0x00000001) { break; }
g_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;
@ -366,7 +366,7 @@ bool LoopAnalysis::CheckLoopRegisterUsage(CCodeSection * Section)
g_Notify->BreakPoint(__FILE__, __LINE__); g_Notify->BreakPoint(__FILE__, __LINE__);
#ifdef legacycode #ifdef legacycode
if (m_Command.Hex == 0x0407000D) { break; } if (m_Command.Hex == 0x0407000D) { break; }
g_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;
@ -542,14 +542,14 @@ 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:
g_Notify->DisplayError(stdstr_f("Unhandled R4300i OpCode in FillSectionInfo\n%s", R4300iOpcodeName(m_Command.Hex, m_PC)).c_str()); g_Notify->DisplayError(stdstr_f("Unhandled R4300i opcode in FillSectionInfo\n%s", R4300iOpcodeName(m_Command.Hex, m_PC)).c_str());
m_NextInstruction = END_BLOCK; m_NextInstruction = END_BLOCK;
m_PC -= 4; m_PC -= 4;
} }
} }
else else
{ {
g_Notify->DisplayError(stdstr_f("Unhandled R4300i OpCode in FillSectionInfo 3\n%s", R4300iOpcodeName(m_Command.Hex, m_PC)).c_str()); g_Notify->DisplayError(stdstr_f("Unhandled R4300i opcode in FillSectionInfo 3\n%s", R4300iOpcodeName(m_Command.Hex, m_PC)).c_str());
m_NextInstruction = END_BLOCK; m_NextInstruction = END_BLOCK;
m_PC -= 4; m_PC -= 4;
} }
@ -627,7 +627,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:
g_Notify->DisplayError(stdstr_f("Unhandled R4300i OpCode in FillSectionInfo 2\n%s", R4300iOpcodeName(m_Command.Hex, m_PC)).c_str()); g_Notify->DisplayError(stdstr_f("Unhandled R4300i opcode in FillSectionInfo 2\n%s", R4300iOpcodeName(m_Command.Hex, m_PC)).c_str());
m_NextInstruction = END_BLOCK; m_NextInstruction = END_BLOCK;
m_PC -= 4; m_PC -= 4;
} }
@ -727,7 +727,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; }
g_Notify->DisplayError(stdstr_f("Unhandled R4300i OpCode in FillSectionInfo 1\n%s\n%X", R4300iOpcodeName(m_Command.Hex, m_PC), m_Command.Hex).c_str()); g_Notify->DisplayError(stdstr_f("Unhandled R4300i opcode in FillSectionInfo 1\n%s\n%X", R4300iOpcodeName(m_Command.Hex, m_PC), m_Command.Hex).c_str());
} }
CPU_Message(" %s state: %X value: %X", CRegName::GPR[5], m_Reg.GetMipsRegState(5), m_Reg.GetMipsRegLo(5)); CPU_Message(" %s state: %X value: %X", CRegName::GPR[5], m_Reg.GetMipsRegState(5), m_Reg.GetMipsRegLo(5));

Some files were not shown because too many files have changed in this diff Show More