[Glide64] Make ucode an enum
This commit is contained in:
parent
f15a154cd4
commit
431c7b625d
|
@ -8135,8 +8135,7 @@ static void cc__t0_inter_t1_using_primlod__mul_shade()
|
||||||
cc_t0_mul_shade();
|
cc_t0_mul_shade();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
//*/
|
if (g_settings->ucode() == CSettings::ucode_PerfectDark)
|
||||||
if (g_settings->ucode == 7)
|
|
||||||
lod_frac = rdp.prim_lodfrac;
|
lod_frac = rdp.prim_lodfrac;
|
||||||
CCMB(GR_COMBINE_FUNCTION_SCALE_OTHER,
|
CCMB(GR_COMBINE_FUNCTION_SCALE_OTHER,
|
||||||
GR_COMBINE_FACTOR_LOCAL,
|
GR_COMBINE_FACTOR_LOCAL,
|
||||||
|
|
|
@ -1249,7 +1249,7 @@ void CALL RomOpen(void)
|
||||||
WriteTrace(TraceGlide64, TraceDebug, "-");
|
WriteTrace(TraceGlide64, TraceDebug, "-");
|
||||||
no_dlist = true;
|
no_dlist = true;
|
||||||
g_romopen = TRUE;
|
g_romopen = TRUE;
|
||||||
ucode_error_report = TRUE; // allowed to report ucode errors
|
g_ucode_error_report = TRUE; // allowed to report ucode errors
|
||||||
rdp_reset();
|
rdp_reset();
|
||||||
|
|
||||||
// Get the country code & translate to NTSC(0) or PAL(1)
|
// Get the country code & translate to NTSC(0) or PAL(1)
|
||||||
|
@ -1697,7 +1697,7 @@ void newSwapBuffers()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (g_settings->wireframe || g_settings->buff_clear || (g_settings->hacks(CSettings::hack_PPL) && g_settings->ucode == 6))
|
if (g_settings->wireframe || g_settings->buff_clear || (g_settings->hacks(CSettings::hack_PPL) && g_settings->ucode() == CSettings::ucode_S2DEX))
|
||||||
{
|
{
|
||||||
grDepthMask((g_settings->hacks(CSettings::hack_RE2) && g_settings->fb_depth_render_enabled()) ? FXFALSE : FXTRUE);
|
grDepthMask((g_settings->hacks(CSettings::hack_RE2) && g_settings->fb_depth_render_enabled()) ? FXFALSE : FXTRUE);
|
||||||
grBufferClear(0, 0, 0xFFFF);
|
grBufferClear(0, 0, 0xFFFF);
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
#include <Common/StdString.h>
|
||||||
#include "Gfx_1.3.h"
|
#include "Gfx_1.3.h"
|
||||||
#include "SettingsID.h"
|
#include "SettingsID.h"
|
||||||
|
|
||||||
|
@ -51,7 +52,7 @@ ghq_cache_size(0),
|
||||||
ghq_hirs_let_texartists_fly(0),
|
ghq_hirs_let_texartists_fly(0),
|
||||||
ghq_hirs_dump(0),
|
ghq_hirs_dump(0),
|
||||||
autodetect_ucode(0),
|
autodetect_ucode(0),
|
||||||
ucode(0),
|
m_ucode(ucode_Fast3D),
|
||||||
unk_as_red(0),
|
unk_as_red(0),
|
||||||
unk_clear(0),
|
unk_clear(0),
|
||||||
wireframe(0),
|
wireframe(0),
|
||||||
|
@ -123,7 +124,7 @@ void CSettings::RegisterSettings(void)
|
||||||
general_setting(Set_Rotate, "rotate", Rotate_None);
|
general_setting(Set_Rotate, "rotate", Rotate_None);
|
||||||
general_setting(Set_wrpAnisotropic, "wrpAnisotropic", 0);
|
general_setting(Set_wrpAnisotropic, "wrpAnisotropic", 0);
|
||||||
general_setting(Set_autodetect_ucode, "autodetect_ucode", 1);
|
general_setting(Set_autodetect_ucode, "autodetect_ucode", 1);
|
||||||
general_setting(Set_ucode, "ucode", 2);
|
general_setting(Set_ucode, "ucode", ucode_F3DEX2);
|
||||||
general_setting(Set_wireframe, "wireframe", 0);
|
general_setting(Set_wireframe, "wireframe", 0);
|
||||||
general_setting(Set_wfmode, "wfmode", 1);
|
general_setting(Set_wfmode, "wfmode", 1);
|
||||||
general_setting(Set_unk_as_red, "unk_as_red", 0);
|
general_setting(Set_unk_as_red, "unk_as_red", 0);
|
||||||
|
@ -271,6 +272,26 @@ void CSettings::UpdateFrameBufferBits(uint32_t BitsToAdd, uint32_t BitsToRemove)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CSettings::ucode_t CSettings::DetectUCode(uint32_t uc_crc)
|
||||||
|
{
|
||||||
|
RegisterSetting(Set_ucodeLookup, Data_DWORD_RDB_Setting, stdstr_f("%08lx", uc_crc).c_str(), "ucode", (unsigned int)-2, NULL);
|
||||||
|
CSettings::ucode_t uc = (CSettings::ucode_t)GetSetting(Set_ucodeLookup);
|
||||||
|
if (uc == CSettings::uCode_NotFound || uc == CSettings::uCode_Unsupported)
|
||||||
|
{
|
||||||
|
m_ucode = (CSettings::ucode_t)GetSetting(Set_ucode);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_ucode = uc;
|
||||||
|
}
|
||||||
|
return uc;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CSettings::SetUcode(ucode_t value)
|
||||||
|
{
|
||||||
|
m_ucode = value;
|
||||||
|
}
|
||||||
|
|
||||||
void CSettings::UpdateAspectRatio(void)
|
void CSettings::UpdateAspectRatio(void)
|
||||||
{
|
{
|
||||||
switch (m_aspectmode)
|
switch (m_aspectmode)
|
||||||
|
@ -325,19 +346,18 @@ void CSettings::ReadSettings()
|
||||||
|
|
||||||
#ifndef _ENDUSER_RELEASE_
|
#ifndef _ENDUSER_RELEASE_
|
||||||
this->autodetect_ucode = GetSetting(Set_autodetect_ucode);
|
this->autodetect_ucode = GetSetting(Set_autodetect_ucode);
|
||||||
this->ucode = GetSetting(Set_ucode);
|
|
||||||
this->wireframe = GetSetting(Set_wireframe);
|
this->wireframe = GetSetting(Set_wireframe);
|
||||||
this->wfmode = GetSetting(Set_wfmode);
|
this->wfmode = GetSetting(Set_wfmode);
|
||||||
this->unk_as_red = GetSetting(Set_unk_as_red);
|
this->unk_as_red = GetSetting(Set_unk_as_red);
|
||||||
this->unk_clear = GetSetting(Set_unk_clear);
|
this->unk_clear = GetSetting(Set_unk_clear);
|
||||||
#else
|
#else
|
||||||
this->autodetect_ucode = TRUE;
|
this->autodetect_ucode = TRUE;
|
||||||
this->ucode = 2;
|
|
||||||
this->wireframe = FALSE;
|
this->wireframe = FALSE;
|
||||||
this->wfmode = 0;
|
this->wfmode = 0;
|
||||||
this->unk_as_red = FALSE;
|
this->unk_as_red = FALSE;
|
||||||
this->unk_clear = FALSE;
|
this->unk_clear = FALSE;
|
||||||
#endif
|
#endif
|
||||||
|
m_ucode = ucode_F3DEX2;
|
||||||
|
|
||||||
char texture_dir[260];
|
char texture_dir[260];
|
||||||
memset(texture_dir, 0, sizeof(texture_dir));
|
memset(texture_dir, 0, sizeof(texture_dir));
|
||||||
|
|
|
@ -127,6 +127,23 @@ public:
|
||||||
STIPPLE_Rotate = 0x2,
|
STIPPLE_Rotate = 0x2,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum ucode_t
|
||||||
|
{
|
||||||
|
uCode_NotFound = -2,
|
||||||
|
uCode_Unsupported = -1,
|
||||||
|
ucode_Fast3D = 0,
|
||||||
|
ucode_F3DEX = 1,
|
||||||
|
ucode_F3DEX2 = 2,
|
||||||
|
ucode_WaveRace = 3,
|
||||||
|
ucode_StarWars = 4,
|
||||||
|
ucode_DiddyKong = 5,
|
||||||
|
ucode_S2DEX = 6,
|
||||||
|
ucode_PerfectDark = 7,
|
||||||
|
ucode_CBFD = 8,
|
||||||
|
ucode_zSort = 9,
|
||||||
|
ucode_Turbo3d = 21,
|
||||||
|
};
|
||||||
|
|
||||||
uint32_t res_x, scr_res_x;
|
uint32_t res_x, scr_res_x;
|
||||||
uint32_t res_y, scr_res_y;
|
uint32_t res_y, scr_res_y;
|
||||||
#ifndef ANDROID
|
#ifndef ANDROID
|
||||||
|
@ -200,7 +217,7 @@ public:
|
||||||
|
|
||||||
//Debug
|
//Debug
|
||||||
int autodetect_ucode;
|
int autodetect_ucode;
|
||||||
int ucode;
|
inline ucode_t ucode(void) const { return m_ucode; }
|
||||||
int unk_as_red;
|
int unk_as_red;
|
||||||
int unk_clear;
|
int unk_clear;
|
||||||
int wireframe;
|
int wireframe;
|
||||||
|
@ -246,6 +263,8 @@ public:
|
||||||
void SetGhqFltr(TextureFilter_t value);
|
void SetGhqFltr(TextureFilter_t value);
|
||||||
void SetGhqEnht(TextureEnhancement_t value);
|
void SetGhqEnht(TextureEnhancement_t value);
|
||||||
void UpdateFrameBufferBits(uint32_t BitsToAdd, uint32_t BitsToRemove);
|
void UpdateFrameBufferBits(uint32_t BitsToAdd, uint32_t BitsToRemove);
|
||||||
|
ucode_t DetectUCode(uint32_t uc_crc);
|
||||||
|
void SetUcode(ucode_t value);
|
||||||
|
|
||||||
void ReadGameSettings(const char * name);
|
void ReadGameSettings(const char * name);
|
||||||
void WriteSettings(void);
|
void WriteSettings(void);
|
||||||
|
@ -267,6 +286,7 @@ private:
|
||||||
PixelLevelOfDetail_t m_lodmode;
|
PixelLevelOfDetail_t m_lodmode;
|
||||||
TextureFilter_t m_ghq_fltr;
|
TextureFilter_t m_ghq_fltr;
|
||||||
TextureEnhancement_t m_ghq_enht;
|
TextureEnhancement_t m_ghq_enht;
|
||||||
|
ucode_t m_ucode;
|
||||||
StippleMode_t m_stipple_mode;
|
StippleMode_t m_stipple_mode;
|
||||||
hacks_t m_hacks;
|
hacks_t m_hacks;
|
||||||
};
|
};
|
||||||
|
|
|
@ -1799,7 +1799,7 @@ void update()
|
||||||
grDepthBufferFunction(g_settings->zmode_compare_less ? GR_CMP_LESS : GR_CMP_LEQUAL);
|
grDepthBufferFunction(g_settings->zmode_compare_less ? GR_CMP_LESS : GR_CMP_LEQUAL);
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
grDepthBiasLevel(g_settings->ucode == 7 ? -4 : 0);
|
grDepthBiasLevel(g_settings->ucode() == CSettings::ucode_PerfectDark ? -4 : 0);
|
||||||
grDepthBufferFunction(GR_CMP_LESS);
|
grDepthBufferFunction(GR_CMP_LESS);
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
|
|
|
@ -148,7 +148,7 @@ char out_buf[2048];
|
||||||
|
|
||||||
uint32_t frame_count; // frame counter
|
uint32_t frame_count; // frame counter
|
||||||
|
|
||||||
int ucode_error_report = TRUE;
|
bool g_ucode_error_report = TRUE;
|
||||||
int wrong_tile = -1;
|
int wrong_tile = -1;
|
||||||
|
|
||||||
// ** RDP graphics functions **
|
// ** RDP graphics functions **
|
||||||
|
@ -222,7 +222,7 @@ void microcheck();
|
||||||
#include "turbo3D.h"
|
#include "turbo3D.h"
|
||||||
|
|
||||||
static int reset = 0;
|
static int reset = 0;
|
||||||
static int old_ucode = -1;
|
static CSettings::ucode_t g_old_ucode = CSettings::uCode_Unsupported;
|
||||||
|
|
||||||
void RDP::Reset()
|
void RDP::Reset()
|
||||||
{
|
{
|
||||||
|
@ -315,41 +315,36 @@ void microcheck()
|
||||||
ucf.close();
|
ucf.close();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
g_old_ucode = g_settings->ucode();
|
||||||
WriteTrace(TraceRDP, TraceDebug, "ucode = %08lx", uc_crc);
|
WriteTrace(TraceRDP, TraceDebug, "ucode = %08lx", uc_crc);
|
||||||
|
CSettings::ucode_t uc = g_settings->DetectUCode(uc_crc);
|
||||||
RegisterSetting(Set_ucodeLookup, Data_DWORD_RDB_Setting, stdstr_f("%08lx", uc_crc).c_str(), "ucode", (unsigned int)-2, NULL);
|
if (uc == CSettings::uCode_NotFound)
|
||||||
int uc = GetSetting(Set_ucodeLookup);
|
{
|
||||||
|
if (g_ucode_error_report)
|
||||||
if (uc == -2 && ucode_error_report)
|
|
||||||
{
|
{
|
||||||
g_settings->ucode = GetSetting(Set_ucode);
|
|
||||||
|
|
||||||
ReleaseGfx();
|
ReleaseGfx();
|
||||||
WriteTrace(TraceGlide64, TraceError, "uCode crc not found in INI, using currently selected uCode %08lx", (unsigned long)uc_crc);
|
WriteTrace(TraceGlide64, TraceError, "uCode crc not found in INI, using currently selected uCode %08lx", (unsigned long)uc_crc);
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
MessageBox(gfx.hWnd, stdstr_f("Error: uCode crc not found in INI, using currently selected uCode\n\n%08lx", uc_crc).c_str(), "Error", MB_OK | MB_ICONEXCLAMATION);
|
MessageBox(gfx.hWnd, stdstr_f("Error: uCode crc not found in INI, using currently selected uCode\n\n%08lx", uc_crc).c_str(), "Error", MB_OK | MB_ICONEXCLAMATION);
|
||||||
#endif
|
#endif
|
||||||
|
g_ucode_error_report = false; // don't report any more ucode errors from this game
|
||||||
ucode_error_report = FALSE; // don't report any more ucode errors from this game
|
|
||||||
}
|
}
|
||||||
else if (uc == -1 && ucode_error_report)
|
}
|
||||||
|
else if (uc == CSettings::uCode_Unsupported)
|
||||||
|
{
|
||||||
|
if (g_ucode_error_report)
|
||||||
{
|
{
|
||||||
g_settings->ucode = GetSetting(Set_ucode);
|
|
||||||
|
|
||||||
ReleaseGfx();
|
ReleaseGfx();
|
||||||
WriteTrace(TraceGlide64, TraceError, "Unsupported uCode! crc: %08lx", (unsigned long)uc_crc);
|
WriteTrace(TraceGlide64, TraceError, "Unsupported uCode! crc: %08lx", (unsigned long)uc_crc);
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
MessageBox(gfx.hWnd, stdstr_f("Error: Unsupported uCode!\n\ncrc: %08lx", uc_crc).c_str(), "Error", MB_OK | MB_ICONEXCLAMATION);
|
MessageBox(gfx.hWnd, stdstr_f("Error: Unsupported uCode!\n\ncrc: %08lx", uc_crc).c_str(), "Error", MB_OK | MB_ICONEXCLAMATION);
|
||||||
#endif
|
#endif
|
||||||
|
g_ucode_error_report = FALSE; // don't report any more ucode errors from this game
|
||||||
ucode_error_report = FALSE; // don't report any more ucode errors from this game
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
old_ucode = g_settings->ucode;
|
WriteTrace(TraceRDP, TraceDebug, "microcheck: old ucode: %d, new ucode: %d", g_old_ucode, uc);
|
||||||
g_settings->ucode = uc;
|
|
||||||
WriteTrace(TraceRDP, TraceDebug, "microcheck: old ucode: %d, new ucode: %d", old_ucode, uc);
|
|
||||||
if (uc_crc == 0x8d5735b2 || uc_crc == 0xb1821ed3 || uc_crc == 0x1118b3e0) //F3DLP.Rej ucode. perspective texture correction is not implemented
|
if (uc_crc == 0x8d5735b2 || uc_crc == 0xb1821ed3 || uc_crc == 0x1118b3e0) //F3DLP.Rej ucode. perspective texture correction is not implemented
|
||||||
{
|
{
|
||||||
rdp.Persp_en = 1;
|
rdp.Persp_en = 1;
|
||||||
|
@ -591,7 +586,7 @@ EXPORT void CALL ProcessDList(void)
|
||||||
else
|
else
|
||||||
memset(microcode, 0, 4096);
|
memset(microcode, 0, 4096);
|
||||||
}
|
}
|
||||||
else if (((old_ucode == ucode_S2DEX) && (g_settings->ucode == ucode_F3DEX)) || g_settings->force_microcheck)
|
else if ((g_old_ucode == CSettings::ucode_S2DEX && g_settings->ucode() == CSettings::ucode_F3DEX) || g_settings->force_microcheck)
|
||||||
{
|
{
|
||||||
uint32_t startUcode = *(uint32_t*)(gfx.DMEM + 0xFD0);
|
uint32_t startUcode = *(uint32_t*)(gfx.DMEM + 0xFD0);
|
||||||
memcpy(microcode, gfx.RDRAM + startUcode, 4096);
|
memcpy(microcode, gfx.RDRAM + startUcode, 4096);
|
||||||
|
@ -599,11 +594,15 @@ EXPORT void CALL ProcessDList(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (exception)
|
if (exception)
|
||||||
|
{
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// Switch to fullscreen?
|
// Switch to fullscreen?
|
||||||
if (to_fullscreen)
|
if (to_fullscreen)
|
||||||
|
{
|
||||||
GoToFullScreen();
|
GoToFullScreen();
|
||||||
|
}
|
||||||
|
|
||||||
//* Set states *//
|
//* Set states *//
|
||||||
if (g_settings->swapmode() != CSettings::SwapMode_Old)
|
if (g_settings->swapmode() != CSettings::SwapMode_Old)
|
||||||
|
@ -656,7 +655,7 @@ EXPORT void CALL ProcessDList(void)
|
||||||
// Get the start of the display list and the length of it
|
// Get the start of the display list and the length of it
|
||||||
uint32_t dlist_start = *(uint32_t*)(gfx.DMEM + 0xFF0);
|
uint32_t dlist_start = *(uint32_t*)(gfx.DMEM + 0xFF0);
|
||||||
uint32_t dlist_length = *(uint32_t*)(gfx.DMEM + 0xFF4);
|
uint32_t dlist_length = *(uint32_t*)(gfx.DMEM + 0xFF4);
|
||||||
WriteTrace(TraceRDP, TraceDebug, "--- NEW DLIST --- crc: %08lx, ucode: %d, fbuf: %08lx, fbuf_width: %d, dlist start: %08lx, dlist_length: %d, x_scale: %f, y_scale: %f", uc_crc, g_settings->ucode, *gfx.VI_ORIGIN_REG, *gfx.VI_WIDTH_REG, dlist_start, dlist_length, (*gfx.VI_X_SCALE_REG & 0xFFF) / 1024.0f, (*gfx.VI_Y_SCALE_REG & 0xFFF) / 1024.0f);
|
WriteTrace(TraceRDP, TraceDebug, "--- NEW DLIST --- crc: %08lx, ucode: %d, fbuf: %08lx, fbuf_width: %d, dlist start: %08lx, dlist_length: %d, x_scale: %f, y_scale: %f", uc_crc, g_settings->ucode(), *gfx.VI_ORIGIN_REG, *gfx.VI_WIDTH_REG, dlist_start, dlist_length, (*gfx.VI_X_SCALE_REG & 0xFFF) / 1024.0f, (*gfx.VI_Y_SCALE_REG & 0xFFF) / 1024.0f);
|
||||||
|
|
||||||
// Do nothing if dlist is empty
|
// Do nothing if dlist is empty
|
||||||
if (dlist_start == 0)
|
if (dlist_start == 0)
|
||||||
|
@ -682,14 +681,15 @@ EXPORT void CALL ProcessDList(void)
|
||||||
#ifdef CATCH_EXCEPTIONS
|
#ifdef CATCH_EXCEPTIONS
|
||||||
try {
|
try {
|
||||||
#endif
|
#endif
|
||||||
if (g_settings->ucode == ucode_Turbo3d)
|
if (g_settings->ucode() == CSettings::ucode_Turbo3d)
|
||||||
{
|
{
|
||||||
Turbo3D();
|
Turbo3D();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// MAIN PROCESSING LOOP
|
// MAIN PROCESSING LOOP
|
||||||
do {
|
do
|
||||||
|
{
|
||||||
// Get the address of the next command
|
// Get the address of the next command
|
||||||
a = rdp.pc[rdp.pc_i] & BMASK;
|
a = rdp.pc[rdp.pc_i] & BMASK;
|
||||||
|
|
||||||
|
@ -708,7 +708,7 @@ EXPORT void CALL ProcessDList(void)
|
||||||
perf_cur = CDateTime().SetToNow().Value();
|
perf_cur = CDateTime().SetToNow().Value();
|
||||||
#endif
|
#endif
|
||||||
// Process this instruction
|
// Process this instruction
|
||||||
gfx_instruction[g_settings->ucode][rdp.cmd0 >> 24]();
|
gfx_instruction[g_settings->ucode()][rdp.cmd0 >> 24]();
|
||||||
|
|
||||||
// check DL counter
|
// check DL counter
|
||||||
if (rdp.dl_count != -1)
|
if (rdp.dl_count != -1)
|
||||||
|
@ -928,7 +928,7 @@ static void rdp_texrect()
|
||||||
rdp.pc[rdp.pc_i] += 8;
|
rdp.pc[rdp.pc_i] += 8;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (g_settings->hacks(CSettings::hack_Yoshi) && g_settings->ucode == ucode_S2DEX)
|
if (g_settings->hacks(CSettings::hack_Yoshi) && g_settings->ucode() == CSettings::ucode_S2DEX)
|
||||||
{
|
{
|
||||||
ys_memrect();
|
ys_memrect();
|
||||||
return;
|
return;
|
||||||
|
@ -947,7 +947,7 @@ static void rdp_texrect()
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((g_settings->ucode == ucode_CBFD) && rdp.cur_image && rdp.cur_image->format)
|
if ((g_settings->ucode() == CSettings::ucode_CBFD) && rdp.cur_image && rdp.cur_image->format)
|
||||||
{
|
{
|
||||||
//WriteTrace(TraceRDP, TraceDebug, "Wrong Texrect. texaddr: %08lx, cimg: %08lx, cimg_end: %08lx", rdp.timg.addr, rdp.maincimg[1].addr, rdp.maincimg[1].addr+rdp.ci_width*rdp.ci_height*rdp.ci_size);
|
//WriteTrace(TraceRDP, TraceDebug, "Wrong Texrect. texaddr: %08lx, cimg: %08lx, cimg_end: %08lx", rdp.timg.addr, rdp.maincimg[1].addr, rdp.maincimg[1].addr+rdp.ci_width*rdp.ci_height*rdp.ci_size);
|
||||||
WriteTrace(TraceRDP, TraceDebug, "Shadow texrect is skipped.");
|
WriteTrace(TraceRDP, TraceDebug, "Shadow texrect is skipped.");
|
||||||
|
@ -955,7 +955,7 @@ static void rdp_texrect()
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((g_settings->ucode == ucode_PerfectDark) && rdp.ci_count > 0 && (rdp.frame_buffers[rdp.ci_count - 1].status == ci_zcopy))
|
if ((g_settings->ucode() == CSettings::ucode_PerfectDark) && rdp.ci_count > 0 && (rdp.frame_buffers[rdp.ci_count - 1].status == ci_zcopy))
|
||||||
{
|
{
|
||||||
pd_zcopy();
|
pd_zcopy();
|
||||||
WriteTrace(TraceRDP, TraceDebug, "Depth buffer copied.");
|
WriteTrace(TraceRDP, TraceDebug, "Depth buffer copied.");
|
||||||
|
@ -1059,7 +1059,7 @@ static void rdp_texrect()
|
||||||
//*/
|
//*/
|
||||||
//*
|
//*
|
||||||
//remove motion blur in night vision
|
//remove motion blur in night vision
|
||||||
if ((g_settings->ucode == ucode_PerfectDark) && (rdp.maincimg[1].addr != rdp.maincimg[0].addr) && (rdp.timg.addr >= rdp.maincimg[1].addr) && (rdp.timg.addr < (rdp.maincimg[1].addr + rdp.ci_width*rdp.ci_height*rdp.ci_size)))
|
if (g_settings->ucode() == CSettings::ucode_PerfectDark && (rdp.maincimg[1].addr != rdp.maincimg[0].addr) && (rdp.timg.addr >= rdp.maincimg[1].addr) && (rdp.timg.addr < (rdp.maincimg[1].addr + rdp.ci_width*rdp.ci_height*rdp.ci_size)))
|
||||||
{
|
{
|
||||||
if (g_settings->fb_emulation_enabled() && rdp.ci_count > 0 && rdp.frame_buffers[rdp.ci_count - 1].status == ci_copy_self)
|
if (g_settings->fb_emulation_enabled() && rdp.ci_count > 0 && rdp.frame_buffers[rdp.ci_count - 1].status == ci_copy_self)
|
||||||
{
|
{
|
||||||
|
@ -1072,12 +1072,12 @@ static void rdp_texrect()
|
||||||
|
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
uint32_t tile = (uint16_t)((rdp.cmd1 & 0x07000000) >> 24);
|
uint32_t tile_no = (uint16_t)((rdp.cmd1 & 0x07000000) >> 24);
|
||||||
|
|
||||||
rdp.texrecting = 1;
|
rdp.texrecting = 1;
|
||||||
|
|
||||||
uint32_t prev_tile = rdp.cur_tile;
|
uint32_t prev_tile = rdp.cur_tile;
|
||||||
rdp.cur_tile = tile;
|
rdp.cur_tile = tile_no;
|
||||||
|
|
||||||
const float Z = set_sprite_combine_mode();
|
const float Z = set_sprite_combine_mode();
|
||||||
|
|
||||||
|
@ -1112,7 +1112,7 @@ static void rdp_texrect()
|
||||||
float s_ul_y = ul_y * rdp.scale_y + rdp.offset_y;
|
float s_ul_y = ul_y * rdp.scale_y + rdp.offset_y;
|
||||||
float s_lr_y = lr_y * rdp.scale_y + rdp.offset_y;
|
float s_lr_y = lr_y * rdp.scale_y + rdp.offset_y;
|
||||||
|
|
||||||
WriteTrace(TraceRDP, TraceDebug, "texrect (%.2f, %.2f, %.2f, %.2f), tile: %d, #%d, #%d", ul_x, ul_y, lr_x, lr_y, tile, rdp.tri_n, rdp.tri_n + 1);
|
WriteTrace(TraceRDP, TraceDebug, "texrect (%.2f, %.2f, %.2f, %.2f), tile: %d, #%d, #%d", ul_x, ul_y, lr_x, lr_y, tile_no, rdp.tri_n, rdp.tri_n + 1);
|
||||||
WriteTrace(TraceRDP, TraceDebug, "(%f, %f) -> (%f, %f), s: (%d, %d) -> (%d, %d)", s_ul_x, s_ul_y, s_lr_x, s_lr_y, rdp.scissor.ul_x, rdp.scissor.ul_y, rdp.scissor.lr_x, rdp.scissor.lr_y);
|
WriteTrace(TraceRDP, TraceDebug, "(%f, %f) -> (%f, %f), s: (%d, %d) -> (%d, %d)", s_ul_x, s_ul_y, s_lr_x, s_lr_y, rdp.scissor.ul_x, rdp.scissor.ul_y, rdp.scissor.lr_x, rdp.scissor.lr_y);
|
||||||
WriteTrace(TraceRDP, TraceDebug, "\toff_x: %f, off_y: %f, dsdx: %f, dtdy: %f", off_x_i / 32.0f, off_y_i / 32.0f, dsdx, dtdy);
|
WriteTrace(TraceRDP, TraceDebug, "\toff_x: %f, off_y: %f, dsdx: %f, dtdy: %f", off_x_i / 32.0f, off_y_i / 32.0f, dsdx, dtdy);
|
||||||
|
|
||||||
|
@ -1528,17 +1528,17 @@ static void rdp_setothermode()
|
||||||
#define F3DEX2_SETOTHERMODE(cmd,sft,len,data) { \
|
#define F3DEX2_SETOTHERMODE(cmd,sft,len,data) { \
|
||||||
rdp.cmd0 = (uint32_t)((cmd<<24) | ((32-(sft)-(len))<<8) | (((len)-1))); \
|
rdp.cmd0 = (uint32_t)((cmd<<24) | ((32-(sft)-(len))<<8) | (((len)-1))); \
|
||||||
rdp.cmd1 = (uint32_t)(data); \
|
rdp.cmd1 = (uint32_t)(data); \
|
||||||
gfx_instruction[g_settings->ucode][cmd] (); \
|
gfx_instruction[g_settings->ucode()][cmd] (); \
|
||||||
}
|
}
|
||||||
#define SETOTHERMODE(cmd,sft,len,data) { \
|
#define SETOTHERMODE(cmd,sft,len,data) { \
|
||||||
rdp.cmd0 = (uint32_t)((cmd<<24) | ((sft)<<8) | (len)); \
|
rdp.cmd0 = (uint32_t)((cmd<<24) | ((sft)<<8) | (len)); \
|
||||||
rdp.cmd1 = (uint32_t)data; \
|
rdp.cmd1 = (uint32_t)data; \
|
||||||
gfx_instruction[g_settings->ucode][cmd] (); \
|
gfx_instruction[g_settings->ucode()][cmd] (); \
|
||||||
}
|
}
|
||||||
|
|
||||||
WriteTrace(TraceRDP, TraceDebug, "rdp_setothermode");
|
WriteTrace(TraceRDP, TraceDebug, "rdp_setothermode");
|
||||||
|
|
||||||
if ((g_settings->ucode == ucode_F3DEX2) || (g_settings->ucode == ucode_CBFD))
|
if (g_settings->ucode() == CSettings::ucode_F3DEX2 || g_settings->ucode() == CSettings::ucode_CBFD)
|
||||||
{
|
{
|
||||||
int cmd0 = rdp.cmd0;
|
int cmd0 = rdp.cmd0;
|
||||||
F3DEX2_SETOTHERMODE(0xE2, 0, 32, rdp.cmd1); // SETOTHERMODE_L
|
F3DEX2_SETOTHERMODE(0xE2, 0, 32, rdp.cmd1); // SETOTHERMODE_L
|
||||||
|
@ -2221,7 +2221,7 @@ static void rdp_fillrect()
|
||||||
WriteTrace(TraceRDP, TraceDebug, "Fillrect. Wrong coordinates. Skipped");
|
WriteTrace(TraceRDP, TraceDebug, "Fillrect. Wrong coordinates. Skipped");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
int pd_multiplayer = (g_settings->ucode == ucode_PerfectDark) && (rdp.cycle_mode == 3) && (rdp.fill_color == 0xFFFCFFFC);
|
bool pd_multiplayer = g_settings->ucode() == CSettings::ucode_PerfectDark && rdp.cycle_mode == 3 && rdp.fill_color == 0xFFFCFFFC;
|
||||||
if ((rdp.cimg == rdp.zimg) || (g_settings->fb_emulation_enabled() && rdp.ci_count > 0 && rdp.frame_buffers[rdp.ci_count - 1].status == ci_zimg) || pd_multiplayer)
|
if ((rdp.cimg == rdp.zimg) || (g_settings->fb_emulation_enabled() && rdp.ci_count > 0 && rdp.frame_buffers[rdp.ci_count - 1].status == ci_zimg) || pd_multiplayer)
|
||||||
{
|
{
|
||||||
WriteTrace(TraceRDP, TraceDebug, "Fillrect - cleared the depth buffer");
|
WriteTrace(TraceRDP, TraceDebug, "Fillrect - cleared the depth buffer");
|
||||||
|
@ -2737,7 +2737,7 @@ static void rdp_setcolorimage()
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case ci_zimg:
|
case ci_zimg:
|
||||||
if (g_settings->ucode != ucode_PerfectDark)
|
if (g_settings->ucode() != CSettings::ucode_PerfectDark)
|
||||||
{
|
{
|
||||||
if (g_settings->fb_hwfbe_enabled() && !rdp.copy_ci_index && (rdp.copy_zi_index || g_settings->hacks(CSettings::hack_BAR)))
|
if (g_settings->fb_hwfbe_enabled() && !rdp.copy_ci_index && (rdp.copy_zi_index || g_settings->hacks(CSettings::hack_BAR)))
|
||||||
{
|
{
|
||||||
|
@ -2751,7 +2751,7 @@ static void rdp_setcolorimage()
|
||||||
rdp.skip_drawing = TRUE;
|
rdp.skip_drawing = TRUE;
|
||||||
break;
|
break;
|
||||||
case ci_zcopy:
|
case ci_zcopy:
|
||||||
if (g_settings->ucode != ucode_PerfectDark)
|
if (g_settings->ucode() != CSettings::ucode_PerfectDark)
|
||||||
{
|
{
|
||||||
if (g_settings->fb_hwfbe_enabled() && !rdp.copy_ci_index && rdp.copy_zi_index == rdp.ci_count)
|
if (g_settings->fb_hwfbe_enabled() && !rdp.copy_ci_index && rdp.copy_zi_index == rdp.ci_count)
|
||||||
{
|
{
|
||||||
|
@ -2938,7 +2938,7 @@ static void rdp_setcolorimage()
|
||||||
|
|
||||||
static void rsp_reserved0()
|
static void rsp_reserved0()
|
||||||
{
|
{
|
||||||
if (g_settings->ucode == ucode_DiddyKong)
|
if (g_settings->ucode() == CSettings::ucode_DiddyKong)
|
||||||
{
|
{
|
||||||
ucode5_texshiftaddr = segoffset(rdp.cmd1);
|
ucode5_texshiftaddr = segoffset(rdp.cmd1);
|
||||||
ucode5_texshiftcount = 0;
|
ucode5_texshiftcount = 0;
|
||||||
|
@ -3271,8 +3271,8 @@ void DetectFrameBufferUsage()
|
||||||
// Go to the next instruction
|
// Go to the next instruction
|
||||||
rdp.pc[rdp.pc_i] = (a + 8) & BMASK;
|
rdp.pc[rdp.pc_i] = (a + 8) & BMASK;
|
||||||
|
|
||||||
if (uintptr_t(reinterpret_cast<void*>(gfx_instruction_lite[g_settings->ucode][rdp.cmd0 >> 24])))
|
if (uintptr_t(reinterpret_cast<void*>(gfx_instruction_lite[g_settings->ucode()][rdp.cmd0 >> 24])))
|
||||||
gfx_instruction_lite[g_settings->ucode][rdp.cmd0 >> 24]();
|
gfx_instruction_lite[g_settings->ucode()][rdp.cmd0 >> 24]();
|
||||||
|
|
||||||
// check DL counter
|
// check DL counter
|
||||||
if (rdp.dl_count != -1)
|
if (rdp.dl_count != -1)
|
||||||
|
@ -3366,7 +3366,7 @@ void DetectFrameBufferUsage()
|
||||||
{
|
{
|
||||||
if (g_settings->fb_hwfbe_enabled())
|
if (g_settings->fb_hwfbe_enabled())
|
||||||
{
|
{
|
||||||
if (rdp.read_previous_ci && !previous_ci_was_read && (g_settings->swapmode() != CSettings::SwapMode_Hybrid) && (g_settings->ucode != ucode_PerfectDark))
|
if (rdp.read_previous_ci && !previous_ci_was_read && (g_settings->swapmode() != CSettings::SwapMode_Hybrid) && (g_settings->ucode() != CSettings::ucode_PerfectDark))
|
||||||
{
|
{
|
||||||
int ind = (rdp.ci_count > 0) ? rdp.ci_count - 1 : 0;
|
int ind = (rdp.ci_count > 0) ? rdp.ci_count - 1 : 0;
|
||||||
uint32_t height = rdp.frame_buffers[ind].height;
|
uint32_t height = rdp.frame_buffers[ind].height;
|
||||||
|
|
|
@ -612,7 +612,7 @@ extern uint32_t offset_cursor;
|
||||||
extern uint32_t offset_textures;
|
extern uint32_t offset_textures;
|
||||||
extern uint32_t offset_texbuf1;
|
extern uint32_t offset_texbuf1;
|
||||||
|
|
||||||
extern int ucode_error_report;
|
extern bool g_ucode_error_report;
|
||||||
|
|
||||||
// RDP functions
|
// RDP functions
|
||||||
void rdp_reset();
|
void rdp_reset();
|
||||||
|
|
|
@ -243,9 +243,10 @@ static void t3dLoadObject(uint32_t pstate, uint32_t pvtx, uint32_t ptri)
|
||||||
static void Turbo3D()
|
static void Turbo3D()
|
||||||
{
|
{
|
||||||
WriteTrace(TraceRDP, TraceDebug, "Start Turbo3D microcode");
|
WriteTrace(TraceRDP, TraceDebug, "Start Turbo3D microcode");
|
||||||
g_settings->ucode = ucode_Fast3D;
|
g_settings->SetUcode(CSettings::ucode_Fast3D);
|
||||||
uint32_t a = 0, pgstate = 0, pstate = 0, pvtx = 0, ptri = 0;
|
uint32_t a = 0, pgstate = 0, pstate = 0, pvtx = 0, ptri = 0;
|
||||||
do {
|
do
|
||||||
|
{
|
||||||
a = rdp.pc[rdp.pc_i] & BMASK;
|
a = rdp.pc[rdp.pc_i] & BMASK;
|
||||||
pgstate = ((uint32_t*)gfx.RDRAM)[a >> 2];
|
pgstate = ((uint32_t*)gfx.RDRAM)[a >> 2];
|
||||||
pstate = ((uint32_t*)gfx.RDRAM)[(a >> 2) + 1];
|
pstate = ((uint32_t*)gfx.RDRAM)[(a >> 2) + 1];
|
||||||
|
@ -258,11 +259,12 @@ static void Turbo3D()
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (pgstate)
|
if (pgstate)
|
||||||
|
{
|
||||||
t3dLoadGlobState(pgstate);
|
t3dLoadGlobState(pgstate);
|
||||||
|
}
|
||||||
t3dLoadObject(pstate, pvtx, ptri);
|
t3dLoadObject(pstate, pvtx, ptri);
|
||||||
// Go to the next instruction
|
// Go to the next instruction
|
||||||
rdp.pc[rdp.pc_i] += 16;
|
rdp.pc[rdp.pc_i] += 16;
|
||||||
} while (pstate);
|
} while (pstate);
|
||||||
// rdp_fullsync();
|
g_settings->SetUcode(CSettings::ucode_Turbo3d);
|
||||||
g_settings->ucode = ucode_Turbo3d;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,18 +37,6 @@
|
||||||
//
|
//
|
||||||
//****************************************************************
|
//****************************************************************
|
||||||
|
|
||||||
#define ucode_Fast3D 0
|
|
||||||
#define ucode_F3DEX 1
|
|
||||||
#define ucode_F3DEX2 2
|
|
||||||
#define ucode_WaveRace 3
|
|
||||||
#define ucode_StarWars 4
|
|
||||||
#define ucode_DiddyKong 5
|
|
||||||
#define ucode_S2DEX 6
|
|
||||||
#define ucode_PerfectDark 7
|
|
||||||
#define ucode_CBFD 8
|
|
||||||
#define ucode_zSort 9
|
|
||||||
#define ucode_Turbo3d 21
|
|
||||||
|
|
||||||
static void rsp_vertex(int v0, int n)
|
static void rsp_vertex(int v0, int n)
|
||||||
{
|
{
|
||||||
uint32_t addr = segoffset(rdp.cmd1) & 0x00FFFFFF;
|
uint32_t addr = segoffset(rdp.cmd1) & 0x00FFFFFF;
|
||||||
|
@ -814,7 +802,7 @@ static void uc0_setothermode_h()
|
||||||
WriteTrace(TraceRDP, TraceDebug, "uc0:setothermode_h: ");
|
WriteTrace(TraceRDP, TraceDebug, "uc0:setothermode_h: ");
|
||||||
|
|
||||||
int shift, len;
|
int shift, len;
|
||||||
if ((g_settings->ucode == ucode_F3DEX2) || (g_settings->ucode == ucode_CBFD))
|
if (g_settings->ucode() == CSettings::ucode_F3DEX2 || g_settings->ucode() == CSettings::ucode_CBFD)
|
||||||
{
|
{
|
||||||
len = (rdp.cmd0 & 0xFF) + 1;
|
len = (rdp.cmd0 & 0xFF) + 1;
|
||||||
shift = 32 - ((rdp.cmd0 >> 8) & 0xFF) - len;
|
shift = 32 - ((rdp.cmd0 >> 8) & 0xFF) - len;
|
||||||
|
@ -892,7 +880,7 @@ static void uc0_setothermode_l()
|
||||||
WriteTrace(TraceRDP, TraceDebug, "uc0:setothermode_l ");
|
WriteTrace(TraceRDP, TraceDebug, "uc0:setothermode_l ");
|
||||||
|
|
||||||
int shift, len;
|
int shift, len;
|
||||||
if ((g_settings->ucode == ucode_F3DEX2) || (g_settings->ucode == ucode_CBFD))
|
if (g_settings->ucode() == CSettings::ucode_F3DEX2 || g_settings->ucode() == CSettings::ucode_CBFD)
|
||||||
{
|
{
|
||||||
len = (rdp.cmd0 & 0xFF) + 1;
|
len = (rdp.cmd0 & 0xFF) + 1;
|
||||||
shift = 32 - ((rdp.cmd0 >> 8) & 0xFF) - len;
|
shift = 32 - ((rdp.cmd0 >> 8) & 0xFF) - len;
|
||||||
|
|
|
@ -738,7 +738,7 @@ static void uc6_bg(bool bg_1cyc)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (g_settings->ucode == ucode_F3DEX2 || g_settings->hacks(CSettings::hack_PPL))
|
if (g_settings->ucode() == CSettings::ucode_F3DEX2 || g_settings->hacks(CSettings::hack_PPL))
|
||||||
{
|
{
|
||||||
if ((d.imagePtr != rdp.cimg) && (d.imagePtr != rdp.ocimg) && d.imagePtr) //can't draw from framebuffer
|
if ((d.imagePtr != rdp.cimg) && (d.imagePtr != rdp.ocimg) && d.imagePtr) //can't draw from framebuffer
|
||||||
DrawImage(d);
|
DrawImage(d);
|
||||||
|
|
|
@ -63,7 +63,7 @@ void uc9_rpdcmd()
|
||||||
a++;
|
a++;
|
||||||
rdp.cmd3 = ((uint32_t*)gfx.RDRAM)[a++];
|
rdp.cmd3 = ((uint32_t*)gfx.RDRAM)[a++];
|
||||||
}
|
}
|
||||||
gfx_instruction[ucode_zSort][cmd]();
|
gfx_instruction[CSettings::ucode_zSort][cmd]();
|
||||||
};
|
};
|
||||||
rdp.LLE = 0;
|
rdp.LLE = 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue