commit
d8ab26891f
|
@ -263,12 +263,14 @@ Good Name=Akumajou Dracula Mokushiroku - Real Action Adventure (J)
|
||||||
Internal Name=DRACULA MOKUSHIROKU
|
Internal Name=DRACULA MOKUSHIROKU
|
||||||
depthmode=0
|
depthmode=0
|
||||||
fb_clear=1
|
fb_clear=1
|
||||||
|
old_style_adither=1
|
||||||
|
|
||||||
[A5533106-B9F25E5B-C:4A]
|
[A5533106-B9F25E5B-C:4A]
|
||||||
Good Name=Akumajou Dracula Mokushiroku Gaiden - Legend of Cornell (J)
|
Good Name=Akumajou Dracula Mokushiroku Gaiden - Legend of Cornell (J)
|
||||||
Internal Name=DRACULA MOKUSHIROKU2
|
Internal Name=DRACULA MOKUSHIROKU2
|
||||||
depthmode=0
|
depthmode=0
|
||||||
fb_clear=1
|
fb_clear=1
|
||||||
|
old_style_adither=1
|
||||||
|
|
||||||
[D9EDD54D-6BB8E274-C:50]
|
[D9EDD54D-6BB8E274-C:50]
|
||||||
Good Name=All-Star Baseball '99 (E)
|
Good Name=All-Star Baseball '99 (E)
|
||||||
|
@ -633,12 +635,14 @@ Good Name=Castlevania - Legacy of Darkness (E) (M3)
|
||||||
Internal Name=CASTLEVANIA2
|
Internal Name=CASTLEVANIA2
|
||||||
depthmode=0
|
depthmode=0
|
||||||
fb_clear=1
|
fb_clear=1
|
||||||
|
old_style_adither=1
|
||||||
|
|
||||||
[1CC06338-87388926-C:45]
|
[1CC06338-87388926-C:45]
|
||||||
Good Name=Castlevania - Legacy of Darkness (U)
|
Good Name=Castlevania - Legacy of Darkness (U)
|
||||||
Internal Name=CASTLEVANIA2
|
Internal Name=CASTLEVANIA2
|
||||||
depthmode=0
|
depthmode=0
|
||||||
fb_clear=1
|
fb_clear=1
|
||||||
|
old_style_adither=1
|
||||||
|
|
||||||
[DCCF2134-9DD63578-C:50]
|
[DCCF2134-9DD63578-C:50]
|
||||||
Good Name=Centre Court Tennis (E)
|
Good Name=Centre Court Tennis (E)
|
||||||
|
@ -2250,6 +2254,7 @@ wrap_big_tex=1
|
||||||
Good Name=Nintama Rantarou 64 Game Gallery (J)
|
Good Name=Nintama Rantarou 64 Game Gallery (J)
|
||||||
Internal Name=NINTAMAGAMEGALLERY64
|
Internal Name=NINTAMAGAMEGALLERY64
|
||||||
depthmode=0
|
depthmode=0
|
||||||
|
fb_smart=0
|
||||||
force_microcheck=1
|
force_microcheck=1
|
||||||
|
|
||||||
[8A97A197-272DF6C1-C:50]
|
[8A97A197-272DF6C1-C:50]
|
||||||
|
@ -2267,6 +2272,13 @@ Good Name=Nuclear Strike 64 (U)
|
||||||
Internal Name=NUCLEARSTRIKE64
|
Internal Name=NUCLEARSTRIKE64
|
||||||
buff_clear=0
|
buff_clear=0
|
||||||
|
|
||||||
|
[D83BB920-CC406416-C:4A]
|
||||||
|
Good Name=Nushi Duri 64 (J) (V1.0)
|
||||||
|
buff_clear=1
|
||||||
|
depthmode=0
|
||||||
|
force_microcheck=1
|
||||||
|
wrap_big_tex=0
|
||||||
|
|
||||||
[C5F1DE79-5D4BEB6E-C:4A]
|
[C5F1DE79-5D4BEB6E-C:4A]
|
||||||
Good Name=Nushi Duri 64 (J) (V1.1)
|
Good Name=Nushi Duri 64 (J) (V1.1)
|
||||||
Internal Name=ǼÂÞØ64
|
Internal Name=ǼÂÞØ64
|
||||||
|
@ -2382,6 +2394,20 @@ filtering=1
|
||||||
optimize_texrect=0
|
optimize_texrect=0
|
||||||
useless_is_useless=1
|
useless_is_useless=1
|
||||||
|
|
||||||
|
[EE08C602-6BC2D5A6-C:50]
|
||||||
|
Good Name=PGA European Tour (E) (M5)
|
||||||
|
Internal Name=PGA European Tour
|
||||||
|
buff_clear=0
|
||||||
|
fb_read_always=1
|
||||||
|
swapmode=0
|
||||||
|
|
||||||
|
[B54CE881-BCCB6126-C:45]
|
||||||
|
Good Name=PGA European Tour (U)
|
||||||
|
Internal Name=PGA European Tour
|
||||||
|
buff_clear=0
|
||||||
|
fb_read_always=1
|
||||||
|
swapmode=0
|
||||||
|
|
||||||
[1AA05AD5-46F52D80-C:50]
|
[1AA05AD5-46F52D80-C:50]
|
||||||
Good Name=Pilotwings 64 (E) (M3)
|
Good Name=Pilotwings 64 (E) (M3)
|
||||||
Internal Name=Pilot Wings64
|
Internal Name=Pilot Wings64
|
||||||
|
@ -2745,8 +2771,10 @@ force_quad3d=1
|
||||||
Good Name=Pro Mahjong Tsuwamono 64 - Jansou Battle ni Chousen (J)
|
Good Name=Pro Mahjong Tsuwamono 64 - Jansou Battle ni Chousen (J)
|
||||||
Internal Name=TSUWAMONO64
|
Internal Name=TSUWAMONO64
|
||||||
depthmode=0
|
depthmode=0
|
||||||
|
fb_smart=0 //disabling FB is a horrible hack
|
||||||
force_microcheck=1
|
force_microcheck=1
|
||||||
|
|
||||||
|
|
||||||
//================ Q ================
|
//================ Q ================
|
||||||
[16931D74-65DC6D34-C:50]
|
[16931D74-65DC6D34-C:50]
|
||||||
Good Name=Quake 64 (E)
|
Good Name=Quake 64 (E)
|
||||||
|
@ -3162,7 +3190,7 @@ Good Name=Super Mario 64 (E) (M3)
|
||||||
Internal Name=SUPER MARIO 64
|
Internal Name=SUPER MARIO 64
|
||||||
depth_bias=32
|
depth_bias=32
|
||||||
depthmode=1
|
depthmode=1
|
||||||
filtering=1
|
filtering=0
|
||||||
lodmode=1
|
lodmode=1
|
||||||
|
|
||||||
[4EAA3D0E-74757C24-C:4A]
|
[4EAA3D0E-74757C24-C:4A]
|
||||||
|
@ -3170,7 +3198,7 @@ Good Name=Super Mario 64 (J)
|
||||||
Internal Name=SUPER MARIO 64
|
Internal Name=SUPER MARIO 64
|
||||||
depth_bias=32
|
depth_bias=32
|
||||||
depthmode=1
|
depthmode=1
|
||||||
filtering=1
|
filtering=0
|
||||||
lodmode=1
|
lodmode=1
|
||||||
|
|
||||||
[635A2BFF-8B022326-C:45]
|
[635A2BFF-8B022326-C:45]
|
||||||
|
@ -3178,7 +3206,7 @@ Good Name=Super Mario 64 (U)
|
||||||
Internal Name=SUPER MARIO 64
|
Internal Name=SUPER MARIO 64
|
||||||
depth_bias=32
|
depth_bias=32
|
||||||
depthmode=1
|
depthmode=1
|
||||||
filtering=1
|
filtering=0
|
||||||
lodmode=1
|
lodmode=1
|
||||||
|
|
||||||
[D6FBA4A8-6326AA2C-C:4A]
|
[D6FBA4A8-6326AA2C-C:4A]
|
||||||
|
@ -3186,7 +3214,7 @@ Good Name=Super Mario 64 - Shindou Edition (J)
|
||||||
Internal Name=SUPERMARIO64
|
Internal Name=SUPERMARIO64
|
||||||
depth_bias=32
|
depth_bias=32
|
||||||
depthmode=1
|
depthmode=1
|
||||||
filtering=1
|
filtering=0
|
||||||
lodmode=1
|
lodmode=1
|
||||||
|
|
||||||
[66572080-28E348E1-C:4A]
|
[66572080-28E348E1-C:4A]
|
||||||
|
@ -3757,30 +3785,38 @@ depthmode=1
|
||||||
Good Name=Waialae Country Club - True Golf Classics (E) (M4) (V1.0)
|
Good Name=Waialae Country Club - True Golf Classics (E) (M4) (V1.0)
|
||||||
Internal Name=Waialae Country Club
|
Internal Name=Waialae Country Club
|
||||||
depthmode=0
|
depthmode=0
|
||||||
fb_smart=0
|
fb_smart=1
|
||||||
wrap_big_tex=1
|
wrap_big_tex=1
|
||||||
|
|
||||||
[0C5057AD-046E126E-C:50]
|
[0C5057AD-046E126E-C:50]
|
||||||
Good Name=Waialae Country Club - True Golf Classics (E) (M4) (V1.1)
|
Good Name=Waialae Country Club - True Golf Classics (E) (M4) (V1.1)
|
||||||
Internal Name=Waialae Country Club
|
Internal Name=Waialae Country Club
|
||||||
depthmode=0
|
depthmode=0
|
||||||
fb_smart=0
|
fb_smart=1
|
||||||
wrap_big_tex=1
|
wrap_big_tex=1
|
||||||
|
|
||||||
[8066D58A-C3DECAC1-C:45]
|
[8066D58A-C3DECAC1-C:45]
|
||||||
Good Name=Waialae Country Club - True Golf Classics (U) (V1.0)
|
Good Name=Waialae Country Club - True Golf Classics (U) (V1.0)
|
||||||
Internal Name=Waialae Country Club
|
Internal Name=Waialae Country Club
|
||||||
depthmode=0
|
depthmode=0
|
||||||
fb_smart=0
|
fb_smart=1
|
||||||
wrap_big_tex=1
|
wrap_big_tex=1
|
||||||
|
|
||||||
[DD318CE2-B73798BA-C:45]
|
[DD318CE2-B73798BA-C:45]
|
||||||
Good Name=Waialae Country Club - True Golf Classics (U) (V1.1)
|
Good Name=Waialae Country Club - True Golf Classics (U) (V1.1)
|
||||||
Internal Name=Waialae Country Club
|
Internal Name=Waialae Country Club
|
||||||
depthmode=0
|
depthmode=0
|
||||||
fb_smart=0
|
fb_smart=1
|
||||||
wrap_big_tex=1
|
wrap_big_tex=1
|
||||||
|
|
||||||
|
[D715CC70-271CF5D6-C:50]
|
||||||
|
Good Name=War Gods (E)
|
||||||
|
filtering=2
|
||||||
|
|
||||||
|
[F7FE28F6-C3F2ACC3-C:45]
|
||||||
|
Good Name=War Gods (U)
|
||||||
|
filtering=2
|
||||||
|
|
||||||
[650EFA96-30DDF9A7-C:50]
|
[650EFA96-30DDF9A7-C:50]
|
||||||
Good Name=Wave Race 64 (E) (M2)
|
Good Name=Wave Race 64 (E) (M2)
|
||||||
Internal Name=WAVE RACE 64
|
Internal Name=WAVE RACE 64
|
||||||
|
@ -4000,3 +4036,6 @@ buff_clear=0
|
||||||
force_microcheck=1
|
force_microcheck=1
|
||||||
swapmode=0
|
swapmode=0
|
||||||
|
|
||||||
|
[37955E65-C6F2B7B3-C:0]
|
||||||
|
Good Name=Tamiya Racing 64 (Unreleased)
|
||||||
|
force_microcheck=1
|
||||||
|
|
|
@ -720,6 +720,7 @@ Cheat3="Have\All Difficulties",E95E2008 585A
|
||||||
Cheat4="Have\All Tracks",E95E2014 1050
|
Cheat4="Have\All Tracks",E95E2014 1050
|
||||||
Cheat5="Have\All Boards",E95E201C 595B,E95E201A 504F
|
Cheat5="Have\All Boards",E95E201C 595B,E95E201A 504F
|
||||||
Cheat1="Low Timer",E85E1FFC 595A,E85E1FFA 595A
|
Cheat1="Low Timer",E85E1FFC 595A,E85E1FFA 595A
|
||||||
|
Cheat6="exhalatio audio hack",81052760 AD99
|
||||||
|
|
||||||
//----
|
//----
|
||||||
|
|
||||||
|
@ -9369,6 +9370,10 @@ Cheat12="Have Shotgun",E8878B88 5959
|
||||||
|
|
||||||
//----
|
//----
|
||||||
|
|
||||||
|
[E688A5B8-B14B3F18-C:50]
|
||||||
|
Good Name=Twisted Edge Extreme Snowboarding (E)
|
||||||
|
Cheat0="exhalatio audio hack",81051960 AD99
|
||||||
|
|
||||||
[BBC99D32-117DAA80-C:45]
|
[BBC99D32-117DAA80-C:45]
|
||||||
Name=Twisted Edge Extreme Snowboarding (U)
|
Name=Twisted Edge Extreme Snowboarding (U)
|
||||||
Cheat0="Max\50000 Stunt Points",E95E8010 1CAA
|
Cheat0="Max\50000 Stunt Points",E95E8010 1CAA
|
||||||
|
@ -9377,6 +9382,7 @@ Cheat3="Have\All Difficulties",E95E8048 585A
|
||||||
Cheat4="Have\All Tracks",E95E8054 1050
|
Cheat4="Have\All Tracks",E95E8054 1050
|
||||||
Cheat5="Have\All Boards",E95E7D5C 595B,E95E7D5A 504F
|
Cheat5="Have\All Boards",E95E7D5C 595B,E95E7D5A 504F
|
||||||
Cheat1="Low Timer",E86AEC51 595A,E86AE957 595A
|
Cheat1="Low Timer",E86AEC51 595A,E86AE957 595A
|
||||||
|
Cheat6="exhalatio audio hack",81051840 AD99
|
||||||
|
|
||||||
//----
|
//----
|
||||||
|
|
||||||
|
|
1114
Config/Project64.rdb
1114
Config/Project64.rdb
File diff suppressed because it is too large
Load Diff
|
@ -65,10 +65,10 @@ static SRes Lzma2Dec_GetOldProps(Byte prop, Byte *props)
|
||||||
return SZ_ERROR_UNSUPPORTED;
|
return SZ_ERROR_UNSUPPORTED;
|
||||||
dicSize = (prop == 40) ? 0xFFFFFFFF : LZMA2_DIC_SIZE_FROM_PROP(prop);
|
dicSize = (prop == 40) ? 0xFFFFFFFF : LZMA2_DIC_SIZE_FROM_PROP(prop);
|
||||||
props[0] = (Byte)LZMA2_LCLP_MAX;
|
props[0] = (Byte)LZMA2_LCLP_MAX;
|
||||||
props[1] = (Byte)(dicSize);
|
props[1] = (Byte)((dicSize)& 0xFF);
|
||||||
props[2] = (Byte)(dicSize >> 8);
|
props[2] = (Byte)((dicSize >> 8) & 0xFF);
|
||||||
props[3] = (Byte)(dicSize >> 16);
|
props[3] = (Byte)((dicSize >> 16) & 0xFF);
|
||||||
props[4] = (Byte)(dicSize >> 24);
|
props[4] = (Byte)((dicSize >> 24) & 0xFF);
|
||||||
return SZ_OK;
|
return SZ_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -157,6 +157,10 @@
|
||||||
RelativePath=".\path.cpp"
|
RelativePath=".\path.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath=".\Platform.cpp"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\stdafx.cpp"
|
RelativePath=".\stdafx.cpp"
|
||||||
>
|
>
|
||||||
|
@ -230,6 +234,10 @@
|
||||||
RelativePath=".\path.h"
|
RelativePath=".\path.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath=".\Platform.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\SmartPointer.h"
|
RelativePath=".\SmartPointer.h"
|
||||||
>
|
>
|
||||||
|
@ -258,6 +266,10 @@
|
||||||
RelativePath=".\TraceDefs.h"
|
RelativePath=".\TraceDefs.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath=".\TraceModulesCommon.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\Util.h"
|
RelativePath=".\Util.h"
|
||||||
>
|
>
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#include "MemoryManagement.h"
|
#include "MemoryManagement.h"
|
||||||
|
|
||||||
static bool TranslateFromMemProtect ( MEM_PROTECTION memProtection, int & OsMemProtection)
|
static bool TranslateFromMemProtect(MEM_PROTECTION memProtection, int & OsMemProtection)
|
||||||
{
|
{
|
||||||
switch (memProtection)
|
switch (memProtection)
|
||||||
{
|
{
|
||||||
|
@ -16,6 +16,20 @@ static bool TranslateFromMemProtect ( MEM_PROTECTION memProtection, int & OsMemP
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool TranslateToMemProtect(int OsMemProtection, MEM_PROTECTION & memProtection)
|
||||||
|
{
|
||||||
|
switch (OsMemProtection)
|
||||||
|
{
|
||||||
|
case PAGE_NOACCESS: memProtection = MEM_NOACCESS; break;
|
||||||
|
case PAGE_READONLY: memProtection = MEM_READONLY; break;
|
||||||
|
case PAGE_READWRITE: memProtection = MEM_READWRITE; break;
|
||||||
|
case PAGE_EXECUTE_READWRITE: memProtection = MEM_EXECUTE_READWRITE; break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
void* AllocateAddressSpace(size_t size)
|
void* AllocateAddressSpace(size_t size)
|
||||||
{
|
{
|
||||||
return VirtualAlloc(NULL, size, MEM_RESERVE | MEM_TOP_DOWN, PAGE_NOACCESS);
|
return VirtualAlloc(NULL, size, MEM_RESERVE | MEM_TOP_DOWN, PAGE_NOACCESS);
|
||||||
|
@ -29,7 +43,7 @@ bool FreeAddressSpace(void* addr, size_t size)
|
||||||
void* CommitMemory(void* addr, size_t size, MEM_PROTECTION memProtection)
|
void* CommitMemory(void* addr, size_t size, MEM_PROTECTION memProtection)
|
||||||
{
|
{
|
||||||
int OsMemProtection;
|
int OsMemProtection;
|
||||||
if (!TranslateFromMemProtect(memProtection,OsMemProtection))
|
if (!TranslateFromMemProtect(memProtection, OsMemProtection))
|
||||||
{
|
{
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -44,7 +58,7 @@ bool DecommitMemory(void* addr, size_t size)
|
||||||
bool ProtectMemory(void* addr, size_t size, MEM_PROTECTION memProtection, MEM_PROTECTION * OldProtect)
|
bool ProtectMemory(void* addr, size_t size, MEM_PROTECTION memProtection, MEM_PROTECTION * OldProtect)
|
||||||
{
|
{
|
||||||
int OsMemProtection;
|
int OsMemProtection;
|
||||||
if (!TranslateFromMemProtect(memProtection,OsMemProtection))
|
if (!TranslateFromMemProtect(memProtection, OsMemProtection))
|
||||||
{
|
{
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -53,6 +67,10 @@ bool ProtectMemory(void* addr, size_t size, MEM_PROTECTION memProtection, MEM_PR
|
||||||
BOOL res = VirtualProtect(addr, size, OsMemProtection, &OldOsProtect);
|
BOOL res = VirtualProtect(addr, size, OsMemProtection, &OldOsProtect);
|
||||||
if (OldProtect != NULL)
|
if (OldProtect != NULL)
|
||||||
{
|
{
|
||||||
|
if (!TranslateToMemProtect(OldOsProtect, *OldProtect))
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return res != 0;
|
return res != 0;
|
||||||
}
|
}
|
|
@ -1,7 +1,7 @@
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
|
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
int _vscprintf (const char * format, va_list pargs)
|
int _vscprintf(const char * format, va_list pargs)
|
||||||
{
|
{
|
||||||
int retval;
|
int retval;
|
||||||
va_list argcopy;
|
va_list argcopy;
|
||||||
|
@ -11,3 +11,18 @@ int _vscprintf (const char * format, va_list pargs)
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
#include <float.h>
|
||||||
|
|
||||||
|
int fesetround(int RoundType)
|
||||||
|
{
|
||||||
|
static const unsigned int msRound[4] = { _RC_NEAR, _RC_CHOP, _RC_UP, _RC_DOWN };
|
||||||
|
int32_t res = _controlfp(msRound[RoundType], _MCW_RC);
|
||||||
|
if (res == _RC_NEAR) { return FE_TONEAREST; }
|
||||||
|
if (res == _RC_CHOP) { return FE_TOWARDZERO; }
|
||||||
|
if (res == _RC_UP) { return FE_UPWARD; }
|
||||||
|
if (res == _RC_DOWN) { return FE_DOWNWARD; }
|
||||||
|
return FE_TONEAREST;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
|
@ -7,8 +7,17 @@
|
||||||
#define _stricmp strcasecmp
|
#define _stricmp strcasecmp
|
||||||
#define _strnicmp strncasecmp
|
#define _strnicmp strncasecmp
|
||||||
#define _snprintf snprintf
|
#define _snprintf snprintf
|
||||||
|
#define _isnan isnan
|
||||||
#define GetCurrentThreadId pthread_self
|
#define GetCurrentThreadId pthread_self
|
||||||
|
|
||||||
int _vscprintf (const char * format, va_list pargs);
|
int _vscprintf (const char * format, va_list pargs);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
//FPU rounding code
|
||||||
|
#ifdef _WIN32
|
||||||
|
typedef enum { FE_TONEAREST = 0, FE_TOWARDZERO, FE_UPWARD, FE_DOWNWARD } eRoundType;
|
||||||
|
int fesetround(int RoundType);
|
||||||
|
#else
|
||||||
|
#include <fenv.h>
|
||||||
|
#endif
|
||||||
|
|
|
@ -4,22 +4,23 @@
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
#include <Windows.h>
|
#include <Windows.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
stdstr::stdstr()
|
stdstr::stdstr()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
stdstr::stdstr(const std::string & str) :
|
stdstr::stdstr(const std::string & str) :
|
||||||
std::string(str)
|
std::string(str)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
stdstr::stdstr(const stdstr & str) :
|
stdstr::stdstr(const stdstr & str) :
|
||||||
std::string((const std::string &)str)
|
std::string((const std::string &)str)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
stdstr::stdstr(const char * str) :
|
stdstr::stdstr(const char * str) :
|
||||||
std::string(str ? str : "")
|
std::string(str ? str : "")
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,13 +1,61 @@
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include "Util.h"
|
#include "Util.h"
|
||||||
|
#ifdef _WIN32
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#include <Tlhelp32.h>
|
#include <Tlhelp32.h>
|
||||||
|
#else
|
||||||
|
#include <unistd.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
pjutil::DynLibHandle pjutil::DynLibOpen(const char *pccLibraryPath, bool ShowErrors)
|
||||||
|
{
|
||||||
|
if (pccLibraryPath == NULL)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
UINT LastErrorMode = SetErrorMode(ShowErrors ? 0 : SEM_FAILCRITICALERRORS);
|
||||||
|
pjutil::DynLibHandle lib = (pjutil::DynLibHandle)LoadLibrary(pccLibraryPath);
|
||||||
|
SetErrorMode(LastErrorMode);
|
||||||
|
return lib;
|
||||||
|
}
|
||||||
|
|
||||||
|
void * pjutil::DynLibGetProc(pjutil::DynLibHandle LibHandle, const char * ProcedureName)
|
||||||
|
{
|
||||||
|
if (ProcedureName == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
return GetProcAddress((HMODULE)LibHandle, ProcedureName);
|
||||||
|
}
|
||||||
|
|
||||||
|
void pjutil::DynLibClose(pjutil::DynLibHandle LibHandle)
|
||||||
|
{
|
||||||
|
FreeLibrary((HMODULE)LibHandle);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
static void EmptyThreadFunction(void)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void pjutil::DynLibCallDllMain(void)
|
||||||
|
{
|
||||||
|
//jabo had a bug so I call CreateThread so the dllmain in the plugins will get called again with thread attached
|
||||||
|
DWORD ThreadID;
|
||||||
|
HANDLE hthread = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)EmptyThreadFunction, NULL, 0, &ThreadID);
|
||||||
|
CloseHandle(hthread);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void pjutil::Sleep(uint32_t timeout)
|
void pjutil::Sleep(uint32_t timeout)
|
||||||
{
|
{
|
||||||
|
#ifdef _WIN32
|
||||||
::Sleep(timeout);
|
::Sleep(timeout);
|
||||||
|
#else
|
||||||
|
sleep(timeout);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
bool pjutil::TerminatedExistingExe()
|
bool pjutil::TerminatedExistingExe()
|
||||||
{
|
{
|
||||||
bool bTerminated = false;
|
bool bTerminated = false;
|
||||||
|
@ -60,3 +108,4 @@ bool pjutil::TerminatedExistingExe()
|
||||||
}
|
}
|
||||||
return bTerminated;
|
return bTerminated;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
|
@ -4,6 +4,14 @@
|
||||||
class pjutil
|
class pjutil
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
typedef void * DynLibHandle;
|
||||||
|
|
||||||
|
static DynLibHandle DynLibOpen(const char *pccLibraryPath, bool ShowErrors = true);
|
||||||
|
static void * DynLibGetProc(DynLibHandle LibHandle, const char * ProcedureName);
|
||||||
|
static void DynLibClose(DynLibHandle LibHandle);
|
||||||
|
#ifdef _WIN32
|
||||||
|
static void DynLibCallDllMain(void);
|
||||||
|
#endif
|
||||||
static void Sleep(uint32_t timeout);
|
static void Sleep(uint32_t timeout);
|
||||||
static bool TerminatedExistingExe();
|
static bool TerminatedExistingExe();
|
||||||
|
|
||||||
|
|
|
@ -2038,14 +2038,14 @@ void newSwapBuffers()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//hotkeys
|
//hotkeys
|
||||||
if (CheckKeyPressed(G64_VK_BACK, 0x0001))
|
//if (CheckKeyPressed(G64_VK_BACK, 0x0001))
|
||||||
{
|
//{
|
||||||
hotkey_info.hk_filtering = 100;
|
//hotkey_info.hk_filtering = 100;
|
||||||
if (settings.filtering < 2)
|
//if (settings.filtering < 2)
|
||||||
settings.filtering++;
|
//settings.filtering++;
|
||||||
else
|
//else
|
||||||
settings.filtering = 0;
|
//settings.filtering = 0;
|
||||||
}
|
//}
|
||||||
if ((abs((int)(frame_count - curframe)) > 3 ) && CheckKeyPressed(G64_VK_ALT, 0x8000)) //alt +
|
if ((abs((int)(frame_count - curframe)) > 3 ) && CheckKeyPressed(G64_VK_ALT, 0x8000)) //alt +
|
||||||
{
|
{
|
||||||
if (CheckKeyPressed(G64_VK_B, 0x8000)) //b
|
if (CheckKeyPressed(G64_VK_B, 0x8000)) //b
|
||||||
|
|
|
@ -7,7 +7,7 @@ typedef const char * LPCSTR;
|
||||||
#include "7zip.h"
|
#include "7zip.h"
|
||||||
#include <Common/StdString.h>
|
#include <Common/StdString.h>
|
||||||
|
|
||||||
C7zip::C7zip (const char * FileName) :
|
C7zip::C7zip(const char * FileName) :
|
||||||
m_FileSize(0),
|
m_FileSize(0),
|
||||||
m_CurrentFile(-1),
|
m_CurrentFile(-1),
|
||||||
m_blockIndex(0xFFFFFFFF),
|
m_blockIndex(0xFFFFFFFF),
|
||||||
|
@ -129,7 +129,7 @@ bool C7zip::GetFile(int index, Byte * Data, size_t DataLen)
|
||||||
|
|
||||||
char Msg[200];
|
char Msg[200];
|
||||||
std::wstring FileName = FileNameIndex(index);
|
std::wstring FileName = FileNameIndex(index);
|
||||||
_snprintf(Msg, sizeof(Msg) / sizeof(Msg[0]), "extracting %s", stdstr().FromUTF16(FileName.c_str()));
|
_snprintf(Msg, sizeof(Msg) / sizeof(Msg[0]), "extracting %s", stdstr().FromUTF16(FileName.c_str()).c_str());
|
||||||
m_NotfyCallback(Msg, m_NotfyCallbackInfo);
|
m_NotfyCallback(Msg, m_NotfyCallbackInfo);
|
||||||
|
|
||||||
SRes res = SzArEx_Extract(m_db, &m_archiveLookStream.s, index,
|
SRes res = SzArEx_Extract(m_db, &m_archiveLookStream.s, index,
|
||||||
|
|
|
@ -11,7 +11,9 @@
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include "FramePerSecondClass.h"
|
#include "FramePerSecondClass.h"
|
||||||
#include <Project64-core/N64System/N64Types.h>
|
#include <Project64-core/N64System/N64Types.h>
|
||||||
|
#ifdef _WIN32
|
||||||
#include <Windows.h>
|
#include <Windows.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
CFramePerSecond::CFramePerSecond()
|
CFramePerSecond::CFramePerSecond()
|
||||||
{
|
{
|
||||||
|
@ -25,9 +27,11 @@ CFramePerSecond::CFramePerSecond()
|
||||||
m_ScreenHertz = 60;
|
m_ScreenHertz = 60;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
LARGE_INTEGER Freq;
|
LARGE_INTEGER Freq;
|
||||||
QueryPerformanceFrequency(&Freq);
|
QueryPerformanceFrequency(&Freq);
|
||||||
m_Frequency = Freq.QuadPart;
|
m_Frequency = Freq.QuadPart;
|
||||||
|
#endif
|
||||||
Reset(true);
|
Reset(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,7 +52,9 @@ void CFramePerSecond::Reset(bool ClearDisplay)
|
||||||
}
|
}
|
||||||
if (ClearDisplay)
|
if (ClearDisplay)
|
||||||
{
|
{
|
||||||
|
#ifdef _WIN32
|
||||||
g_Notify->DisplayMessage2("");
|
g_Notify->DisplayMessage2("");
|
||||||
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -60,6 +66,7 @@ void CFramePerSecond::Reset(bool ClearDisplay)
|
||||||
|
|
||||||
void CFramePerSecond::UpdateViCounter(void)
|
void CFramePerSecond::UpdateViCounter(void)
|
||||||
{
|
{
|
||||||
|
#ifdef _WIN32
|
||||||
if (m_iFrameRateType != FR_VIs && m_iFrameRateType != FR_PERCENT)
|
if (m_iFrameRateType != FR_VIs && m_iFrameRateType != FR_PERCENT)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
|
@ -73,10 +80,12 @@ void CFramePerSecond::UpdateViCounter(void)
|
||||||
DisplayViCounter(0);
|
DisplayViCounter(0);
|
||||||
}
|
}
|
||||||
m_CurrentFrame += 1;
|
m_CurrentFrame += 1;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void CFramePerSecond::DisplayViCounter(uint32_t FrameRate)
|
void CFramePerSecond::DisplayViCounter(uint32_t FrameRate)
|
||||||
{
|
{
|
||||||
|
#ifdef _WIN32
|
||||||
if (m_iFrameRateType == FR_VIs)
|
if (m_iFrameRateType == FR_VIs)
|
||||||
{
|
{
|
||||||
if (FrameRate != 0)
|
if (FrameRate != 0)
|
||||||
|
@ -87,7 +96,7 @@ void CFramePerSecond::DisplayViCounter(uint32_t FrameRate)
|
||||||
{
|
{
|
||||||
if (m_CurrentFrame > (NoOfFrames << 3))
|
if (m_CurrentFrame > (NoOfFrames << 3))
|
||||||
{
|
{
|
||||||
__int64 Total;
|
int64_t Total;
|
||||||
|
|
||||||
Total = 0;
|
Total = 0;
|
||||||
for (int count = 0; count < NoOfFrames; count++)
|
for (int count = 0; count < NoOfFrames; count++)
|
||||||
|
@ -113,7 +122,7 @@ void CFramePerSecond::DisplayViCounter(uint32_t FrameRate)
|
||||||
{
|
{
|
||||||
if (m_CurrentFrame > (NoOfFrames << 3))
|
if (m_CurrentFrame > (NoOfFrames << 3))
|
||||||
{
|
{
|
||||||
__int64 Total;
|
int64_t Total;
|
||||||
|
|
||||||
Total = 0;
|
Total = 0;
|
||||||
for (int count = 0; count < NoOfFrames; count++)
|
for (int count = 0; count < NoOfFrames; count++)
|
||||||
|
@ -130,6 +139,7 @@ void CFramePerSecond::DisplayViCounter(uint32_t FrameRate)
|
||||||
}
|
}
|
||||||
g_Notify->DisplayMessage2(stdstr_f("%.1f %%", Percent * 100).c_str());
|
g_Notify->DisplayMessage2(stdstr_f("%.1f %%", Percent * 100).c_str());
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void CFramePerSecond::FrameRateTypeChanged(CFramePerSecond * _this)
|
void CFramePerSecond::FrameRateTypeChanged(CFramePerSecond * _this)
|
||||||
|
@ -146,6 +156,7 @@ void CFramePerSecond::ScreenHertzChanged(CFramePerSecond * _this)
|
||||||
|
|
||||||
void CFramePerSecond::UpdateDlCounter(void)
|
void CFramePerSecond::UpdateDlCounter(void)
|
||||||
{
|
{
|
||||||
|
#ifdef _WIN32
|
||||||
if (m_iFrameRateType != FR_DLs)
|
if (m_iFrameRateType != FR_DLs)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
|
@ -158,10 +169,12 @@ void CFramePerSecond::UpdateDlCounter(void)
|
||||||
DisplayDlCounter(0);
|
DisplayDlCounter(0);
|
||||||
}
|
}
|
||||||
m_CurrentFrame += 1;
|
m_CurrentFrame += 1;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void CFramePerSecond::DisplayDlCounter(uint32_t FrameRate)
|
void CFramePerSecond::DisplayDlCounter(uint32_t FrameRate)
|
||||||
{
|
{
|
||||||
|
#ifdef _WIN32
|
||||||
if (m_iFrameRateType != FR_DLs)
|
if (m_iFrameRateType != FR_DLs)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
|
@ -174,7 +187,7 @@ void CFramePerSecond::DisplayDlCounter(uint32_t FrameRate)
|
||||||
{
|
{
|
||||||
if (m_CurrentFrame > (NoOfFrames << 2))
|
if (m_CurrentFrame > (NoOfFrames << 2))
|
||||||
{
|
{
|
||||||
__int64 Total;
|
int64_t Total;
|
||||||
|
|
||||||
Total = 0;
|
Total = 0;
|
||||||
for (int count = 0; count < NoOfFrames; count++)
|
for (int count = 0; count < NoOfFrames; count++)
|
||||||
|
@ -188,4 +201,5 @@ void CFramePerSecond::DisplayDlCounter(uint32_t FrameRate)
|
||||||
g_Notify->DisplayMessage2("DL/s: -.--");
|
g_Notify->DisplayMessage2("DL/s: -.--");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
|
@ -24,13 +24,16 @@ public:
|
||||||
void DisplayViCounter(uint32_t FrameRate);
|
void DisplayViCounter(uint32_t FrameRate);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
CFramePerSecond(const CFramePerSecond&); // Disable copy constructor
|
||||||
|
CFramePerSecond& operator=(const CFramePerSecond&); // Disable assignment
|
||||||
|
|
||||||
static void FrameRateTypeChanged(CFramePerSecond * _this);
|
static void FrameRateTypeChanged(CFramePerSecond * _this);
|
||||||
static void ScreenHertzChanged(CFramePerSecond * _this);
|
static void ScreenHertzChanged(CFramePerSecond * _this);
|
||||||
|
|
||||||
int m_iFrameRateType, m_ScreenHertz;
|
int32_t m_iFrameRateType, m_ScreenHertz;
|
||||||
|
|
||||||
enum { NoOfFrames = 7 };
|
enum { NoOfFrames = 7 };
|
||||||
|
|
||||||
int64_t m_Frequency, m_Frames[NoOfFrames], m_LastFrame;
|
int64_t m_Frequency, m_Frames[NoOfFrames], m_LastFrame;
|
||||||
int m_CurrentFrame;
|
int32_t m_CurrentFrame;
|
||||||
};
|
};
|
||||||
|
|
|
@ -21,6 +21,30 @@
|
||||||
#include <float.h>
|
#include <float.h>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
|
|
||||||
|
#if (defined(_MSC_VER) && (_MSC_VER < 1800))
|
||||||
|
double round(double num)
|
||||||
|
{
|
||||||
|
return (num - floor(num) > 0.5) ? ceil(num) : floor(num);
|
||||||
|
}
|
||||||
|
|
||||||
|
float roundf(float num)
|
||||||
|
{
|
||||||
|
return (num - floorf(num) > 0.5) ? ceilf(num) : floorf(num);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (defined(_MSC_VER) && (_MSC_VER < 1700))
|
||||||
|
double trunc(double num)
|
||||||
|
{
|
||||||
|
return (num < 0) ? ceil(num) : floor(num);
|
||||||
|
}
|
||||||
|
|
||||||
|
float truncf(float num)
|
||||||
|
{
|
||||||
|
return (num < 0) ? ceilf(num) : floorf(num);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void InPermLoop();
|
void InPermLoop();
|
||||||
void TestInterpreterJump(uint32_t PC, uint32_t TargetPC, int32_t Reg1, int32_t Reg2);
|
void TestInterpreterJump(uint32_t PC, uint32_t TargetPC, int32_t Reg1, int32_t Reg2);
|
||||||
|
|
||||||
|
@ -57,14 +81,12 @@ const int32_t R4300iOp::LWR_SHIFT[4] = { 24, 16, 8, 0 };
|
||||||
m_JumpToLocation = (*_PROGRAM_COUNTER);\
|
m_JumpToLocation = (*_PROGRAM_COUNTER);\
|
||||||
return;
|
return;
|
||||||
|
|
||||||
//#define TEST_COP1_USABLE_EXCEPTION
|
|
||||||
#define TEST_COP1_USABLE_EXCEPTION() \
|
#define TEST_COP1_USABLE_EXCEPTION() \
|
||||||
if ((g_Reg->STATUS_REGISTER & STATUS_CU1) == 0) {\
|
if ((g_Reg->STATUS_REGISTER & STATUS_CU1) == 0) {\
|
||||||
g_Reg->DoCopUnusableException(m_NextInstruction == JUMP,1);\
|
g_Reg->DoCopUnusableException(m_NextInstruction == JUMP,1);\
|
||||||
m_NextInstruction = JUMP;\
|
m_NextInstruction = JUMP;\
|
||||||
m_JumpToLocation = (*_PROGRAM_COUNTER);\
|
m_JumpToLocation = (*_PROGRAM_COUNTER);\
|
||||||
return;\
|
return;}\
|
||||||
}
|
|
||||||
|
|
||||||
#define TLB_READ_EXCEPTION(Address) \
|
#define TLB_READ_EXCEPTION(Address) \
|
||||||
g_Reg->DoTLBReadMiss(m_NextInstruction == JUMP,Address);\
|
g_Reg->DoTLBReadMiss(m_NextInstruction == JUMP,Address);\
|
||||||
|
@ -104,13 +126,13 @@ void R4300iOp::COP1_BC()
|
||||||
|
|
||||||
void R4300iOp::COP1_S()
|
void R4300iOp::COP1_S()
|
||||||
{
|
{
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
Jump_CoP1_S[m_Opcode.funct]();
|
Jump_CoP1_S[m_Opcode.funct]();
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D()
|
void R4300iOp::COP1_D()
|
||||||
{
|
{
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
Jump_CoP1_D[m_Opcode.funct]();
|
Jump_CoP1_D[m_Opcode.funct]();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2286,10 +2308,10 @@ void R4300iOp::COP1_CT()
|
||||||
_FPCR[m_Opcode.fs] = _GPR[m_Opcode.rt].W[0];
|
_FPCR[m_Opcode.fs] = _GPR[m_Opcode.rt].W[0];
|
||||||
switch ((_FPCR[m_Opcode.fs] & 3))
|
switch ((_FPCR[m_Opcode.fs] & 3))
|
||||||
{
|
{
|
||||||
case 0: *_RoundingModel = ROUND_NEAR; break;
|
case 0: *_RoundingModel = FE_TONEAREST; break;
|
||||||
case 1: *_RoundingModel = ROUND_CHOP; break;
|
case 1: *_RoundingModel = FE_TOWARDZERO; break;
|
||||||
case 2: *_RoundingModel = ROUND_UP; break;
|
case 2: *_RoundingModel = FE_UPWARD; break;
|
||||||
case 3: *_RoundingModel = ROUND_DOWN; break;
|
case 3: *_RoundingModel = FE_DOWNWARD; break;
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -2358,186 +2380,148 @@ void R4300iOp::COP1_BCTL()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/************************** COP1: S functions ************************/
|
/************************** COP1: S functions ************************/
|
||||||
__inline void Float_RoundToInteger32(int32_t * Dest, float * Source)
|
__inline void Float_RoundToInteger32(int32_t * Dest, const float * Source, int RoundType)
|
||||||
{
|
{
|
||||||
#ifdef _M_IX86
|
#pragma warning(push)
|
||||||
_asm
|
#pragma warning(disable:4244) //warning C4244: disabe conversion from 'float' to 'int32_t', possible loss of data
|
||||||
{
|
|
||||||
mov esi, [Source]
|
|
||||||
mov edi, [Dest]
|
|
||||||
fld dword ptr[esi]
|
|
||||||
fistp dword ptr[edi]
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
__m128 xmm;
|
|
||||||
|
|
||||||
xmm = _mm_load_ss(Source);
|
if (RoundType == FE_TONEAREST) { *Dest = roundf(*Source); }
|
||||||
*(Dest) = _mm_cvt_ss2si(xmm);
|
if (RoundType == FE_TOWARDZERO) { *Dest = truncf(*Source); }
|
||||||
#endif
|
if (RoundType == FE_UPWARD) { *Dest = ceilf(*Source); }
|
||||||
|
if (RoundType == FE_DOWNWARD) { *Dest = floorf(*Source); }
|
||||||
|
|
||||||
|
#pragma warning(pop)
|
||||||
}
|
}
|
||||||
|
|
||||||
__inline void Float_RoundToInteger64(int64_t * Dest, float * Source)
|
__inline void Float_RoundToInteger64(int64_t * Dest, const float * Source, int RoundType)
|
||||||
{
|
{
|
||||||
#ifdef _M_IX86
|
#pragma warning(push)
|
||||||
_asm
|
#pragma warning(disable:4244) //warning C4244: disabe conversion from 'float' to 'int64_t', possible loss of data
|
||||||
{
|
|
||||||
mov esi, [Source]
|
|
||||||
mov edi, [Dest]
|
|
||||||
fld dword ptr[esi]
|
|
||||||
fistp qword ptr[edi]
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
__m128 xmm;
|
|
||||||
|
|
||||||
xmm = _mm_load_ss(Source);
|
if (RoundType == FE_TONEAREST) { *Dest = roundf(*Source); }
|
||||||
*(Dest) = _mm_cvtss_si64(xmm);
|
if (RoundType == FE_TOWARDZERO) { *Dest = truncf(*Source); }
|
||||||
#endif
|
if (RoundType == FE_UPWARD) { *Dest = ceilf(*Source); }
|
||||||
|
if (RoundType == FE_DOWNWARD) { *Dest = floorf(*Source); }
|
||||||
|
|
||||||
|
#pragma warning(pop)
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_ADD()
|
void R4300iOp::COP1_S_ADD()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(float *)_FPR_S[m_Opcode.fd] = (*(float *)_FPR_S[m_Opcode.fs] + *(float *)_FPR_S[m_Opcode.ft]);
|
*(float *)_FPR_S[m_Opcode.fd] = (*(float *)_FPR_S[m_Opcode.fs] + *(float *)_FPR_S[m_Opcode.ft]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_SUB()
|
void R4300iOp::COP1_S_SUB()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(float *)_FPR_S[m_Opcode.fd] = (*(float *)_FPR_S[m_Opcode.fs] - *(float *)_FPR_S[m_Opcode.ft]);
|
*(float *)_FPR_S[m_Opcode.fd] = (*(float *)_FPR_S[m_Opcode.fs] - *(float *)_FPR_S[m_Opcode.ft]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_MUL()
|
void R4300iOp::COP1_S_MUL()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(float *)_FPR_S[m_Opcode.fd] = (*(float *)_FPR_S[m_Opcode.fs] * *(float *)_FPR_S[m_Opcode.ft]);
|
*(float *)_FPR_S[m_Opcode.fd] = (*(float *)_FPR_S[m_Opcode.fs] * *(float *)_FPR_S[m_Opcode.ft]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_DIV()
|
void R4300iOp::COP1_S_DIV()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(float *)_FPR_S[m_Opcode.fd] = (*(float *)_FPR_S[m_Opcode.fs] / *(float *)_FPR_S[m_Opcode.ft]);
|
*(float *)_FPR_S[m_Opcode.fd] = (*(float *)_FPR_S[m_Opcode.fs] / *(float *)_FPR_S[m_Opcode.ft]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_SQRT()
|
void R4300iOp::COP1_S_SQRT()
|
||||||
{
|
{
|
||||||
float * Dest = (float *)(_FPR_S[m_Opcode.fd]);
|
|
||||||
float * Source = (float *)(_FPR_S[m_Opcode.fs]);
|
|
||||||
|
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
#ifdef _M_IX86
|
|
||||||
_asm
|
|
||||||
{
|
|
||||||
push esi
|
|
||||||
mov esi, dword ptr[Source]
|
|
||||||
fld dword ptr[esi]
|
|
||||||
fsqrt
|
|
||||||
mov esi, dword ptr[Dest]
|
|
||||||
fstp dword ptr[esi]
|
|
||||||
pop esi
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
__m128 xmm;
|
|
||||||
|
|
||||||
xmm = _mm_load_ss(Source);
|
*(float *)(_FPR_S[m_Opcode.fd]) = sqrtf(*(float *)(_FPR_S[m_Opcode.fs]));
|
||||||
xmm = _mm_sqrt_ss(xmm);
|
|
||||||
*(Dest) = _mm_cvtss_f32(xmm);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_ABS()
|
void R4300iOp::COP1_S_ABS()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(float *)_FPR_S[m_Opcode.fd] = (float)fabs(*(float *)_FPR_S[m_Opcode.fs]);
|
*(float *)_FPR_S[m_Opcode.fd] = (float)fabs(*(float *)_FPR_S[m_Opcode.fs]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_MOV()
|
void R4300iOp::COP1_S_MOV()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(float *)_FPR_S[m_Opcode.fd] = *(float *)_FPR_S[m_Opcode.fs];
|
*(float *)_FPR_S[m_Opcode.fd] = *(float *)_FPR_S[m_Opcode.fs];
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_NEG()
|
void R4300iOp::COP1_S_NEG()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(float *)_FPR_S[m_Opcode.fd] = (*(float *)_FPR_S[m_Opcode.fs] * -1.0f);
|
*(float *)_FPR_S[m_Opcode.fd] = (*(float *)_FPR_S[m_Opcode.fs] * -1.0f);
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_TRUNC_L()
|
void R4300iOp::COP1_S_TRUNC_L()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(_RC_CHOP, _MCW_RC);
|
Float_RoundToInteger64(&*(int64_t *)_FPR_D[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs], FE_TOWARDZERO);
|
||||||
Float_RoundToInteger64(&*(int64_t *)_FPR_D[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_CEIL_L()
|
void R4300iOp::COP1_S_CEIL_L()
|
||||||
{ //added by Witten
|
{ //added by Witten
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(_RC_UP, _MCW_RC);
|
Float_RoundToInteger64(&*(int64_t *)_FPR_D[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs], FE_UPWARD);
|
||||||
Float_RoundToInteger64(&*(int64_t *)_FPR_D[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_FLOOR_L()
|
void R4300iOp::COP1_S_FLOOR_L()
|
||||||
{ //added by Witten
|
{ //added by Witten
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(_RC_DOWN, _MCW_RC);
|
Float_RoundToInteger64(&*(int64_t *)_FPR_D[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs], FE_DOWNWARD);
|
||||||
Float_RoundToInteger64(&*(int64_t *)_FPR_D[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_ROUND_W()
|
void R4300iOp::COP1_S_ROUND_W()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(_RC_NEAR, _MCW_RC);
|
Float_RoundToInteger32(&*(int32_t *)_FPR_S[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs], FE_TONEAREST);
|
||||||
Float_RoundToInteger32(&*(int32_t *)_FPR_S[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_TRUNC_W()
|
void R4300iOp::COP1_S_TRUNC_W()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(_RC_CHOP, _MCW_RC);
|
Float_RoundToInteger32(&*(int32_t *)_FPR_S[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs], FE_TOWARDZERO);
|
||||||
Float_RoundToInteger32(&*(int32_t *)_FPR_S[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_CEIL_W()
|
void R4300iOp::COP1_S_CEIL_W()
|
||||||
{ //added by Witten
|
{ //added by Witten
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(_RC_UP, _MCW_RC);
|
Float_RoundToInteger32(&*(int32_t *)_FPR_S[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs], FE_UPWARD);
|
||||||
Float_RoundToInteger32(&*(int32_t *)_FPR_S[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_FLOOR_W()
|
void R4300iOp::COP1_S_FLOOR_W()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(_RC_DOWN, _MCW_RC);
|
Float_RoundToInteger32(&*(int32_t *)_FPR_S[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs], FE_DOWNWARD);
|
||||||
Float_RoundToInteger32(&*(int32_t *)_FPR_S[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_CVT_D()
|
void R4300iOp::COP1_S_CVT_D()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(double *)_FPR_D[m_Opcode.fd] = (double)(*(float *)_FPR_S[m_Opcode.fs]);
|
*(double *)_FPR_D[m_Opcode.fd] = (double)(*(float *)_FPR_S[m_Opcode.fs]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_CVT_W()
|
void R4300iOp::COP1_S_CVT_W()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
Float_RoundToInteger32(&*(int32_t *)_FPR_S[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs], *_RoundingModel);
|
||||||
Float_RoundToInteger32(&*(int32_t *)_FPR_S[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_CVT_L()
|
void R4300iOp::COP1_S_CVT_L()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
Float_RoundToInteger64(&*(int64_t *)_FPR_D[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs], *_RoundingModel);
|
||||||
Float_RoundToInteger64(&*(int64_t *)_FPR_D[m_Opcode.fd], &*(float *)_FPR_S[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_S_CMP()
|
void R4300iOp::COP1_S_CMP()
|
||||||
|
@ -2554,7 +2538,7 @@ void R4300iOp::COP1_S_CMP()
|
||||||
{
|
{
|
||||||
if (bHaveDebugger())
|
if (bHaveDebugger())
|
||||||
{
|
{
|
||||||
g_Notify->DisplayError(stdstr_f("%s: Nan ?",__FUNCTION__).c_str());
|
g_Notify->DisplayError(stdstr_f("%s: Nan ?", __FUNCTION__).c_str());
|
||||||
}
|
}
|
||||||
less = false;
|
less = false;
|
||||||
equal = false;
|
equal = false;
|
||||||
|
@ -2588,166 +2572,147 @@ void R4300iOp::COP1_S_CMP()
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************** COP1: D functions ************************/
|
/************************** COP1: D functions ************************/
|
||||||
__inline void Double_RoundToInteger32(uint32_t * Dest, double * Source)
|
__inline void Double_RoundToInteger32(uint32_t * Dest, const double * Source, int RoundType)
|
||||||
{
|
{
|
||||||
#ifdef _M_IX86
|
#pragma warning(push)
|
||||||
_asm
|
#pragma warning(disable:4244) //warning C4244: disabe conversion from 'double' to 'uint32_t', possible loss of data
|
||||||
{
|
|
||||||
mov esi, [Source]
|
|
||||||
mov edi, [Dest]
|
|
||||||
fld qword ptr [esi]
|
|
||||||
fistp dword ptr [edi]
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
__m128d xmm;
|
|
||||||
|
|
||||||
xmm = _mm_load_sd(Source);
|
if (RoundType == FE_TONEAREST) { *Dest = round(*Source); }
|
||||||
*(Dest) = _mm_cvtsd_si32(xmm);
|
if (RoundType == FE_TOWARDZERO) { *Dest = trunc(*Source); }
|
||||||
#endif
|
if (RoundType == FE_UPWARD) { *Dest = ceil(*Source); }
|
||||||
|
if (RoundType == FE_DOWNWARD) { *Dest = floor(*Source); }
|
||||||
|
|
||||||
|
#pragma warning(pop)
|
||||||
}
|
}
|
||||||
|
|
||||||
__inline void Double_RoundToInteger64(uint64_t * Dest, double * Source)
|
__inline void Double_RoundToInteger64(uint64_t * Dest, const double * Source, int RoundType)
|
||||||
{
|
{
|
||||||
#ifdef _M_IX86
|
#pragma warning(push)
|
||||||
_asm
|
#pragma warning(disable:4244) //warning C4244: disabe conversion from 'double' to 'uint64_t', possible loss of data
|
||||||
{
|
|
||||||
mov esi, [Source]
|
|
||||||
mov edi, [Dest]
|
|
||||||
fld qword ptr [esi]
|
|
||||||
fistp qword ptr [edi]
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
__m128d xmm;
|
|
||||||
|
|
||||||
xmm = _mm_load_sd(Source);
|
if (RoundType == FE_TONEAREST) { *Dest = round(*Source); }
|
||||||
*(Dest) = _mm_cvtsd_si64(xmm);
|
if (RoundType == FE_TOWARDZERO) { *Dest = trunc(*Source); }
|
||||||
#endif
|
if (RoundType == FE_UPWARD) { *Dest = ceil(*Source); }
|
||||||
|
if (RoundType == FE_DOWNWARD) { *Dest = floor(*Source); }
|
||||||
|
|
||||||
|
#pragma warning(pop)
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_ADD()
|
void R4300iOp::COP1_D_ADD()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(double *)_FPR_D[m_Opcode.fd] = *(double *)_FPR_D[m_Opcode.fs] + *(double *)_FPR_D[m_Opcode.ft];
|
*(double *)_FPR_D[m_Opcode.fd] = *(double *)_FPR_D[m_Opcode.fs] + *(double *)_FPR_D[m_Opcode.ft];
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_SUB()
|
void R4300iOp::COP1_D_SUB()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(double *)_FPR_D[m_Opcode.fd] = *(double *)_FPR_D[m_Opcode.fs] - *(double *)_FPR_D[m_Opcode.ft];
|
*(double *)_FPR_D[m_Opcode.fd] = *(double *)_FPR_D[m_Opcode.fs] - *(double *)_FPR_D[m_Opcode.ft];
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_MUL()
|
void R4300iOp::COP1_D_MUL()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(double *)_FPR_D[m_Opcode.fd] = *(double *)_FPR_D[m_Opcode.fs] * *(double *)_FPR_D[m_Opcode.ft];
|
*(double *)_FPR_D[m_Opcode.fd] = *(double *)_FPR_D[m_Opcode.fs] * *(double *)_FPR_D[m_Opcode.ft];
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_DIV()
|
void R4300iOp::COP1_D_DIV()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(double *)_FPR_D[m_Opcode.fd] = *(double *)_FPR_D[m_Opcode.fs] / *(double *)_FPR_D[m_Opcode.ft];
|
*(double *)_FPR_D[m_Opcode.fd] = *(double *)_FPR_D[m_Opcode.fs] / *(double *)_FPR_D[m_Opcode.ft];
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_SQRT()
|
void R4300iOp::COP1_D_SQRT()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(double *)_FPR_D[m_Opcode.fd] = (double)sqrt(*(double *)_FPR_D[m_Opcode.fs]);
|
*(double *)_FPR_D[m_Opcode.fd] = (double)sqrt(*(double *)_FPR_D[m_Opcode.fs]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_ABS()
|
void R4300iOp::COP1_D_ABS()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(double *)_FPR_D[m_Opcode.fd] = fabs(*(double *)_FPR_D[m_Opcode.fs]);
|
*(double *)_FPR_D[m_Opcode.fd] = fabs(*(double *)_FPR_D[m_Opcode.fs]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_MOV()
|
void R4300iOp::COP1_D_MOV()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(int64_t *)_FPR_D[m_Opcode.fd] = *(int64_t *)_FPR_D[m_Opcode.fs];
|
*(int64_t *)_FPR_D[m_Opcode.fd] = *(int64_t *)_FPR_D[m_Opcode.fs];
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_NEG()
|
void R4300iOp::COP1_D_NEG()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(double *)_FPR_D[m_Opcode.fd] = (*(double *)_FPR_D[m_Opcode.fs] * -1.0);
|
*(double *)_FPR_D[m_Opcode.fd] = (*(double *)_FPR_D[m_Opcode.fs] * -1.0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_TRUNC_L()
|
void R4300iOp::COP1_D_TRUNC_L()
|
||||||
{ //added by Witten
|
{ //added by Witten
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(RC_CHOP, _MCW_RC);
|
Double_RoundToInteger64(&*(uint64_t *)_FPR_S[m_Opcode.fd], &*(double *)_FPR_D[m_Opcode.fs], FE_TOWARDZERO);
|
||||||
Double_RoundToInteger64(&*(uint64_t *)_FPR_S[m_Opcode.fd], &*(double *)_FPR_D[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_CEIL_L()
|
void R4300iOp::COP1_D_CEIL_L()
|
||||||
{ //added by Witten
|
{ //added by Witten
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(RC_UP, _MCW_RC);
|
Double_RoundToInteger64(&*(uint64_t *)_FPR_S[m_Opcode.fd], &*(double *)_FPR_D[m_Opcode.fs], FE_UPWARD);
|
||||||
Double_RoundToInteger64(&*(uint64_t *)_FPR_S[m_Opcode.fd], &*(double *)_FPR_D[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_FLOOR_L()
|
void R4300iOp::COP1_D_FLOOR_L()
|
||||||
{ //added by Witten
|
{ //added by Witten
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(_RC_DOWN, _MCW_RC);
|
Double_RoundToInteger64(&*(uint64_t *)_FPR_D[m_Opcode.fd], &*(double *)_FPR_S[m_Opcode.fs], FE_DOWNWARD);
|
||||||
Double_RoundToInteger64(&*(uint64_t *)_FPR_D[m_Opcode.fd], &*(double *)_FPR_S[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_ROUND_W()
|
void R4300iOp::COP1_D_ROUND_W()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(_RC_NEAR, _MCW_RC);
|
Double_RoundToInteger32(&*(uint32_t *)_FPR_S[m_Opcode.fd], &*(double *)_FPR_D[m_Opcode.fs], FE_TONEAREST);
|
||||||
Double_RoundToInteger32(&*(uint32_t *)_FPR_S[m_Opcode.fd], &*(double *)_FPR_D[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_TRUNC_W()
|
void R4300iOp::COP1_D_TRUNC_W()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(RC_CHOP, _MCW_RC);
|
Double_RoundToInteger32(&*(uint32_t *)_FPR_S[m_Opcode.fd], &*(double *)_FPR_D[m_Opcode.fs], FE_TOWARDZERO);
|
||||||
Double_RoundToInteger32(&*(uint32_t *)_FPR_S[m_Opcode.fd], &*(double *)_FPR_D[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_CEIL_W()
|
void R4300iOp::COP1_D_CEIL_W()
|
||||||
{ //added by Witten
|
{ //added by Witten
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(RC_UP, _MCW_RC);
|
Double_RoundToInteger32(&*(uint32_t *)_FPR_S[m_Opcode.fd], &*(double *)_FPR_D[m_Opcode.fs], FE_UPWARD);
|
||||||
Double_RoundToInteger32(&*(uint32_t *)_FPR_S[m_Opcode.fd], &*(double *)_FPR_D[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_FLOOR_W()
|
void R4300iOp::COP1_D_FLOOR_W()
|
||||||
{ //added by Witten
|
{ //added by Witten
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(_RC_DOWN, _MCW_RC);
|
Double_RoundToInteger32(&*(uint32_t *)_FPR_D[m_Opcode.fd], &*(double *)_FPR_S[m_Opcode.fs], FE_DOWNWARD);
|
||||||
Double_RoundToInteger32(&*(uint32_t *)_FPR_D[m_Opcode.fd], &*(double *)_FPR_S[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_CVT_S()
|
void R4300iOp::COP1_D_CVT_S()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(float *)_FPR_S[m_Opcode.fd] = (float)*(double *)_FPR_D[m_Opcode.fs];
|
*(float *)_FPR_S[m_Opcode.fd] = (float)*(double *)_FPR_D[m_Opcode.fs];
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_CVT_W()
|
void R4300iOp::COP1_D_CVT_W()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
Double_RoundToInteger32(&*(uint32_t *)_FPR_S[m_Opcode.fd], &*(double *)_FPR_D[m_Opcode.fs], *_RoundingModel);
|
||||||
Double_RoundToInteger32(&*(uint32_t *)_FPR_S[m_Opcode.fd], &*(double *)_FPR_D[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_CVT_L()
|
void R4300iOp::COP1_D_CVT_L()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
Double_RoundToInteger64(&*(uint64_t *)_FPR_D[m_Opcode.fd], &*(double *)_FPR_D[m_Opcode.fs], *_RoundingModel);
|
||||||
Double_RoundToInteger64(&*(uint64_t *)_FPR_D[m_Opcode.fd], &*(double *)_FPR_D[m_Opcode.fs]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_D_CMP()
|
void R4300iOp::COP1_D_CMP()
|
||||||
|
@ -2765,7 +2730,7 @@ void R4300iOp::COP1_D_CMP()
|
||||||
{
|
{
|
||||||
if (bHaveDebugger())
|
if (bHaveDebugger())
|
||||||
{
|
{
|
||||||
g_Notify->DisplayError(stdstr_f("%s: Nan ?",__FUNCTION__).c_str());
|
g_Notify->DisplayError(stdstr_f("%s: Nan ?", __FUNCTION__).c_str());
|
||||||
}
|
}
|
||||||
less = false;
|
less = false;
|
||||||
equal = false;
|
equal = false;
|
||||||
|
@ -2802,14 +2767,14 @@ void R4300iOp::COP1_D_CMP()
|
||||||
void R4300iOp::COP1_W_CVT_S()
|
void R4300iOp::COP1_W_CVT_S()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(float *)_FPR_S[m_Opcode.fd] = (float)*(int32_t *)_FPR_S[m_Opcode.fs];
|
*(float *)_FPR_S[m_Opcode.fd] = (float)*(int32_t *)_FPR_S[m_Opcode.fs];
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_W_CVT_D()
|
void R4300iOp::COP1_W_CVT_D()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(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];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2817,14 +2782,14 @@ void R4300iOp::COP1_W_CVT_D()
|
||||||
void R4300iOp::COP1_L_CVT_S()
|
void R4300iOp::COP1_L_CVT_S()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(float *)_FPR_S[m_Opcode.fd] = (float)*(int64_t *)_FPR_D[m_Opcode.fs];
|
*(float *)_FPR_S[m_Opcode.fd] = (float)*(int64_t *)_FPR_D[m_Opcode.fs];
|
||||||
}
|
}
|
||||||
|
|
||||||
void R4300iOp::COP1_L_CVT_D()
|
void R4300iOp::COP1_L_CVT_D()
|
||||||
{
|
{
|
||||||
TEST_COP1_USABLE_EXCEPTION();
|
TEST_COP1_USABLE_EXCEPTION();
|
||||||
_controlfp(*_RoundingModel, _MCW_RC);
|
fesetround(*_RoundingModel);
|
||||||
*(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];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,84 @@
|
||||||
|
/****************************************************************************
|
||||||
|
* *
|
||||||
|
* Project64 - A Nintendo 64 emulator. *
|
||||||
|
* http://www.pj64-emu.com/ *
|
||||||
|
* Copyright (C) 2012 Project64. All rights reserved. *
|
||||||
|
* *
|
||||||
|
* License: *
|
||||||
|
* GNU/GPLv2 http://www.gnu.org/licenses/gpl-2.0.html *
|
||||||
|
* *
|
||||||
|
****************************************************************************/
|
||||||
|
#pragma once
|
||||||
|
#include "stdafx.h"
|
||||||
|
#include <Project64-core/N64System/SystemGlobals.h>
|
||||||
|
#include <Project64-core/N64System/Mips/RegisterClass.h>
|
||||||
|
|
||||||
|
void DiskCommand()
|
||||||
|
{
|
||||||
|
//ASIC_CMD_STATUS - Commands
|
||||||
|
uint32_t cmd = g_Reg->ASIC_CMD;
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
SYSTEMTIME sysTime;
|
||||||
|
::GetLocalTime(&sysTime);
|
||||||
|
//stdstr_f timestamp("%04d/%02d/%02d %02d:%02d:%02d.%03d %05d,", sysTime.wYear, sysTime.wMonth, sysTime.wDay, sysTime.wHour, sysTime.wMinute, sysTime.wSecond, sysTime.wMilliseconds, GetCurrentThreadId());
|
||||||
|
|
||||||
|
//BCD format needed for 64DD RTC
|
||||||
|
uint8_t year = (uint8_t)(((sysTime.wYear / 10) << 4) | (sysTime.wYear % 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 hour = (uint8_t)(((sysTime.wHour / 10) << 4) | (sysTime.wHour % 10));
|
||||||
|
uint8_t minute = (uint8_t)(((sysTime.wMinute / 10) << 4) | (sysTime.wMinute % 10));
|
||||||
|
uint8_t second = (uint8_t)(((sysTime.wSecond / 10) << 4) | (sysTime.wSecond % 10));
|
||||||
|
#else
|
||||||
|
time_t ltime;
|
||||||
|
ltime = time(<ime);
|
||||||
|
|
||||||
|
struct tm result = { 0 };
|
||||||
|
localtime_r(<ime, &result);
|
||||||
|
|
||||||
|
//stdstr_f timestamp("%04d/%02d/%02d %02d:%02d:%02d.%03d %05d,", result.tm_year + 1900, result.tm_mon + 1, result.tm_mday, result.tm_hour, result.tm_min, result.tm_sec, milliseconds, GetCurrentThreadId());
|
||||||
|
|
||||||
|
//BCD format needed for 64DD RTC
|
||||||
|
uint8_t year = (uint8_t)(((result.tm_year / 10) << 4) | (result.tm_year % 10));
|
||||||
|
uint8_t month = (uint8_t)(((result.tm_mon / 10) << 4) | (result.tm_mon % 10));
|
||||||
|
uint8_t day = (uint8_t)(((result.tm_mday / 10) << 4) | (result.tm_mday % 10));
|
||||||
|
uint8_t hour = (uint8_t)(((result.tm_hour / 10) << 4) | (result.tm_hour % 10));
|
||||||
|
uint8_t minute = (uint8_t)(((result.tm_min / 10) << 4) | (result.tm_min % 10));
|
||||||
|
uint8_t second = (uint8_t)(((result.tm_sec / 10) << 4) | (result.tm_sec % 10));
|
||||||
|
#endif
|
||||||
|
|
||||||
|
switch (cmd & 0xFFFF0000)
|
||||||
|
{
|
||||||
|
case 0x00080000:
|
||||||
|
//Unset Disk Changed Bit
|
||||||
|
g_Reg->ASIC_STATUS &= ~DD_STATUS_DISK_CHNG; break;
|
||||||
|
case 0x00090000:
|
||||||
|
//Unset Reset Bit
|
||||||
|
g_Reg->ASIC_STATUS &= ~DD_STATUS_RST_STATE; break;
|
||||||
|
case 0x00120000:
|
||||||
|
//RTC Get Year & Month
|
||||||
|
g_Reg->ASIC_DATA = (year << 24) | (month << 16); break;
|
||||||
|
case 0x00130000:
|
||||||
|
//RTC Get Day & Hour
|
||||||
|
g_Reg->ASIC_DATA = (day << 24) | (hour << 16); break;
|
||||||
|
case 0x00140000:
|
||||||
|
//RTC Get Minute & Second
|
||||||
|
g_Reg->ASIC_DATA = (minute << 24) | (second << 16); break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void DiskReset(void)
|
||||||
|
{
|
||||||
|
//ASIC_HARD_RESET 0xAAAA0000
|
||||||
|
g_Reg->ASIC_STATUS |= DD_STATUS_RST_STATE;
|
||||||
|
}
|
||||||
|
|
||||||
|
void DiskBMControl(void)
|
||||||
|
{
|
||||||
|
if (g_Reg->ASIC_BM_CTL & DD_BM_CTL_MECHA_RST)
|
||||||
|
{
|
||||||
|
g_Reg->ASIC_STATUS &= ~DD_STATUS_MECHA_INT;
|
||||||
|
g_Reg->FAKE_CAUSE_REGISTER &= ~CAUSE_IP3;
|
||||||
|
}
|
||||||
|
}
|
|
@ -9,25 +9,8 @@
|
||||||
* *
|
* *
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
#pragma once
|
#pragma once
|
||||||
|
#include "stdafx.h"
|
||||||
|
|
||||||
typedef std::map<DWORD, stdstr> StringMap;
|
void DiskCommand(void);
|
||||||
|
void DiskReset(void);
|
||||||
class CMemoryLabel
|
void DiskBMControl(void);
|
||||||
{
|
|
||||||
// Variable dealing with Labels
|
|
||||||
StringMap m_LabelList;
|
|
||||||
int m_NewLabels;
|
|
||||||
stdstr CurrentLabelFile;
|
|
||||||
|
|
||||||
DWORD AsciiToHex ( char * HexValue );
|
|
||||||
void ProcessCODFile ( BYTE * File, DWORD FileLen );
|
|
||||||
|
|
||||||
public:
|
|
||||||
//Functions related to Labels
|
|
||||||
void AddMemoryLabel ( DWORD Address, const char * Message, ... );
|
|
||||||
stdstr LabelName ( DWORD Address ) const;
|
|
||||||
stdstr StoredLabelName ( DWORD Address );
|
|
||||||
void LoadLabelList ( char * file );
|
|
||||||
int NewLabels (); // How many new labels been added since loading/saving label file
|
|
||||||
void SaveLabelList ();
|
|
||||||
};
|
|
|
@ -34,6 +34,7 @@ void CDMA::OnFirstDMA()
|
||||||
{
|
{
|
||||||
case CIC_NUS_6101: offset = +0x0318; break;
|
case CIC_NUS_6101: offset = +0x0318; break;
|
||||||
case CIC_NUS_5167: offset = +0x0318; break;
|
case CIC_NUS_5167: offset = +0x0318; break;
|
||||||
|
case CIC_NUS_8303: offset = +0x0318; break;
|
||||||
case CIC_UNKNOWN:
|
case CIC_UNKNOWN:
|
||||||
case CIC_NUS_6102: offset = +0x0318; break;
|
case CIC_NUS_6102: offset = +0x0318; break;
|
||||||
case CIC_NUS_6103: offset = +0x0318; break;
|
case CIC_NUS_6103: offset = +0x0318; break;
|
||||||
|
@ -181,6 +182,75 @@ void CDMA::PI_DMA_WRITE()
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//64DD IPL ROM
|
||||||
|
if (g_Reg->PI_CART_ADDR_REG >= 0x06000000 && g_Reg->PI_CART_ADDR_REG <= 0x063FFFFF)
|
||||||
|
{
|
||||||
|
uint32_t i;
|
||||||
|
|
||||||
|
#ifdef legacycode
|
||||||
|
#ifdef ROM_IN_MAPSPACE
|
||||||
|
if (WrittenToRom)
|
||||||
|
{
|
||||||
|
uint32_t OldProtect;
|
||||||
|
VirtualProtect(ROM, m_RomFileSize, PAGE_READONLY, &OldProtect);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
uint8_t * ROM = g_DDRom->GetRomAddress();
|
||||||
|
uint8_t * RDRAM = g_MMU->Rdram();
|
||||||
|
g_Reg->PI_CART_ADDR_REG -= 0x06000000;
|
||||||
|
if (g_Reg->PI_CART_ADDR_REG + PI_WR_LEN_REG < g_DDRom->GetRomSize())
|
||||||
|
{
|
||||||
|
for (i = 0; i < PI_WR_LEN_REG; i++)
|
||||||
|
{
|
||||||
|
*(RDRAM + ((g_Reg->PI_DRAM_ADDR_REG + i) ^ 3)) = *(ROM + ((g_Reg->PI_CART_ADDR_REG + i) ^ 3));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (g_Reg->PI_CART_ADDR_REG >= g_DDRom->GetRomSize())
|
||||||
|
{
|
||||||
|
uint32_t cart = g_Reg->PI_CART_ADDR_REG - g_DDRom->GetRomSize();
|
||||||
|
while (cart >= g_DDRom->GetRomSize())
|
||||||
|
{
|
||||||
|
cart -= g_DDRom->GetRomSize();
|
||||||
|
}
|
||||||
|
for (i = 0; i < PI_WR_LEN_REG; i++)
|
||||||
|
{
|
||||||
|
*(RDRAM + ((g_Reg->PI_DRAM_ADDR_REG + i) ^ 3)) = *(ROM + ((cart + i) ^ 3));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
uint32_t Len;
|
||||||
|
Len = g_DDRom->GetRomSize() - g_Reg->PI_CART_ADDR_REG;
|
||||||
|
for (i = 0; i < Len; i++)
|
||||||
|
{
|
||||||
|
*(RDRAM + ((g_Reg->PI_DRAM_ADDR_REG + i) ^ 3)) = *(ROM + ((g_Reg->PI_CART_ADDR_REG + i) ^ 3));
|
||||||
|
}
|
||||||
|
for (i = Len; i < PI_WR_LEN_REG - Len; i++)
|
||||||
|
{
|
||||||
|
*(RDRAM + ((g_Reg->PI_DRAM_ADDR_REG + i) ^ 3)) = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
g_Reg->PI_CART_ADDR_REG += 0x06000000;
|
||||||
|
|
||||||
|
if (!g_System->DmaUsed())
|
||||||
|
{
|
||||||
|
g_System->SetDmaUsed(true);
|
||||||
|
OnFirstDMA();
|
||||||
|
}
|
||||||
|
if (g_Recompiler && g_System->bSMM_PIDMA())
|
||||||
|
{
|
||||||
|
g_Recompiler->ClearRecompCode_Phys(g_Reg->PI_DRAM_ADDR_REG, g_Reg->PI_WR_LEN_REG, CRecompiler::Remove_DMA);
|
||||||
|
}
|
||||||
|
g_Reg->PI_STATUS_REG &= ~PI_STATUS_DMA_BUSY;
|
||||||
|
g_Reg->MI_INTR_REG |= MI_INTR_PI;
|
||||||
|
g_Reg->CheckInterrupts();
|
||||||
|
//ChangeTimer(PiTimer,(int32_t)(PI_WR_LEN_REG * 8.9) + 50);
|
||||||
|
//ChangeTimer(PiTimer,(int32_t)(PI_WR_LEN_REG * 8.9));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (g_Reg->PI_CART_ADDR_REG >= 0x08000000 && g_Reg->PI_CART_ADDR_REG <= 0x08088000)
|
if (g_Reg->PI_CART_ADDR_REG >= 0x08000000 && g_Reg->PI_CART_ADDR_REG <= 0x08088000)
|
||||||
{
|
{
|
||||||
if (g_System->m_SaveUsing == SaveChip_Auto)
|
if (g_System->m_SaveUsing == SaveChip_Auto)
|
||||||
|
|
|
@ -1,213 +0,0 @@
|
||||||
/****************************************************************************
|
|
||||||
* *
|
|
||||||
* Project64 - A Nintendo 64 emulator. *
|
|
||||||
* http://www.pj64-emu.com/ *
|
|
||||||
* Copyright (C) 2012 Project64. All rights reserved. *
|
|
||||||
* *
|
|
||||||
* License: *
|
|
||||||
* GNU/GPLv2 http://www.gnu.org/licenses/gpl-2.0.html *
|
|
||||||
* *
|
|
||||||
****************************************************************************/
|
|
||||||
#include "stdafx.h"
|
|
||||||
|
|
||||||
DWORD CMemoryLabel::AsciiToHex (char * HexValue)
|
|
||||||
{
|
|
||||||
DWORD Count, Finish, Current, Value = 0;
|
|
||||||
|
|
||||||
Finish = strlen(HexValue);
|
|
||||||
if (Finish > 8 )
|
|
||||||
{
|
|
||||||
Finish = 8;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (Count = 0; Count < Finish; Count++)
|
|
||||||
{
|
|
||||||
Value = (Value << 4);
|
|
||||||
Current = HexValue[Count];
|
|
||||||
if(Current >= '0' && Current <= '9')
|
|
||||||
{
|
|
||||||
Value += Current - '0';
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if(Current > 'F')
|
|
||||||
Current -= 32; //32 is the distance between A and a
|
|
||||||
|
|
||||||
if (Current >= 'A' && Current <= 'F')
|
|
||||||
{
|
|
||||||
Value += Current - 55; //55 is the code for 'A' less 10
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Value = (Value >> 4);
|
|
||||||
Count = Finish;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return Value;
|
|
||||||
}
|
|
||||||
|
|
||||||
void CMemoryLabel::AddMemoryLabel ( DWORD Address, const char * Message, ... )
|
|
||||||
{
|
|
||||||
StringMap::iterator Item = m_LabelList.find(Address);
|
|
||||||
if (Item == m_LabelList.end())
|
|
||||||
{
|
|
||||||
char Msg[1000];
|
|
||||||
va_list ap;
|
|
||||||
|
|
||||||
va_start( ap, Message );
|
|
||||||
_vsnprintf( Msg,sizeof(Msg),Message, ap );
|
|
||||||
va_end( ap );
|
|
||||||
|
|
||||||
//if item is already in the list then do not add it
|
|
||||||
m_LabelList.insert(StringMap::value_type(Address,stdstr(Msg)));
|
|
||||||
m_NewLabels += 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
stdstr CMemoryLabel::LabelName ( DWORD Address ) const
|
|
||||||
{
|
|
||||||
//StringMap::iterator theIterator = m_LabelList.find(Address);
|
|
||||||
//if (theIterator != m_LabelList.end())
|
|
||||||
//{
|
|
||||||
// return (*theIterator).second;
|
|
||||||
//}
|
|
||||||
|
|
||||||
char strLabelName[100];
|
|
||||||
sprintf(strLabelName,"0x%08X",Address);
|
|
||||||
return stdstr(strLabelName);
|
|
||||||
}
|
|
||||||
|
|
||||||
stdstr CMemoryLabel::StoredLabelName ( DWORD Address )
|
|
||||||
{
|
|
||||||
StringMap::iterator theIterator = m_LabelList.find(Address);
|
|
||||||
if (theIterator != m_LabelList.end())
|
|
||||||
{
|
|
||||||
return (*theIterator).second;
|
|
||||||
}
|
|
||||||
return stdstr("");
|
|
||||||
}
|
|
||||||
|
|
||||||
void CMemoryLabel::LoadLabelList ( char * file )
|
|
||||||
{
|
|
||||||
m_LabelList.clear();
|
|
||||||
CurrentLabelFile = file;
|
|
||||||
|
|
||||||
HANDLE hFile = CreateFile(file,GENERIC_READ, FILE_SHARE_READ|FILE_SHARE_WRITE,NULL,
|
|
||||||
OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL | FILE_FLAG_SEQUENTIAL_SCAN, NULL);
|
|
||||||
if (hFile == INVALID_HANDLE_VALUE)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
SetFilePointer(hFile,0,NULL,FILE_BEGIN);
|
|
||||||
|
|
||||||
DWORD FileSize = GetFileSize(hFile,NULL);
|
|
||||||
void * FileContents = VirtualAlloc(NULL,FileSize,MEM_COMMIT,PAGE_READWRITE );
|
|
||||||
|
|
||||||
if (FileContents)
|
|
||||||
{
|
|
||||||
DWORD dwRead;
|
|
||||||
if (!ReadFile(hFile,FileContents,FileSize,&dwRead,NULL))
|
|
||||||
{
|
|
||||||
VirtualFree(FileContents, 0, MEM_RELEASE);
|
|
||||||
FileContents = NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (FileContents)
|
|
||||||
{
|
|
||||||
ProcessCODFile((BYTE *)FileContents, FileSize);
|
|
||||||
}
|
|
||||||
|
|
||||||
VirtualFree(FileContents, 0, MEM_RELEASE);
|
|
||||||
CloseHandle(hFile);
|
|
||||||
|
|
||||||
m_NewLabels = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// How many new labels been added since loading/saving label file
|
|
||||||
int CMemoryLabel::NewLabels()
|
|
||||||
{
|
|
||||||
return m_NewLabels;
|
|
||||||
}
|
|
||||||
|
|
||||||
void CMemoryLabel::SaveLabelList()
|
|
||||||
{
|
|
||||||
m_NewLabels = 0;
|
|
||||||
|
|
||||||
if (CurrentLabelFile.length() == 0)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
HANDLE hFile = CreateFile(CurrentLabelFile.c_str(),GENERIC_WRITE, FILE_SHARE_READ|FILE_SHARE_WRITE,NULL,
|
|
||||||
CREATE_ALWAYS,FILE_ATTRIBUTE_NORMAL | FILE_FLAG_SEQUENTIAL_SCAN, NULL);
|
|
||||||
SetFilePointer(hFile,0,NULL,FILE_BEGIN);
|
|
||||||
|
|
||||||
for (StringMap::iterator Item = m_LabelList.begin(); Item != m_LabelList.end(); Item++)
|
|
||||||
{
|
|
||||||
char Text[300];
|
|
||||||
DWORD dwWritten;
|
|
||||||
|
|
||||||
sprintf(Text, "0x%08X,%s\r\n",(*Item).first,((*Item).second).c_str());
|
|
||||||
|
|
||||||
WriteFile( hFile,Text,strlen(Text),&dwWritten,NULL );
|
|
||||||
}
|
|
||||||
|
|
||||||
CloseHandle(hFile);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void CMemoryLabel::ProcessCODFile(BYTE * File, DWORD FileLen)
|
|
||||||
{
|
|
||||||
char * CurrentPos = (char *)File;
|
|
||||||
char Label[40];
|
|
||||||
DWORD Address;
|
|
||||||
int Length;
|
|
||||||
|
|
||||||
while ( CurrentPos < (char *)File + FileLen )
|
|
||||||
{
|
|
||||||
if (*CurrentPos != '0')
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
CurrentPos += 1;
|
|
||||||
if (*CurrentPos != 'x')
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
CurrentPos += 1;
|
|
||||||
|
|
||||||
if (strchr(CurrentPos,',') - CurrentPos != 8)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
Address = AsciiToHex (CurrentPos);
|
|
||||||
CurrentPos += 9;
|
|
||||||
|
|
||||||
|
|
||||||
if (strchr(CurrentPos,'\r') == NULL)
|
|
||||||
{
|
|
||||||
Length = strchr(CurrentPos,'\n') - CurrentPos;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Length = strchr(CurrentPos,'\r') - CurrentPos;
|
|
||||||
if (Length > (strchr(CurrentPos,'\n') - CurrentPos))
|
|
||||||
{
|
|
||||||
Length = strchr(CurrentPos,'\n') - CurrentPos;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Stay within label array bounds
|
|
||||||
if (Length > 39)
|
|
||||||
Length = 39;
|
|
||||||
|
|
||||||
memcpy(Label,CurrentPos,Length);
|
|
||||||
Label[Length] = '\0';
|
|
||||||
|
|
||||||
AddMemoryLabel (Address, Label);
|
|
||||||
CurrentPos = strchr(CurrentPos,'\n') + 1;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -16,11 +16,18 @@
|
||||||
#include <Project64-core/N64System/N64Class.h>
|
#include <Project64-core/N64System/N64Class.h>
|
||||||
#include <Project64-core/N64System/Recompiler/x86CodeLog.h>
|
#include <Project64-core/N64System/Recompiler/x86CodeLog.h>
|
||||||
#include <Project64-core/N64System/Mips/OpcodeName.h>
|
#include <Project64-core/N64System/Mips/OpcodeName.h>
|
||||||
|
#include <Project64-core/N64System/Mips/Disk.h>
|
||||||
#include <Project64-core/ExceptionHandler.h>
|
#include <Project64-core/ExceptionHandler.h>
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <Common/MemoryManagement.h>
|
#include <Common/MemoryManagement.h>
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
#include <Windows.h>
|
||||||
|
#else
|
||||||
|
#include <sys/time.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
uint32_t RegModValue;
|
uint32_t RegModValue;
|
||||||
|
|
||||||
uint8_t * CMipsMemoryVM::m_Reserve1 = NULL;
|
uint8_t * CMipsMemoryVM::m_Reserve1 = NULL;
|
||||||
|
@ -194,6 +201,33 @@ bool CMipsMemoryVM::Initialize()
|
||||||
m_Rom = g_Rom->GetRomAddress();
|
m_Rom = g_Rom->GetRomAddress();
|
||||||
m_RomSize = g_Rom->GetRomSize();
|
m_RomSize = g_Rom->GetRomSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//64DD IPL
|
||||||
|
if (g_DDRom != NULL)
|
||||||
|
{
|
||||||
|
if (g_Settings->LoadBool(Game_LoadRomToMemory))
|
||||||
|
{
|
||||||
|
m_DDRomMapped = true;
|
||||||
|
m_DDRom = m_RDRAM + 0x06000000;
|
||||||
|
m_DDRomSize = g_DDRom->GetRomSize();
|
||||||
|
if (CommitMemory(m_DDRom, g_DDRom->GetRomSize(), MEM_READWRITE) == NULL)
|
||||||
|
{
|
||||||
|
WriteTrace(TraceN64System, TraceError, "Failed to Allocate Rom (Size: 0x%X)", g_DDRom->GetRomSize());
|
||||||
|
FreeMemory();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
memcpy(m_DDRom, g_DDRom->GetRomAddress(), g_DDRom->GetRomSize());
|
||||||
|
|
||||||
|
::ProtectMemory(m_DDRom, g_DDRom->GetRomSize(), MEM_READONLY);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_DDRomMapped = false;
|
||||||
|
m_DDRom = g_DDRom->GetRomAddress();
|
||||||
|
m_DDRomSize = g_DDRom->GetRomSize();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
CPifRam::Reset();
|
CPifRam::Reset();
|
||||||
|
|
||||||
m_TLB_ReadMap = new size_t[0x100000];
|
m_TLB_ReadMap = new size_t[0x100000];
|
||||||
|
@ -838,7 +872,7 @@ void CMipsMemoryVM::Compile_LW(x86Reg Reg, uint32_t VAddr)
|
||||||
if (g_Plugins->Audio()->AiReadLength != NULL)
|
if (g_Plugins->Audio()->AiReadLength != NULL)
|
||||||
{
|
{
|
||||||
BeforeCallDirect(m_RegWorkingSet);
|
BeforeCallDirect(m_RegWorkingSet);
|
||||||
Call_Direct(g_Plugins->Audio()->AiReadLength, "AiReadLength");
|
Call_Direct((void *)g_Plugins->Audio()->AiReadLength, "AiReadLength");
|
||||||
MoveX86regToVariable(x86_EAX, &m_TempValue, "m_TempValue");
|
MoveX86regToVariable(x86_EAX, &m_TempValue, "m_TempValue");
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
MoveVariableToX86reg(&m_TempValue, "m_TempValue", Reg);
|
MoveVariableToX86reg(&m_TempValue, "m_TempValue", Reg);
|
||||||
|
@ -917,6 +951,40 @@ void CMipsMemoryVM::Compile_LW(x86Reg Reg, uint32_t VAddr)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case 0x05000000:
|
||||||
|
//64DD Registers
|
||||||
|
if (g_Settings->LoadBool(Setting_EnableDisk))
|
||||||
|
{
|
||||||
|
switch (PAddr)
|
||||||
|
{
|
||||||
|
case 0x05000500: MoveVariableToX86reg(&g_Reg->ASIC_DATA, "ASIC_DATA", Reg); break;
|
||||||
|
case 0x05000504: MoveVariableToX86reg(&g_Reg->ASIC_MISC_REG, "ASIC_MISC_REG", Reg); break;
|
||||||
|
case 0x05000508: MoveVariableToX86reg(&g_Reg->ASIC_STATUS, "ASIC_STATUS", Reg); break;
|
||||||
|
case 0x0500050C: MoveVariableToX86reg(&g_Reg->ASIC_CUR_TK, "ASIC_CUR_TK", Reg); break;
|
||||||
|
case 0x05000510: MoveVariableToX86reg(&g_Reg->ASIC_BM_STATUS, "ASIC_BM_STATUS", Reg); break;
|
||||||
|
case 0x05000514: MoveVariableToX86reg(&g_Reg->ASIC_ERR_SECTOR, "ASIC_ERR_SECTOR", Reg); break;
|
||||||
|
case 0x05000518: MoveVariableToX86reg(&g_Reg->ASIC_SEQ_STATUS, "ASIC_SEQ_STATUS", Reg); break;
|
||||||
|
case 0x0500051C: MoveVariableToX86reg(&g_Reg->ASIC_CUR_SECTOR, "ASIC_CUR_SECTOR", Reg); break;
|
||||||
|
case 0x05000520: MoveVariableToX86reg(&g_Reg->ASIC_HARD_RESET, "ASIC_HARD_RESET", Reg); break;
|
||||||
|
case 0x05000524: MoveVariableToX86reg(&g_Reg->ASIC_C1_S0, "ASIC_C1_S0", Reg); break;
|
||||||
|
case 0x05000528: MoveVariableToX86reg(&g_Reg->ASIC_HOST_SECBYTE, "ASIC_HOST_SECBYTE", Reg); break;
|
||||||
|
case 0x0500052C: MoveVariableToX86reg(&g_Reg->ASIC_C1_S2, "ASIC_C1_S2", Reg); break;
|
||||||
|
case 0x05000530: MoveVariableToX86reg(&g_Reg->ASIC_SEC_BYTE, "ASIC_SEC_BYTE", Reg); break;
|
||||||
|
case 0x05000534: MoveVariableToX86reg(&g_Reg->ASIC_C1_S4, "ASIC_C1_S4", Reg); break;
|
||||||
|
case 0x05000538: MoveVariableToX86reg(&g_Reg->ASIC_C1_S6, "ASIC_C1_S6", Reg); break;
|
||||||
|
case 0x0500053C: MoveVariableToX86reg(&g_Reg->ASIC_CUR_ADDR, "ASIC_CUR_ADDR", Reg); break;
|
||||||
|
case 0x05000540: MoveVariableToX86reg(&g_Reg->ASIC_ID_REG, "ASIC_ID_REG", Reg); break;
|
||||||
|
case 0x05000544: MoveVariableToX86reg(&g_Reg->ASIC_TEST_REG, "ASIC_TEST_REG", Reg); break;
|
||||||
|
case 0x05000548: MoveVariableToX86reg(&g_Reg->ASIC_TEST_PIN_SEL, "ASIC_TEST_PIN_SEL", Reg); break;
|
||||||
|
default:
|
||||||
|
MoveConstToX86reg(0, Reg);
|
||||||
|
if (g_Settings->LoadBool(Debugger_ShowUnhandledMemory))
|
||||||
|
{
|
||||||
|
g_Notify->DisplayError(stdstr_f("%s\nFailed to translate address: %08X", __FUNCTION__, VAddr).c_str());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
case 0x1FC00000:
|
case 0x1FC00000:
|
||||||
sprintf(VarName, "m_RDRAM + %X", PAddr);
|
sprintf(VarName, "m_RDRAM + %X", PAddr);
|
||||||
MoveVariableToX86reg(PAddr + m_RDRAM, VarName, Reg);
|
MoveVariableToX86reg(PAddr + m_RDRAM, VarName, Reg);
|
||||||
|
@ -928,6 +996,12 @@ void CMipsMemoryVM::Compile_LW(x86Reg Reg, uint32_t VAddr)
|
||||||
sprintf(VarName, "m_RDRAM + %X", PAddr);
|
sprintf(VarName, "m_RDRAM + %X", PAddr);
|
||||||
MoveVariableToX86reg(PAddr + m_RDRAM, VarName, Reg);
|
MoveVariableToX86reg(PAddr + m_RDRAM, VarName, Reg);
|
||||||
}
|
}
|
||||||
|
else if ((PAddr & 0xFF000000) == 0x06000000 && (PAddr - 0x06000000) < m_DDRomSize)
|
||||||
|
{
|
||||||
|
// read from ddrom
|
||||||
|
sprintf(VarName, "m_RDRAM + %X", PAddr);
|
||||||
|
MoveVariableToX86reg(PAddr + m_RDRAM, VarName, Reg);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
MoveConstToX86reg(((PAddr & 0xFFFF) << 16) | (PAddr & 0xFFFF), Reg);
|
MoveConstToX86reg(((PAddr & 0xFFFF) << 16) | (PAddr & 0xFFFF), Reg);
|
||||||
|
@ -1392,7 +1466,7 @@ void CMipsMemoryVM::Compile_SW_Const(uint32_t Value, uint32_t VAddr)
|
||||||
Jump = m_RecompPos - 1;
|
Jump = m_RecompPos - 1;
|
||||||
MoveConstToVariable(Value, &g_Reg->VI_STATUS_REG, "VI_STATUS_REG");
|
MoveConstToVariable(Value, &g_Reg->VI_STATUS_REG, "VI_STATUS_REG");
|
||||||
BeforeCallDirect(m_RegWorkingSet);
|
BeforeCallDirect(m_RegWorkingSet);
|
||||||
Call_Direct(g_Plugins->Gfx()->ViStatusChanged, "ViStatusChanged");
|
Call_Direct((void *)g_Plugins->Gfx()->ViStatusChanged, "ViStatusChanged");
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
CPU_Message("");
|
CPU_Message("");
|
||||||
CPU_Message(" Continue:");
|
CPU_Message(" Continue:");
|
||||||
|
@ -1408,7 +1482,7 @@ void CMipsMemoryVM::Compile_SW_Const(uint32_t Value, uint32_t VAddr)
|
||||||
Jump = m_RecompPos - 1;
|
Jump = m_RecompPos - 1;
|
||||||
MoveConstToVariable(Value, &g_Reg->VI_WIDTH_REG, "VI_WIDTH_REG");
|
MoveConstToVariable(Value, &g_Reg->VI_WIDTH_REG, "VI_WIDTH_REG");
|
||||||
BeforeCallDirect(m_RegWorkingSet);
|
BeforeCallDirect(m_RegWorkingSet);
|
||||||
Call_Direct(g_Plugins->Gfx()->ViWidthChanged, "ViWidthChanged");
|
Call_Direct((void *)g_Plugins->Gfx()->ViWidthChanged, "ViWidthChanged");
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
CPU_Message("");
|
CPU_Message("");
|
||||||
CPU_Message(" Continue:");
|
CPU_Message(" Continue:");
|
||||||
|
@ -1454,7 +1528,7 @@ void CMipsMemoryVM::Compile_SW_Const(uint32_t Value, uint32_t VAddr)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Call_Direct(g_Plugins->Audio()->AiLenChanged, "AiLenChanged");
|
Call_Direct((void *)g_Plugins->Audio()->AiLenChanged, "AiLenChanged");
|
||||||
}
|
}
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
break;
|
break;
|
||||||
|
@ -1747,7 +1821,7 @@ void CMipsMemoryVM::Compile_SW_Register(x86Reg Reg, uint32_t VAddr)
|
||||||
Jump = m_RecompPos - 1;
|
Jump = m_RecompPos - 1;
|
||||||
MoveX86regToVariable(Reg, &g_Reg->VI_STATUS_REG, "VI_STATUS_REG");
|
MoveX86regToVariable(Reg, &g_Reg->VI_STATUS_REG, "VI_STATUS_REG");
|
||||||
BeforeCallDirect(m_RegWorkingSet);
|
BeforeCallDirect(m_RegWorkingSet);
|
||||||
Call_Direct(g_Plugins->Gfx()->ViStatusChanged, "ViStatusChanged");
|
Call_Direct((void *)g_Plugins->Gfx()->ViStatusChanged, "ViStatusChanged");
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
CPU_Message("");
|
CPU_Message("");
|
||||||
CPU_Message(" Continue:");
|
CPU_Message(" Continue:");
|
||||||
|
@ -1766,7 +1840,7 @@ void CMipsMemoryVM::Compile_SW_Register(x86Reg Reg, uint32_t VAddr)
|
||||||
Jump = m_RecompPos - 1;
|
Jump = m_RecompPos - 1;
|
||||||
MoveX86regToVariable(Reg, &g_Reg->VI_WIDTH_REG, "VI_WIDTH_REG");
|
MoveX86regToVariable(Reg, &g_Reg->VI_WIDTH_REG, "VI_WIDTH_REG");
|
||||||
BeforeCallDirect(m_RegWorkingSet);
|
BeforeCallDirect(m_RegWorkingSet);
|
||||||
Call_Direct(g_Plugins->Gfx()->ViWidthChanged, "ViWidthChanged");
|
Call_Direct((void *)g_Plugins->Gfx()->ViWidthChanged, "ViWidthChanged");
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
CPU_Message("");
|
CPU_Message("");
|
||||||
CPU_Message(" Continue:");
|
CPU_Message(" Continue:");
|
||||||
|
@ -1814,7 +1888,7 @@ void CMipsMemoryVM::Compile_SW_Register(x86Reg Reg, uint32_t VAddr)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Call_Direct(g_Plugins->Audio()->AiLenChanged, "g_Plugins->Audio()->LenChanged");
|
Call_Direct((void *)g_Plugins->Audio()->AiLenChanged, "g_Plugins->Audio()->LenChanged");
|
||||||
}
|
}
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
break;
|
break;
|
||||||
|
@ -1942,6 +2016,49 @@ void CMipsMemoryVM::Compile_SW_Register(x86Reg Reg, uint32_t VAddr)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case 0x05000000:
|
||||||
|
//64DD Registers
|
||||||
|
if (g_Settings->LoadBool(Setting_EnableDisk))
|
||||||
|
{
|
||||||
|
switch (PAddr)
|
||||||
|
{
|
||||||
|
case 0x05000500: MoveX86regToVariable(Reg, &g_Reg->ASIC_DATA, "ASIC_DATA"); break;
|
||||||
|
case 0x05000508:
|
||||||
|
{
|
||||||
|
//ASIC_CMD
|
||||||
|
MoveX86regToVariable(Reg, &g_Reg->ASIC_CMD, "ASIC_CMD");
|
||||||
|
BeforeCallDirect(m_RegWorkingSet);
|
||||||
|
Call_Direct(AddressOf(&DiskCommand), "DiskCommand");
|
||||||
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
|
OrConstToVariable((uint32_t)DD_STATUS_MECHA_INT, &g_Reg->ASIC_STATUS, "ASIC_STATUS");
|
||||||
|
OrConstToVariable((uint32_t)CAUSE_IP3, &g_Reg->FAKE_CAUSE_REGISTER, "FAKE_CAUSE_REGISTER");
|
||||||
|
BeforeCallDirect(m_RegWorkingSet);
|
||||||
|
Call_Direct(AddressOf(&CRegisters::CheckInterrupts), "CRegisters::CheckInterrupts");
|
||||||
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 0x05000510:
|
||||||
|
{
|
||||||
|
//ASIC_BM_CTL
|
||||||
|
MoveX86regToVariable(Reg, &g_Reg->ASIC_BM_CTL, "ASIC_BM_CTL");
|
||||||
|
BeforeCallDirect(m_RegWorkingSet);
|
||||||
|
Call_Direct(AddressOf(&DiskBMControl), "DiskBMControl");
|
||||||
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 0x05000518:
|
||||||
|
break;
|
||||||
|
case 0x05000520:
|
||||||
|
BeforeCallDirect(m_RegWorkingSet);
|
||||||
|
Call_Direct(AddressOf(&DiskReset), "DiskReset");
|
||||||
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
|
break;
|
||||||
|
case 0x05000528: MoveX86regToVariable(Reg, &g_Reg->ASIC_HOST_SECBYTE, "ASIC_HOST_SECBYTE"); break;
|
||||||
|
case 0x05000530: MoveX86regToVariable(Reg, &g_Reg->ASIC_SEC_BYTE, "ASIC_SEC_BYTE"); break;
|
||||||
|
case 0x05000548: MoveX86regToVariable(Reg, &g_Reg->ASIC_TEST_PIN_SEL, "ASIC_TEST_PIN_SEL"); break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
case 0x1FC00000:
|
case 0x1FC00000:
|
||||||
sprintf(VarName, "m_RDRAM + %X", PAddr);
|
sprintf(VarName, "m_RDRAM + %X", PAddr);
|
||||||
MoveX86regToVariable(Reg, PAddr + m_RDRAM, VarName);
|
MoveX86regToVariable(Reg, PAddr + m_RDRAM, VarName);
|
||||||
|
@ -2106,8 +2223,10 @@ bool CMipsMemoryVM::LW_NonMemory(uint32_t PAddr, uint32_t* Value)
|
||||||
case 0x04700000: Load32RDRAMInterface(); break;
|
case 0x04700000: Load32RDRAMInterface(); break;
|
||||||
case 0x04800000: Load32SerialInterface(); break;
|
case 0x04800000: Load32SerialInterface(); break;
|
||||||
case 0x05000000: Load32CartridgeDomain2Address1(); break;
|
case 0x05000000: Load32CartridgeDomain2Address1(); break;
|
||||||
|
case 0x06000000: Load32CartridgeDomain1Address1(); break;
|
||||||
case 0x08000000: Load32CartridgeDomain2Address2(); break;
|
case 0x08000000: Load32CartridgeDomain2Address2(); break;
|
||||||
case 0x1FC00000: Load32PifRam(); break;
|
case 0x1FC00000: Load32PifRam(); break;
|
||||||
|
case 0x1FF00000: Load32CartridgeDomain1Address3(); break;
|
||||||
default:
|
default:
|
||||||
if (bHaveDebugger())
|
if (bHaveDebugger())
|
||||||
{
|
{
|
||||||
|
@ -2271,6 +2390,7 @@ bool CMipsMemoryVM::SW_NonMemory(uint32_t PAddr, uint32_t Value)
|
||||||
case 0x04600000: Write32PeripheralInterface(); break;
|
case 0x04600000: Write32PeripheralInterface(); break;
|
||||||
case 0x04700000: Write32RDRAMInterface(); break;
|
case 0x04700000: Write32RDRAMInterface(); break;
|
||||||
case 0x04800000: Write32SerialInterface(); break;
|
case 0x04800000: Write32SerialInterface(); break;
|
||||||
|
case 0x05000000: Write32CartridgeDomain2Address1(); break;
|
||||||
case 0x08000000: Write32CartridgeDomain2Address2(); break;
|
case 0x08000000: Write32CartridgeDomain2Address2(); break;
|
||||||
case 0x1FC00000: Write32PifRam(); break;
|
case 0x1FC00000: Write32PifRam(); break;
|
||||||
default:
|
default:
|
||||||
|
@ -4257,8 +4377,8 @@ void CMipsMemoryVM::TLB_Unmaped(uint32_t Vaddr, uint32_t Len)
|
||||||
for (count = Vaddr; count < End; count += 0x1000)
|
for (count = Vaddr; count < End; count += 0x1000)
|
||||||
{
|
{
|
||||||
size_t Index = count >> 12;
|
size_t Index = count >> 12;
|
||||||
m_TLB_ReadMap[Index] = NULL;
|
m_TLB_ReadMap[Index] = 0;
|
||||||
m_TLB_WriteMap[Index] = NULL;
|
m_TLB_WriteMap[Index] = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4678,14 +4798,66 @@ void CMipsMemoryVM::Load32SerialInterface(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CMipsMemoryVM::Load32CartridgeDomain1Address1(void)
|
||||||
|
{
|
||||||
|
//64DD IPL ROM
|
||||||
|
if (g_DDRom != NULL && (m_MemLookupAddress & 0xFFFFFF) < g_MMU->m_DDRomSize)
|
||||||
|
{
|
||||||
|
m_MemLookupValue.UW[0] = *(uint32_t *)&g_MMU->m_DDRom[(m_MemLookupAddress & 0xFFFFFF)];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_MemLookupValue.UW[0] = m_MemLookupAddress & 0xFFFF;
|
||||||
|
m_MemLookupValue.UW[0] = (m_MemLookupValue.UW[0] << 16) | m_MemLookupValue.UW[0];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void CMipsMemoryVM::Load32CartridgeDomain1Address3(void)
|
||||||
|
{
|
||||||
|
m_MemLookupValue.UW[0] = m_MemLookupAddress & 0xFFFF;
|
||||||
|
m_MemLookupValue.UW[0] = (m_MemLookupValue.UW[0] << 16) | m_MemLookupValue.UW[0];
|
||||||
|
}
|
||||||
|
|
||||||
void CMipsMemoryVM::Load32CartridgeDomain2Address1(void)
|
void CMipsMemoryVM::Load32CartridgeDomain2Address1(void)
|
||||||
{
|
{
|
||||||
|
//64DD REGISTERS
|
||||||
|
if (g_Settings->LoadBool(Setting_EnableDisk))
|
||||||
|
{
|
||||||
|
switch (m_MemLookupAddress & 0x1FFFFFFF)
|
||||||
|
{
|
||||||
|
case 0x05000500: m_MemLookupValue.UW[0] = g_Reg->ASIC_DATA; break;
|
||||||
|
case 0x05000504: m_MemLookupValue.UW[0] = g_Reg->ASIC_MISC_REG; break;
|
||||||
|
case 0x05000508: m_MemLookupValue.UW[0] = g_Reg->ASIC_STATUS; break;
|
||||||
|
case 0x0500050C: m_MemLookupValue.UW[0] = g_Reg->ASIC_CUR_TK; break;
|
||||||
|
case 0x05000510: m_MemLookupValue.UW[0] = g_Reg->ASIC_BM_STATUS; break;
|
||||||
|
case 0x05000514: m_MemLookupValue.UW[0] = g_Reg->ASIC_ERR_SECTOR; break;
|
||||||
|
case 0x05000518: m_MemLookupValue.UW[0] = g_Reg->ASIC_SEQ_STATUS; break;
|
||||||
|
case 0x0500051C: m_MemLookupValue.UW[0] = g_Reg->ASIC_CUR_SECTOR; break;
|
||||||
|
case 0x05000520: m_MemLookupValue.UW[0] = g_Reg->ASIC_HARD_RESET; break;
|
||||||
|
case 0x05000524: m_MemLookupValue.UW[0] = g_Reg->ASIC_C1_S0; break;
|
||||||
|
case 0x05000528: m_MemLookupValue.UW[0] = g_Reg->ASIC_HOST_SECBYTE; break;
|
||||||
|
case 0x0500052C: m_MemLookupValue.UW[0] = g_Reg->ASIC_C1_S2; break;
|
||||||
|
case 0x05000530: m_MemLookupValue.UW[0] = g_Reg->ASIC_SEC_BYTE; break;
|
||||||
|
case 0x05000534: m_MemLookupValue.UW[0] = g_Reg->ASIC_C1_S4; break;
|
||||||
|
case 0x05000538: m_MemLookupValue.UW[0] = g_Reg->ASIC_C1_S6; break;
|
||||||
|
case 0x0500053C: m_MemLookupValue.UW[0] = g_Reg->ASIC_CUR_ADDR; break;
|
||||||
|
case 0x05000540: m_MemLookupValue.UW[0] = g_Reg->ASIC_ID_REG; break;
|
||||||
|
case 0x05000544: m_MemLookupValue.UW[0] = g_Reg->ASIC_TEST_REG; break;
|
||||||
|
case 0x05000548: m_MemLookupValue.UW[0] = g_Reg->ASIC_TEST_PIN_SEL; break;
|
||||||
|
default:
|
||||||
m_MemLookupValue.UW[0] = m_MemLookupAddress & 0xFFFF;
|
m_MemLookupValue.UW[0] = m_MemLookupAddress & 0xFFFF;
|
||||||
m_MemLookupValue.UW[0] = (m_MemLookupValue.UW[0] << 16) | m_MemLookupValue.UW[0];
|
m_MemLookupValue.UW[0] = (m_MemLookupValue.UW[0] << 16) | m_MemLookupValue.UW[0];
|
||||||
if (bHaveDebugger())
|
if (bHaveDebugger())
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_MemLookupValue.UW[0] = m_MemLookupAddress & 0xFFFF;
|
||||||
|
m_MemLookupValue.UW[0] = (m_MemLookupValue.UW[0] << 16) | m_MemLookupValue.UW[0];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CMipsMemoryVM::Load32CartridgeDomain2Address2(void)
|
void CMipsMemoryVM::Load32CartridgeDomain2Address2(void)
|
||||||
|
@ -4765,10 +4937,6 @@ void CMipsMemoryVM::Load32Rom(void)
|
||||||
{
|
{
|
||||||
m_MemLookupValue.UW[0] = m_MemLookupAddress & 0xFFFF;
|
m_MemLookupValue.UW[0] = m_MemLookupAddress & 0xFFFF;
|
||||||
m_MemLookupValue.UW[0] = (m_MemLookupValue.UW[0] << 16) | m_MemLookupValue.UW[0];
|
m_MemLookupValue.UW[0] = (m_MemLookupValue.UW[0] << 16) | m_MemLookupValue.UW[0];
|
||||||
if (bHaveDebugger())
|
|
||||||
{
|
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5321,6 +5489,42 @@ void CMipsMemoryVM::Write32SerialInterface(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CMipsMemoryVM::Write32CartridgeDomain2Address1(void)
|
||||||
|
{
|
||||||
|
//64DD Registers
|
||||||
|
if (g_Settings->LoadBool(Setting_EnableDisk))
|
||||||
|
{
|
||||||
|
switch (m_MemLookupAddress & 0xFFFFFFF)
|
||||||
|
{
|
||||||
|
case 0x05000500: g_Reg->ASIC_DATA = m_MemLookupValue.UW[0]; break;
|
||||||
|
case 0x05000508:
|
||||||
|
g_Reg->ASIC_CMD = m_MemLookupValue.UW[0];
|
||||||
|
DiskCommand();
|
||||||
|
g_Reg->ASIC_STATUS |= DD_STATUS_MECHA_INT;
|
||||||
|
g_Reg->FAKE_CAUSE_REGISTER |= CAUSE_IP3;
|
||||||
|
g_Reg->CheckInterrupts();
|
||||||
|
break;
|
||||||
|
case 0x05000510:
|
||||||
|
//ASIC_BM_STATUS_CTL
|
||||||
|
g_Reg->ASIC_BM_CTL = m_MemLookupValue.UW[0];
|
||||||
|
DiskBMControl();
|
||||||
|
break;
|
||||||
|
case 0x05000518:
|
||||||
|
//ASIC_SEQ_STATUS_CTL
|
||||||
|
break;
|
||||||
|
case 0x05000520: DiskReset(); break;
|
||||||
|
case 0x05000528: g_Reg->ASIC_HOST_SECBYTE = m_MemLookupValue.UW[0]; break;
|
||||||
|
case 0x05000530: g_Reg->ASIC_SEC_BYTE = m_MemLookupValue.UW[0]; break;
|
||||||
|
case 0x05000548: g_Reg->ASIC_TEST_PIN_SEL = m_MemLookupValue.UW[0]; break;
|
||||||
|
default:
|
||||||
|
if (bHaveDebugger())
|
||||||
|
{
|
||||||
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void CMipsMemoryVM::Write32CartridgeDomain2Address2(void)
|
void CMipsMemoryVM::Write32CartridgeDomain2Address2(void)
|
||||||
{
|
{
|
||||||
if (g_System->m_SaveUsing == SaveChip_Sram)
|
if (g_System->m_SaveUsing == SaveChip_Sram)
|
||||||
|
|
|
@ -185,6 +185,8 @@ private:
|
||||||
static void Load32PeripheralInterface(void);
|
static void Load32PeripheralInterface(void);
|
||||||
static void Load32RDRAMInterface(void);
|
static void Load32RDRAMInterface(void);
|
||||||
static void Load32SerialInterface(void);
|
static void Load32SerialInterface(void);
|
||||||
|
static void Load32CartridgeDomain1Address1(void);
|
||||||
|
static void Load32CartridgeDomain1Address3(void);
|
||||||
static void Load32CartridgeDomain2Address1(void);
|
static void Load32CartridgeDomain2Address1(void);
|
||||||
static void Load32CartridgeDomain2Address2(void);
|
static void Load32CartridgeDomain2Address2(void);
|
||||||
static void Load32PifRam(void);
|
static void Load32PifRam(void);
|
||||||
|
@ -199,6 +201,7 @@ private:
|
||||||
static void Write32PeripheralInterface(void);
|
static void Write32PeripheralInterface(void);
|
||||||
static void Write32RDRAMInterface(void);
|
static void Write32RDRAMInterface(void);
|
||||||
static void Write32SerialInterface(void);
|
static void Write32SerialInterface(void);
|
||||||
|
static void Write32CartridgeDomain2Address1(void);
|
||||||
static void Write32CartridgeDomain2Address2(void);
|
static void Write32CartridgeDomain2Address2(void);
|
||||||
static void Write32PifRam(void);
|
static void Write32PifRam(void);
|
||||||
|
|
||||||
|
@ -214,6 +217,11 @@ private:
|
||||||
bool m_RomWrittenTo;
|
bool m_RomWrittenTo;
|
||||||
uint32_t m_RomWroteValue;
|
uint32_t m_RomWroteValue;
|
||||||
|
|
||||||
|
//DDRom Information
|
||||||
|
bool m_DDRomMapped;
|
||||||
|
uint8_t * m_DDRom;
|
||||||
|
uint32_t m_DDRomSize;
|
||||||
|
|
||||||
//Current Half line
|
//Current Half line
|
||||||
void UpdateHalfLine();
|
void UpdateHalfLine();
|
||||||
uint32_t m_HalfLine;
|
uint32_t m_HalfLine;
|
||||||
|
|
|
@ -21,7 +21,7 @@
|
||||||
#include <Project64-core/N64System/Mips/Mempak.H>
|
#include <Project64-core/N64System/Mips/Mempak.H>
|
||||||
#include <Project64-core/Logging.h>
|
#include <Project64-core/Logging.h>
|
||||||
|
|
||||||
int CPifRamSettings::m_RefCount = 0;
|
int32_t CPifRamSettings::m_RefCount = 0;
|
||||||
bool CPifRamSettings::m_bShowPifRamErrors = false;
|
bool CPifRamSettings::m_bShowPifRamErrors = false;
|
||||||
|
|
||||||
CPifRamSettings::CPifRamSettings()
|
CPifRamSettings::CPifRamSettings()
|
||||||
|
@ -64,7 +64,7 @@ void CPifRam::Reset()
|
||||||
memset(m_PifRom, 0, sizeof(m_PifRom));
|
memset(m_PifRom, 0, sizeof(m_PifRom));
|
||||||
}
|
}
|
||||||
|
|
||||||
void CPifRam::n64_cic_nus_6105(char challenge[], char respone[], int length)
|
void CPifRam::n64_cic_nus_6105(char challenge[], char respone[], int32_t length)
|
||||||
{
|
{
|
||||||
static char lut0[0x10] = {
|
static char lut0[0x10] = {
|
||||||
0x4, 0x7, 0xA, 0x7, 0xE, 0x5, 0xE, 0x1,
|
0x4, 0x7, 0xA, 0x7, 0xE, 0x5, 0xE, 0x1,
|
||||||
|
@ -75,7 +75,7 @@ void CPifRam::n64_cic_nus_6105(char challenge[], char respone[], int length)
|
||||||
0xC, 0x9, 0x8, 0x5, 0x6, 0x3, 0xC, 0x9
|
0xC, 0x9, 0x8, 0x5, 0x6, 0x3, 0xC, 0x9
|
||||||
};
|
};
|
||||||
char key, *lut;
|
char key, *lut;
|
||||||
int i, sgn, mag, mod;
|
int32_t i, sgn, mag, mod;
|
||||||
|
|
||||||
for (key = 0xB, lut = lut0, i = 0; i < length; i++)
|
for (key = 0xB, lut = lut0, i = 0; i < length; i++)
|
||||||
{
|
{
|
||||||
|
@ -105,8 +105,8 @@ void CPifRam::PifRamRead()
|
||||||
|
|
||||||
CONTROL * Controllers = g_Plugins->Control()->PluginControllers();
|
CONTROL * Controllers = g_Plugins->Control()->PluginControllers();
|
||||||
|
|
||||||
int Channel = 0;
|
int32_t Channel = 0;
|
||||||
for (int CurPos = 0; CurPos < 0x40; CurPos++)
|
for (int32_t CurPos = 0; CurPos < 0x40; CurPos++)
|
||||||
{
|
{
|
||||||
switch (m_PifRam[CurPos])
|
switch (m_PifRam[CurPos])
|
||||||
{
|
{
|
||||||
|
@ -160,7 +160,7 @@ void CPifRam::PifRamRead()
|
||||||
void CPifRam::PifRamWrite()
|
void CPifRam::PifRamWrite()
|
||||||
{
|
{
|
||||||
CONTROL * Controllers = g_Plugins->Control()->PluginControllers();
|
CONTROL * Controllers = g_Plugins->Control()->PluginControllers();
|
||||||
int Channel = 0, CurPos;
|
int32_t Channel = 0, CurPos;
|
||||||
|
|
||||||
if (m_PifRam[0x3F] > 0x1)
|
if (m_PifRam[0x3F] > 0x1)
|
||||||
{
|
{
|
||||||
|
@ -170,7 +170,7 @@ void CPifRam::PifRamWrite()
|
||||||
// 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 (int i = 0; i < 15; i++)
|
for (int32_t i = 0; i < 15; i++)
|
||||||
{
|
{
|
||||||
Challenge[i * 2] = (m_PifRam[48 + i] >> 4) & 0x0f;
|
Challenge[i * 2] = (m_PifRam[48 + i] >> 4) & 0x0f;
|
||||||
Challenge[i * 2 + 1] = m_PifRam[48 + i] & 0x0f;
|
Challenge[i * 2 + 1] = m_PifRam[48 + i] & 0x0f;
|
||||||
|
@ -178,13 +178,13 @@ void CPifRam::PifRamWrite()
|
||||||
n64_cic_nus_6105(Challenge, Response, CHALLENGE_LENGTH - 2);
|
n64_cic_nus_6105(Challenge, Response, CHALLENGE_LENGTH - 2);
|
||||||
uint64_t ResponseValue = 0;
|
uint64_t ResponseValue = 0;
|
||||||
m_PifRam[46] = m_PifRam[47] = 0x00;
|
m_PifRam[46] = m_PifRam[47] = 0x00;
|
||||||
for (int z = 8; z > 0; z--)
|
for (int32_t z = 8; z > 0; z--)
|
||||||
{
|
{
|
||||||
ResponseValue = (ResponseValue << 8) | ((Response[(z - 1) * 2] << 4) + Response[(z - 1) * 2 + 1]);
|
ResponseValue = (ResponseValue << 8) | ((Response[(z - 1) * 2] << 4) + Response[(z - 1) * 2 + 1]);
|
||||||
}
|
}
|
||||||
memcpy(&m_PifRam[48], &ResponseValue, sizeof(uint64_t));
|
memcpy(&m_PifRam[48], &ResponseValue, sizeof(uint64_t));
|
||||||
ResponseValue = 0;
|
ResponseValue = 0;
|
||||||
for (int z = 7; z > 0; z--)
|
for (int32_t z = 7; z > 0; z--)
|
||||||
{
|
{
|
||||||
ResponseValue = (ResponseValue << 8) | ((Response[((z + 8) - 1) * 2] << 4) + Response[((z + 8) - 1) * 2 + 1]);
|
ResponseValue = (ResponseValue << 8) | ((Response[((z + 8) - 1) * 2] << 4) + Response[((z + 8) - 1) * 2 + 1]);
|
||||||
}
|
}
|
||||||
|
@ -327,8 +327,8 @@ void CPifRam::SI_DMA_READ()
|
||||||
{
|
{
|
||||||
if ((count % 4) == 0)
|
if ((count % 4) == 0)
|
||||||
{
|
{
|
||||||
sprintf(HexData, "\0");
|
HexData[0] = '\0';
|
||||||
sprintf(AsciiData, "\0");
|
AsciiData[0] = '\0';
|
||||||
}
|
}
|
||||||
sprintf(Addon, "%02X %02X %02X %02X",
|
sprintf(Addon, "%02X %02X %02X %02X",
|
||||||
m_PifRam[(count << 2) + 0], m_PifRam[(count << 2) + 1],
|
m_PifRam[(count << 2) + 0], m_PifRam[(count << 2) + 1],
|
||||||
|
@ -414,8 +414,8 @@ void CPifRam::SI_DMA_WRITE()
|
||||||
{
|
{
|
||||||
if ((count % 4) == 0)
|
if ((count % 4) == 0)
|
||||||
{
|
{
|
||||||
sprintf(HexData, "\0");
|
HexData[0] = '\0';
|
||||||
sprintf(AsciiData, "\0");
|
AsciiData[0] = '\0';
|
||||||
}
|
}
|
||||||
sprintf(Addon, "%02X %02X %02X %02X",
|
sprintf(Addon, "%02X %02X %02X %02X",
|
||||||
m_PifRam[(count << 2) + 0], m_PifRam[(count << 2) + 1],
|
m_PifRam[(count << 2) + 0], m_PifRam[(count << 2) + 1],
|
||||||
|
@ -454,7 +454,7 @@ void CPifRam::SI_DMA_WRITE()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CPifRam::ProcessControllerCommand(int Control, uint8_t * Command)
|
void CPifRam::ProcessControllerCommand(int32_t Control, uint8_t * Command)
|
||||||
{
|
{
|
||||||
CONTROL * Controllers = g_Plugins->Control()->PluginControllers();
|
CONTROL * Controllers = g_Plugins->Control()->PluginControllers();
|
||||||
|
|
||||||
|
@ -603,7 +603,8 @@ void CPifRam::ProcessControllerCommand(int Control, uint8_t * Command)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CPifRam::ReadControllerCommand(int Control, uint8_t * Command) {
|
void CPifRam::ReadControllerCommand(int32_t Control, uint8_t * Command)
|
||||||
|
{
|
||||||
CONTROL * Controllers = g_Plugins->Control()->PluginControllers();
|
CONTROL * Controllers = g_Plugins->Control()->PluginControllers();
|
||||||
|
|
||||||
switch (Command[2])
|
switch (Command[2])
|
||||||
|
@ -642,11 +643,11 @@ void CPifRam::ReadControllerCommand(int Control, uint8_t * Command) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CPifRam::LogControllerPakData(char * Description)
|
void CPifRam::LogControllerPakData(const char * Description)
|
||||||
{
|
{
|
||||||
uint8_t * PIF_Ram = g_MMU->PifRam();
|
uint8_t * PIF_Ram = g_MMU->PifRam();
|
||||||
|
|
||||||
int count, count2;
|
int32_t count, count2;
|
||||||
char HexData[100], AsciiData[100], Addon[20];
|
char HexData[100], AsciiData[100], Addon[20];
|
||||||
LogMessage("\t%s:", Description);
|
LogMessage("\t%s:", Description);
|
||||||
LogMessage("\t------------------------------");
|
LogMessage("\t------------------------------");
|
||||||
|
@ -654,8 +655,8 @@ void CPifRam::LogControllerPakData(char * Description)
|
||||||
{
|
{
|
||||||
if ((count % 4) == 0)
|
if ((count % 4) == 0)
|
||||||
{
|
{
|
||||||
sprintf(HexData, "\0");
|
HexData[0] = '\0';
|
||||||
sprintf(AsciiData, "\0");
|
AsciiData[0] = '\0';
|
||||||
}
|
}
|
||||||
sprintf(Addon, "%02X %02X %02X %02X",
|
sprintf(Addon, "%02X %02X %02X %02X",
|
||||||
PIF_Ram[(count << 2) + 0], PIF_Ram[(count << 2) + 1],
|
PIF_Ram[(count << 2) + 0], PIF_Ram[(count << 2) + 1],
|
||||||
|
|
|
@ -29,7 +29,7 @@ private:
|
||||||
|
|
||||||
static bool m_bShowPifRamErrors;
|
static bool m_bShowPifRamErrors;
|
||||||
|
|
||||||
static int m_RefCount;
|
static int32_t m_RefCount;
|
||||||
};
|
};
|
||||||
|
|
||||||
class CPifRam :
|
class CPifRam :
|
||||||
|
@ -54,9 +54,13 @@ protected:
|
||||||
uint8_t m_PifRam[0x40];
|
uint8_t m_PifRam[0x40];
|
||||||
|
|
||||||
private:
|
private:
|
||||||
#define CHALLENGE_LENGTH 0x20
|
CPifRam(); // Disable default constructor
|
||||||
void ProcessControllerCommand(int Control, uint8_t * Command);
|
CPifRam(const CPifRam&); // Disable copy constructor
|
||||||
void ReadControllerCommand(int Control, uint8_t * Command);
|
CPifRam& operator=(const CPifRam&); // Disable assignment
|
||||||
void LogControllerPakData(char * Description);
|
|
||||||
void n64_cic_nus_6105(char challenge[], char response[], int length);
|
enum { CHALLENGE_LENGTH = 0x20 };
|
||||||
|
void ProcessControllerCommand(int32_t Control, uint8_t * Command);
|
||||||
|
void ReadControllerCommand(int32_t Control, uint8_t * Command);
|
||||||
|
void LogControllerPakData(const char * Description);
|
||||||
|
void n64_cic_nus_6105(char challenge[], char response[], int32_t length);
|
||||||
};
|
};
|
||||||
|
|
|
@ -60,7 +60,7 @@ float ** CSystemRegisters::_FPR_S;
|
||||||
double ** CSystemRegisters::_FPR_D;
|
double ** CSystemRegisters::_FPR_D;
|
||||||
uint32_t * CSystemRegisters::_FPCR = NULL;
|
uint32_t * CSystemRegisters::_FPCR = NULL;
|
||||||
uint32_t * CSystemRegisters::_LLBit = NULL;
|
uint32_t * CSystemRegisters::_LLBit = NULL;
|
||||||
ROUNDING_MODE * CSystemRegisters::_RoundingModel = NULL;
|
int32_t * CSystemRegisters::_RoundingModel = NULL;
|
||||||
|
|
||||||
CP0registers::CP0registers(uint32_t * _CP0) :
|
CP0registers::CP0registers(uint32_t * _CP0) :
|
||||||
INDEX_REGISTER(_CP0[0]),
|
INDEX_REGISTER(_CP0[0]),
|
||||||
|
@ -213,6 +213,32 @@ SI_STATUS_REG(SerialInterface[3])
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Disk_InterfaceReg::Disk_InterfaceReg(uint32_t * DiskInterface) :
|
||||||
|
ASIC_DATA(DiskInterface[0]),
|
||||||
|
ASIC_MISC_REG(DiskInterface[1]),
|
||||||
|
ASIC_STATUS(DiskInterface[2]),
|
||||||
|
ASIC_CUR_TK(DiskInterface[3]),
|
||||||
|
ASIC_BM_STATUS(DiskInterface[4]),
|
||||||
|
ASIC_ERR_SECTOR(DiskInterface[5]),
|
||||||
|
ASIC_SEQ_STATUS(DiskInterface[6]),
|
||||||
|
ASIC_CUR_SECTOR(DiskInterface[7]),
|
||||||
|
ASIC_HARD_RESET(DiskInterface[8]),
|
||||||
|
ASIC_C1_S0(DiskInterface[9]),
|
||||||
|
ASIC_HOST_SECBYTE(DiskInterface[10]),
|
||||||
|
ASIC_C1_S2(DiskInterface[11]),
|
||||||
|
ASIC_SEC_BYTE(DiskInterface[12]),
|
||||||
|
ASIC_C1_S4(DiskInterface[13]),
|
||||||
|
ASIC_C1_S6(DiskInterface[14]),
|
||||||
|
ASIC_CUR_ADDR(DiskInterface[15]),
|
||||||
|
ASIC_ID_REG(DiskInterface[16]),
|
||||||
|
ASIC_TEST_REG(DiskInterface[17]),
|
||||||
|
ASIC_TEST_PIN_SEL(DiskInterface[18]),
|
||||||
|
ASIC_CMD(DiskInterface[19]),
|
||||||
|
ASIC_BM_CTL(DiskInterface[20]),
|
||||||
|
ASIC_SEQ_CTL(DiskInterface[21])
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
CRegisters::CRegisters(CN64System * System, CSystemEvents * SystemEvents) :
|
CRegisters::CRegisters(CN64System * System, CSystemEvents * SystemEvents) :
|
||||||
CP0registers(m_CP0),
|
CP0registers(m_CP0),
|
||||||
Rdram_InterfaceReg(m_RDRAM_Registers),
|
Rdram_InterfaceReg(m_RDRAM_Registers),
|
||||||
|
@ -224,6 +250,7 @@ RDRAMInt_InterfaceReg(m_RDRAM_Interface),
|
||||||
SigProcessor_InterfaceReg(m_SigProcessor_Interface),
|
SigProcessor_InterfaceReg(m_SigProcessor_Interface),
|
||||||
DisplayControlReg(m_Display_ControlReg),
|
DisplayControlReg(m_Display_ControlReg),
|
||||||
Serial_InterfaceReg(m_SerialInterface),
|
Serial_InterfaceReg(m_SerialInterface),
|
||||||
|
Disk_InterfaceReg(m_DiskInterface),
|
||||||
m_System(System),
|
m_System(System),
|
||||||
m_SystemEvents(SystemEvents)
|
m_SystemEvents(SystemEvents)
|
||||||
{
|
{
|
||||||
|
@ -240,7 +267,7 @@ void CRegisters::Reset()
|
||||||
memset(m_FPCR, 0, sizeof(m_FPCR));
|
memset(m_FPCR, 0, sizeof(m_FPCR));
|
||||||
m_HI.DW = 0;
|
m_HI.DW = 0;
|
||||||
m_LO.DW = 0;
|
m_LO.DW = 0;
|
||||||
m_RoundingModel = ROUND_NEAR;
|
m_RoundingModel = FE_TONEAREST;
|
||||||
|
|
||||||
m_LLBit = 0;
|
m_LLBit = 0;
|
||||||
|
|
||||||
|
@ -254,6 +281,7 @@ void CRegisters::Reset()
|
||||||
memset(m_SigProcessor_Interface, 0, sizeof(m_SigProcessor_Interface));
|
memset(m_SigProcessor_Interface, 0, sizeof(m_SigProcessor_Interface));
|
||||||
memset(m_Peripheral_Interface, 0, sizeof(m_Peripheral_Interface));
|
memset(m_Peripheral_Interface, 0, sizeof(m_Peripheral_Interface));
|
||||||
memset(m_SerialInterface, 0, sizeof(m_SerialInterface));
|
memset(m_SerialInterface, 0, sizeof(m_SerialInterface));
|
||||||
|
memset(m_DiskInterface, 0, sizeof(m_DiskInterface));
|
||||||
|
|
||||||
m_AudioIntrReg = 0;
|
m_AudioIntrReg = 0;
|
||||||
m_GfxIntrReg = 0;
|
m_GfxIntrReg = 0;
|
||||||
|
|
|
@ -482,12 +482,70 @@ enum
|
||||||
SI_STATUS_INTERRUPT = 0x1000,
|
SI_STATUS_INTERRUPT = 0x1000,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum ROUNDING_MODE
|
//Disk Interface
|
||||||
|
class Disk_InterfaceReg
|
||||||
{
|
{
|
||||||
ROUND_NEAR = 0x00000000, // _RC_NEAR
|
protected:
|
||||||
ROUND_DOWN = 0x00000100, // _RC_DOWN
|
Disk_InterfaceReg (uint32_t * Disk_Interface);
|
||||||
ROUND_UP = 0x00000200, // _RC_UP
|
|
||||||
ROUND_CHOP = 0x00000300, // _RC_CHOP
|
public:
|
||||||
|
uint32_t & ASIC_DATA;
|
||||||
|
uint32_t & ASIC_MISC_REG;
|
||||||
|
uint32_t & ASIC_STATUS;
|
||||||
|
uint32_t & ASIC_CMD;
|
||||||
|
uint32_t & ASIC_CUR_TK;
|
||||||
|
uint32_t & ASIC_BM_STATUS;
|
||||||
|
uint32_t & ASIC_BM_CTL;
|
||||||
|
uint32_t & ASIC_ERR_SECTOR;
|
||||||
|
uint32_t & ASIC_SEQ_STATUS;
|
||||||
|
uint32_t & ASIC_SEQ_CTL;
|
||||||
|
uint32_t & ASIC_CUR_SECTOR;
|
||||||
|
uint32_t & ASIC_HARD_RESET;
|
||||||
|
uint32_t & ASIC_C1_S0;
|
||||||
|
uint32_t & ASIC_HOST_SECBYTE;
|
||||||
|
uint32_t & ASIC_C1_S2;
|
||||||
|
uint32_t & ASIC_SEC_BYTE;
|
||||||
|
uint32_t & ASIC_C1_S4;
|
||||||
|
uint32_t & ASIC_C1_S6;
|
||||||
|
uint32_t & ASIC_CUR_ADDR;
|
||||||
|
uint32_t & ASIC_ID_REG;
|
||||||
|
uint32_t & ASIC_TEST_REG;
|
||||||
|
uint32_t & ASIC_TEST_PIN_SEL;
|
||||||
|
|
||||||
|
private:
|
||||||
|
Disk_InterfaceReg(); // Disable default constructor
|
||||||
|
Disk_InterfaceReg(const Disk_InterfaceReg&); // Disable copy constructor
|
||||||
|
Disk_InterfaceReg& operator=(const Disk_InterfaceReg&); // Disable assignment
|
||||||
|
};
|
||||||
|
|
||||||
|
//Disk Interface Flags
|
||||||
|
enum
|
||||||
|
{
|
||||||
|
DD_STATUS_DATA_RQ = 0x40000000,
|
||||||
|
DD_STATUS_C2_XFER = 0x10000000,
|
||||||
|
DD_STATUS_BM_ERR = 0x08000000,
|
||||||
|
DD_STATUS_BM_INT = 0x04000000,
|
||||||
|
DD_STATUS_MECHA_INT = 0x02000000,
|
||||||
|
DD_STATUS_DISK_PRES = 0x01000000,
|
||||||
|
DD_STATUS_BUSY_STATE = 0x00800000,
|
||||||
|
DD_STATUS_RST_STATE = 0x00400000,
|
||||||
|
DD_STATUS_MTR_N_SPIN = 0x00100000,
|
||||||
|
DD_STATUS_HEAD_RTRCT = 0x00080000,
|
||||||
|
DD_STATUS_WR_PR_ERR = 0x00040000,
|
||||||
|
DD_STATUS_MECHA_ERR = 0x00020000,
|
||||||
|
DD_STATUS_DISK_CHNG = 0x00010000,
|
||||||
|
|
||||||
|
DD_BM_STATUS_RUNNING = 0x80000000,
|
||||||
|
DD_BM_STATUS_ERROR = 0x04000000,
|
||||||
|
DD_BM_STATUS_MICRO = 0x02000000,
|
||||||
|
DD_BM_STATUS_BLOCK = 0x01000000,
|
||||||
|
|
||||||
|
DD_BM_CTL_START = 0x80000000,
|
||||||
|
DD_BM_CTL_MNGRMODE = 0x40000000,
|
||||||
|
DD_BM_CTL_INTMASK = 0x20000000,
|
||||||
|
DD_BM_CTL_RESET = 0x10000000,
|
||||||
|
DD_BM_CTL_BLK_TRANS = 0x02000000,
|
||||||
|
DD_BM_CTL_MECHA_RST = 0x01000000
|
||||||
};
|
};
|
||||||
|
|
||||||
class CRegName
|
class CRegName
|
||||||
|
@ -514,7 +572,7 @@ protected:
|
||||||
static double ** _FPR_D;
|
static double ** _FPR_D;
|
||||||
static uint32_t * _FPCR;
|
static uint32_t * _FPCR;
|
||||||
static uint32_t * _LLBit;
|
static uint32_t * _LLBit;
|
||||||
static ROUNDING_MODE * _RoundingModel;
|
static int32_t * _RoundingModel;
|
||||||
};
|
};
|
||||||
|
|
||||||
class CN64System;
|
class CN64System;
|
||||||
|
@ -534,7 +592,8 @@ class CRegisters :
|
||||||
public RDRAMInt_InterfaceReg,
|
public RDRAMInt_InterfaceReg,
|
||||||
public SigProcessor_InterfaceReg,
|
public SigProcessor_InterfaceReg,
|
||||||
public DisplayControlReg,
|
public DisplayControlReg,
|
||||||
public Serial_InterfaceReg
|
public Serial_InterfaceReg,
|
||||||
|
public Disk_InterfaceReg
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CRegisters(CN64System * System, CSystemEvents * SystemEvents);
|
CRegisters(CN64System * System, CSystemEvents * SystemEvents);
|
||||||
|
@ -549,7 +608,7 @@ public:
|
||||||
|
|
||||||
//Floating point registers/information
|
//Floating point registers/information
|
||||||
uint32_t m_FPCR[32];
|
uint32_t m_FPCR[32];
|
||||||
ROUNDING_MODE 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];
|
||||||
|
@ -564,6 +623,7 @@ public:
|
||||||
uint32_t m_Peripheral_Interface[13];
|
uint32_t m_Peripheral_Interface[13];
|
||||||
uint32_t m_RDRAM_Interface[8];
|
uint32_t m_RDRAM_Interface[8];
|
||||||
uint32_t m_SerialInterface[4];
|
uint32_t m_SerialInterface[4];
|
||||||
|
uint32_t m_DiskInterface[22];
|
||||||
uint32_t m_AudioIntrReg;
|
uint32_t m_AudioIntrReg;
|
||||||
uint32_t m_GfxIntrReg;
|
uint32_t m_GfxIntrReg;
|
||||||
uint32_t m_RspIntrReg;
|
uint32_t m_RspIntrReg;
|
||||||
|
|
|
@ -29,7 +29,7 @@ void Rumblepak::ReadFrom(uint8_t * command)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Rumblepak::WriteTo(int Control, uint8_t * command)
|
void Rumblepak::WriteTo(int32_t Control, uint8_t * command)
|
||||||
{
|
{
|
||||||
uint32_t address = (command[3] << 8) | (command[4] & 0xE0);
|
uint32_t address = (command[3] << 8) | (command[4] & 0xE0);
|
||||||
|
|
||||||
|
|
|
@ -14,5 +14,5 @@ class Rumblepak
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
static void ReadFrom(uint8_t * command);
|
static void ReadFrom(uint8_t * command);
|
||||||
static void WriteTo(int Control, uint8_t * command);
|
static void WriteTo(int32_t Control, uint8_t * command);
|
||||||
};
|
};
|
||||||
|
|
|
@ -52,7 +52,7 @@ bool CSram::LoadSram()
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSram::DmaFromSram(uint8_t * dest, int StartOffset, int len)
|
void CSram::DmaFromSram(uint8_t * dest, int32_t StartOffset, int32_t len)
|
||||||
{
|
{
|
||||||
DWORD dwRead;
|
DWORD dwRead;
|
||||||
uint32_t i;
|
uint32_t i;
|
||||||
|
@ -133,7 +133,7 @@ void CSram::DmaFromSram(uint8_t * dest, int StartOffset, int len)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSram::DmaToSram(uint8_t * Source, int StartOffset, int len)
|
void CSram::DmaToSram(uint8_t * Source, int32_t StartOffset, int32_t len)
|
||||||
{
|
{
|
||||||
DWORD dwWritten;
|
DWORD dwWritten;
|
||||||
uint32_t i;
|
uint32_t i;
|
||||||
|
|
|
@ -16,8 +16,8 @@ public:
|
||||||
CSram(bool ReadOnly);
|
CSram(bool ReadOnly);
|
||||||
~CSram();
|
~CSram();
|
||||||
|
|
||||||
void DmaFromSram(uint8_t * dest, int StartOffset, int len);
|
void DmaFromSram(uint8_t * dest, int32_t StartOffset, int32_t len);
|
||||||
void DmaToSram(uint8_t * Source, int StartOffset, int len);
|
void DmaToSram(uint8_t * Source, int32_t StartOffset, int32_t len);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool LoadSram();
|
bool LoadSram();
|
||||||
|
|
|
@ -18,12 +18,10 @@ CSystemEvents::CSystemEvents(CN64System * System, CPlugins * Plugins) :
|
||||||
m_Plugins(Plugins),
|
m_Plugins(Plugins),
|
||||||
m_bDoSomething(false)
|
m_bDoSomething(false)
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
CSystemEvents::~CSystemEvents()
|
CSystemEvents::~CSystemEvents()
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSystemEvents::QueueEvent(SystemEvent action)
|
void CSystemEvents::QueueEvent(SystemEvent action)
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
#include <Project64-core/N64System/N64Class.h>
|
#include <Project64-core/N64System/N64Class.h>
|
||||||
#include <Project64-core/3rdParty/zip.h>
|
#include <Project64-core/3rdParty/zip.h>
|
||||||
|
|
||||||
CSystemTimer::CSystemTimer(int & NextTimer) :
|
CSystemTimer::CSystemTimer( int32_t & NextTimer ) :
|
||||||
m_NextTimer(NextTimer),
|
m_NextTimer(NextTimer),
|
||||||
m_inFixTimer(false)
|
m_inFixTimer(false)
|
||||||
{
|
{
|
||||||
|
|
|
@ -39,7 +39,7 @@ public:
|
||||||
};
|
};
|
||||||
|
|
||||||
public:
|
public:
|
||||||
CSystemTimer(int & NextTimer);
|
CSystemTimer(int32_t & NextTimer);
|
||||||
void SetTimer(TimerType Type, uint32_t Cycles, bool bRelative);
|
void SetTimer(TimerType Type, uint32_t Cycles, bool bRelative);
|
||||||
uint32_t GetTimer(TimerType Type);
|
uint32_t GetTimer(TimerType Type);
|
||||||
void StopTimer(TimerType Type);
|
void StopTimer(TimerType Type);
|
||||||
|
@ -65,8 +65,8 @@ private:
|
||||||
CSystemTimer& operator=(const CSystemTimer&); // Disable assignment
|
CSystemTimer& operator=(const CSystemTimer&); // Disable assignment
|
||||||
|
|
||||||
TIMER_DETAILS m_TimerDetatils[MaxTimer];
|
TIMER_DETAILS m_TimerDetatils[MaxTimer];
|
||||||
int m_LastUpdate; //Timer at last update
|
int32_t m_LastUpdate; //Timer at last update
|
||||||
int & m_NextTimer;
|
int32_t & m_NextTimer;
|
||||||
TimerType m_Current;
|
TimerType m_Current;
|
||||||
bool m_inFixTimer;
|
bool m_inFixTimer;
|
||||||
|
|
||||||
|
|
|
@ -212,6 +212,12 @@ bool CN64System::RunFileImage(const char * FileLoc)
|
||||||
WriteTrace(TraceN64System, TraceDebug, "Loading \"%s\"", FileLoc);
|
WriteTrace(TraceN64System, TraceDebug, "Loading \"%s\"", FileLoc);
|
||||||
if (g_Rom->LoadN64Image(FileLoc))
|
if (g_Rom->LoadN64Image(FileLoc))
|
||||||
{
|
{
|
||||||
|
if (g_Rom->CicChipID() == CIC_NUS_8303)
|
||||||
|
{
|
||||||
|
//64DD IPL
|
||||||
|
g_DDRom = g_Rom;
|
||||||
|
}
|
||||||
|
|
||||||
g_System->RefreshGameSettings();
|
g_System->RefreshGameSettings();
|
||||||
|
|
||||||
g_Settings->SaveString(Game_File, FileLoc);
|
g_Settings->SaveString(Game_File, FileLoc);
|
||||||
|
@ -586,6 +592,10 @@ 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
|
||||||
|
m_Reg.ASIC_STATUS = DD_STATUS_RST_STATE;
|
||||||
|
m_Reg.ASIC_ID_REG = 0x00030000;
|
||||||
|
|
||||||
//m_Reg.REVISION_REGISTER = 0x00000511;
|
//m_Reg.REVISION_REGISTER = 0x00000511;
|
||||||
m_Reg.FixFpuLocations();
|
m_Reg.FixFpuLocations();
|
||||||
|
|
||||||
|
|
|
@ -127,8 +127,6 @@ bool CN64Rom::AllocateAndLoadN64Image(const char * FileLoc, bool LoadBootCodeOnl
|
||||||
ByteSwapRom();
|
ByteSwapRom();
|
||||||
|
|
||||||
//Protect the memory so that it can not be written to.
|
//Protect the memory so that it can not be written to.
|
||||||
DWORD OldProtect;
|
|
||||||
VirtualProtect(m_ROMImage, m_RomFileSize, PAGE_READONLY, &OldProtect);
|
|
||||||
ProtectMemory(m_ROMImage, m_RomFileSize, MEM_READONLY);
|
ProtectMemory(m_ROMImage, m_RomFileSize, MEM_READONLY);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,11 +33,11 @@ SPECIAL_TIMERS CProfiling::StartTimer(SPECIAL_TIMERS Address)
|
||||||
uint32_t HiValue, LoValue;
|
uint32_t HiValue, LoValue;
|
||||||
_asm
|
_asm
|
||||||
{
|
{
|
||||||
pushad
|
pushad;
|
||||||
rdtsc
|
rdtsc;
|
||||||
mov HiValue, edx
|
mov HiValue, edx;
|
||||||
mov LoValue, eax
|
mov LoValue, eax;
|
||||||
popad
|
popad;
|
||||||
}
|
}
|
||||||
m_StartTimeHi = HiValue;
|
m_StartTimeHi = HiValue;
|
||||||
m_StartTimeLo = LoValue;
|
m_StartTimeLo = LoValue;
|
||||||
|
@ -47,18 +47,19 @@ SPECIAL_TIMERS CProfiling::StartTimer(SPECIAL_TIMERS Address)
|
||||||
return OldTimerAddr;
|
return OldTimerAddr;
|
||||||
}
|
}
|
||||||
|
|
||||||
SPECIAL_TIMERS CProfiling::StopTimer() {
|
SPECIAL_TIMERS CProfiling::StopTimer()
|
||||||
|
{
|
||||||
uint32_t HiValue, LoValue;
|
uint32_t HiValue, LoValue;
|
||||||
|
|
||||||
if (m_CurrentTimerAddr == Timer_None) { return m_CurrentTimerAddr; }
|
if (m_CurrentTimerAddr == Timer_None) { return m_CurrentTimerAddr; }
|
||||||
|
|
||||||
#ifdef _M_IX86
|
#ifdef _M_IX86
|
||||||
_asm {
|
_asm {
|
||||||
pushad
|
pushad;
|
||||||
rdtsc
|
rdtsc;
|
||||||
mov HiValue, edx
|
mov HiValue, edx;
|
||||||
mov LoValue, eax
|
mov LoValue, eax;
|
||||||
popad
|
popad;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
|
@ -81,7 +82,8 @@ SPECIAL_TIMERS CProfiling::StopTimer() {
|
||||||
return OldTimerAddr;
|
return OldTimerAddr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CProfiling::ShowCPU_Usage() {
|
void CProfiling::ShowCPU_Usage()
|
||||||
|
{
|
||||||
int64_t TotalTime, CPU = 0, Alist = 0, Dlist = 0, Idle = 0;
|
int64_t TotalTime, CPU = 0, Alist = 0, Dlist = 0, Idle = 0;
|
||||||
PROFILE_ENRTY Entry;
|
PROFILE_ENRTY Entry;
|
||||||
|
|
||||||
|
@ -117,16 +119,19 @@ void CProfiling::ShowCPU_Usage() {
|
||||||
ResetCounters();
|
ResetCounters();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CProfiling::ResetCounters() {
|
void CProfiling::ResetCounters()
|
||||||
|
{
|
||||||
m_Entries.clear();
|
m_Entries.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
struct TIMER_NAME {
|
struct TIMER_NAME
|
||||||
|
{
|
||||||
SPECIAL_TIMERS Timer;
|
SPECIAL_TIMERS Timer;
|
||||||
char * Name;
|
const char * Name;
|
||||||
};
|
};
|
||||||
|
|
||||||
void CProfiling::GenerateLog() {
|
void CProfiling::GenerateLog()
|
||||||
|
{
|
||||||
stdstr LogFileName;
|
stdstr LogFileName;
|
||||||
{
|
{
|
||||||
CLog Log;
|
CLog Log;
|
||||||
|
@ -135,20 +140,25 @@ void CProfiling::GenerateLog() {
|
||||||
|
|
||||||
//Get the total time
|
//Get the total time
|
||||||
int64_t TotalTime = 0;
|
int64_t TotalTime = 0;
|
||||||
for (PROFILE_ENRTY itemTime = m_Entries.begin(); itemTime != m_Entries.end(); itemTime++) {
|
for (PROFILE_ENRTY itemTime = m_Entries.begin(); itemTime != m_Entries.end(); itemTime++)
|
||||||
|
{
|
||||||
TotalTime += itemTime->second;
|
TotalTime += itemTime->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
//Create a sortable list of items
|
//Create a sortable list of items
|
||||||
std::vector<PROFILE_VALUE *> ItemList;
|
std::vector<PROFILE_VALUE *> ItemList;
|
||||||
for (PROFILE_ENRTY Entry = m_Entries.begin(); Entry != m_Entries.end(); Entry++) {
|
for (PROFILE_ENRTY Entry = m_Entries.begin(); Entry != m_Entries.end(); Entry++)
|
||||||
|
{
|
||||||
ItemList.push_back(&(*Entry));
|
ItemList.push_back(&(*Entry));
|
||||||
}
|
}
|
||||||
|
|
||||||
//sort the list with a basic bubble sort
|
//sort the list with a basic bubble sort
|
||||||
for (size_t OuterPass = 0; OuterPass < (ItemList.size() - 1); OuterPass++) {
|
for (size_t OuterPass = 0; OuterPass < (ItemList.size() - 1); OuterPass++)
|
||||||
for (size_t InnerPass = 0; InnerPass < (ItemList.size() - 1); InnerPass++) {
|
{
|
||||||
if (ItemList[InnerPass]->second < ItemList[InnerPass + 1]->second) {
|
for (size_t InnerPass = 0; InnerPass < (ItemList.size() - 1); InnerPass++)
|
||||||
|
{
|
||||||
|
if (ItemList[InnerPass]->second < ItemList[InnerPass + 1]->second)
|
||||||
|
{
|
||||||
PROFILE_VALUE * TempPtr = ItemList[InnerPass];
|
PROFILE_VALUE * TempPtr = ItemList[InnerPass];
|
||||||
ItemList[InnerPass] = ItemList[InnerPass + 1];
|
ItemList[InnerPass] = ItemList[InnerPass + 1];
|
||||||
ItemList[InnerPass + 1] = TempPtr;
|
ItemList[InnerPass + 1] = TempPtr;
|
||||||
|
@ -156,7 +166,8 @@ void CProfiling::GenerateLog() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
TIMER_NAME TimerNames[] = {
|
TIMER_NAME TimerNames[] =
|
||||||
|
{
|
||||||
{ Timer_R4300, "R4300" },
|
{ Timer_R4300, "R4300" },
|
||||||
{ Timer_RSP_Dlist, "RSP: Dlist" },
|
{ Timer_RSP_Dlist, "RSP: Dlist" },
|
||||||
{ Timer_RSP_Alist, "RSP: Alist" },
|
{ Timer_RSP_Alist, "RSP: Alist" },
|
||||||
|
@ -172,13 +183,16 @@ void CProfiling::GenerateLog() {
|
||||||
{ Timer_CompileDone, "Timer_CompileDone" },
|
{ Timer_CompileDone, "Timer_CompileDone" },
|
||||||
};
|
};
|
||||||
|
|
||||||
for (size_t count = 0; count < ItemList.size(); count++) {
|
for (size_t count = 0; count < ItemList.size(); count++)
|
||||||
|
{
|
||||||
char Buffer[255];
|
char Buffer[255];
|
||||||
double CpuUsage = ((double)ItemList[count]->second / (double)TotalTime) * 100;
|
double CpuUsage = ((double)ItemList[count]->second / (double)TotalTime) * 100;
|
||||||
if (CpuUsage <= 0.2) { continue; }
|
if (CpuUsage <= 0.2) { continue; }
|
||||||
sprintf(Buffer, "Func 0x%08X", ItemList[count]->first);
|
sprintf(Buffer, "Func 0x%08X", ItemList[count]->first);
|
||||||
for (int NameID = 0; NameID < (sizeof(TimerNames) / sizeof(TIMER_NAME)); NameID++) {
|
for (int NameID = 0; NameID < (sizeof(TimerNames) / sizeof(TIMER_NAME)); NameID++)
|
||||||
if (ItemList[count]->first == TimerNames[NameID].Timer) {
|
{
|
||||||
|
if (ItemList[count]->first == TimerNames[NameID].Timer)
|
||||||
|
{
|
||||||
strcpy(Buffer, TimerNames[NameID].Name);
|
strcpy(Buffer, TimerNames[NameID].Name);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,7 +20,6 @@
|
||||||
#include <Project64-core/N64System/Recompiler/LoopAnalysis.h>
|
#include <Project64-core/N64System/Recompiler/LoopAnalysis.h>
|
||||||
#include <Project64-core/N64System/Recompiler/SectionInfo.h>
|
#include <Project64-core/N64System/Recompiler/SectionInfo.h>
|
||||||
#include <Project64-core/ExceptionHandler.h>
|
#include <Project64-core/ExceptionHandler.h>
|
||||||
#include <Windows.h>
|
|
||||||
|
|
||||||
void InPermLoop();
|
void InPermLoop();
|
||||||
|
|
||||||
|
@ -31,7 +30,9 @@ static bool DelaySlotEffectsJump(uint32_t JumpPC)
|
||||||
OPCODE Command;
|
OPCODE Command;
|
||||||
|
|
||||||
if (!g_MMU->LW_VAddr(JumpPC, Command.Hex))
|
if (!g_MMU->LW_VAddr(JumpPC, Command.Hex))
|
||||||
|
{
|
||||||
return true;
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
switch (Command.op)
|
switch (Command.op)
|
||||||
{
|
{
|
||||||
|
@ -109,21 +110,21 @@ static bool DelaySlotEffectsJump(uint32_t JumpPC)
|
||||||
}
|
}
|
||||||
|
|
||||||
CCodeSection::CCodeSection(CCodeBlock * CodeBlock, uint32_t EnterPC, uint32_t ID, bool LinkAllowed) :
|
CCodeSection::CCodeSection(CCodeBlock * CodeBlock, uint32_t EnterPC, uint32_t ID, bool LinkAllowed) :
|
||||||
m_BlockInfo(CodeBlock),
|
m_BlockInfo(CodeBlock),
|
||||||
m_SectionID(ID),
|
m_SectionID(ID),
|
||||||
m_EnterPC(EnterPC),
|
m_EnterPC(EnterPC),
|
||||||
m_EndPC((uint32_t)-1),
|
m_EndPC((uint32_t)-1),
|
||||||
m_ContinueSection(NULL),
|
m_ContinueSection(NULL),
|
||||||
m_JumpSection(NULL),
|
m_JumpSection(NULL),
|
||||||
m_EndSection(false),
|
m_EndSection(false),
|
||||||
m_LinkAllowed(LinkAllowed),
|
m_LinkAllowed(LinkAllowed),
|
||||||
m_Test(0),
|
m_Test(0),
|
||||||
m_Test2(0),
|
m_Test2(0),
|
||||||
m_CompiledLocation(NULL),
|
m_CompiledLocation(NULL),
|
||||||
m_InLoop(false),
|
m_InLoop(false),
|
||||||
m_DelaySlot(false)
|
m_DelaySlot(false)
|
||||||
{
|
{
|
||||||
CPU_Message(__FUNCTION__ ": ID %d EnterPC 0x%08X", ID, EnterPC);
|
CPU_Message("%s: ID %d EnterPC 0x%08X", __FUNCTION__, ID, EnterPC);
|
||||||
}
|
}
|
||||||
|
|
||||||
CCodeSection::~CCodeSection()
|
CCodeSection::~CCodeSection()
|
||||||
|
@ -1035,14 +1036,14 @@ bool CCodeSection::GenerateX86Code(uint32_t Test)
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
__try
|
__except_try()
|
||||||
{
|
{
|
||||||
if (!g_MMU->LW_VAddr(m_CompilePC, m_Opcode.Hex))
|
if (!g_MMU->LW_VAddr(m_CompilePC, m_Opcode.Hex))
|
||||||
{
|
{
|
||||||
g_Notify->FatalError(GS(MSG_FAIL_LOAD_WORD));
|
g_Notify->FatalError(GS(MSG_FAIL_LOAD_WORD));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
__except (g_MMU->MemoryFilter(GetExceptionCode(), GetExceptionInformation()))
|
__except_catch()
|
||||||
{
|
{
|
||||||
g_Notify->FatalError(GS(MSG_UNKNOWN_MEM_ACTION));
|
g_Notify->FatalError(GS(MSG_UNKNOWN_MEM_ACTION));
|
||||||
}
|
}
|
||||||
|
@ -1659,7 +1660,7 @@ void CCodeSection::UnlinkParent(CCodeSection * Parent, bool ContinueSection)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
CPU_Message(__FUNCTION__ ": Section %d Parent: %d ContinueSection = %s", m_SectionID, Parent->m_SectionID, ContinueSection ? "Yes" : "No");
|
CPU_Message("%s: Section %d Parent: %d ContinueSection = %s", __FUNCTION__, m_SectionID, Parent->m_SectionID, ContinueSection ? "Yes" : "No");
|
||||||
if (Parent->m_ContinueSection == this && Parent->m_JumpSection == this)
|
if (Parent->m_ContinueSection == this && Parent->m_JumpSection == this)
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
|
|
|
@ -15,7 +15,6 @@
|
||||||
#include <Project64-core/N64System/N64Class.h>
|
#include <Project64-core/N64System/N64Class.h>
|
||||||
#include <Project64-core/N64System/Interpreter/InterpreterCPU.h>
|
#include <Project64-core/N64System/Interpreter/InterpreterCPU.h>
|
||||||
#include <Project64-core/ExceptionHandler.h>
|
#include <Project64-core/ExceptionHandler.h>
|
||||||
#include <Objbase.h>
|
|
||||||
|
|
||||||
CRecompiler::CRecompiler(CRegisters & Registers, CProfiling & Profile, bool & EndEmulation) :
|
CRecompiler::CRecompiler(CRegisters & Registers, CProfiling & Profile, bool & EndEmulation) :
|
||||||
m_Registers(Registers),
|
m_Registers(Registers),
|
||||||
|
@ -36,7 +35,6 @@ CRecompiler::~CRecompiler()
|
||||||
|
|
||||||
void CRecompiler::Run()
|
void CRecompiler::Run()
|
||||||
{
|
{
|
||||||
CoInitialize(NULL);
|
|
||||||
if (bLogX86Code())
|
if (bLogX86Code())
|
||||||
{
|
{
|
||||||
Start_x86_Log();
|
Start_x86_Log();
|
||||||
|
@ -57,7 +55,7 @@ void CRecompiler::Run()
|
||||||
#ifdef legacycode
|
#ifdef legacycode
|
||||||
*g_MemoryStack = (uint32_t)(RDRAM+(_GPR[29].W[0] & 0x1FFFFFFF));
|
*g_MemoryStack = (uint32_t)(RDRAM+(_GPR[29].W[0] & 0x1FFFFFFF));
|
||||||
#endif
|
#endif
|
||||||
__try
|
__except_try()
|
||||||
{
|
{
|
||||||
if (g_System->LookUpMode() == FuncFind_VirtualLookup)
|
if (g_System->LookUpMode() == FuncFind_VirtualLookup)
|
||||||
{
|
{
|
||||||
|
@ -100,7 +98,7 @@ void CRecompiler::Run()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
__except (g_MMU->MemoryFilter(GetExceptionCode(), GetExceptionInformation()))
|
__except_catch()
|
||||||
{
|
{
|
||||||
g_Notify->DisplayError(MSG_UNKNOWN_MEM_ACTION);
|
g_Notify->DisplayError(MSG_UNKNOWN_MEM_ACTION);
|
||||||
}
|
}
|
||||||
|
@ -945,7 +943,7 @@ CCompiledFunc * CRecompiler::CompilerCode()
|
||||||
}
|
}
|
||||||
|
|
||||||
CCompiledFunc * Func = new CCompiledFunc(CodeBlock);
|
CCompiledFunc * Func = new CCompiledFunc(CodeBlock);
|
||||||
CCompiledFuncList::_Pairib ret = m_Functions.insert(CCompiledFuncList::value_type(Func->EnterPC(), Func));
|
std::pair<CCompiledFuncList::iterator, bool> ret = m_Functions.insert(CCompiledFuncList::value_type(Func->EnterPC(), Func));
|
||||||
if (ret.second == false)
|
if (ret.second == false)
|
||||||
{
|
{
|
||||||
Func->SetNext(ret.first->second->Next());
|
Func->SetNext(ret.first->second->Next());
|
||||||
|
@ -1048,7 +1046,7 @@ void CRecompiler::ResetMemoryStackPos()
|
||||||
}
|
}
|
||||||
if (m_Registers.m_GPR[29].UW[0] == 0)
|
if (m_Registers.m_GPR[29].UW[0] == 0)
|
||||||
{
|
{
|
||||||
m_MemoryStack = NULL;
|
m_MemoryStack = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,6 @@
|
||||||
#include <Project64-core/N64System/SystemGlobals.h>
|
#include <Project64-core/N64System/SystemGlobals.h>
|
||||||
#include <Project64-core/N64System/Recompiler/RecompilerClass.h>
|
#include <Project64-core/N64System/Recompiler/RecompilerClass.h>
|
||||||
#include <Common/MemoryManagement.h>
|
#include <Common/MemoryManagement.h>
|
||||||
#include <Windows.h>
|
|
||||||
|
|
||||||
CRecompMemory::CRecompMemory() :
|
CRecompMemory::CRecompMemory() :
|
||||||
m_RecompCode(NULL),
|
m_RecompCode(NULL),
|
||||||
|
@ -26,7 +25,7 @@ CRecompMemory::~CRecompMemory()
|
||||||
{
|
{
|
||||||
if (m_RecompCode)
|
if (m_RecompCode)
|
||||||
{
|
{
|
||||||
VirtualFree(m_RecompCode, 0, MEM_RELEASE);
|
FreeAddressSpace(m_RecompCode,MaxCompileBufferSize + 4);
|
||||||
m_RecompCode = NULL;
|
m_RecompCode = NULL;
|
||||||
}
|
}
|
||||||
m_RecompPos = NULL;
|
m_RecompPos = NULL;
|
||||||
|
@ -34,7 +33,7 @@ CRecompMemory::~CRecompMemory()
|
||||||
|
|
||||||
bool CRecompMemory::AllocateMemory()
|
bool CRecompMemory::AllocateMemory()
|
||||||
{
|
{
|
||||||
uint8_t * RecompCodeBase = (uint8_t *)VirtualAlloc(NULL, MaxCompileBufferSize + 4, MEM_RESERVE | MEM_TOP_DOWN, PAGE_EXECUTE_READWRITE);
|
uint8_t * RecompCodeBase = (uint8_t *)AllocateAddressSpace(MaxCompileBufferSize + 4);
|
||||||
if (RecompCodeBase == NULL)
|
if (RecompCodeBase == NULL)
|
||||||
{
|
{
|
||||||
WriteTrace(TraceRecompiler, TraceError, "failed to allocate RecompCodeBase");
|
WriteTrace(TraceRecompiler, TraceError, "failed to allocate RecompCodeBase");
|
||||||
|
@ -42,11 +41,11 @@ bool CRecompMemory::AllocateMemory()
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_RecompCode = (uint8_t *)VirtualAlloc(RecompCodeBase, InitialCompileBufferSize, MEM_COMMIT, PAGE_EXECUTE_READWRITE);
|
m_RecompCode = (uint8_t *)CommitMemory(RecompCodeBase, InitialCompileBufferSize, MEM_EXECUTE_READWRITE);
|
||||||
if (m_RecompCode == NULL)
|
if (m_RecompCode == NULL)
|
||||||
{
|
{
|
||||||
WriteTrace(TraceRecompiler, TraceError, "failed to commit initial buffer");
|
WriteTrace(TraceRecompiler, TraceError, "failed to commit initial buffer");
|
||||||
VirtualFree(RecompCodeBase, 0, MEM_RELEASE);
|
FreeAddressSpace(RecompCodeBase,MaxCompileBufferSize + 4);
|
||||||
g_Notify->DisplayError(MSG_MEM_ALLOC_ERROR);
|
g_Notify->DisplayError(MSG_MEM_ALLOC_ERROR);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -68,7 +67,7 @@ void CRecompMemory::CheckRecompMem()
|
||||||
g_Recompiler->ResetRecompCode(true);
|
g_Recompiler->ResetRecompCode(true);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
LPVOID MemAddr = VirtualAlloc(m_RecompCode + m_RecompSize, IncreaseCompileBufferSize, MEM_COMMIT, PAGE_EXECUTE_READWRITE);
|
void * MemAddr = CommitMemory(m_RecompCode + m_RecompSize, IncreaseCompileBufferSize, MEM_EXECUTE_READWRITE);
|
||||||
if (MemAddr == NULL)
|
if (MemAddr == NULL)
|
||||||
{
|
{
|
||||||
WriteTrace(TraceRecompiler, TraceError, "failed to increase buffer");
|
WriteTrace(TraceRecompiler, TraceError, "failed to increase buffer");
|
||||||
|
|
|
@ -2300,7 +2300,7 @@ void CRecompilerOps::DADDIU()
|
||||||
|
|
||||||
BeforeCallDirect(m_RegWorkingSet);
|
BeforeCallDirect(m_RegWorkingSet);
|
||||||
MoveConstToVariable(m_Opcode.Hex, &R4300iOp::m_Opcode.Hex, "R4300iOp::m_Opcode.Hex");
|
MoveConstToVariable(m_Opcode.Hex, &R4300iOp::m_Opcode.Hex, "R4300iOp::m_Opcode.Hex");
|
||||||
Call_Direct(R4300iOp::DADDIU, "R4300iOp::DADDIU");
|
Call_Direct((void *)R4300iOp::DADDIU, "R4300iOp::DADDIU");
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3191,7 +3191,7 @@ void CRecompilerOps::SPECIAL_DMULT()
|
||||||
|
|
||||||
BeforeCallDirect(m_RegWorkingSet);
|
BeforeCallDirect(m_RegWorkingSet);
|
||||||
MoveConstToVariable(m_Opcode.Hex, &R4300iOp::m_Opcode.Hex, "R4300iOp::m_Opcode.Hex");
|
MoveConstToVariable(m_Opcode.Hex, &R4300iOp::m_Opcode.Hex, "R4300iOp::m_Opcode.Hex");
|
||||||
Call_Direct(R4300iOp::SPECIAL_DMULT, "R4300iOp::SPECIAL_DMULT");
|
Call_Direct((void *)R4300iOp::SPECIAL_DMULT, "R4300iOp::SPECIAL_DMULT");
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3203,7 +3203,7 @@ void CRecompilerOps::SPECIAL_DMULTU()
|
||||||
UnMap_GPR(m_Opcode.rt, true);
|
UnMap_GPR(m_Opcode.rt, true);
|
||||||
BeforeCallDirect(m_RegWorkingSet);
|
BeforeCallDirect(m_RegWorkingSet);
|
||||||
MoveConstToVariable(m_Opcode.Hex, &R4300iOp::m_Opcode.Hex, "R4300iOp::m_Opcode.Hex");
|
MoveConstToVariable(m_Opcode.Hex, &R4300iOp::m_Opcode.Hex, "R4300iOp::m_Opcode.Hex");
|
||||||
Call_Direct(R4300iOp::SPECIAL_DMULTU, "R4300iOp::SPECIAL_DMULTU");
|
Call_Direct((void *)R4300iOp::SPECIAL_DMULTU, "R4300iOp::SPECIAL_DMULTU");
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
|
|
||||||
#ifdef toremove
|
#ifdef toremove
|
||||||
|
@ -3282,7 +3282,7 @@ void CRecompilerOps::SPECIAL_DDIV()
|
||||||
UnMap_GPR(m_Opcode.rt, true);
|
UnMap_GPR(m_Opcode.rt, true);
|
||||||
BeforeCallDirect(m_RegWorkingSet);
|
BeforeCallDirect(m_RegWorkingSet);
|
||||||
MoveConstToVariable(m_Opcode.Hex, &R4300iOp::m_Opcode.Hex, "R4300iOp::m_Opcode.Hex");
|
MoveConstToVariable(m_Opcode.Hex, &R4300iOp::m_Opcode.Hex, "R4300iOp::m_Opcode.Hex");
|
||||||
Call_Direct(R4300iOp::SPECIAL_DDIV, "R4300iOp::SPECIAL_DDIV");
|
Call_Direct((void *)R4300iOp::SPECIAL_DDIV, "R4300iOp::SPECIAL_DDIV");
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3294,7 +3294,7 @@ void CRecompilerOps::SPECIAL_DDIVU()
|
||||||
UnMap_GPR(m_Opcode.rt, true);
|
UnMap_GPR(m_Opcode.rt, true);
|
||||||
BeforeCallDirect(m_RegWorkingSet);
|
BeforeCallDirect(m_RegWorkingSet);
|
||||||
MoveConstToVariable(m_Opcode.Hex, &R4300iOp::m_Opcode.Hex, "R4300iOp::m_Opcode.Hex");
|
MoveConstToVariable(m_Opcode.Hex, &R4300iOp::m_Opcode.Hex, "R4300iOp::m_Opcode.Hex");
|
||||||
Call_Direct(R4300iOp::SPECIAL_DDIVU, "R4300iOp::SPECIAL_DDIVU");
|
Call_Direct((void *)R4300iOp::SPECIAL_DDIVU, "R4300iOp::SPECIAL_DDIVU");
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4876,7 +4876,7 @@ void CRecompilerOps::SPECIAL_DADDU()
|
||||||
if (IsConst(source2))
|
if (IsConst(source2))
|
||||||
{
|
{
|
||||||
AddConstToX86Reg(GetMipsRegMapLo(m_Opcode.rd), GetMipsRegLo(source2));
|
AddConstToX86Reg(GetMipsRegMapLo(m_Opcode.rd), GetMipsRegLo(source2));
|
||||||
AddConstToX86Reg(GetMipsRegMapHi(m_Opcode.rd), GetMipsRegHi(source2));
|
AdcConstToX86Reg(GetMipsRegMapHi(m_Opcode.rd), GetMipsRegHi(source2));
|
||||||
}
|
}
|
||||||
else if (IsMapped(source2))
|
else if (IsMapped(source2))
|
||||||
{
|
{
|
||||||
|
@ -5563,7 +5563,7 @@ void CRecompilerOps::COP0_CO_ERET(void)
|
||||||
CPU_Message(" %X %s", m_CompilePC, R4300iOpcodeName(m_Opcode.Hex, m_CompilePC));
|
CPU_Message(" %X %s", m_CompilePC, R4300iOpcodeName(m_Opcode.Hex, m_CompilePC));
|
||||||
|
|
||||||
m_RegWorkingSet.WriteBackRegisters();
|
m_RegWorkingSet.WriteBackRegisters();
|
||||||
Call_Direct(compiler_COP0_CO_ERET, "compiler_COP0_CO_ERET");
|
Call_Direct((void *)compiler_COP0_CO_ERET, "compiler_COP0_CO_ERET");
|
||||||
|
|
||||||
UpdateCounters(m_RegWorkingSet, true, true);
|
UpdateCounters(m_RegWorkingSet, true, true);
|
||||||
m_Section->CompileExit(m_CompilePC, (uint32_t)-1, m_RegWorkingSet, CExitInfo::Normal, true, NULL);
|
m_Section->CompileExit(m_CompilePC, (uint32_t)-1, m_RegWorkingSet, CExitInfo::Normal, true, NULL);
|
||||||
|
@ -5573,11 +5573,12 @@ void CRecompilerOps::COP0_CO_ERET(void)
|
||||||
/************************** FPU Options **************************/
|
/************************** FPU Options **************************/
|
||||||
void CRecompilerOps::ChangeDefaultRoundingModel()
|
void CRecompilerOps::ChangeDefaultRoundingModel()
|
||||||
{
|
{
|
||||||
switch ((_FPCR[31] & 3)) {
|
switch ((_FPCR[31] & 3))
|
||||||
case 0: *_RoundingModel = ROUND_NEAR; break;
|
{
|
||||||
case 1: *_RoundingModel = ROUND_CHOP; break;
|
case 0: *_RoundingModel = FE_TONEAREST; break;
|
||||||
case 2: *_RoundingModel = ROUND_UP; break;
|
case 1: *_RoundingModel = FE_TOWARDZERO; break;
|
||||||
case 3: *_RoundingModel = ROUND_DOWN; break;
|
case 2: *_RoundingModel = FE_UPWARD; break;
|
||||||
|
case 3: *_RoundingModel = FE_DOWNWARD; break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5746,7 +5747,7 @@ void CRecompilerOps::COP1_CT()
|
||||||
MoveX86regToVariable(Map_TempReg(x86_Any, m_Opcode.rt, false), &_FPCR[m_Opcode.fs], CRegName::FPR_Ctrl[m_Opcode.fs]);
|
MoveX86regToVariable(Map_TempReg(x86_Any, m_Opcode.rt, false), &_FPCR[m_Opcode.fs], CRegName::FPR_Ctrl[m_Opcode.fs]);
|
||||||
}
|
}
|
||||||
BeforeCallDirect(m_RegWorkingSet);
|
BeforeCallDirect(m_RegWorkingSet);
|
||||||
Call_Direct(ChangeDefaultRoundingModel, "ChangeDefaultRoundingModel");
|
Call_Direct((void *)ChangeDefaultRoundingModel, "ChangeDefaultRoundingModel");
|
||||||
AfterCallDirect(m_RegWorkingSet);
|
AfterCallDirect(m_RegWorkingSet);
|
||||||
m_RegWorkingSet.SetRoundingModel(CRegInfo::RoundUnknown);
|
m_RegWorkingSet.SetRoundingModel(CRegInfo::RoundUnknown);
|
||||||
}
|
}
|
||||||
|
@ -6578,7 +6579,7 @@ void CRecompilerOps::UnknownOpcode()
|
||||||
m_RegWorkingSet.SetBlockCycleCount(m_RegWorkingSet.GetBlockCycleCount() - g_System->CountPerOp());
|
m_RegWorkingSet.SetBlockCycleCount(m_RegWorkingSet.GetBlockCycleCount() - g_System->CountPerOp());
|
||||||
|
|
||||||
MoveConstToVariable(m_Opcode.Hex, &R4300iOp::m_Opcode.Hex, "R4300iOp::m_Opcode.Hex");
|
MoveConstToVariable(m_Opcode.Hex, &R4300iOp::m_Opcode.Hex, "R4300iOp::m_Opcode.Hex");
|
||||||
Call_Direct(R4300iOp::UnknownOpcode, "R4300iOp::UnknownOpcode");
|
Call_Direct((void *)R4300iOp::UnknownOpcode, "R4300iOp::UnknownOpcode");
|
||||||
Ret();
|
Ret();
|
||||||
if (m_NextInstruction == NORMAL) { m_NextInstruction = END_BLOCK; }
|
if (m_NextInstruction == NORMAL) { m_NextInstruction = END_BLOCK; }
|
||||||
}
|
}
|
||||||
|
@ -6712,7 +6713,7 @@ void CRecompilerOps::OverflowDelaySlot(bool TestTimer)
|
||||||
}
|
}
|
||||||
|
|
||||||
PushImm32("g_System->CountPerOp()", g_System->CountPerOp());
|
PushImm32("g_System->CountPerOp()", g_System->CountPerOp());
|
||||||
Call_Direct(CInterpreterCPU::ExecuteOps, "CInterpreterCPU::ExecuteOps");
|
Call_Direct((void *)CInterpreterCPU::ExecuteOps, "CInterpreterCPU::ExecuteOps");
|
||||||
AddConstToX86Reg(x86_ESP, 4);
|
AddConstToX86Reg(x86_ESP, 4);
|
||||||
|
|
||||||
if (g_System->bFastSP() && g_Recompiler)
|
if (g_System->bFastSP() && g_Recompiler)
|
||||||
|
|
|
@ -16,11 +16,12 @@
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <float.h>
|
||||||
#include "x86CodeLog.h"
|
#include "x86CodeLog.h"
|
||||||
|
|
||||||
uint32_t CRegInfo::m_fpuControl = 0;
|
uint32_t CRegInfo::m_fpuControl = 0;
|
||||||
|
|
||||||
char *Format_Name[] = { "Unknown", "dword", "qword", "float", "double" };
|
const char *Format_Name[] = { "Unknown", "dword", "qword", "float", "double" };
|
||||||
|
|
||||||
CRegInfo::CRegInfo() :
|
CRegInfo::CRegInfo() :
|
||||||
m_CycleCount(0),
|
m_CycleCount(0),
|
||||||
|
@ -160,8 +161,12 @@ void CRegInfo::FixRoundModel(FPU_ROUND RoundMethod)
|
||||||
|
|
||||||
if (RoundMethod == RoundDefault)
|
if (RoundMethod == RoundDefault)
|
||||||
{
|
{
|
||||||
|
static const unsigned int msRound[4] = { _RC_NEAR, _RC_CHOP, _RC_UP, _RC_DOWN };
|
||||||
|
|
||||||
x86Reg RoundReg = Map_TempReg(x86_Any, -1, false);
|
x86Reg RoundReg = Map_TempReg(x86_Any, -1, false);
|
||||||
MoveVariableToX86reg(&g_Reg->m_RoundingModel, "m_RoundingModel", RoundReg);
|
MoveVariableToX86reg(&g_Reg->m_RoundingModel, "m_RoundingModel", RoundReg);
|
||||||
|
MoveVariableDispToX86Reg((void *)&msRound[0], "msRound", RoundReg, RoundReg, Multip_x4);
|
||||||
|
|
||||||
ShiftLeftSignImmed(RoundReg, 2);
|
ShiftLeftSignImmed(RoundReg, 2);
|
||||||
OrX86RegToX86Reg(reg, RoundReg);
|
OrX86RegToX86Reg(reg, RoundReg);
|
||||||
SetX86Protected(RoundReg, false);
|
SetX86Protected(RoundReg, false);
|
||||||
|
@ -526,7 +531,7 @@ CX86Ops::x86Reg CRegInfo::UnMap_8BitTempReg()
|
||||||
for (count = 0; count < 10; count++)
|
for (count = 0; count < 10; count++)
|
||||||
{
|
{
|
||||||
if (!Is8BitReg((x86Reg)count)) { continue; }
|
if (!Is8BitReg((x86Reg)count)) { continue; }
|
||||||
if (GetMipsRegState((x86Reg)count) == Temp_Mapped)
|
if (GetX86Mapped((x86Reg)count) == Temp_Mapped)
|
||||||
{
|
{
|
||||||
if (GetX86Protected((x86Reg)count) == false)
|
if (GetX86Protected((x86Reg)count) == false)
|
||||||
{
|
{
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include <Project64-core/N64System/SystemGlobals.h>
|
#include <Project64-core/N64System/SystemGlobals.h>
|
||||||
#include <Project64-core/N64System/Mips/MemoryVirtualMem.h>
|
#include <Project64-core/N64System/Mips/MemoryVirtualMem.h>
|
||||||
#include "X86ops.h"
|
#include <Project64-core/N64System/Recompiler/X86ops.h>
|
||||||
#include "x86CodeLog.h"
|
#include "x86CodeLog.h"
|
||||||
|
|
||||||
#define PUTDST8(dest,value) (*((uint8_t *)(dest))=(uint8_t)(value)); dest += 1;
|
#define PUTDST8(dest,value) (*((uint8_t *)(dest))=(uint8_t)(value)); dest += 1;
|
||||||
|
@ -211,7 +211,7 @@ void CX86Ops::X86BreakPoint(const char * FileName, int LineNumber)
|
||||||
Pushad();
|
Pushad();
|
||||||
PushImm32(stdstr_f("%d", LineNumber).c_str(), LineNumber);
|
PushImm32(stdstr_f("%d", LineNumber).c_str(), LineNumber);
|
||||||
PushImm32(FileName, (uint32_t)FileName);
|
PushImm32(FileName, (uint32_t)FileName);
|
||||||
Call_Direct(BreakPointNotification, "BreakPointNotification");
|
Call_Direct((void *)BreakPointNotification, "BreakPointNotification");
|
||||||
AddConstToX86Reg(x86_ESP, 8);
|
AddConstToX86Reg(x86_ESP, 8);
|
||||||
Popad();
|
Popad();
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,10 +11,11 @@
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include "SpeedLimiterClass.h"
|
#include "SpeedLimiterClass.h"
|
||||||
#include <Common/Util.h>
|
#include <Common/Util.h>
|
||||||
|
#ifdef _WIN32
|
||||||
#include <Windows.h>
|
#include <Windows.h>
|
||||||
#include <Mmsystem.h>
|
#include <Mmsystem.h>
|
||||||
|
|
||||||
#pragma comment(lib, "winmm.lib")
|
#pragma comment(lib, "winmm.lib")
|
||||||
|
#endif
|
||||||
|
|
||||||
CSpeedLimiter::CSpeedLimiter()
|
CSpeedLimiter::CSpeedLimiter()
|
||||||
{
|
{
|
||||||
|
@ -24,19 +25,23 @@ CSpeedLimiter::CSpeedLimiter()
|
||||||
m_BaseSpeed = 60;
|
m_BaseSpeed = 60;
|
||||||
m_Ratio = 1000.0F / (float)m_Speed;
|
m_Ratio = 1000.0F / (float)m_Speed;
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
TIMECAPS Caps;
|
TIMECAPS Caps;
|
||||||
timeGetDevCaps(&Caps, sizeof(Caps));
|
timeGetDevCaps(&Caps, sizeof(Caps));
|
||||||
if (timeBeginPeriod(Caps.wPeriodMin) == TIMERR_NOCANDO)
|
if (timeBeginPeriod(Caps.wPeriodMin) == TIMERR_NOCANDO)
|
||||||
{
|
{
|
||||||
g_Notify->DisplayError("Error during timer begin");
|
g_Notify->DisplayError("Error during timer begin");
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
CSpeedLimiter::~CSpeedLimiter()
|
CSpeedLimiter::~CSpeedLimiter()
|
||||||
{
|
{
|
||||||
|
#ifdef _WIN32
|
||||||
TIMECAPS Caps;
|
TIMECAPS Caps;
|
||||||
timeGetDevCaps(&Caps, sizeof(Caps));
|
timeGetDevCaps(&Caps, sizeof(Caps));
|
||||||
timeEndPeriod(Caps.wPeriodMin);
|
timeEndPeriod(Caps.wPeriodMin);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSpeedLimiter::SetHertz(uint32_t Hertz)
|
void CSpeedLimiter::SetHertz(uint32_t Hertz)
|
||||||
|
@ -50,11 +55,14 @@ void CSpeedLimiter::FixSpeedRatio()
|
||||||
{
|
{
|
||||||
m_Ratio = 1000.0f / static_cast<double>(m_Speed);
|
m_Ratio = 1000.0f / static_cast<double>(m_Speed);
|
||||||
m_Frames = 0;
|
m_Frames = 0;
|
||||||
|
#ifdef _WIN32
|
||||||
m_LastTime = timeGetTime();
|
m_LastTime = timeGetTime();
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CSpeedLimiter::Timer_Process(uint32_t * FrameRate)
|
bool CSpeedLimiter::Timer_Process(uint32_t * FrameRate)
|
||||||
{
|
{
|
||||||
|
#ifdef _WIN32
|
||||||
m_Frames += 1;
|
m_Frames += 1;
|
||||||
uint32_t CurrentTime = timeGetTime();
|
uint32_t CurrentTime = timeGetTime();
|
||||||
|
|
||||||
|
@ -85,6 +93,9 @@ bool CSpeedLimiter::Timer_Process(uint32_t * FrameRate)
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
return false;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSpeedLimiter::IncreaseSpeed()
|
void CSpeedLimiter::IncreaseSpeed()
|
||||||
|
|
|
@ -21,6 +21,7 @@ CRegisters * g_Reg = NULL; //Current Register Set attacted to the g_MMU
|
||||||
CNotification * g_Notify = NULL;
|
CNotification * g_Notify = NULL;
|
||||||
CPlugins * g_Plugins = NULL;
|
CPlugins * g_Plugins = NULL;
|
||||||
CN64Rom * g_Rom = NULL; //The current rom that this system is executing.. it can only execute one file at the time
|
CN64Rom * g_Rom = NULL; //The current rom that this system is executing.. it can only execute one file at the time
|
||||||
|
CN64Rom * g_DDRom = NULL; //64DD IPL ROM
|
||||||
CAudio * g_Audio = NULL;
|
CAudio * g_Audio = NULL;
|
||||||
CSystemTimer * g_SystemTimer = NULL;
|
CSystemTimer * g_SystemTimer = NULL;
|
||||||
CTransVaddr * g_TransVaddr = NULL;
|
CTransVaddr * g_TransVaddr = NULL;
|
||||||
|
|
|
@ -35,6 +35,7 @@ extern CPlugins * g_Plugins;
|
||||||
|
|
||||||
class CN64Rom;
|
class CN64Rom;
|
||||||
extern CN64Rom * g_Rom; //The current rom that this system is executing.. it can only execute one file at the time
|
extern CN64Rom * g_Rom; //The current rom that this system is executing.. it can only execute one file at the time
|
||||||
|
extern CN64Rom * g_DDRom; //64DD IPL ROM
|
||||||
|
|
||||||
class CAudio;
|
class CAudio;
|
||||||
extern CAudio * g_Audio;
|
extern CAudio * g_Audio;
|
||||||
|
|
|
@ -14,16 +14,18 @@
|
||||||
#include <Project64-core/N64System/Mips/MemoryVirtualMem.h>
|
#include <Project64-core/N64System/Mips/MemoryVirtualMem.h>
|
||||||
#include <Project64-core/N64System/Mips/RegisterClass.h>
|
#include <Project64-core/N64System/Mips/RegisterClass.h>
|
||||||
#include <Project64-core/N64System/N64Class.h>
|
#include <Project64-core/N64System/N64Class.h>
|
||||||
#include "AudioPlugin.h"
|
#include <Project64-core/Plugins/AudioPlugin.h>
|
||||||
|
#ifdef _WIN32
|
||||||
#include <Windows.h>
|
#include <Windows.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
CAudioPlugin::CAudioPlugin() :
|
CAudioPlugin::CAudioPlugin() :
|
||||||
AiLenChanged(NULL),
|
AiLenChanged(NULL),
|
||||||
AiReadLength(NULL),
|
AiReadLength(NULL),
|
||||||
ProcessAList(NULL),
|
ProcessAList(NULL),
|
||||||
m_hAudioThread(NULL),
|
m_hAudioThread(NULL),
|
||||||
AiUpdate(NULL),
|
AiUpdate(NULL),
|
||||||
AiDacrateChanged(NULL)
|
AiDacrateChanged(NULL)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -36,7 +38,7 @@ CAudioPlugin::~CAudioPlugin()
|
||||||
bool CAudioPlugin::LoadFunctions(void)
|
bool CAudioPlugin::LoadFunctions(void)
|
||||||
{
|
{
|
||||||
// Find entries for functions in DLL
|
// Find entries for functions in DLL
|
||||||
void(__cdecl *InitiateAudio) (void);
|
void(CALL *InitiateAudio)(void);
|
||||||
LoadFunction(InitiateAudio);
|
LoadFunction(InitiateAudio);
|
||||||
LoadFunction(AiDacrateChanged);
|
LoadFunction(AiDacrateChanged);
|
||||||
LoadFunction(AiLenChanged);
|
LoadFunction(AiLenChanged);
|
||||||
|
@ -62,8 +64,8 @@ bool CAudioPlugin::Initiate(CN64System * System, RenderWindow * Window)
|
||||||
{
|
{
|
||||||
struct AUDIO_INFO
|
struct AUDIO_INFO
|
||||||
{
|
{
|
||||||
HWND hwnd;
|
void * hwnd;
|
||||||
HINSTANCE hinst;
|
void * hinst;
|
||||||
|
|
||||||
int32_t MemoryBswaped; // If this is set to TRUE, then the memory has been pre
|
int32_t MemoryBswaped; // If this is set to TRUE, then the memory has been pre
|
||||||
|
|
||||||
|
@ -85,19 +87,19 @@ bool CAudioPlugin::Initiate(CN64System * System, RenderWindow * Window)
|
||||||
uint32_t * AI__DACRATE_REG;
|
uint32_t * AI__DACRATE_REG;
|
||||||
uint32_t * AI__BITRATE_REG;
|
uint32_t * AI__BITRATE_REG;
|
||||||
|
|
||||||
void(__cdecl *CheckInterrupts)(void);
|
void(CALL *CheckInterrupts)(void);
|
||||||
};
|
};
|
||||||
|
|
||||||
//Get Function from DLL
|
//Get Function from DLL
|
||||||
int32_t(__cdecl *InitiateAudio)(AUDIO_INFO Audio_Info);
|
int32_t(CALL *InitiateAudio)(AUDIO_INFO Audio_Info);
|
||||||
LoadFunction(InitiateAudio);
|
LoadFunction(InitiateAudio);
|
||||||
if (InitiateAudio == NULL) { return false; }
|
if (InitiateAudio == NULL) { return false; }
|
||||||
|
|
||||||
AUDIO_INFO Info = { 0 };
|
AUDIO_INFO Info = { 0 };
|
||||||
|
|
||||||
Info.hwnd = (HWND)Window->GetWindowHandle();
|
Info.hwnd = Window ? Window->GetWindowHandle() : NULL;
|
||||||
Info.hinst = GetModuleHandle(NULL);
|
Info.hinst = Window ? Window->GetModuleInstance() : NULL;;
|
||||||
Info.MemoryBswaped = TRUE;
|
Info.MemoryBswaped = true;
|
||||||
Info.CheckInterrupts = DummyCheckInterrupts;
|
Info.CheckInterrupts = DummyCheckInterrupts;
|
||||||
|
|
||||||
// We are initializing the plugin before any rom is loaded so we do not have any correct
|
// We are initializing the plugin before any rom is loaded so we do not have any correct
|
||||||
|
@ -137,10 +139,9 @@ bool CAudioPlugin::Initiate(CN64System * System, RenderWindow * Window)
|
||||||
|
|
||||||
m_Initialized = InitiateAudio(Info) != 0;
|
m_Initialized = InitiateAudio(Info) != 0;
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
//jabo had a bug so I call CreateThread so his dllmain gets called again
|
//jabo had a bug so I call CreateThread so his dllmain gets called again
|
||||||
DWORD ThreadID;
|
pjutil::DynLibCallDllMain();
|
||||||
HANDLE hthread = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)DummyFunction, NULL, 0, &ThreadID);
|
|
||||||
CloseHandle(hthread);
|
|
||||||
|
|
||||||
if (System != NULL)
|
if (System != NULL)
|
||||||
{
|
{
|
||||||
|
@ -151,6 +152,7 @@ bool CAudioPlugin::Initiate(CN64System * System, RenderWindow * Window)
|
||||||
WriteTrace(TraceAudioPlugin, TraceDebug, "Terminate Audio Thread");
|
WriteTrace(TraceAudioPlugin, TraceDebug, "Terminate Audio Thread");
|
||||||
TerminateThread(m_hAudioThread, 0);
|
TerminateThread(m_hAudioThread, 0);
|
||||||
}
|
}
|
||||||
|
DWORD ThreadID;
|
||||||
m_hAudioThread = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)AudioThread, (LPVOID)this, 0, &ThreadID);
|
m_hAudioThread = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)AudioThread, (LPVOID)this, 0, &ThreadID);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -159,17 +161,20 @@ bool CAudioPlugin::Initiate(CN64System * System, RenderWindow * Window)
|
||||||
DacrateChanged(System->SystemType());
|
DacrateChanged(System->SystemType());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
return m_Initialized;
|
return m_Initialized;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CAudioPlugin::UnloadPluginDetails(void)
|
void CAudioPlugin::UnloadPluginDetails(void)
|
||||||
{
|
{
|
||||||
|
#ifdef _WIN32
|
||||||
if (m_hAudioThread)
|
if (m_hAudioThread)
|
||||||
{
|
{
|
||||||
WriteTrace(TraceAudioPlugin, TraceDebug, "Terminate Audio Thread");
|
WriteTrace(TraceAudioPlugin, TraceDebug, "Terminate Audio Thread");
|
||||||
TerminateThread(m_hAudioThread, 0);
|
TerminateThread(m_hAudioThread, 0);
|
||||||
m_hAudioThread = NULL;
|
m_hAudioThread = NULL;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
AiDacrateChanged = NULL;
|
AiDacrateChanged = NULL;
|
||||||
AiLenChanged = NULL;
|
AiLenChanged = NULL;
|
||||||
AiReadLength = NULL;
|
AiReadLength = NULL;
|
||||||
|
@ -187,6 +192,7 @@ void CAudioPlugin::DacrateChanged(SYSTEM_TYPE Type)
|
||||||
AiDacrateChanged(Type);
|
AiDacrateChanged(Type);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
void CAudioPlugin::AudioThread(CAudioPlugin * _this)
|
void CAudioPlugin::AudioThread(CAudioPlugin * _this)
|
||||||
{
|
{
|
||||||
SetThreadPriority(GetCurrentThread(), THREAD_PRIORITY_TIME_CRITICAL);
|
SetThreadPriority(GetCurrentThread(), THREAD_PRIORITY_TIME_CRITICAL);
|
||||||
|
@ -199,3 +205,4 @@ void CAudioPlugin::AudioThread(CAudioPlugin * _this)
|
||||||
_this->AiUpdate(true);
|
_this->AiUpdate(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
* *
|
* *
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
#pragma once
|
#pragma once
|
||||||
#include "PluginBase.h"
|
#include <Project64-core/Plugins/PluginBase.h>
|
||||||
|
|
||||||
class CAudioPlugin : public CPlugin
|
class CAudioPlugin : public CPlugin
|
||||||
{
|
{
|
||||||
|
|
|
@ -13,16 +13,15 @@
|
||||||
#include <Project64-core/N64System/N64RomClass.h>
|
#include <Project64-core/N64System/N64RomClass.h>
|
||||||
#include <Project64-core/N64System/Mips/RegisterClass.h>
|
#include <Project64-core/N64System/Mips/RegisterClass.h>
|
||||||
#include "ControllerPlugin.h"
|
#include "ControllerPlugin.h"
|
||||||
#include <Windows.h>
|
|
||||||
|
|
||||||
CControl_Plugin::CControl_Plugin(void) :
|
CControl_Plugin::CControl_Plugin(void) :
|
||||||
WM_KeyDown(NULL),
|
WM_KeyDown(NULL),
|
||||||
WM_KeyUp(NULL),
|
WM_KeyUp(NULL),
|
||||||
RumbleCommand(NULL),
|
RumbleCommand(NULL),
|
||||||
GetKeys(NULL),
|
GetKeys(NULL),
|
||||||
ReadController(NULL),
|
ReadController(NULL),
|
||||||
ControllerCommand(NULL),
|
ControllerCommand(NULL),
|
||||||
m_AllocatedControllers(false)
|
m_AllocatedControllers(false)
|
||||||
{
|
{
|
||||||
memset(&m_PluginControllers, 0, sizeof(m_PluginControllers));
|
memset(&m_PluginControllers, 0, sizeof(m_PluginControllers));
|
||||||
memset(&m_Controllers, 0, sizeof(m_Controllers));
|
memset(&m_Controllers, 0, sizeof(m_Controllers));
|
||||||
|
@ -37,7 +36,7 @@ CControl_Plugin::~CControl_Plugin()
|
||||||
bool CControl_Plugin::LoadFunctions(void)
|
bool CControl_Plugin::LoadFunctions(void)
|
||||||
{
|
{
|
||||||
// Find entries for functions in DLL
|
// Find entries for functions in DLL
|
||||||
void(__cdecl *InitiateControllers)(void);
|
void(CALL *InitiateControllers)(void);
|
||||||
LoadFunction(InitiateControllers);
|
LoadFunction(InitiateControllers);
|
||||||
LoadFunction(ControllerCommand);
|
LoadFunction(ControllerCommand);
|
||||||
LoadFunction(GetKeys);
|
LoadFunction(GetKeys);
|
||||||
|
@ -65,40 +64,39 @@ bool CControl_Plugin::LoadFunctions(void)
|
||||||
|
|
||||||
bool CControl_Plugin::Initiate(CN64System * System, RenderWindow * Window)
|
bool CControl_Plugin::Initiate(CN64System * System, RenderWindow * Window)
|
||||||
{
|
{
|
||||||
CONTROL_INFO ControlInfo;
|
|
||||||
uint8_t Buffer[100];
|
uint8_t Buffer[100];
|
||||||
|
|
||||||
for (int32_t i = 0; i < 4; i++)
|
for (int32_t i = 0; i < 4; i++)
|
||||||
{
|
{
|
||||||
m_PluginControllers[i].Present = FALSE;
|
m_PluginControllers[i].Present = false;
|
||||||
m_PluginControllers[i].RawData = FALSE;
|
m_PluginControllers[i].RawData = false;
|
||||||
m_PluginControllers[i].Plugin = PLUGIN_NONE;
|
m_PluginControllers[i].Plugin = PLUGIN_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_PluginInfo.Version >= 0x0101)
|
|
||||||
{
|
|
||||||
ControlInfo.Controls = m_PluginControllers;
|
|
||||||
ControlInfo.HEADER = (System == NULL ? Buffer : g_Rom->GetRomAddress());
|
|
||||||
ControlInfo.hinst = GetModuleHandle(NULL);
|
|
||||||
ControlInfo.hMainWindow = Window ? (HWND)Window->GetWindowHandle() : NULL;
|
|
||||||
ControlInfo.MemoryBswaped = TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test Plugin version
|
// Test Plugin version
|
||||||
if (m_PluginInfo.Version == 0x0100)
|
if (m_PluginInfo.Version == 0x0100)
|
||||||
{
|
{
|
||||||
//Get Function from DLL
|
//Get Function from DLL
|
||||||
void(__cdecl *InitiateControllers_1_0)(HWND hMainWindow, CONTROL Controls[4]);
|
void(CALL *InitiateControllers_1_0)(void * hMainWindow, CONTROL Controls[4]);
|
||||||
InitiateControllers_1_0 = (void(__cdecl *)(HWND, CONTROL *))GetProcAddress((HMODULE)m_hDll, "InitiateControllers");
|
_LoadFunction("InitiateControllers",InitiateControllers_1_0);
|
||||||
if (InitiateControllers_1_0 == NULL) { return false; }
|
if (InitiateControllers_1_0 == NULL) { return false; }
|
||||||
InitiateControllers_1_0((HWND)Window->GetWindowHandle(), m_PluginControllers);
|
InitiateControllers_1_0(Window->GetWindowHandle(), m_PluginControllers);
|
||||||
m_Initialized = true;
|
m_Initialized = true;
|
||||||
}
|
}
|
||||||
else if (m_PluginInfo.Version == 0x0101)
|
else if (m_PluginInfo.Version >= 0x0101)
|
||||||
|
{
|
||||||
|
CONTROL_INFO ControlInfo;
|
||||||
|
ControlInfo.Controls = m_PluginControllers;
|
||||||
|
ControlInfo.HEADER = (System == NULL ? Buffer : g_Rom->GetRomAddress());
|
||||||
|
ControlInfo.hinst = Window ? Window->GetModuleInstance() : NULL;
|
||||||
|
ControlInfo.hMainWindow = Window ? Window->GetWindowHandle() : NULL;
|
||||||
|
ControlInfo.MemoryBswaped = true;
|
||||||
|
|
||||||
|
if (m_PluginInfo.Version == 0x0101)
|
||||||
{
|
{
|
||||||
//Get Function from DLL
|
//Get Function from DLL
|
||||||
void(__cdecl *InitiateControllers_1_1)(CONTROL_INFO ControlInfo);
|
void(CALL *InitiateControllers_1_1)(CONTROL_INFO ControlInfo);
|
||||||
InitiateControllers_1_1 = (void(__cdecl *)(CONTROL_INFO))GetProcAddress((HMODULE)m_hDll, "InitiateControllers");
|
_LoadFunction("InitiateControllers",InitiateControllers_1_1);
|
||||||
if (InitiateControllers_1_1 == NULL) { return false; }
|
if (InitiateControllers_1_1 == NULL) { return false; }
|
||||||
|
|
||||||
InitiateControllers_1_1(ControlInfo);
|
InitiateControllers_1_1(ControlInfo);
|
||||||
|
@ -107,18 +105,19 @@ bool CControl_Plugin::Initiate(CN64System * System, RenderWindow * Window)
|
||||||
else if (m_PluginInfo.Version >= 0x0102)
|
else if (m_PluginInfo.Version >= 0x0102)
|
||||||
{
|
{
|
||||||
//Get Function from DLL
|
//Get Function from DLL
|
||||||
void(__cdecl *InitiateControllers_1_2)(CONTROL_INFO * ControlInfo);
|
void(CALL *InitiateControllers_1_2)(CONTROL_INFO * ControlInfo);
|
||||||
InitiateControllers_1_2 = (void(__cdecl *)(CONTROL_INFO *))GetProcAddress((HMODULE)m_hDll, "InitiateControllers");
|
_LoadFunction("InitiateControllers",InitiateControllers_1_2);
|
||||||
if (InitiateControllers_1_2 == NULL) { return false; }
|
if (InitiateControllers_1_2 == NULL) { return false; }
|
||||||
|
|
||||||
InitiateControllers_1_2(&ControlInfo);
|
InitiateControllers_1_2(&ControlInfo);
|
||||||
m_Initialized = true;
|
m_Initialized = true;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
//jabo had a bug so I call CreateThread so his dllmain gets called again
|
//jabo had a bug so I call CreateThread so his dllmain gets called again
|
||||||
DWORD ThreadID;
|
pjutil::DynLibCallDllMain();
|
||||||
HANDLE hthread = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)DummyFunction, NULL, 0, &ThreadID);
|
#endif
|
||||||
CloseHandle(hthread);
|
|
||||||
|
|
||||||
return m_Initialized;
|
return m_Initialized;
|
||||||
}
|
}
|
||||||
|
@ -178,7 +177,7 @@ void CControl_Plugin::SetControl(CControl_Plugin const * const Plugin)
|
||||||
}
|
}
|
||||||
|
|
||||||
CCONTROL::CCONTROL(int32_t &Present, int32_t &RawData, int32_t &PlugType) :
|
CCONTROL::CCONTROL(int32_t &Present, int32_t &RawData, int32_t &PlugType) :
|
||||||
m_Present(Present), m_RawData(RawData), m_PlugType(PlugType)
|
m_Present(Present), m_RawData(RawData), m_PlugType(PlugType)
|
||||||
{
|
{
|
||||||
m_Buttons.Value = 0;
|
m_Buttons.Value = 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
* *
|
* *
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
#pragma once
|
#pragma once
|
||||||
#include "PluginBase.h"
|
#include <Project64-core/Plugins/PluginBase.h>
|
||||||
|
|
||||||
#pragma warning(push)
|
#pragma warning(push)
|
||||||
#pragma warning(disable : 4201) // warning C4201: nonstandard extension used : nameless struct/union
|
#pragma warning(disable : 4201) // warning C4201: nonstandard extension used : nameless struct/union
|
||||||
|
|
|
@ -14,25 +14,24 @@
|
||||||
#include <Project64-core/N64System/Mips/MemoryVirtualMem.h>
|
#include <Project64-core/N64System/Mips/MemoryVirtualMem.h>
|
||||||
#include <Project64-core/N64System/Mips/RegisterClass.h>
|
#include <Project64-core/N64System/Mips/RegisterClass.h>
|
||||||
#include "GFXPlugin.h"
|
#include "GFXPlugin.h"
|
||||||
#include <Windows.h>
|
|
||||||
|
|
||||||
CGfxPlugin::CGfxPlugin() :
|
CGfxPlugin::CGfxPlugin() :
|
||||||
CaptureScreen(NULL),
|
CaptureScreen(NULL),
|
||||||
ChangeWindow(NULL),
|
ChangeWindow(NULL),
|
||||||
DrawScreen(NULL),
|
DrawScreen(NULL),
|
||||||
DrawStatus(NULL),
|
DrawStatus(NULL),
|
||||||
MoveScreen(NULL),
|
MoveScreen(NULL),
|
||||||
ProcessDList(NULL),
|
ProcessDList(NULL),
|
||||||
ProcessRDPList(NULL),
|
ProcessRDPList(NULL),
|
||||||
ShowCFB(NULL),
|
ShowCFB(NULL),
|
||||||
UpdateScreen(NULL),
|
UpdateScreen(NULL),
|
||||||
ViStatusChanged(NULL),
|
ViStatusChanged(NULL),
|
||||||
ViWidthChanged(NULL),
|
ViWidthChanged(NULL),
|
||||||
SoftReset(NULL),
|
SoftReset(NULL),
|
||||||
GetRomBrowserMenu(NULL),
|
GetRomBrowserMenu(NULL),
|
||||||
OnRomBrowserMenuItem(NULL),
|
OnRomBrowserMenuItem(NULL),
|
||||||
GetDebugInfo(NULL),
|
GetDebugInfo(NULL),
|
||||||
InitiateDebugger(NULL)
|
InitiateDebugger(NULL)
|
||||||
{
|
{
|
||||||
memset(&m_GFXDebug, 0, sizeof(m_GFXDebug));
|
memset(&m_GFXDebug, 0, sizeof(m_GFXDebug));
|
||||||
}
|
}
|
||||||
|
@ -46,7 +45,7 @@ CGfxPlugin::~CGfxPlugin()
|
||||||
bool CGfxPlugin::LoadFunctions(void)
|
bool CGfxPlugin::LoadFunctions(void)
|
||||||
{
|
{
|
||||||
// Find entries for functions in DLL
|
// Find entries for functions in DLL
|
||||||
int32_t(__cdecl *InitiateGFX) (void * Gfx_Info);
|
int32_t(CALL *InitiateGFX) (void * Gfx_Info);
|
||||||
LoadFunction(InitiateGFX);
|
LoadFunction(InitiateGFX);
|
||||||
LoadFunction(ChangeWindow);
|
LoadFunction(ChangeWindow);
|
||||||
LoadFunction(DrawScreen);
|
LoadFunction(DrawScreen);
|
||||||
|
@ -94,8 +93,9 @@ bool CGfxPlugin::LoadFunctions(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (GetDebugInfo != NULL)
|
if (GetDebugInfo != NULL)
|
||||||
|
{
|
||||||
GetDebugInfo(&m_GFXDebug);
|
GetDebugInfo(&m_GFXDebug);
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -108,8 +108,8 @@ bool CGfxPlugin::Initiate(CN64System * System, RenderWindow * Window)
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
HWND hWnd; /* Render window */
|
void * hWnd; /* Render window */
|
||||||
HWND hStatusBar; /* if render window does not have a status bar then this is NULL */
|
void * hStatusBar; /* if render window does not have a status bar then this is NULL */
|
||||||
|
|
||||||
int32_t MemoryBswaped; // If this is set to TRUE, then the memory has been pre
|
int32_t MemoryBswaped; // If this is set to TRUE, then the memory has been pre
|
||||||
// bswap on a dword (32 bits) boundry
|
// bswap on a dword (32 bits) boundry
|
||||||
|
@ -148,19 +148,19 @@ bool CGfxPlugin::Initiate(CN64System * System, RenderWindow * Window)
|
||||||
uint32_t * VI__X_SCALE_REG;
|
uint32_t * VI__X_SCALE_REG;
|
||||||
uint32_t * VI__Y_SCALE_REG;
|
uint32_t * VI__Y_SCALE_REG;
|
||||||
|
|
||||||
void(__cdecl *CheckInterrupts)(void);
|
void(CALL *CheckInterrupts)(void);
|
||||||
} GFX_INFO;
|
} GFX_INFO;
|
||||||
|
|
||||||
//Get Function from DLL
|
//Get Function from DLL
|
||||||
int32_t(__cdecl *InitiateGFX)(GFX_INFO Gfx_Info);
|
int32_t(CALL *InitiateGFX)(GFX_INFO Gfx_Info);
|
||||||
InitiateGFX = (int32_t(__cdecl *)(GFX_INFO))GetProcAddress((HMODULE)m_hDll, "InitiateGFX");
|
_LoadFunction("InitiateGFX",InitiateGFX);
|
||||||
if (InitiateGFX == NULL) { return false; }
|
if (InitiateGFX == NULL) { return false; }
|
||||||
|
|
||||||
GFX_INFO Info = { 0 };
|
GFX_INFO Info = { 0 };
|
||||||
|
|
||||||
Info.MemoryBswaped = TRUE;
|
Info.MemoryBswaped = true;
|
||||||
Info.hWnd = (HWND)Window->GetWindowHandle();
|
Info.hWnd = Window->GetWindowHandle();
|
||||||
Info.hStatusBar = (HWND)Window->GetStatusBar();
|
Info.hStatusBar = Window->GetStatusBar();
|
||||||
Info.CheckInterrupts = DummyCheckInterrupts;
|
Info.CheckInterrupts = DummyCheckInterrupts;
|
||||||
|
|
||||||
// We are initializing the plugin before any rom is loaded so we do not have any correct
|
// We are initializing the plugin before any rom is loaded so we do not have any correct
|
||||||
|
@ -224,20 +224,20 @@ bool CGfxPlugin::Initiate(CN64System * System, RenderWindow * Window)
|
||||||
|
|
||||||
m_Initialized = InitiateGFX(Info) != 0;
|
m_Initialized = InitiateGFX(Info) != 0;
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
//jabo had a bug so I call CreateThread so his dllmain gets called again
|
//jabo had a bug so I call CreateThread so his dllmain gets called again
|
||||||
DWORD ThreadID;
|
pjutil::DynLibCallDllMain();
|
||||||
HANDLE hthread = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)DummyFunction, NULL, 0, &ThreadID);
|
#endif
|
||||||
CloseHandle(hthread);
|
|
||||||
|
|
||||||
return m_Initialized;
|
return m_Initialized;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CGfxPlugin::UnloadPluginDetails(void)
|
void CGfxPlugin::UnloadPluginDetails(void)
|
||||||
{
|
{
|
||||||
if (m_hDll != NULL)
|
if (m_LibHandle != NULL)
|
||||||
{
|
{
|
||||||
FreeLibrary((HMODULE)m_hDll);
|
pjutil::DynLibClose(m_LibHandle);
|
||||||
m_hDll = NULL;
|
m_LibHandle = NULL;
|
||||||
}
|
}
|
||||||
memset(&m_GFXDebug, 0, sizeof(m_GFXDebug));
|
memset(&m_GFXDebug, 0, sizeof(m_GFXDebug));
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
* *
|
* *
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
#pragma once
|
#pragma once
|
||||||
#include "PluginBase.h"
|
#include <Project64-core/Plugins/PluginBase.h>
|
||||||
|
|
||||||
class CGfxPlugin : public CPlugin
|
class CGfxPlugin : public CPlugin
|
||||||
{
|
{
|
||||||
|
|
|
@ -9,22 +9,21 @@
|
||||||
* *
|
* *
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include "PluginBase.h"
|
#include <Project64-core/Plugins/PluginBase.h>
|
||||||
#include <Windows.h>
|
|
||||||
|
|
||||||
CPlugin::CPlugin() :
|
CPlugin::CPlugin() :
|
||||||
DllAbout(NULL),
|
DllAbout(NULL),
|
||||||
DllConfig(NULL),
|
DllConfig(NULL),
|
||||||
CloseDLL(NULL),
|
CloseDLL(NULL),
|
||||||
RomOpen(NULL),
|
RomOpen(NULL),
|
||||||
RomClosed(NULL),
|
RomClosed(NULL),
|
||||||
PluginOpened(NULL),
|
PluginOpened(NULL),
|
||||||
SetSettingInfo(NULL),
|
SetSettingInfo(NULL),
|
||||||
SetSettingInfo2(NULL),
|
SetSettingInfo2(NULL),
|
||||||
SetSettingInfo3(NULL),
|
SetSettingInfo3(NULL),
|
||||||
m_hDll(NULL),
|
m_LibHandle(NULL),
|
||||||
m_Initialized(false),
|
m_Initialized(false),
|
||||||
m_RomOpen(false)
|
m_RomOpen(false)
|
||||||
{
|
{
|
||||||
memset(&m_PluginInfo, 0, sizeof(m_PluginInfo));
|
memset(&m_PluginInfo, 0, sizeof(m_PluginInfo));
|
||||||
}
|
}
|
||||||
|
@ -37,31 +36,21 @@ CPlugin::~CPlugin()
|
||||||
bool CPlugin::Load(const char * FileName)
|
bool CPlugin::Load(const char * FileName)
|
||||||
{
|
{
|
||||||
// Already loaded, so unload first.
|
// Already loaded, so unload first.
|
||||||
if (m_hDll != NULL)
|
if (m_LibHandle != NULL)
|
||||||
{
|
{
|
||||||
UnloadPlugin();
|
UnloadPlugin();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Try to load the plugin DLL
|
// Try to load the plugin DLL
|
||||||
//Try to load the DLL library
|
//Try to load the DLL library
|
||||||
if (bHaveDebugger())
|
m_LibHandle = pjutil::DynLibOpen(FileName, bHaveDebugger());
|
||||||
{
|
if (m_LibHandle == NULL)
|
||||||
m_hDll = LoadLibrary(FileName);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
UINT LastErrorMode = SetErrorMode(SEM_FAILCRITICALERRORS);
|
|
||||||
m_hDll = LoadLibrary(FileName);
|
|
||||||
SetErrorMode(LastErrorMode);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (m_hDll == NULL)
|
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get DLL information
|
// Get DLL information
|
||||||
void(__cdecl *GetDllInfo) (PLUGIN_INFO * PluginInfo);
|
void(CALL *GetDllInfo) (PLUGIN_INFO * PluginInfo);
|
||||||
LoadFunction(GetDllInfo);
|
LoadFunction(GetDllInfo);
|
||||||
if (GetDllInfo == NULL) { return false; }
|
if (GetDllInfo == NULL) { return false; }
|
||||||
|
|
||||||
|
@ -69,14 +58,14 @@ bool CPlugin::Load(const char * FileName)
|
||||||
if (!ValidPluginVersion(m_PluginInfo)) { return false; }
|
if (!ValidPluginVersion(m_PluginInfo)) { return false; }
|
||||||
if (m_PluginInfo.Type != type()) { return false; }
|
if (m_PluginInfo.Type != type()) { return false; }
|
||||||
|
|
||||||
CloseDLL = (void(__cdecl *)(void)) GetProcAddress((HMODULE)m_hDll, "CloseDLL");
|
LoadFunction(CloseDLL);
|
||||||
RomOpen = (void(__cdecl *)(void)) GetProcAddress((HMODULE)m_hDll, "RomOpen");
|
LoadFunction(RomOpen);
|
||||||
RomClosed = (void(__cdecl *)(void)) GetProcAddress((HMODULE)m_hDll, "RomClosed");
|
LoadFunction(RomClosed);
|
||||||
PluginOpened = (void(__cdecl *)(void)) GetProcAddress((HMODULE)m_hDll, "PluginLoaded");
|
_LoadFunction("PluginLoaded", PluginOpened);
|
||||||
DllConfig = (void(__cdecl *)(void *)) GetProcAddress((HMODULE)m_hDll, "DllConfig");
|
LoadFunction(DllConfig);
|
||||||
DllAbout = (void(__cdecl *)(void *)) GetProcAddress((HMODULE)m_hDll, "DllAbout");
|
LoadFunction(DllAbout);
|
||||||
|
|
||||||
SetSettingInfo3 = (void(__cdecl *)(PLUGIN_SETTINGS3 *))GetProcAddress((HMODULE)m_hDll, "SetSettingInfo3");
|
LoadFunction(SetSettingInfo3);
|
||||||
if (SetSettingInfo3)
|
if (SetSettingInfo3)
|
||||||
{
|
{
|
||||||
PLUGIN_SETTINGS3 info;
|
PLUGIN_SETTINGS3 info;
|
||||||
|
@ -84,7 +73,7 @@ bool CPlugin::Load(const char * FileName)
|
||||||
SetSettingInfo3(&info);
|
SetSettingInfo3(&info);
|
||||||
}
|
}
|
||||||
|
|
||||||
SetSettingInfo2 = (void(__cdecl *)(PLUGIN_SETTINGS2 *))GetProcAddress((HMODULE)m_hDll, "SetSettingInfo2");
|
LoadFunction(SetSettingInfo2);
|
||||||
if (SetSettingInfo2)
|
if (SetSettingInfo2)
|
||||||
{
|
{
|
||||||
PLUGIN_SETTINGS2 info;
|
PLUGIN_SETTINGS2 info;
|
||||||
|
@ -92,7 +81,7 @@ bool CPlugin::Load(const char * FileName)
|
||||||
SetSettingInfo2(&info);
|
SetSettingInfo2(&info);
|
||||||
}
|
}
|
||||||
|
|
||||||
SetSettingInfo = (void(__cdecl *)(PLUGIN_SETTINGS *))GetProcAddress((HMODULE)m_hDll, "SetSettingInfo");
|
LoadFunction(SetSettingInfo);
|
||||||
if (SetSettingInfo)
|
if (SetSettingInfo)
|
||||||
{
|
{
|
||||||
PLUGIN_SETTINGS info;
|
PLUGIN_SETTINGS info;
|
||||||
|
@ -114,7 +103,9 @@ bool CPlugin::Load(const char * FileName)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (RomClosed == NULL)
|
if (RomClosed == NULL)
|
||||||
|
{
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
if (!LoadFunctions())
|
if (!LoadFunctions())
|
||||||
{
|
{
|
||||||
|
@ -150,7 +141,9 @@ void CPlugin::RomOpened()
|
||||||
void CPlugin::RomClose()
|
void CPlugin::RomClose()
|
||||||
{
|
{
|
||||||
if (!m_RomOpen)
|
if (!m_RomOpen)
|
||||||
|
{
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
WriteTrace(PluginTraceType(), TraceDebug, "Before Rom Close");
|
WriteTrace(PluginTraceType(), TraceDebug, "Before Rom Close");
|
||||||
RomClosed();
|
RomClosed();
|
||||||
|
@ -186,11 +179,11 @@ void CPlugin::UnloadPlugin()
|
||||||
{
|
{
|
||||||
WriteTrace(PluginTraceType(), TraceDebug, "(%s): unloading", PluginType());
|
WriteTrace(PluginTraceType(), TraceDebug, "(%s): unloading", PluginType());
|
||||||
memset(&m_PluginInfo, 0, sizeof(m_PluginInfo));
|
memset(&m_PluginInfo, 0, sizeof(m_PluginInfo));
|
||||||
if (m_hDll != NULL)
|
if (m_LibHandle != NULL)
|
||||||
{
|
{
|
||||||
UnloadPluginDetails();
|
UnloadPluginDetails();
|
||||||
FreeLibrary((HMODULE)m_hDll);
|
pjutil::DynLibClose(m_LibHandle);
|
||||||
m_hDll = NULL;
|
m_LibHandle = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
DllAbout = NULL;
|
DllAbout = NULL;
|
||||||
|
@ -256,5 +249,5 @@ bool CPlugin::ValidPluginVersion(PLUGIN_INFO & PluginInfo)
|
||||||
if (PluginInfo.Version == 0x0102) { return true; }
|
if (PluginInfo.Version == 0x0102) { return true; }
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return FALSE;
|
return false;
|
||||||
}
|
}
|
|
@ -12,7 +12,8 @@
|
||||||
|
|
||||||
#include <Project64-core/Settings/DebugSettings.h>
|
#include <Project64-core/Settings/DebugSettings.h>
|
||||||
#include <Project64-core/TraceModulesProject64.h>
|
#include <Project64-core/TraceModulesProject64.h>
|
||||||
#include "PluginClass.h"
|
#include <Project64-core/Plugins/PluginClass.h>
|
||||||
|
#include <Common/Util.h>
|
||||||
|
|
||||||
#if defined(_WIN32)
|
#if defined(_WIN32)
|
||||||
#define CALL __cdecl
|
#define CALL __cdecl
|
||||||
|
@ -60,17 +61,18 @@ protected:
|
||||||
void(CALL *SetSettingInfo2) (PLUGIN_SETTINGS2 *);
|
void(CALL *SetSettingInfo2) (PLUGIN_SETTINGS2 *);
|
||||||
void(CALL *SetSettingInfo3) (PLUGIN_SETTINGS3 *);
|
void(CALL *SetSettingInfo3) (PLUGIN_SETTINGS3 *);
|
||||||
|
|
||||||
void * m_hDll;
|
pjutil::DynLibHandle m_LibHandle;
|
||||||
bool m_Initialized, m_RomOpen;
|
bool m_Initialized, m_RomOpen;
|
||||||
PLUGIN_INFO m_PluginInfo;
|
PLUGIN_INFO m_PluginInfo;
|
||||||
|
|
||||||
// Loads a function pointer from the currently loaded DLL
|
// Loads a function pointer from the currently loaded DLL
|
||||||
template <typename T>
|
void _LoadFunctionVoid(const char * szFunctionName, void ** functionPointer)
|
||||||
void _LoadFunction(const char * szFunctionName, T & functionPointer) {
|
{
|
||||||
functionPointer = (T)GetProcAddress((HMODULE)m_hDll, szFunctionName);
|
*functionPointer = pjutil::DynLibGetProc(m_LibHandle, szFunctionName);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Simple wrapper around _LoadFunction() to avoid having to specify the same two arguments
|
// Simple wrapper around _LoadFunction() to avoid having to specify the same two arguments
|
||||||
// i.e. _LoadFunction("CloseDLL", CloseDLL);
|
// i.e. _LoadFunction("CloseDLL", CloseDLL);
|
||||||
#define LoadFunction(functionName) _LoadFunction(#functionName, functionName)
|
#define LoadFunction(functionName) _LoadFunctionVoid(#functionName, (void **)&functionName)
|
||||||
|
#define _LoadFunction(functionName,function) _LoadFunctionVoid(functionName, (void **)&function)
|
||||||
};
|
};
|
||||||
|
|
|
@ -11,17 +11,17 @@
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include <Project64-core/N64System/SystemGlobals.h>
|
#include <Project64-core/N64System/SystemGlobals.h>
|
||||||
#include <Project64-core/N64System/N64Class.h>
|
#include <Project64-core/N64System/N64Class.h>
|
||||||
|
#include <Project64-core/Plugins/PluginClass.h>
|
||||||
#include <Common/path.h>
|
#include <Common/path.h>
|
||||||
#include "PluginClass.h"
|
|
||||||
|
|
||||||
CPlugins::CPlugins(const stdstr & PluginDir) :
|
CPlugins::CPlugins(const stdstr & PluginDir) :
|
||||||
m_MainWindow(NULL),
|
m_MainWindow(NULL),
|
||||||
m_SyncWindow(NULL),
|
m_SyncWindow(NULL),
|
||||||
m_PluginDir(PluginDir),
|
m_PluginDir(PluginDir),
|
||||||
m_Gfx(NULL),
|
m_Gfx(NULL),
|
||||||
m_Audio(NULL),
|
m_Audio(NULL),
|
||||||
m_RSP(NULL),
|
m_RSP(NULL),
|
||||||
m_Control(NULL)
|
m_Control(NULL)
|
||||||
{
|
{
|
||||||
CreatePlugins();
|
CreatePlugins();
|
||||||
g_Settings->RegisterChangeCB(Plugin_RSP_Current, this, (CSettings::SettingChangedFunc)PluginChanged);
|
g_Settings->RegisterChangeCB(Plugin_RSP_Current, this, (CSettings::SettingChangedFunc)PluginChanged);
|
||||||
|
|
|
@ -90,6 +90,7 @@ __interface RenderWindow
|
||||||
virtual bool ResetPluginsInUiThread(CPlugins * plugins, CN64System * System) = 0;
|
virtual bool ResetPluginsInUiThread(CPlugins * plugins, CN64System * System) = 0;
|
||||||
virtual void * GetWindowHandle(void) const = 0;
|
virtual void * GetWindowHandle(void) const = 0;
|
||||||
virtual void * GetStatusBar(void) const = 0;
|
virtual void * GetStatusBar(void) const = 0;
|
||||||
|
virtual void * GetModuleInstance(void) const = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
class CPlugins :
|
class CPlugins :
|
||||||
|
|
|
@ -14,17 +14,16 @@
|
||||||
#include <Project64-core/N64System/Mips/RegisterClass.h>
|
#include <Project64-core/N64System/Mips/RegisterClass.h>
|
||||||
#include "RSPPlugin.h"
|
#include "RSPPlugin.h"
|
||||||
#include "GFXPlugin.h"
|
#include "GFXPlugin.h"
|
||||||
#include "AudioPlugin.h"
|
#include <Project64-core/Plugins/AudioPlugin.h>
|
||||||
#include <Windows.h>
|
|
||||||
|
|
||||||
void DummyFunc1(int a) { a += 1; }
|
void DummyFunc1(int a) { a += 1; }
|
||||||
|
|
||||||
CRSP_Plugin::CRSP_Plugin(void) :
|
CRSP_Plugin::CRSP_Plugin(void) :
|
||||||
DoRspCycles(NULL),
|
DoRspCycles(NULL),
|
||||||
EnableDebugging(NULL),
|
EnableDebugging(NULL),
|
||||||
m_CycleCount(0),
|
m_CycleCount(0),
|
||||||
GetDebugInfo(NULL),
|
GetDebugInfo(NULL),
|
||||||
InitiateDebugger(NULL)
|
InitiateDebugger(NULL)
|
||||||
{
|
{
|
||||||
memset(&m_RSPDebug, 0, sizeof(m_RSPDebug));
|
memset(&m_RSPDebug, 0, sizeof(m_RSPDebug));
|
||||||
}
|
}
|
||||||
|
@ -38,7 +37,7 @@ CRSP_Plugin::~CRSP_Plugin()
|
||||||
bool CRSP_Plugin::LoadFunctions(void)
|
bool CRSP_Plugin::LoadFunctions(void)
|
||||||
{
|
{
|
||||||
// Find entries for functions in DLL
|
// Find entries for functions in DLL
|
||||||
void(__cdecl *InitiateRSP)(void);
|
void(CALL *InitiateRSP)(void);
|
||||||
LoadFunction(InitiateRSP);
|
LoadFunction(InitiateRSP);
|
||||||
LoadFunction(DoRspCycles);
|
LoadFunction(DoRspCycles);
|
||||||
_LoadFunction("GetRspDebugInfo", GetDebugInfo);
|
_LoadFunction("GetRspDebugInfo", GetDebugInfo);
|
||||||
|
@ -59,8 +58,9 @@ bool CRSP_Plugin::LoadFunctions(void)
|
||||||
|
|
||||||
// Get debug info if able
|
// Get debug info if able
|
||||||
if (GetDebugInfo != NULL)
|
if (GetDebugInfo != NULL)
|
||||||
|
{
|
||||||
GetDebugInfo(&m_RSPDebug);
|
GetDebugInfo(&m_RSPDebug);
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -73,7 +73,7 @@ bool CRSP_Plugin::Initiate(CPlugins * Plugins, CN64System * System)
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
HINSTANCE hInst;
|
void * hInst;
|
||||||
int MemoryBswaped; /* If this is set to TRUE, then the memory has been pre
|
int MemoryBswaped; /* If this is set to TRUE, then the memory has been pre
|
||||||
bswap on a dword (32 bits) boundry */
|
bswap on a dword (32 bits) boundry */
|
||||||
uint8_t * RDRAM;
|
uint8_t * RDRAM;
|
||||||
|
@ -101,21 +101,21 @@ bool CRSP_Plugin::Initiate(CPlugins * Plugins, CN64System * System)
|
||||||
uint32_t * DPC__PIPEBUSY_REG;
|
uint32_t * DPC__PIPEBUSY_REG;
|
||||||
uint32_t * DPC__TMEM_REG;
|
uint32_t * DPC__TMEM_REG;
|
||||||
|
|
||||||
void(__cdecl *CheckInterrupts)(void);
|
void(CALL *CheckInterrupts)(void);
|
||||||
void(__cdecl *ProcessDlist)(void);
|
void(CALL *ProcessDlist)(void);
|
||||||
void(__cdecl *ProcessAlist)(void);
|
void(CALL *ProcessAlist)(void);
|
||||||
void(__cdecl *ProcessRdpList)(void);
|
void(CALL *ProcessRdpList)(void);
|
||||||
void(__cdecl *ShowCFB)(void);
|
void(CALL *ShowCFB)(void);
|
||||||
} RSP_INFO_1_1;
|
} RSP_INFO_1_1;
|
||||||
|
|
||||||
RSP_INFO_1_1 Info = { 0 };
|
RSP_INFO_1_1 Info = { 0 };
|
||||||
|
|
||||||
Info.hInst = GetModuleHandle(NULL);
|
Info.hInst = Plugins->MainWindow()->GetModuleInstance();
|
||||||
Info.CheckInterrupts = DummyCheckInterrupts;
|
Info.CheckInterrupts = DummyCheckInterrupts;
|
||||||
Info.MemoryBswaped = (System == NULL); // only true when the system's not yet loaded
|
Info.MemoryBswaped = (System == NULL); // only true when the system's not yet loaded
|
||||||
|
|
||||||
//Get Function from DLL
|
//Get Function from DLL
|
||||||
void(__cdecl *InitiateRSP) (RSP_INFO_1_1 Audio_Info, uint32_t * Cycles);
|
void(CALL *InitiateRSP) (RSP_INFO_1_1 Audio_Info, uint32_t * Cycles);
|
||||||
LoadFunction(InitiateRSP);
|
LoadFunction(InitiateRSP);
|
||||||
if (InitiateRSP == NULL) { return false; }
|
if (InitiateRSP == NULL) { return false; }
|
||||||
|
|
||||||
|
@ -193,10 +193,10 @@ bool CRSP_Plugin::Initiate(CPlugins * Plugins, CN64System * System)
|
||||||
InitiateRSP(Info, &m_CycleCount);
|
InitiateRSP(Info, &m_CycleCount);
|
||||||
m_Initialized = true;
|
m_Initialized = true;
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
//jabo had a bug so I call CreateThread so his dllmain gets called again
|
//jabo had a bug so I call CreateThread so his dllmain gets called again
|
||||||
DWORD ThreadID;
|
pjutil::DynLibCallDllMain();
|
||||||
HANDLE hthread = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)DummyFunction, NULL, 0, &ThreadID);
|
#endif
|
||||||
CloseHandle(hthread);
|
|
||||||
return m_Initialized;
|
return m_Initialized;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
* *
|
* *
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
#pragma once
|
#pragma once
|
||||||
#include "PluginBase.h"
|
#include <Project64-core/Plugins/PluginBase.h>
|
||||||
|
|
||||||
class CRSP_Plugin : public CPlugin
|
class CRSP_Plugin : public CPlugin
|
||||||
{
|
{
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
#include "../stdafx.h"
|
|
@ -46,6 +46,7 @@
|
||||||
<ClCompile Include="N64System\Interpreter\InterpreterOps.cpp" />
|
<ClCompile Include="N64System\Interpreter\InterpreterOps.cpp" />
|
||||||
<ClCompile Include="N64System\Interpreter\InterpreterOps32.cpp" />
|
<ClCompile Include="N64System\Interpreter\InterpreterOps32.cpp" />
|
||||||
<ClCompile Include="N64System\Mips\Audio.cpp" />
|
<ClCompile Include="N64System\Mips\Audio.cpp" />
|
||||||
|
<ClCompile Include="N64System\Mips\Disk.cpp" />
|
||||||
<ClCompile Include="N64System\Mips\Dma.cpp" />
|
<ClCompile Include="N64System\Mips\Dma.cpp" />
|
||||||
<ClCompile Include="N64System\Mips\Eeprom.cpp" />
|
<ClCompile Include="N64System\Mips\Eeprom.cpp" />
|
||||||
<ClCompile Include="N64System\Mips\FlashRam.cpp" />
|
<ClCompile Include="N64System\Mips\FlashRam.cpp" />
|
||||||
|
@ -129,6 +130,7 @@
|
||||||
<ClInclude Include="N64System\Interpreter\InterpreterOps32.h" />
|
<ClInclude Include="N64System\Interpreter\InterpreterOps32.h" />
|
||||||
<ClInclude Include="N64System\Interpreter\InterpreterOps.h" />
|
<ClInclude Include="N64System\Interpreter\InterpreterOps.h" />
|
||||||
<ClInclude Include="N64System\Mips\Audio.h" />
|
<ClInclude Include="N64System\Mips\Audio.h" />
|
||||||
|
<ClInclude Include="N64System\Mips\Disk.h" />
|
||||||
<ClInclude Include="N64System\Mips\Dma.h" />
|
<ClInclude Include="N64System\Mips\Dma.h" />
|
||||||
<ClInclude Include="N64System\Mips\Eeprom.h" />
|
<ClInclude Include="N64System\Mips\Eeprom.h" />
|
||||||
<ClInclude Include="N64System\Mips\FlashRam.h" />
|
<ClInclude Include="N64System\Mips\FlashRam.h" />
|
||||||
|
|
|
@ -294,6 +294,9 @@
|
||||||
<ClCompile Include="MemoryExceptionFilter.cpp">
|
<ClCompile Include="MemoryExceptionFilter.cpp">
|
||||||
<Filter>Source Files\N64 System</Filter>
|
<Filter>Source Files\N64 System</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="N64System\Mips\Disk.cpp">
|
||||||
|
<Filter>Source Files\N64 System\Mips</Filter>
|
||||||
|
</ClCompile>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClInclude Include="stdafx.h">
|
<ClInclude Include="stdafx.h">
|
||||||
|
@ -572,5 +575,8 @@
|
||||||
<ClInclude Include="ExceptionHandler.h">
|
<ClInclude Include="ExceptionHandler.h">
|
||||||
<Filter>Header Files</Filter>
|
<Filter>Header Files</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
<ClInclude Include="N64System\Mips\Disk.h">
|
||||||
|
<Filter>Header Files\N64 System\Mips</Filter>
|
||||||
|
</ClInclude>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
</Project>
|
</Project>
|
|
@ -60,6 +60,13 @@ CSettingTypeApplication::~CSettingTypeApplication()
|
||||||
|
|
||||||
void CSettingTypeApplication::Initialize( const char * /*AppName*/ )
|
void CSettingTypeApplication::Initialize( const char * /*AppName*/ )
|
||||||
{
|
{
|
||||||
|
CPath BaseDir(g_Settings->LoadStringVal(Cmd_BaseDirectory).c_str(),"");
|
||||||
|
if (!BaseDir.DirectoryExists())
|
||||||
|
{
|
||||||
|
printf("BaseDir does not exists, doing nothing");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
stdstr SettingsFile, OrigSettingsFile;
|
stdstr SettingsFile, OrigSettingsFile;
|
||||||
|
|
||||||
for (int i = 0; i < 100; i++)
|
for (int i = 0; i < 100; i++)
|
||||||
|
@ -77,7 +84,11 @@ void CSettingTypeApplication::Initialize( const char * /*AppName*/ )
|
||||||
{
|
{
|
||||||
delete m_SettingsIniFile;
|
delete m_SettingsIniFile;
|
||||||
}
|
}
|
||||||
|
#ifdef _WIN32
|
||||||
CPath SettingsDir(CPath(SettingsFile).GetDriveDirectory(),"");
|
CPath SettingsDir(CPath(SettingsFile).GetDriveDirectory(),"");
|
||||||
|
#else
|
||||||
|
CPath SettingsDir(CPath(SettingsFile).GetDirectory(), "");
|
||||||
|
#endif
|
||||||
if (!SettingsDir.DirectoryExists())
|
if (!SettingsDir.DirectoryExists())
|
||||||
{
|
{
|
||||||
SettingsDir.DirectoryCreate();
|
SettingsDir.DirectoryCreate();
|
||||||
|
@ -123,7 +134,9 @@ bool CSettingTypeApplication::Load ( int /*Index*/, bool & Value ) const
|
||||||
if (m_DefaultSetting == Default_Constant)
|
if (m_DefaultSetting == Default_Constant)
|
||||||
{
|
{
|
||||||
Value = m_DefaultValue != 0;
|
Value = m_DefaultValue != 0;
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
g_Settings->LoadBool(m_DefaultSetting,Value);
|
g_Settings->LoadBool(m_DefaultSetting,Value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -138,7 +151,9 @@ bool CSettingTypeApplication::Load ( int /*Index*/, uint32_t & Value ) const
|
||||||
if (m_DefaultSetting == Default_Constant)
|
if (m_DefaultSetting == Default_Constant)
|
||||||
{
|
{
|
||||||
Value = m_DefaultValue;
|
Value = m_DefaultValue;
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
g_Settings->LoadDword(m_DefaultSetting,Value);
|
g_Settings->LoadDword(m_DefaultSetting,Value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -168,20 +183,24 @@ void CSettingTypeApplication::LoadDefault ( int /*Index*/, bool & Value ) cons
|
||||||
if (m_DefaultSetting == Default_Constant)
|
if (m_DefaultSetting == Default_Constant)
|
||||||
{
|
{
|
||||||
Value = m_DefaultValue != 0;
|
Value = m_DefaultValue != 0;
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
g_Settings->LoadBool(m_DefaultSetting,Value);
|
g_Settings->LoadBool(m_DefaultSetting,Value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeApplication::LoadDefault ( int /*Index*/, uint32_t & Value ) const
|
void CSettingTypeApplication::LoadDefault(int /*Index*/, uint32_t & Value) const
|
||||||
{
|
{
|
||||||
if (m_DefaultSetting != Default_None)
|
if (m_DefaultSetting != Default_None)
|
||||||
{
|
{
|
||||||
if (m_DefaultSetting == Default_Constant)
|
if (m_DefaultSetting == Default_Constant)
|
||||||
{
|
{
|
||||||
Value = m_DefaultValue;
|
Value = m_DefaultValue;
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
g_Settings->LoadDword(m_DefaultSetting,Value);
|
g_Settings->LoadDword(m_DefaultSetting,Value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -194,7 +213,9 @@ void CSettingTypeApplication::LoadDefault ( int /*Index*/, stdstr & Value ) cons
|
||||||
if (m_DefaultSetting == Default_Constant)
|
if (m_DefaultSetting == Default_Constant)
|
||||||
{
|
{
|
||||||
Value = m_DefaultStr;
|
Value = m_DefaultStr;
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
g_Settings->LoadStringVal(m_DefaultSetting,Value);
|
g_Settings->LoadStringVal(m_DefaultSetting,Value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <Common/IniFileClass.h>
|
#include <Common/IniFileClass.h>
|
||||||
#include "SettingsType-Base.h"
|
#include <Project64-core/Settings/SettingType/SettingsType-Base.h>
|
||||||
|
|
||||||
class CSettingTypeApplication :
|
class CSettingTypeApplication :
|
||||||
public CSettingType
|
public CSettingType
|
||||||
|
|
|
@ -26,6 +26,7 @@ CSettingTypeApplicationPath::~CSettingTypeApplicationPath()
|
||||||
bool CSettingTypeApplicationPath::Load ( int Index, stdstr & Value ) const
|
bool CSettingTypeApplicationPath::Load ( int Index, stdstr & Value ) const
|
||||||
{
|
{
|
||||||
bool bRes = CSettingTypeApplication::Load(Index,Value);
|
bool bRes = CSettingTypeApplication::Load(Index,Value);
|
||||||
|
#ifdef WIN32
|
||||||
if (bRes)
|
if (bRes)
|
||||||
{
|
{
|
||||||
if (Value.substr(0,2) == ".\\" || Value.substr(0,2) == "./" ||
|
if (Value.substr(0,2) == ".\\" || Value.substr(0,2) == "./" ||
|
||||||
|
@ -38,5 +39,6 @@ bool CSettingTypeApplicationPath::Load ( int Index, stdstr & Value ) const
|
||||||
Value = (const std::string &)FullFilePath;
|
Value = (const std::string &)FullFilePath;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
return bRes;
|
return bRes;
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,9 +10,11 @@
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "../Settings.h"
|
#include <Project64-core/Settings/Settings.h>
|
||||||
|
#include <Common/StdString.h>
|
||||||
|
|
||||||
enum SettingType {
|
enum SettingType
|
||||||
|
{
|
||||||
SettingType_Unknown = -1,
|
SettingType_Unknown = -1,
|
||||||
SettingType_ConstString = 0,
|
SettingType_ConstString = 0,
|
||||||
SettingType_ConstValue = 1,
|
SettingType_ConstValue = 1,
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "SettingsType-Base.h"
|
#include <Project64-core/Settings/SettingType/SettingsType-Base.h>
|
||||||
#include <Common/IniFileClass.h>
|
#include <Common/IniFileClass.h>
|
||||||
|
|
||||||
class CSettingTypeCheats :
|
class CSettingTypeCheats :
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include "SettingsType-RomDatabase.h"
|
#include "SettingsType-RomDatabase.h"
|
||||||
#include "SettingsType-RDBCpuType.h"
|
#include "SettingsType-RDBCpuType.h"
|
||||||
#include "../../N64System/N64Types.h"
|
#include <Project64-core/N64System/N64Types.h>
|
||||||
|
|
||||||
CSettingTypeRDBCpuType::CSettingTypeRDBCpuType(const char * Name, SettingID DefaultSetting ) :
|
CSettingTypeRDBCpuType::CSettingTypeRDBCpuType(const char * Name, SettingID DefaultSetting ) :
|
||||||
CSettingTypeRomDatabase(Name,DefaultSetting)
|
CSettingTypeRomDatabase(Name,DefaultSetting)
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include "SettingsType-RomDatabase.h"
|
#include "SettingsType-RomDatabase.h"
|
||||||
#include "SettingsType-RDBSaveChip.h"
|
#include "SettingsType-RDBSaveChip.h"
|
||||||
#include "../../N64System/N64Types.h"
|
#include <Project64-core/N64System/N64Types.h>
|
||||||
|
|
||||||
CSettingTypeRDBSaveChip::CSettingTypeRDBSaveChip(const char * Name, SettingID DefaultSetting ) :
|
CSettingTypeRDBSaveChip::CSettingTypeRDBSaveChip(const char * Name, SettingID DefaultSetting ) :
|
||||||
CSettingTypeRomDatabase(Name,DefaultSetting)
|
CSettingTypeRomDatabase(Name,DefaultSetting)
|
||||||
|
|
|
@ -11,59 +11,79 @@
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include "SettingsType-RelativePath.h"
|
#include "SettingsType-RelativePath.h"
|
||||||
|
|
||||||
CSettingTypeRelativePath::CSettingTypeRelativePath(const char * Path, const char * FileName)
|
CSettingTypeRelativePath::CSettingTypeRelativePath(const char * Directory, const char * FileName) :
|
||||||
|
m_Directory(Directory),
|
||||||
|
m_FileName(FileName)
|
||||||
{
|
{
|
||||||
m_FileName = CPath(CPath::MODULE_DIRECTORY,FileName);
|
BuildPath();
|
||||||
m_FileName.AppendDirectory(Path);
|
g_Settings->RegisterChangeCB(Cmd_BaseDirectory, this, RefreshSettings);
|
||||||
}
|
}
|
||||||
|
|
||||||
CSettingTypeRelativePath::~CSettingTypeRelativePath ( void )
|
CSettingTypeRelativePath::~CSettingTypeRelativePath(void)
|
||||||
{
|
{
|
||||||
|
g_Settings->UnregisterChangeCB(Cmd_BaseDirectory, this, RefreshSettings);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CSettingTypeRelativePath::Load ( int /*Index*/, stdstr & value ) const
|
bool CSettingTypeRelativePath::Load(int /*Index*/, stdstr & value) const
|
||||||
{
|
{
|
||||||
value = (const char *)m_FileName;
|
value = m_FullPath;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
//return the default values
|
//return the default values
|
||||||
void CSettingTypeRelativePath::LoadDefault ( int /*Index*/, bool & /*Value*/ ) const
|
void CSettingTypeRelativePath::LoadDefault(int /*Index*/, bool & /*Value*/) const
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeRelativePath::LoadDefault ( int /*Index*/, uint32_t & /*Value*/ ) const
|
void CSettingTypeRelativePath::LoadDefault(int /*Index*/, uint32_t & /*Value*/) const
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeRelativePath::LoadDefault ( int /*Index*/, stdstr & /*Value*/ ) const
|
void CSettingTypeRelativePath::LoadDefault(int /*Index*/, stdstr & /*Value*/) const
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeRelativePath::Save ( int /*Index*/, bool /*Value*/ )
|
void CSettingTypeRelativePath::Save(int /*Index*/, bool /*Value*/)
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeRelativePath::Save ( int /*Index*/, uint32_t /*Value*/ )
|
void CSettingTypeRelativePath::Save(int /*Index*/, uint32_t /*Value*/)
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeRelativePath::Save ( int /*Index*/, const stdstr & Value )
|
void CSettingTypeRelativePath::Save(int /*Index*/, const stdstr & Value)
|
||||||
{
|
{
|
||||||
m_FileName = CPath(CPath::MODULE_DIRECTORY,Value.c_str());
|
m_Directory = "";
|
||||||
|
m_FileName = Value;
|
||||||
|
BuildPath();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeRelativePath::Save ( int /*Index*/, const char * Value )
|
void CSettingTypeRelativePath::Save(int /*Index*/, const char * Value)
|
||||||
{
|
{
|
||||||
m_FileName = CPath(CPath::MODULE_DIRECTORY,Value);
|
m_Directory = "";
|
||||||
|
m_FileName = Value;
|
||||||
|
BuildPath();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeRelativePath::Delete ( int /*Index*/ )
|
void CSettingTypeRelativePath::Delete(int /*Index*/)
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__, __LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CSettingTypeRelativePath::BuildPath(void)
|
||||||
|
{
|
||||||
|
CPath FullPath(g_Settings->LoadStringVal(Cmd_BaseDirectory).c_str(),"");
|
||||||
|
FullPath.AppendDirectory(m_Directory.c_str());
|
||||||
|
FullPath.SetNameExtension(m_FileName.c_str());
|
||||||
|
m_FullPath = (const char *)FullPath;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CSettingTypeRelativePath::RefreshSettings(void * _this)
|
||||||
|
{
|
||||||
|
((CSettingTypeRelativePath *)_this)->BuildPath();
|
||||||
|
}
|
||||||
|
|
|
@ -10,15 +10,13 @@
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
#pragma once
|
#pragma once
|
||||||
#include <Common/path.h>
|
#include <Common/path.h>
|
||||||
#include "SettingsType-Base.h"
|
#include <Project64-core/Settings/SettingType/SettingsType-Base.h>
|
||||||
|
|
||||||
class CSettingTypeRelativePath :
|
class CSettingTypeRelativePath :
|
||||||
public CSettingType
|
public CSettingType
|
||||||
{
|
{
|
||||||
CPath m_FileName;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
CSettingTypeRelativePath(const char * Path, const char * FileName);
|
CSettingTypeRelativePath(const char * Directory, const char * FileName);
|
||||||
~CSettingTypeRelativePath();
|
~CSettingTypeRelativePath();
|
||||||
|
|
||||||
bool IndexBasedSetting ( void ) const { return false; }
|
bool IndexBasedSetting ( void ) const { return false; }
|
||||||
|
@ -47,4 +45,11 @@ private:
|
||||||
CSettingTypeRelativePath(void); // Disable default constructor
|
CSettingTypeRelativePath(void); // Disable default constructor
|
||||||
CSettingTypeRelativePath(const CSettingTypeRelativePath&); // Disable copy constructor
|
CSettingTypeRelativePath(const CSettingTypeRelativePath&); // Disable copy constructor
|
||||||
CSettingTypeRelativePath& operator=(const CSettingTypeRelativePath&); // Disable assignment
|
CSettingTypeRelativePath& operator=(const CSettingTypeRelativePath&); // Disable assignment
|
||||||
|
|
||||||
|
static void RefreshSettings(void * _this);
|
||||||
|
void BuildPath ( void );
|
||||||
|
|
||||||
|
std::string m_FullPath;
|
||||||
|
std::string m_Directory;
|
||||||
|
std::string m_FileName;
|
||||||
};
|
};
|
||||||
|
|
|
@ -65,12 +65,14 @@ void CSettingTypeRomDatabase::Initialize( void )
|
||||||
m_GlideIniFile = new CIniFile(g_Settings->LoadStringVal(SupportFile_Glide64RDB).c_str());
|
m_GlideIniFile = new CIniFile(g_Settings->LoadStringVal(SupportFile_Glide64RDB).c_str());
|
||||||
|
|
||||||
g_Settings->RegisterChangeCB(Game_IniKey,NULL,GameChanged);
|
g_Settings->RegisterChangeCB(Game_IniKey,NULL,GameChanged);
|
||||||
|
g_Settings->RegisterChangeCB(Cmd_BaseDirectory,NULL,BaseDirChanged);
|
||||||
|
|
||||||
m_SectionIdent = new stdstr(g_Settings->LoadStringVal(Game_IniKey));
|
m_SectionIdent = new stdstr(g_Settings->LoadStringVal(Game_IniKey));
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeRomDatabase::CleanUp( void )
|
void CSettingTypeRomDatabase::CleanUp( void )
|
||||||
{
|
{
|
||||||
|
g_Settings->UnregisterChangeCB(Cmd_BaseDirectory,NULL,BaseDirChanged);
|
||||||
g_Settings->UnregisterChangeCB(Game_IniKey,NULL,GameChanged);
|
g_Settings->UnregisterChangeCB(Game_IniKey,NULL,GameChanged);
|
||||||
if (m_SettingsIniFile)
|
if (m_SettingsIniFile)
|
||||||
{
|
{
|
||||||
|
@ -89,6 +91,22 @@ void CSettingTypeRomDatabase::CleanUp( void )
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CSettingTypeRomDatabase::BaseDirChanged ( void * /*Data */ )
|
||||||
|
{
|
||||||
|
if (m_SettingsIniFile)
|
||||||
|
{
|
||||||
|
delete m_SettingsIniFile;
|
||||||
|
m_SettingsIniFile = NULL;
|
||||||
|
}
|
||||||
|
if (m_GlideIniFile)
|
||||||
|
{
|
||||||
|
delete m_GlideIniFile;
|
||||||
|
m_GlideIniFile = NULL;
|
||||||
|
}
|
||||||
|
m_SettingsIniFile = new CIniFile(g_Settings->LoadStringVal(SupportFile_RomDatabase).c_str());
|
||||||
|
m_GlideIniFile = new CIniFile(g_Settings->LoadStringVal(SupportFile_Glide64RDB).c_str());
|
||||||
|
}
|
||||||
|
|
||||||
void CSettingTypeRomDatabase::GameChanged ( void * /*Data */ )
|
void CSettingTypeRomDatabase::GameChanged ( void * /*Data */ )
|
||||||
{
|
{
|
||||||
if (m_SectionIdent)
|
if (m_SectionIdent)
|
||||||
|
@ -195,7 +213,7 @@ void CSettingTypeRomDatabase::Save ( int /*Index*/, bool Value )
|
||||||
}
|
}
|
||||||
if (m_DeleteOnDefault)
|
if (m_DeleteOnDefault)
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
if (m_GlideSetting)
|
if (m_GlideSetting)
|
||||||
{
|
{
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <Common/IniFileClass.h>
|
#include <Common/IniFileClass.h>
|
||||||
#include "SettingsType-Base.h"
|
#include <Project64-core/Settings/SettingType/SettingsType-Base.h>
|
||||||
|
|
||||||
class CSettingTypeRomDatabase :
|
class CSettingTypeRomDatabase :
|
||||||
public CSettingType
|
public CSettingType
|
||||||
|
@ -51,6 +51,7 @@ public:
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
static void GameChanged ( void * /*Data */ );
|
static void GameChanged ( void * /*Data */ );
|
||||||
|
static void BaseDirChanged ( void * /*Data */ );
|
||||||
|
|
||||||
static bool IsGlideSetting (const char * Name);
|
static bool IsGlideSetting (const char * Name);
|
||||||
static const char * StripNameSection (const char * Name);
|
static const char * StripNameSection (const char * Name);
|
||||||
|
|
|
@ -25,13 +25,13 @@ CSettingTypeSelectedDirectory::~CSettingTypeSelectedDirectory()
|
||||||
|
|
||||||
bool CSettingTypeSelectedDirectory::Load ( int /*Index*/, bool & /*Value*/ ) const
|
bool CSettingTypeSelectedDirectory::Load ( int /*Index*/, bool & /*Value*/ ) const
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CSettingTypeSelectedDirectory::Load ( int /*Index*/, uint32_t & /*Value*/ ) const
|
bool CSettingTypeSelectedDirectory::Load ( int /*Index*/, uint32_t & /*Value*/ ) const
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,33 +44,33 @@ bool CSettingTypeSelectedDirectory::Load ( int /*Index*/, stdstr & Value ) const
|
||||||
//return the default values
|
//return the default values
|
||||||
void CSettingTypeSelectedDirectory::LoadDefault ( int /*Index*/, bool & /*Value*/ ) const
|
void CSettingTypeSelectedDirectory::LoadDefault ( int /*Index*/, bool & /*Value*/ ) const
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeSelectedDirectory::LoadDefault ( int /*Index*/, uint32_t & /*Value*/ ) const
|
void CSettingTypeSelectedDirectory::LoadDefault ( int /*Index*/, uint32_t & /*Value*/ ) const
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeSelectedDirectory::LoadDefault ( int /*Index*/, stdstr & /*Value*/ ) const
|
void CSettingTypeSelectedDirectory::LoadDefault ( int /*Index*/, stdstr & /*Value*/ ) const
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
//Update the settings
|
//Update the settings
|
||||||
void CSettingTypeSelectedDirectory::Save ( int /*Index*/, bool /*Value*/ )
|
void CSettingTypeSelectedDirectory::Save ( int /*Index*/, bool /*Value*/ )
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeSelectedDirectory::Save ( int /*Index*/, uint32_t /*Value*/ )
|
void CSettingTypeSelectedDirectory::Save ( int /*Index*/, uint32_t /*Value*/ )
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeSelectedDirectory::Save ( int /*Index*/, const stdstr & /*Value*/ )
|
void CSettingTypeSelectedDirectory::Save ( int /*Index*/, const stdstr & /*Value*/ )
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSettingTypeSelectedDirectory::Save ( int /*Index*/, const char * Value )
|
void CSettingTypeSelectedDirectory::Save ( int /*Index*/, const char * Value )
|
||||||
|
@ -81,5 +81,5 @@ void CSettingTypeSelectedDirectory::Save ( int /*Index*/, const char * Value )
|
||||||
|
|
||||||
void CSettingTypeSelectedDirectory::Delete( int /*Index*/ )
|
void CSettingTypeSelectedDirectory::Delete( int /*Index*/ )
|
||||||
{
|
{
|
||||||
g_Notify->BreakPoint(__FILE__, __LINE__);
|
g_Notify->BreakPoint(__FILE__,__LINE__);
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "SettingsType-Base.h"
|
#include <Project64-core/Settings/SettingType/SettingsType-Base.h>
|
||||||
|
|
||||||
class CSettingTypeSelectedDirectory :
|
class CSettingTypeSelectedDirectory :
|
||||||
public CSettingType
|
public CSettingType
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "SettingsType-Base.h"
|
#include <Project64-core/Settings/SettingType/SettingsType-Base.h>
|
||||||
|
|
||||||
class CSettingTypeTempBool :
|
class CSettingTypeTempBool :
|
||||||
public CSettingType
|
public CSettingType
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "SettingsType-Base.h"
|
#include <Project64-core/Settings/SettingType/SettingsType-Base.h>
|
||||||
|
|
||||||
class CSettingTypeTempNumber :
|
class CSettingTypeTempNumber :
|
||||||
public CSettingType
|
public CSettingType
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "SettingsType-Base.h"
|
#include <Project64-core/Settings/SettingType/SettingsType-Base.h>
|
||||||
|
|
||||||
class CSettingTypeTempString :
|
class CSettingTypeTempString :
|
||||||
public CSettingType
|
public CSettingType
|
||||||
|
|
|
@ -67,6 +67,7 @@ enum SettingID
|
||||||
Setting_LanguageDir,
|
Setting_LanguageDir,
|
||||||
Setting_LanguageDirDefault,
|
Setting_LanguageDirDefault,
|
||||||
Setting_CurrentLanguage,
|
Setting_CurrentLanguage,
|
||||||
|
Setting_EnableDisk,
|
||||||
|
|
||||||
//RDB TLB Settings
|
//RDB TLB Settings
|
||||||
Rdb_GoodName,
|
Rdb_GoodName,
|
||||||
|
|
|
@ -132,6 +132,7 @@ void CSettings::AddHowToHandleSetting()
|
||||||
|
|
||||||
AddHandler(Setting_RememberCheats, new CSettingTypeApplication("", "Remember Cheats", (uint32_t)false));
|
AddHandler(Setting_RememberCheats, new CSettingTypeApplication("", "Remember Cheats", (uint32_t)false));
|
||||||
AddHandler(Setting_CurrentLanguage, new CSettingTypeApplication("", "Current Language", ""));
|
AddHandler(Setting_CurrentLanguage, new CSettingTypeApplication("", "Current Language", ""));
|
||||||
|
AddHandler(Setting_EnableDisk, new CSettingTypeApplication("", "Enable Disk", (uint32_t)false));
|
||||||
AddHandler(Setting_LanguageDirDefault, new CSettingTypeRelativePath("Lang", ""));
|
AddHandler(Setting_LanguageDirDefault, new CSettingTypeRelativePath("Lang", ""));
|
||||||
AddHandler(Setting_LanguageDir, new CSettingTypeApplicationPath("Directory", "Lang", Setting_LanguageDirDefault));
|
AddHandler(Setting_LanguageDir, new CSettingTypeApplicationPath("Directory", "Lang", Setting_LanguageDirDefault));
|
||||||
|
|
||||||
|
|
|
@ -54,7 +54,8 @@ void CPluginList::AddPluginFromDir(CPath Dir)
|
||||||
Dir.SetNameExtension("*.*");
|
Dir.SetNameExtension("*.*");
|
||||||
if (Dir.FindFirst(_A_SUBDIR))
|
if (Dir.FindFirst(_A_SUBDIR))
|
||||||
{
|
{
|
||||||
do {
|
do
|
||||||
|
{
|
||||||
AddPluginFromDir(Dir);
|
AddPluginFromDir(Dir);
|
||||||
} while (Dir.FindNext());
|
} while (Dir.FindNext());
|
||||||
Dir.UpDirectory();
|
Dir.UpDirectory();
|
||||||
|
@ -64,7 +65,8 @@ void CPluginList::AddPluginFromDir(CPath Dir)
|
||||||
if (Dir.FindFirst())
|
if (Dir.FindFirst())
|
||||||
{
|
{
|
||||||
HMODULE hLib = NULL;
|
HMODULE hLib = NULL;
|
||||||
do {
|
do
|
||||||
|
{
|
||||||
if (hLib)
|
if (hLib)
|
||||||
{
|
{
|
||||||
FreeLibrary(hLib);
|
FreeLibrary(hLib);
|
||||||
|
@ -83,8 +85,8 @@ void CPluginList::AddPluginFromDir(CPath Dir)
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
void(__cdecl *GetDllInfo) (PLUGIN_INFO * PluginInfo);
|
void(CALL *GetDllInfo) (PLUGIN_INFO * PluginInfo);
|
||||||
GetDllInfo = (void(__cdecl *)(PLUGIN_INFO *))GetProcAddress(hLib, "GetDllInfo");
|
GetDllInfo = (void(CALL *)(PLUGIN_INFO *))GetProcAddress(hLib, "GetDllInfo");
|
||||||
if (GetDllInfo == NULL)
|
if (GetDllInfo == NULL)
|
||||||
{
|
{
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -24,14 +24,14 @@ LRESULT CALLBACK MainGui_Proc(HWND WndHandle, DWORD uMsg, DWORD wParam, DWORD lP
|
||||||
extern BOOL set_about_field(HWND hDlg, int nIDDlgItem, const wchar_t * config_string, const wchar_t * language_string);
|
extern BOOL set_about_field(HWND hDlg, int nIDDlgItem, const wchar_t * config_string, const wchar_t * language_string);
|
||||||
|
|
||||||
CMainGui::CMainGui(bool bMainWindow, const char * WindowTitle) :
|
CMainGui::CMainGui(bool bMainWindow, const char * WindowTitle) :
|
||||||
CRomBrowser(m_hMainWindow, m_hStatusWnd),
|
CRomBrowser(m_hMainWindow, m_hStatusWnd),
|
||||||
m_ThreadId(GetCurrentThreadId()),
|
m_ThreadId(GetCurrentThreadId()),
|
||||||
m_bMainWindow(bMainWindow),
|
m_bMainWindow(bMainWindow),
|
||||||
m_Created(false),
|
m_Created(false),
|
||||||
m_AttachingMenu(false),
|
m_AttachingMenu(false),
|
||||||
m_MakingVisible(false),
|
m_MakingVisible(false),
|
||||||
m_ResetPlugins(false),
|
m_ResetPlugins(false),
|
||||||
m_ResetInfo(NULL)
|
m_ResetInfo(NULL)
|
||||||
{
|
{
|
||||||
m_Menu = NULL;
|
m_Menu = NULL;
|
||||||
|
|
||||||
|
@ -273,6 +273,11 @@ void CMainGui::ChangeWinSize(long width, long height)
|
||||||
MoveWindow(m_hMainWindow, wndpl.rcNormalPosition.left, wndpl.rcNormalPosition.top, rc1.right - rc1.left, rc1.bottom - rc1.top, TRUE);
|
MoveWindow(m_hMainWindow, wndpl.rcNormalPosition.left, wndpl.rcNormalPosition.top, rc1.right - rc1.left, rc1.bottom - rc1.top, TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void * CMainGui::GetModuleInstance(void) const
|
||||||
|
{
|
||||||
|
return GetModuleHandle(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
void CMainGui::AboutBox(void)
|
void CMainGui::AboutBox(void)
|
||||||
{
|
{
|
||||||
DialogBoxParamW(GetModuleHandle(NULL), MAKEINTRESOURCEW(IDD_About), m_hMainWindow, (DLGPROC)AboutBoxProc, (LPARAM)this);
|
DialogBoxParamW(GetModuleHandle(NULL), MAKEINTRESOURCEW(IDD_About), m_hMainWindow, (DLGPROC)AboutBoxProc, (LPARAM)this);
|
||||||
|
|
|
@ -89,6 +89,7 @@ public:
|
||||||
//Get Window Handle
|
//Get Window Handle
|
||||||
void * GetWindowHandle(void) const { return m_hMainWindow; }
|
void * GetWindowHandle(void) const { return m_hMainWindow; }
|
||||||
void * GetStatusBar(void) const { return m_hStatusWnd; }
|
void * GetStatusBar(void) const { return m_hStatusWnd; }
|
||||||
|
void * GetModuleInstance(void) const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
CMainGui(void); // Disable default constructor
|
CMainGui(void); // Disable default constructor
|
||||||
|
|
|
@ -459,8 +459,7 @@ bool CRomBrowser::FillRomInfo(ROM_INFO * pRomInfo)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
char drive[_MAX_DRIVE], dir[_MAX_DIR], ext[_MAX_EXT];
|
strncpy(pRomInfo->FileName, CPath(pRomInfo->szFullFileName).GetNameExtension().c_str(), sizeof(pRomInfo->FileName) / sizeof(pRomInfo->FileName[0]));
|
||||||
_splitpath(pRomInfo->szFullFileName, drive, dir, pRomInfo->FileName, ext);
|
|
||||||
}
|
}
|
||||||
if (m_Fields[RB_InternalName].Pos() >= 0)
|
if (m_Fields[RB_InternalName].Pos() >= 0)
|
||||||
{
|
{
|
||||||
|
@ -1576,9 +1575,9 @@ void CRomBrowser::RomList_SortList(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* SaveRomList - save all the rom information about the current roms in the rom brower
|
* SaveRomList - save all the rom information about the current roms in the rom brower
|
||||||
* to a cache file, so it is quick to reload the information
|
* to a cache file, so it is quick to reload the information
|
||||||
*/
|
*/
|
||||||
void CRomBrowser::SaveRomList(strlist & FileList)
|
void CRomBrowser::SaveRomList(strlist & FileList)
|
||||||
{
|
{
|
||||||
MD5 ListHash = RomListHash(FileList);
|
MD5 ListHash = RomListHash(FileList);
|
||||||
|
|
|
@ -126,8 +126,8 @@ void CGamePluginPage::ShowAboutButton(int id)
|
||||||
}
|
}
|
||||||
|
|
||||||
//Get DLL about
|
//Get DLL about
|
||||||
void(__cdecl *DllAbout) (HWND hWnd);
|
void(CALL *DllAbout) (HWND hWnd);
|
||||||
DllAbout = (void(__cdecl *)(HWND))GetProcAddress(hLib, "DllAbout");
|
DllAbout = (void(CALL *)(HWND))GetProcAddress(hLib, "DllAbout");
|
||||||
|
|
||||||
//call the function from the dll
|
//call the function from the dll
|
||||||
DllAbout(m_hWnd);
|
DllAbout(m_hWnd);
|
||||||
|
|
|
@ -118,8 +118,8 @@ void COptionPluginPage::ShowAboutButton(int id)
|
||||||
}
|
}
|
||||||
|
|
||||||
//Get DLL about
|
//Get DLL about
|
||||||
void(__cdecl *DllAbout) (HWND hWnd);
|
void(CALL *DllAbout) (HWND hWnd);
|
||||||
DllAbout = (void(__cdecl *)(HWND))GetProcAddress(hLib, "DllAbout");
|
DllAbout = (void(CALL *)(HWND))GetProcAddress(hLib, "DllAbout");
|
||||||
|
|
||||||
//call the function from the dll
|
//call the function from the dll
|
||||||
DllAbout(m_hWnd);
|
DllAbout(m_hWnd);
|
||||||
|
|
Loading…
Reference in New Issue