[Glide64] Fix up a lot of the logging code

This commit is contained in:
zilmar 2016-02-11 20:58:42 +11:00
parent 6bdd5dd330
commit d70f9a6733
25 changed files with 741 additions and 996 deletions

View File

@ -114,14 +114,12 @@ void calc_linear(VERTEX *v)
v->ov = (acosf(y) / 3.141592654f) * (rdp.tiles[rdp.cur_tile].org_t_scale >> 6); v->ov = (acosf(y) / 3.141592654f) * (rdp.tiles[rdp.cur_tile].org_t_scale >> 6);
} }
v->uv_scaled = 1; v->uv_scaled = 1;
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "calc linear u: %f, v: %f", v->ou, v->ov);
FRDP ("calc linear u: %f, v: %f\n", v->ou, v->ov);
#endif
} }
void calc_sphere(VERTEX *v) void calc_sphere(VERTEX *v)
{ {
// LRDP("calc_sphere\n"); WriteTrace(TraceRDP, TraceDebug, "calc_sphere");
DECLAREALIGN16VAR(vec[3]); DECLAREALIGN16VAR(vec[3]);
int s_scale, t_scale; int s_scale, t_scale;
if (g_settings->hacks&hack_Chopper) if (g_settings->hacks&hack_Chopper)
@ -151,9 +149,7 @@ void calc_sphere(VERTEX *v)
v->ou = (x * 0.5f + 0.5f) * s_scale; v->ou = (x * 0.5f + 0.5f) * s_scale;
v->ov = (y * 0.5f + 0.5f) * t_scale; v->ov = (y * 0.5f + 0.5f) * t_scale;
v->uv_scaled = 1; v->uv_scaled = 1;
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "calc sphere u: %f, v: %f", v->ou, v->ov);
FRDP ("calc sphere u: %f, v: %f\n", v->ou, v->ov);
#endif
} }
float DotProductC(register float *v1, register float *v2) float DotProductC(register float *v1, register float *v2)
@ -195,8 +191,12 @@ void MulMatricesC(float m1[4][4], float m2[4][4], float r[4][4])
register unsigned int i, j; register unsigned int i, j;
for (i = 0; i < 4; i++) for (i = 0; i < 4; i++)
{
for (j = 0; j < 4; j++) for (j = 0; j < 4; j++)
{
row[i][j] = m2[i][j]; row[i][j] = m2[i][j];
}
}
for (i = 0; i < 4; i++) for (i = 0; i < 4; i++)
{ {
// auto-vectorizable algorithm // auto-vectorizable algorithm

File diff suppressed because one or more lines are too long

View File

@ -424,7 +424,7 @@ void ConfigNotebook::set_properties()
lblResolution->SetToolTip(tooltip); lblResolution->SetToolTip(tooltip);
cmbResolution->SetToolTip(tooltip); cmbResolution->SetToolTip(tooltip);
cmbResolution->SetSelection(g_settings->res_data); cmbResolution->SetSelection(g_settings->res_data);
cbxVSync->SetToolTip("Vertical sync\nThis option will enable the vertical sync, which will prevent tearing.\nNote: this option will ONLY have effect if vsync is set to \"Software Controlled\".\n"); cbxVSync->SetToolTip("Vertical sync\nThis option will enable the vertical sync, which will prevent tearing.\nNote: this option will ONLY have effect if vsync is set to \"Software Controlled\".");
cbxVSync->SetValue(g_settings->vsync > 0); cbxVSync->SetValue(g_settings->vsync > 0);
tooltip = "Select a format, in which screen shots will be saved"; tooltip = "Select a format, in which screen shots will be saved";
lblScreenShotFormat->SetToolTip(tooltip); lblScreenShotFormat->SetToolTip(tooltip);
@ -1174,7 +1174,7 @@ void AboutDialog::do_layout()
wxStaticText* label_1 = new wxStaticText(this, wxID_ANY, "authors:"); wxStaticText* label_1 = new wxStaticText(this, wxID_ANY, "authors:");
sizer_1->Add(label_1, 0, wxALL | wxALIGN_CENTER_HORIZONTAL, 5); sizer_1->Add(label_1, 0, wxALL | wxALIGN_CENTER_HORIZONTAL, 5);
wxStaticText* label_2 = new wxStaticText(this, wxID_ANY, "Dave2001. Original author and former main developer.\nHe founded Glide64 project on Dec. 29th, 2001.\nLeft the project at fall of 2002.\n"); wxStaticText* label_2 = new wxStaticText(this, wxID_ANY, "Dave2001. Original author and former main developer.\nHe founded Glide64 project on Dec. 29th, 2001.\nLeft the project at fall of 2002.");
label_2->Enable(false); label_2->Enable(false);
sizer_2->Add(label_2, 0, 0, 0); sizer_2->Add(label_2, 0, 0, 0);
sizer_1->Add(sizer_2, 1, wxEXPAND, 0); sizer_1->Add(sizer_2, 1, wxEXPAND, 0);
@ -1214,7 +1214,7 @@ void AboutDialog::do_layout()
wxStaticText* label_13 = new wxStaticText(this, wxID_ANY, "olivieryuyu"); wxStaticText* label_13 = new wxStaticText(this, wxID_ANY, "olivieryuyu");
sizer_12->Add(label_13, 0, wxALIGN_CENTER_VERTICAL, 0); sizer_12->Add(label_13, 0, wxALIGN_CENTER_VERTICAL, 0);
sizer_1->Add(sizer_12, 1, wxEXPAND, 0); sizer_1->Add(sizer_12, 1, wxEXPAND, 0);
wxStaticText* label_14 = new wxStaticText(this, wxID_ANY, "special thanks to:\n Orkin, Rice, Daniel Borca, Legend.\nThanks to EmuXHaven for hosting my site:\nhttp://glide64.emuxhaven.net\n", wxDefaultPosition, wxDefaultSize, wxALIGN_CENTRE); wxStaticText* label_14 = new wxStaticText(this, wxID_ANY, "special thanks to:\n Orkin, Rice, Daniel Borca, Legend.\nThanks to EmuXHaven for hosting my site:\nhttp://glide64.emuxhaven.net", wxDefaultPosition, wxDefaultSize, wxALIGN_CENTRE);
sizer_1->Add(label_14, 0, wxALIGN_CENTER_HORIZONTAL, 0); sizer_1->Add(label_14, 0, wxALIGN_CENTER_HORIZONTAL, 0);
sizer_1->Add(button_ok, 0, wxLEFT | wxRIGHT | wxBOTTOM | wxEXPAND | wxALIGN_CENTER_HORIZONTAL, 10); sizer_1->Add(button_ok, 0, wxLEFT | wxRIGHT | wxBOTTOM | wxEXPAND | wxALIGN_CENTER_HORIZONTAL, 10);
SetSizer(sizer_1); SetSizer(sizer_1);

View File

@ -45,6 +45,7 @@
#include "Gfx_1.3.h" #include "Gfx_1.3.h"
#include "FBtoScreen.h" #include "FBtoScreen.h"
#include "TexCache.h" #include "TexCache.h"
#include <Glide64/trace.h>
static int SetupFBtoScreenCombiner(uint32_t texture_size, uint32_t opaque) static int SetupFBtoScreenCombiner(uint32_t texture_size, uint32_t opaque)
{ {
@ -148,7 +149,7 @@ static void DrawRE2Video(FB_TO_SCREEN_INFO & fb_info, float scale)
static void DrawRE2Video256(FB_TO_SCREEN_INFO & fb_info) static void DrawRE2Video256(FB_TO_SCREEN_INFO & fb_info)
{ {
FRDP("DrawRE2Video256. ul_x=%d, ul_y=%d, lr_x=%d, lr_y=%d, size=%d, addr=%08lx\n", fb_info.ul_x, fb_info.ul_y, fb_info.lr_x, fb_info.lr_y, fb_info.size, fb_info.addr); WriteTrace(TraceRDP, TraceDebug, "DrawRE2Video256. ul_x=%d, ul_y=%d, lr_x=%d, lr_y=%d, size=%d, addr=%08lx", fb_info.ul_x, fb_info.ul_y, fb_info.lr_x, fb_info.lr_y, fb_info.size, fb_info.addr);
uint32_t * src = (uint32_t*)(gfx.RDRAM + fb_info.addr); uint32_t * src = (uint32_t*)(gfx.RDRAM + fb_info.addr);
GrTexInfo t_info; GrTexInfo t_info;
t_info.smallLodLog2 = GR_LOD_LOG2_256; t_info.smallLodLog2 = GR_LOD_LOG2_256;
@ -195,7 +196,7 @@ static void DrawFrameBufferToScreen256(FB_TO_SCREEN_INFO & fb_info)
DrawRE2Video256(fb_info); DrawRE2Video256(fb_info);
return; return;
} }
FRDP("DrawFrameBufferToScreen256. ul_x=%d, ul_y=%d, lr_x=%d, lr_y=%d, size=%d, addr=%08lx\n", fb_info.ul_x, fb_info.ul_y, fb_info.lr_x, fb_info.lr_y, fb_info.size, fb_info.addr); WriteTrace(TraceRDP, TraceDebug, "DrawFrameBufferToScreen256. ul_x=%d, ul_y=%d, lr_x=%d, lr_y=%d, size=%d, addr=%08lx", fb_info.ul_x, fb_info.ul_y, fb_info.lr_x, fb_info.lr_y, fb_info.size, fb_info.addr);
uint32_t width = fb_info.lr_x - fb_info.ul_x + 1; uint32_t width = fb_info.lr_x - fb_info.ul_x + 1;
uint32_t height = fb_info.lr_y - fb_info.ul_y + 1; uint32_t height = fb_info.lr_y - fb_info.ul_y + 1;
GrTexInfo t_info; GrTexInfo t_info;
@ -313,7 +314,7 @@ bool DrawFrameBufferToScreen(FB_TO_SCREEN_INFO & fb_info)
DrawFrameBufferToScreen256(fb_info); DrawFrameBufferToScreen256(fb_info);
return true; return true;
} }
FRDP("DrawFrameBufferToScreen. ul_x=%d, ul_y=%d, lr_x=%d, lr_y=%d, size=%d, addr=%08lx\n", fb_info.ul_x, fb_info.ul_y, fb_info.lr_x, fb_info.lr_y, fb_info.size, fb_info.addr); WriteTrace(TraceRDP, TraceDebug, "DrawFrameBufferToScreen. ul_x=%d, ul_y=%d, lr_x=%d, lr_y=%d, size=%d, addr=%08lx", fb_info.ul_x, fb_info.ul_y, fb_info.lr_x, fb_info.lr_y, fb_info.size, fb_info.addr);
GrTexInfo t_info; GrTexInfo t_info;
uint8_t * image = gfx.RDRAM + fb_info.addr; uint8_t * image = gfx.RDRAM + fb_info.addr;
uint32_t texwidth; uint32_t texwidth;
@ -429,7 +430,7 @@ bool DrawFrameBufferToScreen(FB_TO_SCREEN_INFO & fb_info)
static void DrawDepthBufferToScreen256(FB_TO_SCREEN_INFO & fb_info) static void DrawDepthBufferToScreen256(FB_TO_SCREEN_INFO & fb_info)
{ {
FRDP("DrawDepthBufferToScreen256. ul_x=%d, ul_y=%d, lr_x=%d, lr_y=%d, size=%d, addr=%08lx\n", fb_info.ul_x, fb_info.ul_y, fb_info.lr_x, fb_info.lr_y, fb_info.size, fb_info.addr); WriteTrace(TraceRDP, TraceDebug, "DrawDepthBufferToScreen256. ul_x=%d, ul_y=%d, lr_x=%d, lr_y=%d, size=%d, addr=%08lx", fb_info.ul_x, fb_info.ul_y, fb_info.lr_x, fb_info.lr_y, fb_info.size, fb_info.addr);
uint32_t width = fb_info.lr_x - fb_info.ul_x + 1; uint32_t width = fb_info.lr_x - fb_info.ul_x + 1;
uint32_t height = fb_info.lr_y - fb_info.ul_y + 1; uint32_t height = fb_info.lr_y - fb_info.ul_y + 1;
GrTexInfo t_info; GrTexInfo t_info;
@ -501,7 +502,7 @@ static void DrawDepthBufferToScreen256(FB_TO_SCREEN_INFO & fb_info)
static void DrawHiresDepthBufferToScreen(FB_TO_SCREEN_INFO & fb_info) static void DrawHiresDepthBufferToScreen(FB_TO_SCREEN_INFO & fb_info)
{ {
FRDP("DrawHiresDepthBufferToScreen. ul_x=%d, ul_y=%d, lr_x=%d, lr_y=%d, size=%d, addr=%08lx\n", fb_info.ul_x, fb_info.ul_y, fb_info.lr_x, fb_info.lr_y, fb_info.size, fb_info.addr); WriteTrace(TraceRDP, TraceDebug, "DrawHiresDepthBufferToScreen. ul_x=%d, ul_y=%d, lr_x=%d, lr_y=%d, size=%d, addr=%08lx", fb_info.ul_x, fb_info.ul_y, fb_info.lr_x, fb_info.lr_y, fb_info.size, fb_info.addr);
GrTexInfo t_info; GrTexInfo t_info;
float scale = 0.25f; float scale = 0.25f;
GrLOD_t LOD = GR_LOD_LOG2_1024; GrLOD_t LOD = GR_LOD_LOG2_1024;
@ -582,7 +583,7 @@ void DrawDepthBufferToScreen(FB_TO_SCREEN_INFO & fb_info)
DrawHiresDepthBufferToScreen(fb_info); DrawHiresDepthBufferToScreen(fb_info);
return; return;
} }
FRDP("DrawDepthBufferToScreen. ul_x=%d, ul_y=%d, lr_x=%d, lr_y=%d, size=%d, addr=%08lx\n", fb_info.ul_x, fb_info.ul_y, fb_info.lr_x, fb_info.lr_y, fb_info.size, fb_info.addr); WriteTrace(TraceRDP, TraceDebug, "DrawDepthBufferToScreen. ul_x=%d, ul_y=%d, lr_x=%d, lr_y=%d, size=%d, addr=%08lx", fb_info.ul_x, fb_info.ul_y, fb_info.lr_x, fb_info.lr_y, fb_info.size, fb_info.addr);
GrTexInfo t_info; GrTexInfo t_info;
uint8_t * image = gfx.RDRAM + fb_info.addr; uint8_t * image = gfx.RDRAM + fb_info.addr;
uint32_t texwidth; uint32_t texwidth;

View File

@ -106,11 +106,9 @@ extern "C" {
//#define ALTTAB_FIX //#define ALTTAB_FIX
//#define EXTREME_LOGGING // lots of logging
// note that some of these things are inserted/removed // note that some of these things are inserted/removed
// from within the code & may not be changed by this define. // from within the code & may not be changed by this define.
//#define TLUT_LOGGING // log every entry of the TLUT?
// ******************************** // ********************************
#define FPS // fps counter able? (not enabled necessarily) #define FPS // fps counter able? (not enabled necessarily)
@ -127,9 +125,7 @@ extern "C" {
// the command is logged before continuing (in case of // the command is logged before continuing (in case of
// crash or exception, the log will not be cut short) // crash or exception, the log will not be cut short)
#ifndef _ENDUSER_RELEASE_ #ifndef _ENDUSER_RELEASE_
#define RDP_LOGGING // Allow logging (will not log unless checked, but allows the option)
// Logging functions will not be compiled if this is not present.
//#define RDP_ERROR_LOG
#endif #endif
#define FPS_FRAMES 10 // Number of frames in which to make an FPS count #define FPS_FRAMES 10 // Number of frames in which to make an FPS count
@ -151,15 +147,7 @@ extern "C" {
//#define SIMULATE_BANSHEE //#define SIMULATE_BANSHEE
//******** //********
#ifdef EXT_LOGGING
extern std::ofstream extlog;
#define EXT(x) extlog.open("ext.txt",std::ios::app); extlog << x; extlog.close();
#else
#define EXT(x)
#endif
#ifndef _ENDUSER_RELEASE_ #ifndef _ENDUSER_RELEASE_
#define UNIMP_LOG // Keep enabled, option in dialog
#define BRIGHT_RED // Keep enabled, option in dialog #define BRIGHT_RED // Keep enabled, option in dialog
#endif #endif
@ -189,78 +177,6 @@ extern "C" {
extern int64 perf_next; extern int64 perf_next;
#endif #endif
#ifdef RDP_LOGGING
extern int log_open;
extern std::ofstream rdp_log;
#define OPEN_RDP_LOG() EXT("OPEN_RDP_LOG ()\n"); if (g_settings->logging && !log_open) { rdp_log.open ("rdp.txt"); log_open=TRUE; }
#define CLOSE_RDP_LOG() EXT("CLOSE_RDP_LOG ()\n"); if (g_settings->logging && log_open) { rdp_log.close (); log_open=FALSE; }
#ifdef LOGNOTKEY
#define LRDP(x) EXT("RDP (...)\n"); if (g_settings->logging && log_open) { if (!CheckKeyPressed(LOGKEY,0x8000)) { rdp_log << x; rdp_log.flush(); } }
#else
#define LRDP(x) EXT("RDP (...)\n"); if (g_settings->logging && log_open) { rdp_log << x; rdp_log.flush(); }
#endif
#else
#define OPEN_RDP_LOG()
#define CLOSE_RDP_LOG()
#define LRDP(x)
#endif
#ifdef RDP_ERROR_LOG
extern int elog_open;
extern std::ofstream rdp_err;
#define OPEN_RDP_E_LOG() EXT("OPEN_RDP_E_LOG ()\n"); if (g_settings->elogging && !elog_open) { rdp_err.open ("rdp_e.txt"); elog_open=TRUE; }
#define CLOSE_RDP_E_LOG() EXT("CLOSE_RDP_LOG ()\n"); if (g_settings->elogging && elog_open) { rdp_err.close (); elog_open=FALSE; }
#define RDP_E(x) if (g_settings->elogging) { FRDP_E (x); }
#else
#define OPEN_RDP_E_LOG()
#define CLOSE_RDP_E_LOG()
#define RDP_E(x)
#endif
#ifdef RDP_LOGGING
__inline void FRDP(const char *fmt, ...)
{
if (!g_settings->logging || !log_open) return;
#ifdef LOGNOTKEY
if (CheckKeyPressed(LOGKEY, 0x8000)) return;
#endif
va_list ap;
va_start(ap, fmt);
vsprintf(out_buf, fmt, ap);
LRDP(out_buf);
va_end(ap);
}
#else
__inline void FRDP(const char * /*fmt*/, ...) {}
#endif
#ifdef RDP_ERROR_LOG
__inline void FRDP_E(const char *fmt, ...)
{
if (!g_settings->elogging || !elog_open) return;
#ifdef LOGNOTKEY
if (CheckKeyPressed(LOGKEY, 0x8000)) return;
#endif
sprintf(out_buf, "%08lx: (%08lx, %08lx) ", rdp.pc[rdp.pc_i] - 8, rdp.cmd0, rdp.cmd1);
rdp_err << out_buf;
va_list ap2;
va_start(ap2, fmt);
vsprintf(out_buf, fmt, ap2);
rdp_err << out_buf;
rdp_err.flush();
va_end(ap2);
}
#else
__inline void FRDP_E(const char * /*fmt*/, ...) {}
#endif
extern int GfxInitDone; extern int GfxInitDone;
extern int romopen; extern int romopen;
extern int to_fullscreen; extern int to_fullscreen;

View File

@ -61,20 +61,6 @@
int ghq_dmptex_toggle_key = 0; int ghq_dmptex_toggle_key = 0;
#endif #endif
#ifdef EXT_LOGGING
std::ofstream extlog;
#endif
#ifdef RDP_LOGGING
int log_open = FALSE;
std::ofstream rdp_log;
#endif
#ifdef RDP_ERROR_LOG
int elog_open = FALSE;
std::ofstream rdp_err;
#endif
GFX_INFO gfx; GFX_INFO gfx;
int to_fullscreen = FALSE; int to_fullscreen = FALSE;
@ -213,8 +199,8 @@ void _ChangeSize()
rdp.vi_height = (vend - vstart) * fscale_y * 1.0126582f; rdp.vi_height = (vend - vstart) * fscale_y * 1.0126582f;
float aspect = (g_settings->adjust_aspect && (fscale_y > fscale_x) && (rdp.vi_width > rdp.vi_height)) ? fscale_x / fscale_y : 1.0f; float aspect = (g_settings->adjust_aspect && (fscale_y > fscale_x) && (rdp.vi_width > rdp.vi_height)) ? fscale_x / fscale_y : 1.0f;
WriteTrace(TraceResolution, TraceDebug, "hstart: %d, hend: %d, vstart: %d, vend: %d\n", hstart, hend, vstart, vend); WriteTrace(TraceResolution, TraceDebug, "hstart: %d, hend: %d, vstart: %d, vend: %d", hstart, hend, vstart, vend);
WriteTrace(TraceResolution, TraceDebug, "size: %d x %d\n", (int)rdp.vi_width, (int)rdp.vi_height); WriteTrace(TraceResolution, TraceDebug, "size: %d x %d", (int)rdp.vi_width, (int)rdp.vi_height);
rdp.scale_x = (float)g_settings->res_x / rdp.vi_width; rdp.scale_x = (float)g_settings->res_x / rdp.vi_width;
if (region > 0 && g_settings->pal230) if (region > 0 && g_settings->pal230)
@ -383,7 +369,7 @@ void ReadSettings()
void ReadSpecialSettings(const char * name) void ReadSpecialSettings(const char * name)
{ {
// char buf [256]; // char buf [256];
// sprintf(buf, "ReadSpecialSettings. Name: %s\n", name); // sprintf(buf, "ReadSpecialSettings. Name: %s", name);
// LOG(buf); // LOG(buf);
g_settings->hacks = 0; g_settings->hacks = 0;
@ -718,8 +704,8 @@ void guLoadTextures()
if (cur&b) *tex8 = 0xFF; if (cur&b) *tex8 = 0xFF;
else *tex8 = 0x00; else *tex8 = 0x00;
tex8++; tex8++;
}
} }
}
grTexDownloadMipMap(GR_TMU0, grTexDownloadMipMap(GR_TMU0,
voodoo.tex_min_addr[GR_TMU0] + offset_font, voodoo.tex_min_addr[GR_TMU0] + offset_font,
@ -794,8 +780,6 @@ int InitGfx()
ReleaseGfx(); ReleaseGfx();
} }
OPEN_RDP_LOG(); // doesn't matter if opens again; it will check for it
OPEN_RDP_E_LOG();
WriteTrace(TraceGlide64, TraceDebug, "-"); WriteTrace(TraceGlide64, TraceDebug, "-");
debugging = FALSE; debugging = FALSE;
@ -1002,7 +986,7 @@ int InitGfx()
fog_t[0] = 0; fog_t[0] = 0;
// for (int f = 0; f < 64; f++) // for (int f = 0; f < 64; f++)
// { // {
// FRDP("fog[%d]=%d->%f\n", f, fog_t[f], guFogTableIndexToW(f)); // WriteTrace(TraceRDP, TraceDebug, "fog[%d]=%d->%f", f, fog_t[f], guFogTableIndexToW(f));
// } // }
grFogTable(fog_t); grFogTable(fog_t);
grVertexLayout(GR_PARAM_FOG_EXT, offsetof(VERTEX, f), GR_PARAM_ENABLE); grVertexLayout(GR_PARAM_FOG_EXT, offsetof(VERTEX, f), GR_PARAM_ENABLE);
@ -1387,7 +1371,7 @@ void CALL CloseDLL(void)
voodoo.gamma_table_g = 0; voodoo.gamma_table_g = 0;
delete[] voodoo.gamma_table_b; delete[] voodoo.gamma_table_b;
voodoo.gamma_table_b = 0; voodoo.gamma_table_b = 0;
} }
/****************************************************************** /******************************************************************
Function: DllTest Function: DllTest
@ -1643,12 +1627,12 @@ void CALL RomClosed(void)
{ {
WriteTrace(TraceGlide64, TraceDebug, "-"); WriteTrace(TraceGlide64, TraceDebug, "-");
CLOSE_RDP_LOG();
CLOSE_RDP_E_LOG();
rdp.window_changed = TRUE; rdp.window_changed = TRUE;
romopen = FALSE; romopen = FALSE;
if (evoodoo) if (evoodoo)
{
ReleaseGfx(); ReleaseGfx();
}
} }
static void CheckDRAMSize() static void CheckDRAMSize()
@ -1667,7 +1651,7 @@ static void CheckDRAMSize()
else else
BMASK = WMASK; BMASK = WMASK;
#ifdef LOGGING #ifdef LOGGING
sprintf(out_buf, "Detected RDRAM size: %08lx\n", BMASK); sprintf(out_buf, "Detected RDRAM size: %08lx", BMASK);
LOG(out_buf); LOG(out_buf);
#endif #endif
} }
@ -1733,9 +1717,6 @@ void CALL RomOpen(void)
CheckDRAMSize(); CheckDRAMSize();
OPEN_RDP_LOG();
OPEN_RDP_E_LOG();
// ** EVOODOO EXTENSIONS ** // ** EVOODOO EXTENSIONS **
if (!GfxInitDone) if (!GfxInitDone)
{ {
@ -1787,7 +1768,7 @@ void drawViRegBG()
fb_info.height = (uint32_t)rdp.vi_height; fb_info.height = (uint32_t)rdp.vi_height;
if (fb_info.height == 0) if (fb_info.height == 0)
{ {
LRDP("Image height = 0 - skipping\n"); WriteTrace(TraceRDP, TraceDebug, "Image height = 0 - skipping");
return; return;
} }
fb_info.ul_x = 0; fb_info.ul_x = 0;
@ -1832,7 +1813,7 @@ output: none
uint32_t update_screen_count = 0; uint32_t update_screen_count = 0;
void CALL UpdateScreen(void) void CALL UpdateScreen(void)
{ {
WriteTrace(TraceGlide64, TraceDebug, "Origin: %08x, Old origin: %08x, width: %d\n", *gfx.VI_ORIGIN_REG, rdp.vi_org_reg, *gfx.VI_WIDTH_REG); WriteTrace(TraceGlide64, TraceDebug, "Origin: %08x, Old origin: %08x, width: %d", *gfx.VI_ORIGIN_REG, rdp.vi_org_reg, *gfx.VI_WIDTH_REG);
uint32_t width = (*gfx.VI_WIDTH_REG) << 1; uint32_t width = (*gfx.VI_WIDTH_REG) << 1;
if (*gfx.VI_ORIGIN_REG > width) if (*gfx.VI_ORIGIN_REG > width)
@ -1862,7 +1843,7 @@ void CALL UpdateScreen(void)
uint32_t limit = (g_settings->hacks&hack_Lego) ? 15 : 30; uint32_t limit = (g_settings->hacks&hack_Lego) ? 15 : 30;
if ((g_settings->frame_buffer&fb_cpu_write_hack) && (update_screen_count > limit) && (rdp.last_bg == 0)) if ((g_settings->frame_buffer&fb_cpu_write_hack) && (update_screen_count > limit) && (rdp.last_bg == 0))
{ {
LRDP("DirectCPUWrite hack!\n"); WriteTrace(TraceRDP, TraceDebug, "DirectCPUWrite hack!");
update_screen_count = 0; update_screen_count = 0;
no_dlist = true; no_dlist = true;
ClearCache(); ClearCache();
@ -1876,9 +1857,9 @@ void CALL UpdateScreen(void)
if (*gfx.VI_ORIGIN_REG > width) if (*gfx.VI_ORIGIN_REG > width)
{ {
ChangeSize(); ChangeSize();
LRDP("ChangeSize done\n"); WriteTrace(TraceRDP, TraceDebug, "ChangeSize done");
DrawFrameBuffer(); DrawFrameBuffer();
LRDP("DrawFrameBuffer done\n"); WriteTrace(TraceRDP, TraceDebug, "DrawFrameBuffer done");
rdp.updatescreen = 1; rdp.updatescreen = 1;
newSwapBuffers(); newSwapBuffers();
} }
@ -1936,7 +1917,7 @@ void newSwapBuffers()
rdp.updatescreen = 0; rdp.updatescreen = 0;
LRDP("swapped\n"); WriteTrace(TraceRDP, TraceDebug, "swapped");
rdp.update |= UPDATE_SCISSOR | UPDATE_COMBINE | UPDATE_ZBUF_ENABLED | UPDATE_CULL_MODE; rdp.update |= UPDATE_SCISSOR | UPDATE_COMBINE | UPDATE_ZBUF_ENABLED | UPDATE_CULL_MODE;
grClipWindow(0, 0, g_settings->scr_res_x, g_settings->scr_res_y); grClipWindow(0, 0, g_settings->scr_res_x, g_settings->scr_res_y);

View File

@ -46,6 +46,7 @@
#include "Gfx_1.3.h" #include "Gfx_1.3.h"
#include "TexBuffer.h" #include "TexBuffer.h"
#include "CRC.h" #include "CRC.h"
#include <Glide64/trace.h>
static TBUFF_COLOR_IMAGE * AllocateTextureBuffer(COLOR_IMAGE & cimage) static TBUFF_COLOR_IMAGE * AllocateTextureBuffer(COLOR_IMAGE & cimage)
{ {
@ -153,7 +154,7 @@ static TBUFF_COLOR_IMAGE * AllocateTextureBuffer(COLOR_IMAGE & cimage)
texbuf.crc = 0; texbuf.crc = 0;
texbuf.t_mem = 0; texbuf.t_mem = 0;
FRDP("\nAllocateTextureBuffer. width: %d, height: %d, scr_width: %f, scr_height: %f, vi_width: %f, vi_height:%f, scale_x: %f, scale_y: %f, lr_u: %f, lr_v: %f, u_scale: %f, v_scale: %f\n", texbuf.width, texbuf.height, texbuf.scr_width, texbuf.scr_height, rdp.vi_width, rdp.vi_height, rdp.scale_x, rdp.scale_y, texbuf.lr_u, texbuf.lr_v, texbuf.u_scale, texbuf.v_scale); WriteTrace(TraceRDP, TraceDebug, "\nAllocateTextureBuffer. width: %d, height: %d, scr_width: %f, scr_height: %f, vi_width: %f, vi_height:%f, scale_x: %f, scale_y: %f, lr_u: %f, lr_v: %f, u_scale: %f, v_scale: %f", texbuf.width, texbuf.height, texbuf.scr_width, texbuf.scr_height, rdp.vi_width, rdp.vi_height, rdp.scale_x, rdp.scale_y, texbuf.lr_u, texbuf.lr_v, texbuf.u_scale, texbuf.v_scale);
uint32_t required = grTexCalcMemRequired(texbuf.info.smallLodLog2, texbuf.info.largeLodLog2, uint32_t required = grTexCalcMemRequired(texbuf.info.smallLodLog2, texbuf.info.largeLodLog2,
texbuf.info.aspectRatioLog2, texbuf.info.format); texbuf.info.aspectRatioLog2, texbuf.info.format);
@ -210,7 +211,7 @@ static TBUFF_COLOR_IMAGE * AllocateTextureBuffer(COLOR_IMAGE & cimage)
int OpenTextureBuffer(COLOR_IMAGE & cimage) int OpenTextureBuffer(COLOR_IMAGE & cimage)
{ {
FRDP("OpenTextureBuffer. cur_tex_buf: %d, addr: %08lx, width: %d, height: %d", rdp.cur_tex_buf, cimage.addr, cimage.width, cimage.height); WriteTrace(TraceRDP, TraceDebug, "OpenTextureBuffer. cur_tex_buf: %d, addr: %08lx, width: %d, height: %d", rdp.cur_tex_buf, cimage.addr, cimage.width, cimage.height);
int found = FALSE, search = TRUE; int found = FALSE, search = TRUE;
TBUFF_COLOR_IMAGE *texbuf = 0; TBUFF_COLOR_IMAGE *texbuf = 0;
@ -229,7 +230,7 @@ int OpenTextureBuffer(COLOR_IMAGE & cimage)
if (g_settings->hacks&hack_PMario) //motion blur effects in Paper Mario if (g_settings->hacks&hack_PMario) //motion blur effects in Paper Mario
{ {
rdp.cur_tex_buf = rdp.acc_tex_buf; rdp.cur_tex_buf = rdp.acc_tex_buf;
FRDP("\nread_whole_frame. last allocated bank: %d\n", rdp.acc_tex_buf); WriteTrace(TraceRDP, TraceDebug, "\nread_whole_frame. last allocated bank: %d", rdp.acc_tex_buf);
} }
else else
{ {
@ -301,22 +302,22 @@ int OpenTextureBuffer(COLOR_IMAGE & cimage)
} }
else else
{ {
LRDP(" not searched"); WriteTrace(TraceRDP, TraceDebug, " not searched");
} }
if (!found) if (!found)
{ {
LRDP(" not found"); WriteTrace(TraceRDP, TraceDebug, " not found");
texbuf = AllocateTextureBuffer(cimage); texbuf = AllocateTextureBuffer(cimage);
} }
else else
{ {
LRDP(" found"); WriteTrace(TraceRDP, TraceDebug, " found");
} }
if (!texbuf) if (!texbuf)
{ {
LRDP(" KO\n"); WriteTrace(TraceRDP, TraceDebug, " KO");
return FALSE; return FALSE;
} }
@ -335,7 +336,7 @@ int OpenTextureBuffer(COLOR_IMAGE & cimage)
} }
//*/ //*/
// memset(gfx.RDRAM+cimage.addr, 0, cimage.width*cimage.height*cimage.size); // memset(gfx.RDRAM+cimage.addr, 0, cimage.width*cimage.height*cimage.size);
FRDP(" texaddr: %08lx, tex_width: %d, tex_height: %d, cur_tex_buf: %d, texformat: %d, motionblur: %d\n", rdp.cur_image->tex_addr, rdp.cur_image->tex_width, rdp.cur_image->tex_height, rdp.cur_tex_buf, rdp.cur_image->info.format, rdp.motionblur); WriteTrace(TraceRDP, TraceDebug, " texaddr: %08lx, tex_width: %d, tex_height: %d, cur_tex_buf: %d, texformat: %d, motionblur: %d", rdp.cur_image->tex_addr, rdp.cur_image->tex_width, rdp.cur_image->tex_height, rdp.cur_tex_buf, rdp.cur_image->info.format, rdp.motionblur);
if (!rdp.offset_x_bak) if (!rdp.offset_x_bak)
{ {
rdp.offset_x_bak = rdp.offset_x; rdp.offset_x_bak = rdp.offset_x;
@ -421,7 +422,7 @@ int CloseTextureBuffer(int draw)
{ {
if (!rdp.cur_image) if (!rdp.cur_image)
{ {
LRDP("CloseTextureBuffer KO\n"); WriteTrace(TraceRDP, TraceDebug, "CloseTextureBuffer KO");
return FALSE; return FALSE;
} }
grRenderBuffer(GR_BUFFER_BACKBUFFER); grRenderBuffer(GR_BUFFER_BACKBUFFER);
@ -431,7 +432,7 @@ int CloseTextureBuffer(int draw)
rdp.update |= UPDATE_VIEWPORT | UPDATE_SCISSOR; rdp.update |= UPDATE_VIEWPORT | UPDATE_SCISSOR;
if (!draw) if (!draw)
{ {
LRDP("CloseTextureBuffer no draw, OK\n"); WriteTrace(TraceRDP, TraceDebug, "CloseTextureBuffer no draw, OK");
rdp.cur_image = 0; rdp.cur_image = 0;
return TRUE; return TRUE;
} }
@ -445,7 +446,7 @@ int CloseTextureBuffer(int draw)
float lr_y = rdp.tbuff_tex->scr_height + rdp.offset_y; float lr_y = rdp.tbuff_tex->scr_height + rdp.offset_y;
float lr_u = rdp.tbuff_tex->lr_u; float lr_u = rdp.tbuff_tex->lr_u;
float lr_v = rdp.tbuff_tex->lr_v; float lr_v = rdp.tbuff_tex->lr_v;
FRDP("lr_x: %f, lr_y: %f, lr_u: %f, lr_v: %f\n", lr_x, lr_y, lr_u, lr_v); WriteTrace(TraceRDP, TraceDebug, "lr_x: %f, lr_y: %f, lr_u: %f, lr_v: %f", lr_x, lr_y, lr_u, lr_v);
// Make the vertices // Make the vertices
VERTEX v[4] = { VERTEX v[4] = {
@ -464,14 +465,14 @@ int CloseTextureBuffer(int draw)
{ {
grFogMode(GR_FOG_WITH_TABLE_ON_FOGCOORD_EXT); grFogMode(GR_FOG_WITH_TABLE_ON_FOGCOORD_EXT);
} }
LRDP("CloseTextureBuffer draw, OK\n"); WriteTrace(TraceRDP, TraceDebug, "CloseTextureBuffer draw, OK");
rdp.tbuff_tex = 0; rdp.tbuff_tex = 0;
return TRUE; return TRUE;
} }
int CopyTextureBuffer(COLOR_IMAGE & fb_from, COLOR_IMAGE & fb_to) int CopyTextureBuffer(COLOR_IMAGE & fb_from, COLOR_IMAGE & fb_to)
{ {
FRDP("CopyTextureBuffer from %08x to %08x\n", fb_from.addr, fb_to.addr); WriteTrace(TraceRDP, TraceDebug, "CopyTextureBuffer from %08x to %08x", fb_from.addr, fb_to.addr);
if (rdp.cur_image) if (rdp.cur_image)
{ {
rdp.cur_image->crc = 0; rdp.cur_image->crc = 0;
@ -481,12 +482,12 @@ int CopyTextureBuffer(COLOR_IMAGE & fb_from, COLOR_IMAGE & fb_to)
} }
else if (!FindTextureBuffer(fb_from.addr, (uint16_t)fb_from.width)) else if (!FindTextureBuffer(fb_from.addr, (uint16_t)fb_from.width))
{ {
LRDP("Can't find 'from' buffer.\n"); WriteTrace(TraceRDP, TraceDebug, "Can't find 'from' buffer.");
return FALSE; return FALSE;
} }
if (!OpenTextureBuffer(fb_to)) if (!OpenTextureBuffer(fb_to))
{ {
LRDP("Can't open new buffer.\n"); WriteTrace(TraceRDP, TraceDebug, "Can't open new buffer.");
return CloseTextureBuffer(TRUE); return CloseTextureBuffer(TRUE);
} }
rdp.tbuff_tex->crc = 0; rdp.tbuff_tex->crc = 0;
@ -500,7 +501,7 @@ int CopyTextureBuffer(COLOR_IMAGE & fb_from, COLOR_IMAGE & fb_to)
float zero = 0.0f; float zero = 0.0f;
float lr_u = rdp.tbuff_tex->lr_u; float lr_u = rdp.tbuff_tex->lr_u;
float lr_v = rdp.tbuff_tex->lr_v; float lr_v = rdp.tbuff_tex->lr_v;
FRDP("lr_x: %f, lr_y: %f\n", lr_x, lr_y); WriteTrace(TraceRDP, TraceDebug, "lr_x: %f, lr_y: %f", lr_x, lr_y);
// Make the vertices // Make the vertices
VERTEX v[4] = { VERTEX v[4] = {
@ -527,7 +528,7 @@ int CopyTextureBuffer(COLOR_IMAGE & fb_from, COLOR_IMAGE & fb_to)
rdp.update |= UPDATE_VIEWPORT | UPDATE_SCISSOR; rdp.update |= UPDATE_VIEWPORT | UPDATE_SCISSOR;
if (g_settings->fog && (rdp.flags & FOG_ENABLED)) if (g_settings->fog && (rdp.flags & FOG_ENABLED))
grFogMode(GR_FOG_WITH_TABLE_ON_FOGCOORD_EXT); grFogMode(GR_FOG_WITH_TABLE_ON_FOGCOORD_EXT);
LRDP("CopyTextureBuffer draw, OK\n"); WriteTrace(TraceRDP, TraceDebug, "CopyTextureBuffer draw, OK");
rdp.tbuff_tex = 0; rdp.tbuff_tex = 0;
rdp.cur_image = 0; rdp.cur_image = 0;
return TRUE; return TRUE;
@ -535,7 +536,7 @@ int CopyTextureBuffer(COLOR_IMAGE & fb_from, COLOR_IMAGE & fb_to)
int CopyDepthBuffer() int CopyDepthBuffer()
{ {
LRDP("CopyDepthBuffer. "); WriteTrace(TraceRDP, TraceDebug, "CopyDepthBuffer. ");
float bound = 1024.0f; float bound = 1024.0f;
GrLOD_t LOD = GR_LOD_LOG2_1024; GrLOD_t LOD = GR_LOD_LOG2_1024;
if (g_settings->scr_res_x > 1024) if (g_settings->scr_res_x > 1024)
@ -556,7 +557,7 @@ int CopyDepthBuffer()
float zero = 0.0f; float zero = 0.0f;
float lr_u = 255.5f; float lr_u = 255.5f;
float lr_v = 255.5f; float lr_v = 255.5f;
FRDP("lr_x: %f, lr_y: %f\n", lr_x, lr_y); WriteTrace(TraceRDP, TraceDebug, "lr_x: %f, lr_y: %f", lr_x, lr_y);
// Make the vertices // Make the vertices
VERTEX v[4] = { VERTEX v[4] = {
@ -581,7 +582,7 @@ int CopyDepthBuffer()
rdp.update |= UPDATE_ZBUF_ENABLED | UPDATE_COMBINE | UPDATE_TEXTURE | UPDATE_ALPHA_COMPARE; rdp.update |= UPDATE_ZBUF_ENABLED | UPDATE_COMBINE | UPDATE_TEXTURE | UPDATE_ALPHA_COMPARE;
if (g_settings->fog && (rdp.flags & FOG_ENABLED)) if (g_settings->fog && (rdp.flags & FOG_ENABLED))
grFogMode(GR_FOG_WITH_TABLE_ON_FOGCOORD_EXT); grFogMode(GR_FOG_WITH_TABLE_ON_FOGCOORD_EXT);
LRDP("CopyDepthBuffer draw, OK\n"); WriteTrace(TraceRDP, TraceDebug, "CopyDepthBuffer draw, OK");
rdp.tbuff_tex = 0; rdp.tbuff_tex = 0;
return TRUE; return TRUE;
} }
@ -590,7 +591,7 @@ int SwapTextureBuffer()
{ {
if (!rdp.tbuff_tex) if (!rdp.tbuff_tex)
return FALSE; return FALSE;
LRDP("SwapTextureBuffer."); WriteTrace(TraceRDP, TraceDebug, "SwapTextureBuffer.");
COLOR_IMAGE ci; COLOR_IMAGE ci;
ci.addr = rdp.tbuff_tex->addr; ci.addr = rdp.tbuff_tex->addr;
ci.format = rdp.tbuff_tex->format; ci.format = rdp.tbuff_tex->format;
@ -602,7 +603,7 @@ int SwapTextureBuffer()
TBUFF_COLOR_IMAGE * texbuf = AllocateTextureBuffer(ci); TBUFF_COLOR_IMAGE * texbuf = AllocateTextureBuffer(ci);
if (!texbuf) if (!texbuf)
{ {
LRDP("Failed!\n"); WriteTrace(TraceRDP, TraceDebug, "Failed!");
return FALSE; return FALSE;
} }
TexBufSetupCombiner(); TexBufSetupCombiner();
@ -657,7 +658,7 @@ int SwapTextureBuffer()
{ {
grFogMode(GR_FOG_WITH_TABLE_ON_FOGCOORD_EXT); grFogMode(GR_FOG_WITH_TABLE_ON_FOGCOORD_EXT);
} }
LRDP("SwapTextureBuffer draw, OK\n"); WriteTrace(TraceRDP, TraceDebug, "SwapTextureBuffer draw, OK");
return TRUE; return TRUE;
} }
@ -683,7 +684,7 @@ int FindTextureBuffer(uint32_t addr, uint16_t width)
{ {
if (rdp.skip_drawing) if (rdp.skip_drawing)
return FALSE; return FALSE;
FRDP("FindTextureBuffer. addr: %08lx, width: %d, scale_x: %f\n", addr, width, rdp.scale_x); WriteTrace(TraceRDP, TraceDebug, "FindTextureBuffer. addr: %08lx, width: %d, scale_x: %f", addr, width, rdp.scale_x);
int found = FALSE; int found = FALSE;
uint32_t shift = 0; uint32_t shift = 0;
for (int i = 0; i < voodoo.num_tmu && !found; i++) for (int i = 0; i < voodoo.num_tmu && !found; i++)
@ -709,7 +710,7 @@ int FindTextureBuffer(uint32_t addr, uint16_t width)
if (!rdp.cur_image) if (!rdp.cur_image)
rdp.cur_tex_buf = index; rdp.cur_tex_buf = index;
found = TRUE; found = TRUE;
// FRDP("FindTextureBuffer, found in TMU%d buffer: %d\n", rdp.tbuff_tex->tmu, j); // WriteTrace(TraceRDP, TraceDebug, "FindTextureBuffer, found in TMU%d buffer: %d", rdp.tbuff_tex->tmu, j);
} }
else //new texture is loaded into this place, texture buffer is not valid anymore else //new texture is loaded into this place, texture buffer is not valid anymore
{ {
@ -735,11 +736,11 @@ int FindTextureBuffer(uint32_t addr, uint16_t width)
rdp.tbuff_tex->v_shift = 0; rdp.tbuff_tex->v_shift = 0;
rdp.tbuff_tex->u_shift = 0; rdp.tbuff_tex->u_shift = 0;
} }
FRDP("FindTextureBuffer, found, u_shift: %d, v_shift: %d, format: %s\n", rdp.tbuff_tex->u_shift, rdp.tbuff_tex->v_shift, str_format[rdp.tbuff_tex->format]); WriteTrace(TraceRDP, TraceDebug, "FindTextureBuffer, found, u_shift: %d, v_shift: %d, format: %s", rdp.tbuff_tex->u_shift, rdp.tbuff_tex->v_shift, str_format[rdp.tbuff_tex->format]);
//FRDP("Buffer, addr=%08lx, end_addr=%08lx, width: %d, height: %d\n", rdp.tbuff_tex->addr, rdp.tbuff_tex->end_addr, rdp.tbuff_tex->width, rdp.tbuff_tex->height); //WriteTrace(TraceRDP, TraceDebug, "Buffer, addr=%08lx, end_addr=%08lx, width: %d, height: %d", rdp.tbuff_tex->addr, rdp.tbuff_tex->end_addr, rdp.tbuff_tex->width, rdp.tbuff_tex->height);
return TRUE; return TRUE;
} }
rdp.tbuff_tex = 0; rdp.tbuff_tex = 0;
LRDP("FindTextureBuffer, not found\n"); WriteTrace(TraceRDP, TraceDebug, "FindTextureBuffer, not found");
return FALSE; return FALSE;
} }

View File

@ -42,6 +42,7 @@
#include "Combine.h" #include "Combine.h"
#include "Util.h" #include "Util.h"
#include <Common/Util.h> #include <Common/Util.h>
#include <Glide64/trace.h>
void LoadTex(int id, int tmu); void LoadTex(int id, int tmu);
@ -173,7 +174,7 @@ uint32_t textureCRC(uint8_t *addr, int width, int height, int line)
void GetTexInfo(int id, int tile) void GetTexInfo(int id, int tile)
{ {
FRDP(" | |-+ GetTexInfo (id: %d, tile: %d)\n", id, tile); WriteTrace(TraceRDP, TraceDebug, " | |-+ GetTexInfo (id: %d, tile: %d)", id, tile);
// this is the NEW cache searching, searches only textures with similar crc's // this is the NEW cache searching, searches only textures with similar crc's
int t; int t;
@ -305,15 +306,15 @@ void GetTexInfo(int id, int tile)
info->splits = 1; info->splits = 1;
} }
LRDP(" | | |-+ Texture approved:\n"); WriteTrace(TraceRDP, TraceDebug, " | | |-+ Texture approved:");
FRDP(" | | | |- tmem: %08lx\n", rdp.tiles[tile].t_mem); WriteTrace(TraceRDP, TraceDebug, " | | | |- tmem: %08lx", rdp.tiles[tile].t_mem);
FRDP(" | | | |- load width: %d\n", width); WriteTrace(TraceRDP, TraceDebug, " | | | |- load width: %d", width);
FRDP(" | | | |- load height: %d\n", height); WriteTrace(TraceRDP, TraceDebug, " | | | |- load height: %d", height);
FRDP(" | | | |- actual width: %d\n", rdp.tiles[tile].width); WriteTrace(TraceRDP, TraceDebug, " | | | |- actual width: %d", rdp.tiles[tile].width);
FRDP(" | | | |- actual height: %d\n", rdp.tiles[tile].height); WriteTrace(TraceRDP, TraceDebug, " | | | |- actual height: %d", rdp.tiles[tile].height);
FRDP(" | | | |- size: %d\n", rdp.tiles[tile].size); WriteTrace(TraceRDP, TraceDebug, " | | | |- size: %d", rdp.tiles[tile].size);
FRDP(" | | | +- format: %d\n", rdp.tiles[tile].format); WriteTrace(TraceRDP, TraceDebug, " | | | +- format: %d", rdp.tiles[tile].format);
LRDP(" | | |- Calculating CRC... "); WriteTrace(TraceRDP, TraceDebug, " | | |- Calculating CRC... ");
// ** CRC CHECK // ** CRC CHECK
@ -332,7 +333,7 @@ void GetTexInfo(int id, int tile)
// Texture too big for tmem & needs to wrap? (trees in mm) // Texture too big for tmem & needs to wrap? (trees in mm)
if (rdp.tiles[tile].t_mem + minval(height, tile_height) * (rdp.tiles[tile].line << 3) > 4096) if (rdp.tiles[tile].t_mem + minval(height, tile_height) * (rdp.tiles[tile].line << 3) > 4096)
{ {
LRDP("TEXTURE WRAPS TMEM!!! "); WriteTrace(TraceRDP, TraceDebug, "TEXTURE WRAPS TMEM!!! ");
// calculate the y value that intersects at 4096 bytes // calculate the y value that intersects at 4096 bytes
int y = (4096 - rdp.tiles[tile].t_mem) / (rdp.tiles[tile].line << 3); int y = (4096 - rdp.tiles[tile].t_mem) / (rdp.tiles[tile].line << 3);
@ -346,7 +347,7 @@ void GetTexInfo(int id, int tile)
rdp.tiles[tile].mask_t = shift; rdp.tiles[tile].mask_t = shift;
// restart the function // restart the function
LRDP("restarting...\n"); WriteTrace(TraceRDP, TraceDebug, "restarting...");
GetTexInfo(id, tile); GetTexInfo(id, tile);
return; return;
} }
@ -411,7 +412,7 @@ void GetTexInfo(int id, int tile)
crc += rdp.pal_256_crc; crc += rdp.pal_256_crc;
} }
FRDP("Done. CRC is: %08lx.\n", crc); WriteTrace(TraceRDP, TraceDebug, "Done. CRC is: %08lx.", crc);
uint32_t flags = (rdp.tiles[tile].clamp_s << 23) | (rdp.tiles[tile].mirror_s << 22) | uint32_t flags = (rdp.tiles[tile].clamp_s << 23) | (rdp.tiles[tile].mirror_s << 22) |
(rdp.tiles[tile].mask_s << 18) | (rdp.tiles[tile].clamp_t << 17) | (rdp.tiles[tile].mask_s << 18) | (rdp.tiles[tile].clamp_t << 17) |
@ -431,7 +432,7 @@ void GetTexInfo(int id, int tile)
info->flags = flags; info->flags = flags;
// Search the texture cache for this texture // Search the texture cache for this texture
LRDP(" | | |-+ Checking cache...\n"); WriteTrace(TraceRDP, TraceDebug, " | | |-+ Checking cache...");
CACHE_LUT *cache; CACHE_LUT *cache;
@ -477,7 +478,7 @@ void GetTexInfo(int id, int tile)
(cache->mod_color2&mod_mask) == (modcolor2&mod_mask) && (cache->mod_color2&mod_mask) == (modcolor2&mod_mask) &&
abs((int)(cache->mod_factor - modfactor)) < 8)) abs((int)(cache->mod_factor - modfactor)) < 8))
{ {
FRDP(" | | | |- Texture found in cache (tmu=%d).\n", node->tmu); WriteTrace(TraceRDP, TraceDebug, " | | | |- Texture found in cache (tmu=%d).", node->tmu);
tex_found[id][node->tmu] = node->number; tex_found[id][node->tmu] = node->number;
if (voodoo.tex_UMA) if (voodoo.tex_UMA)
{ {
@ -490,7 +491,7 @@ void GetTexInfo(int id, int tile)
node = node->pNext; node = node->pNext;
} }
LRDP(" | | | +- Done.\n | | +- GetTexInfo end\n"); WriteTrace(TraceRDP, TraceDebug, " | | | +- Done.\n | | +- GetTexInfo end");
} }
//**************************************************************** //****************************************************************
@ -515,7 +516,7 @@ int ChooseBestTmu(int tmu1, int tmu2)
// SelectTBuffTex - select texture from texture buffer // SelectTBuffTex - select texture from texture buffer
static void SelectTBuffTex(TBUFF_COLOR_IMAGE * pTBuffTex) static void SelectTBuffTex(TBUFF_COLOR_IMAGE * pTBuffTex)
{ {
FRDP("SelectTBuffTex: tex: %d, tmu: %d, tile: %d\n", rdp.tex, pTBuffTex->tmu, pTBuffTex->tile); WriteTrace(TraceRDP, TraceDebug, "SelectTBuffTex: tex: %d, tmu: %d, tile: %d", rdp.tex, pTBuffTex->tmu, pTBuffTex->tile);
grTexSource(pTBuffTex->tile, pTBuffTex->tex_addr, GR_MIPMAPLEVELMASK_BOTH, &(pTBuffTex->info)); grTexSource(pTBuffTex->tile, pTBuffTex->tex_addr, GR_MIPMAPLEVELMASK_BOTH, &(pTBuffTex->info));
} }
@ -524,7 +525,7 @@ static void SelectTBuffTex(TBUFF_COLOR_IMAGE * pTBuffTex)
int SwapTextureBuffer(); int SwapTextureBuffer();
void TexCache() void TexCache()
{ {
LRDP(" |-+ TexCache called\n"); WriteTrace(TraceRDP, TraceDebug, " |-+ TexCache called");
#ifdef TEXTURE_FILTER /* Hiroshi Morii <koolsmoky@users.sourceforge.net> */ // POSTNAPALM #ifdef TEXTURE_FILTER /* Hiroshi Morii <koolsmoky@users.sourceforge.net> */ // POSTNAPALM
if (g_settings->ghq_use && g_settings->ghq_hirs_dump) { if (g_settings->ghq_use && g_settings->ghq_hirs_dump) {
@ -537,11 +538,11 @@ void TexCache()
extern void DisplayLoadProgress(const wchar_t *format, ...); extern void DisplayLoadProgress(const wchar_t *format, ...);
ghq_dmptex_toggle_key = !ghq_dmptex_toggle_key; ghq_dmptex_toggle_key = !ghq_dmptex_toggle_key;
if (ghq_dmptex_toggle_key) { if (ghq_dmptex_toggle_key) {
DisplayLoadProgress(L"Texture dump - ON\n"); DisplayLoadProgress(L"Texture dump - ON");
ClearCache(); ClearCache();
} }
else { else {
DisplayLoadProgress(L"Texture dump - OFF\n"); DisplayLoadProgress(L"Texture dump - OFF");
} }
pjutil::Sleep(1000); pjutil::Sleep(1000);
} }
@ -604,9 +605,9 @@ void TexCache()
tmu_1_mode = TMUMODE_NONE; tmu_1_mode = TMUMODE_NONE;
} }
FRDP(" | |-+ Modes set:\n | | |- tmu_0 = %d\n | | |- tmu_1 = %d\n", WriteTrace(TraceRDP, TraceDebug, " | |-+ Modes set:\n | | |- tmu_0 = %d\n | | |- tmu_1 = %d",
tmu_0, tmu_1); tmu_0, tmu_1);
FRDP(" | | |- tmu_0_mode = %d\n | | |- tmu_1_mode = %d\n", WriteTrace(TraceRDP, TraceDebug, " | | |- tmu_0_mode = %d\n | | |- tmu_1_mode = %d",
tmu_0_mode, tmu_1_mode); tmu_0_mode, tmu_1_mode);
if (tmu_0_mode == TMUMODE_PASSTHRU) { if (tmu_0_mode == TMUMODE_PASSTHRU) {
@ -733,7 +734,7 @@ void TexCache()
// Now actually combine // Now actually combine
if (cmb.cmb_ext_use) if (cmb.cmb_ext_use)
{ {
LRDP(" | | | |- combiner extension\n"); WriteTrace(TraceRDP, TraceDebug, " | | | |- combiner extension");
if (!(cmb.cmb_ext_use & COMBINE_EXT_COLOR)) if (!(cmb.cmb_ext_use & COMBINE_EXT_COLOR))
ColorCombinerToExtension(); ColorCombinerToExtension();
if (!(cmb.cmb_ext_use & COMBINE_EXT_ALPHA)) if (!(cmb.cmb_ext_use & COMBINE_EXT_ALPHA))
@ -762,7 +763,7 @@ void TexCache()
{ {
if (cmb.tex_cmb_ext_use) if (cmb.tex_cmb_ext_use)
{ {
LRDP(" | | | |- combiner extension tmu1\n"); WriteTrace(TraceRDP, TraceDebug, " | | | |- combiner extension tmu1");
if (!(cmb.tex_cmb_ext_use & TEX_COMBINE_EXT_COLOR)) if (!(cmb.tex_cmb_ext_use & TEX_COMBINE_EXT_COLOR))
TexColorCombinerToExtension(GR_TMU1); TexColorCombinerToExtension(GR_TMU1);
if (!(cmb.tex_cmb_ext_use & TEX_COMBINE_EXT_ALPHA)) if (!(cmb.tex_cmb_ext_use & TEX_COMBINE_EXT_ALPHA))
@ -790,7 +791,7 @@ void TexCache()
{ {
if (cmb.tex_cmb_ext_use) if (cmb.tex_cmb_ext_use)
{ {
LRDP(" | | | |- combiner extension tmu0\n"); WriteTrace(TraceRDP, TraceDebug, " | | | |- combiner extension tmu0");
if (!(cmb.tex_cmb_ext_use & TEX_COMBINE_EXT_COLOR)) if (!(cmb.tex_cmb_ext_use & TEX_COMBINE_EXT_COLOR))
TexColorCombinerToExtension(GR_TMU0); TexColorCombinerToExtension(GR_TMU0);
if (!(cmb.tex_cmb_ext_use & TEX_COMBINE_EXT_ALPHA)) if (!(cmb.tex_cmb_ext_use & TEX_COMBINE_EXT_ALPHA))
@ -820,7 +821,7 @@ void TexCache()
{ {
if (aTBuff[0] && aTBuff[0]->cache) if (aTBuff[0] && aTBuff[0]->cache)
{ {
LRDP(" | |- Hires tex T0 found in cache.\n"); WriteTrace(TraceRDP, TraceDebug, " | |- Hires tex T0 found in cache.");
if (GfxInitDone) if (GfxInitDone)
{ {
rdp.cur_cache[0] = aTBuff[0]->cache; rdp.cur_cache[0] = aTBuff[0]->cache;
@ -830,7 +831,7 @@ void TexCache()
} }
else if (tex_found[0][tmu_0] != -1) else if (tex_found[0][tmu_0] != -1)
{ {
LRDP(" | |- T0 found in cache.\n"); WriteTrace(TraceRDP, TraceDebug, " | |- T0 found in cache.");
if (GfxInitDone) if (GfxInitDone)
{ {
CACHE_LUT *cache = voodoo.tex_UMA ? &rdp.cache[0][tex_found[0][0]] : &rdp.cache[tmu_0][tex_found[0][tmu_0]]; CACHE_LUT *cache = voodoo.tex_UMA ? &rdp.cache[0][tex_found[0][0]] : &rdp.cache[tmu_0][tex_found[0][tmu_0]];
@ -851,7 +852,7 @@ void TexCache()
{ {
if (aTBuff[1] && aTBuff[1]->cache) if (aTBuff[1] && aTBuff[1]->cache)
{ {
LRDP(" | |- Hires tex T1 found in cache.\n"); WriteTrace(TraceRDP, TraceDebug, " | |- Hires tex T1 found in cache.");
if (GfxInitDone) if (GfxInitDone)
{ {
rdp.cur_cache[1] = aTBuff[1]->cache; rdp.cur_cache[1] = aTBuff[1]->cache;
@ -861,7 +862,7 @@ void TexCache()
} }
else if (tex_found[1][tmu_1] != -1) else if (tex_found[1][tmu_1] != -1)
{ {
LRDP(" | |- T1 found in cache.\n"); WriteTrace(TraceRDP, TraceDebug, " | |- T1 found in cache.");
if (GfxInitDone) if (GfxInitDone)
{ {
CACHE_LUT *cache = voodoo.tex_UMA ? &rdp.cache[0][tex_found[1][0]] : &rdp.cache[tmu_1][tex_found[1][tmu_1]]; CACHE_LUT *cache = voodoo.tex_UMA ? &rdp.cache[0][tex_found[1][0]] : &rdp.cache[tmu_1][tex_found[1][tmu_1]];
@ -958,7 +959,7 @@ void TexCache()
} }
} }
LRDP(" | +- TexCache End\n"); WriteTrace(TraceRDP, TraceDebug, " | +- TexCache End");
} }
#ifdef TEXTURE_FILTER #ifdef TEXTURE_FILTER
@ -1002,7 +1003,7 @@ inline uint32_t ReverseDXT(uint32_t val, uint32_t /*lrs*/, uint32_t width, uint3
void LoadTex(int id, int tmu) void LoadTex(int id, int tmu)
{ {
FRDP(" | |-+ LoadTex (id: %d, tmu: %d)\n", id, tmu); WriteTrace(TraceRDP, TraceDebug, " | |-+ LoadTex (id: %d, tmu: %d)", id, tmu);
int td = rdp.cur_tile + id; int td = rdp.cur_tile + id;
int lod, aspect; int lod, aspect;
@ -1014,7 +1015,7 @@ void LoadTex(int id, int tmu)
// Clear the cache if it's full // Clear the cache if it's full
if (rdp.n_cached[tmu] >= MAX_CACHE) if (rdp.n_cached[tmu] >= MAX_CACHE)
{ {
LRDP("Cache count reached, clearing...\n"); WriteTrace(TraceRDP, TraceDebug, "Cache count reached, clearing...");
ClearCache(); ClearCache();
if (id == 1 && rdp.tex == 3) if (id == 1 && rdp.tex == 3)
LoadTex(0, rdp.t0); LoadTex(0, rdp.t0);
@ -1263,7 +1264,7 @@ void LoadTex(int id, int tmu)
if (rdp.aTBuffTex[t] && rdp.aTBuffTex[t]->tile == id) //texture buffer will be used instead of frame buffer texture if (rdp.aTBuffTex[t] && rdp.aTBuffTex[t]->tile == id) //texture buffer will be used instead of frame buffer texture
{ {
rdp.aTBuffTex[t]->cache = cache; rdp.aTBuffTex[t]->cache = cache;
FRDP("tbuff_tex selected: %d, tile=%d\n", t, id); WriteTrace(TraceRDP, TraceDebug, "tbuff_tex selected: %d, tile=%d", t, id);
return; return;
} }
} }
@ -1345,7 +1346,7 @@ void LoadTex(int id, int tmu)
g64_crc = CRC32(g64_crc, &cache->mod_factor, 4); g64_crc = CRC32(g64_crc, &cache->mod_factor, 4);
cache->ricecrc = ext_ghq_checksum(addr, tile_width, tile_height, (unsigned short)(rdp.tiles[td].format << 8 | rdp.tiles[td].size), bpl, paladdr); cache->ricecrc = ext_ghq_checksum(addr, tile_width, tile_height, (unsigned short)(rdp.tiles[td].format << 8 | rdp.tiles[td].size), bpl, paladdr);
FRDP("CI RICE CRC. format: %d, size: %d, CRC: %08lx, PalCRC: %08lx\n", rdp.tiles[td].format, rdp.tiles[td].size, (uint32_t)(cache->ricecrc & 0xFFFFFFFF), (uint32_t)(cache->ricecrc >> 32)); WriteTrace(TraceRDP, TraceDebug, "CI RICE CRC. format: %d, size: %d, CRC: %08lx, PalCRC: %08lx", rdp.tiles[td].format, rdp.tiles[td].size, (uint32_t)(cache->ricecrc & 0xFFFFFFFF), (uint32_t)(cache->ricecrc >> 32));
if (ext_ghq_hirestex((uint64)g64_crc, cache->ricecrc, palette, &ghqTexInfo)) if (ext_ghq_hirestex((uint64)g64_crc, cache->ricecrc, palette, &ghqTexInfo))
{ {
cache->is_hires_tex = ghqTexInfo.is_hires_tex; cache->is_hires_tex = ghqTexInfo.is_hires_tex;
@ -1797,7 +1798,7 @@ void LoadTex(int id, int tmu)
// Check for end of memory (too many textures to fit, clear cache) // Check for end of memory (too many textures to fit, clear cache)
if (voodoo.tmem_ptr[tmu] + texture_size >= voodoo.tex_max_addr[tmu]) if (voodoo.tmem_ptr[tmu] + texture_size >= voodoo.tex_max_addr[tmu])
{ {
LRDP("Cache size reached, clearing...\n"); WriteTrace(TraceRDP, TraceDebug, "Cache size reached, clearing...");
ClearCache(); ClearCache();
if (id == 1 && rdp.tex == 3) if (id == 1 && rdp.tex == 3)
@ -1820,5 +1821,5 @@ void LoadTex(int id, int tmu)
t_info); t_info);
} }
LRDP(" | | +- LoadTex end\n"); WriteTrace(TraceRDP, TraceDebug, " | | +- LoadTex end");
} }

View File

@ -47,6 +47,7 @@
#include "Debugger.h" #include "Debugger.h"
#include "TexCache.h" #include "TexCache.h"
#include "DepthBufferRender.h" #include "DepthBufferRender.h"
#include <Glide64/trace.h>
#define Vj rdp.vtxbuf2[j] #define Vj rdp.vtxbuf2[j]
#define Vi rdp.vtxbuf2[i] #define Vi rdp.vtxbuf2[i]
@ -77,7 +78,7 @@ int cull_tri(VERTEX **v) // type changed to VERTEX** [Dave2001]
if (v[0]->scr_off & v[1]->scr_off & v[2]->scr_off) if (v[0]->scr_off & v[1]->scr_off & v[2]->scr_off)
{ {
LRDP(" clipped\n"); WriteTrace(TraceRDP, TraceDebug, " clipped");
return TRUE; return TRUE;
} }
@ -120,13 +121,13 @@ int cull_tri(VERTEX **v) // type changed to VERTEX** [Dave2001]
if ((iarea & 0x7FFFFFFF) == 0) if ((iarea & 0x7FFFFFFF) == 0)
{ {
LRDP(" zero area triangles\n"); WriteTrace(TraceRDP, TraceDebug, " zero area triangles");
return TRUE; return TRUE;
} }
if ((rdp.flags & CULLMASK) && ((int)(iarea ^ mode)) >= 0) if ((rdp.flags & CULLMASK) && ((int)(iarea ^ mode)) >= 0)
{ {
LRDP(" culled\n"); WriteTrace(TraceRDP, TraceDebug, " culled");
return TRUE; return TRUE;
} }
#else #else
@ -143,7 +144,7 @@ int cull_tri(VERTEX **v) // type changed to VERTEX** [Dave2001]
// if ((x1*y2 - y1*x2) < 0.0f) //counter-clockwise, positive // if ((x1*y2 - y1*x2) < 0.0f) //counter-clockwise, positive
if ((y1*x2-x1*y2) < 0.0f) //counter-clockwise, positive if ((y1*x2-x1*y2) < 0.0f) //counter-clockwise, positive
{ {
LRDP (" culled!\n"); WriteTrace(TraceRDP, TraceDebug, " culled!");
return TRUE; return TRUE;
} }
return FALSE; return FALSE;
@ -151,7 +152,7 @@ int cull_tri(VERTEX **v) // type changed to VERTEX** [Dave2001]
// if ((x1*y2 - y1*x2) >= 0.0f) //clockwise, negative // if ((x1*y2 - y1*x2) >= 0.0f) //clockwise, negative
if ((y1*x2-x1*y2) >= 0.0f) //clockwise, negative if ((y1*x2-x1*y2) >= 0.0f) //clockwise, negative
{ {
LRDP (" culled!\n"); WriteTrace(TraceRDP, TraceDebug, " culled!");
return TRUE; return TRUE;
} }
return FALSE; return FALSE;
@ -327,9 +328,7 @@ void draw_tri(VERTEX **vtx, uint16_t linew)
if (v->uv_calculated != rdp.tex_ctr) if (v->uv_calculated != rdp.tex_ctr)
{ {
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, " * CALCULATING VERTEX U/V: %d", v->number);
FRDP(" * CALCULATING VERTEX U/V: %d\n", v->number);
#endif
v->uv_calculated = rdp.tex_ctr; v->uv_calculated = rdp.tex_ctr;
if (!(rdp.geom_mode & 0x00020000)) if (!(rdp.geom_mode & 0x00020000))
@ -343,15 +342,11 @@ void draw_tri(VERTEX **vtx, uint16_t linew)
v->b = vtx[flag]->b; v->b = vtx[flag]->b;
v->g = vtx[flag]->g; v->g = vtx[flag]->g;
v->r = vtx[flag]->r; v->r = vtx[flag]->r;
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, " * Flat shaded, flag%d - r: %d, g: %d, b: %d, a: %d", flag, v->r, v->g, v->b, v->a);
FRDP(" * Flat shaded, flag%d - r: %d, g: %d, b: %d, a: %d\n", flag, v->r, v->g, v->b, v->a);
#endif
} }
else // prim color else // prim color
{ {
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, " * Prim shaded %08lx", rdp.prim_color);
FRDP(" * Prim shaded %08lx\n", rdp.prim_color);
#endif
v->a = (uint8_t)(rdp.prim_color & 0xFF); v->a = (uint8_t)(rdp.prim_color & 0xFF);
v->b = (uint8_t)((rdp.prim_color >> 8) & 0xFF); v->b = (uint8_t)((rdp.prim_color >> 8) & 0xFF);
v->g = (uint8_t)((rdp.prim_color >> 16) & 0xFF); v->g = (uint8_t)((rdp.prim_color >> 16) & 0xFF);
@ -407,9 +402,7 @@ void draw_tri(VERTEX **vtx, uint16_t linew)
v->v0 -= rdp.tiles[rdp.cur_tile].f_ul_t; //required for megaman (boss special attack) v->v0 -= rdp.tiles[rdp.cur_tile].f_ul_t; //required for megaman (boss special attack)
v->u0 *= rdp.aTBuffTex[0]->u_scale; v->u0 *= rdp.aTBuffTex[0]->u_scale;
v->v0 *= rdp.aTBuffTex[0]->v_scale; v->v0 *= rdp.aTBuffTex[0]->v_scale;
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "tbuff_tex t0: (%f, %f)->(%f, %f)", v->ou, v->ov, v->u0, v->v0);
FRDP("tbuff_tex t0: (%f, %f)->(%f, %f)\n", v->ou, v->ov, v->u0, v->v0);
#endif
} }
else else
{ {
@ -450,9 +443,7 @@ void draw_tri(VERTEX **vtx, uint16_t linew)
v->u1 -= rdp.tiles[rdp.cur_tile].f_ul_s; v->u1 -= rdp.tiles[rdp.cur_tile].f_ul_s;
v->u1 *= rdp.aTBuffTex[1]->u_scale; v->u1 *= rdp.aTBuffTex[1]->u_scale;
v->v1 *= rdp.aTBuffTex[1]->v_scale; v->v1 *= rdp.aTBuffTex[1]->v_scale;
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "tbuff_tex t1: (%f, %f)->(%f, %f)", v->ou, v->ov, v->u1, v->v1);
FRDP("tbuff_tex t1: (%f, %f)->(%f, %f)\n", v->ou, v->ov, v->u1, v->v1);
#endif
} }
else else
{ {
@ -465,11 +456,9 @@ void draw_tri(VERTEX **vtx, uint16_t linew)
v->u1_w = v->u1 / v->w; v->u1_w = v->u1 / v->w;
v->v1_w = v->v1 / v->w; v->v1_w = v->v1 / v->w;
} }
// FRDP(" * CALCULATING VERTEX U/V: %d u0: %f, v0: %f, u1: %f, v1: %f\n", v->number, v->u0, v->v0, v->u1, v->v1); // WriteTrace(TraceRDP, TraceDebug, " * CALCULATING VERTEX U/V: %d u0: %f, v0: %f, u1: %f, v1: %f", v->number, v->u0, v->v0, v->u1, v->v1);
} }
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "draw_tri. v[%d] ou=%f, ov = %f", i, v->ou, v->ov);
FRDP("draw_tri. v[%d] ou=%f, ov = %f\n", i, v->ou, v->ov);
#endif
if (v->shade_mod != cmb.shade_mod_hash) if (v->shade_mod != cmb.shade_mod_hash)
apply_shade_mods(v); apply_shade_mods(v);
} //for } //for
@ -765,9 +754,7 @@ void do_triangle_stuff(uint16_t linew, int old_interpolate) // what else?? do th
{ {
if (rdp.vtxbuf[i].not_zclipped)// && rdp.zsrc != 1) if (rdp.vtxbuf[i].not_zclipped)// && rdp.zsrc != 1)
{ {
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, " * NOT ZCLIPPPED: %d", rdp.vtxbuf[i].number);
FRDP (" * NOT ZCLIPPPED: %d\n", rdp.vtxbuf[i].number);
#endif
rdp.vtxbuf[i].x = rdp.vtxbuf[i].sx; rdp.vtxbuf[i].x = rdp.vtxbuf[i].sx;
rdp.vtxbuf[i].y = rdp.vtxbuf[i].sy; rdp.vtxbuf[i].y = rdp.vtxbuf[i].sy;
rdp.vtxbuf[i].z = rdp.vtxbuf[i].sz; rdp.vtxbuf[i].z = rdp.vtxbuf[i].sz;
@ -779,9 +766,7 @@ void do_triangle_stuff(uint16_t linew, int old_interpolate) // what else?? do th
} }
else else
{ {
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, " * ZCLIPPED: %d", rdp.vtxbuf[i].number);
FRDP (" * ZCLIPPED: %d\n", rdp.vtxbuf[i].number);
#endif
rdp.vtxbuf[i].q = 1.0f / rdp.vtxbuf[i].w; rdp.vtxbuf[i].q = 1.0f / rdp.vtxbuf[i].w;
rdp.vtxbuf[i].x = rdp.view_trans[0] + rdp.vtxbuf[i].x * rdp.vtxbuf[i].q * rdp.view_scale[0] + rdp.offset_x; rdp.vtxbuf[i].x = rdp.view_trans[0] + rdp.vtxbuf[i].x * rdp.vtxbuf[i].q * rdp.view_scale[0] + rdp.offset_x;
rdp.vtxbuf[i].y = rdp.view_trans[1] + rdp.vtxbuf[i].y * rdp.vtxbuf[i].q * rdp.view_scale[1] + rdp.offset_y; rdp.vtxbuf[i].y = rdp.view_trans[1] + rdp.vtxbuf[i].y * rdp.vtxbuf[i].q * rdp.view_scale[1] + rdp.offset_y;
@ -1028,7 +1013,7 @@ static void CalculateLOD(VERTEX *v, int n)
grTexDetailControl(GR_TMU0, cmb.dc0_lodbias, cmb.dc0_detailscale, detailmax); grTexDetailControl(GR_TMU0, cmb.dc0_lodbias, cmb.dc0_detailscale, detailmax);
if (voodoo.num_tmu == 2) if (voodoo.num_tmu == 2)
grTexDetailControl(GR_TMU1, cmb.dc1_lodbias, cmb.dc1_detailscale, detailmax); grTexDetailControl(GR_TMU1, cmb.dc1_lodbias, cmb.dc1_detailscale, detailmax);
FRDP("CalculateLOD factor: %f, tile: %d, lod_fraction: %f\n", (float)lodFactor, lod_tile, lod_fraction); WriteTrace(TraceRDP, TraceDebug, "CalculateLOD factor: %f, tile: %d, lod_fraction: %f", (float)lodFactor, lod_tile, lod_fraction);
} }
float ScaleZ(float z) float ScaleZ(float z)
@ -1075,21 +1060,6 @@ static void DepthBuffer(VERTEX * vtx, int n)
vtx[i].z = ScaleZ(vtx[i].z); vtx[i].z = ScaleZ(vtx[i].z);
} }
/*
std::ofstream loga;
#define LOGG(x) loga.open("glide_log.txt",std::ios::app); loga << x; loga.flush(); loga.close();
__inline void FRDP2(char *fmt, ...)
{
va_list ap;
va_start(ap, fmt);
vsprintf(out_buf, fmt, ap);
LOGG(out_buf);
va_end(ap);
}
//*/
//#define LOGG(x)
//#define FRDP2(x)
void clip_tri(int interpolate_colors) void clip_tri(int interpolate_colors)
{ {
int i, j, index, n = rdp.n_global; int i, j, index, n = rdp.n_global;
@ -1493,7 +1463,7 @@ static void render_tri(uint16_t linew, int old_interpolate)
int n = rdp.n_global; int n = rdp.n_global;
if (n < 3) if (n < 3)
{ {
FRDP(" * render_tri: n < 3\n"); WriteTrace(TraceRDP, TraceDebug, " * render_tri: n < 3");
return; return;
} }
int i, j; int i, j;
@ -1511,7 +1481,7 @@ static void render_tri(uint16_t linew, int old_interpolate)
} }
if (!to_render) //all z < 0 if (!to_render) //all z < 0
{ {
FRDP(" * render_tri: all z < 0\n"); WriteTrace(TraceRDP, TraceDebug, " * render_tri: all z < 0");
return; return;
} }
} }
@ -1566,22 +1536,6 @@ static void render_tri(uint16_t linew, int old_interpolate)
InterpolateColors2(*v1, *v2, rdp.vtxbuf[i], percent); InterpolateColors2(*v1, *v2, rdp.vtxbuf[i], percent);
} }
} }
/*
if (rdp.clip)
{
LOGG("Colors before clipping:\n");
unsigned int k;
for(k=0; k<3; k++)
{
FRDP2("V%d: r=%d, g=%d, b=%d, a=%d, f=%d\n", k, org_vtx[k]->r, org_vtx[k]->g, org_vtx[k]->b, org_vtx[k]->a, (short)org_vtx[k]->f);
}
FRDP("Got %d vertex after clipping\n", n);
for(k=0; k<n; k++)
{
FRDP("V%d: r=%d, g=%d, b=%d, a=%d, f=%d\n", k, rdp.vtxbuf[k].r, rdp.vtxbuf[k].g, rdp.vtxbuf[k].b, rdp.vtxbuf[k].a, (short)rdp.vtxbuf[k].f);
}
}
*/
ConvertCoordsConvert(rdp.vtxbuf, n); ConvertCoordsConvert(rdp.vtxbuf, n);
if (rdp.fog_mode == RDP::fog_enabled) if (rdp.fog_mode == RDP::fog_enabled)
@ -1618,7 +1572,7 @@ static void render_tri(uint16_t linew, int old_interpolate)
{ {
for (int k = 0; k < 3; k++) for (int k = 0; k < 3; k++)
{ {
FRDP("v%d %f->%f, width: %d. height: %d, tex_width: %d, tex_height: %d, lr_u: %f, lr_v: %f\n", k, vv0[k], pv[k]->v1, rdp.tbuff_tex->width, rdp.tbuff_tex->height, rdp.tbuff_tex->tex_width, rdp.tbuff_tex->tex_height, rdp.tbuff_tex->lr_u, rdp.tbuff_tex->lr_v); WriteTrace(TraceRDP, TraceDebug, "v%d %f->%f, width: %d. height: %d, tex_width: %d, tex_height: %d, lr_u: %f, lr_v: %f", k, vv0[k], pv[k]->v1, rdp.tbuff_tex->width, rdp.tbuff_tex->height, rdp.tbuff_tex->tex_width, rdp.tbuff_tex->tex_height, rdp.tbuff_tex->lr_u, rdp.tbuff_tex->lr_v);
} }
} }
*/ */
@ -1636,7 +1590,7 @@ static void render_tri(uint16_t linew, int old_interpolate)
{ {
// VERTEX ** pv = rdp.vtx_buffer?(vtx_list2):(vtx_list1); // VERTEX ** pv = rdp.vtx_buffer?(vtx_list2):(vtx_list1);
// for (int k = 0; k < n; k ++) // for (int k = 0; k < n; k ++)
// FRDP ("DRAW[%d]: v.x = %f, v.y = %f, v.z = %f, v.u = %f, v.v = %f\n", k, pv[k]->x, pv[k]->y, pv[k]->z, pv[k]->coord[rdp.t0<<1], pv[k]->coord[(rdp.t0<<1)+1]); // WriteTrace(TraceRDP, TraceDebug, "DRAW[%d]: v.x = %f, v.y = %f, v.z = %f, v.u = %f, v.v = %f", k, pv[k]->x, pv[k]->y, pv[k]->z, pv[k]->coord[rdp.t0<<1], pv[k]->coord[(rdp.t0<<1)+1]);
// pv[k]->y = g_settings->res_y - pv[k]->y; // pv[k]->y = g_settings->res_y - pv[k]->y;
if (linew > 0) if (linew > 0)
@ -1704,7 +1658,7 @@ static void render_tri(uint16_t linew, int old_interpolate)
void add_tri(VERTEX *v, int n, int type) void add_tri(VERTEX *v, int n, int type)
{ {
//FRDP ("ENTER (%f, %f, %f), (%f, %f, %f), (%f, %f, %f)\n", v[0].x, v[0].y, v[0].w, //WriteTrace(TraceRDP, TraceDebug, "ENTER (%f, %f, %f), (%f, %f, %f), (%f, %f, %f)", v[0].x, v[0].y, v[0].w,
// v[1].x, v[1].y, v[1].w, v[2].x, v[2].y, v[2].w); // v[1].x, v[1].y, v[1].w, v[2].x, v[2].y, v[2].w);
// Debug capture // Debug capture
@ -1792,7 +1746,7 @@ void update_scissor()
//Values are inclusive for minimum x and y values and exclusive for maximum x and y values. //Values are inclusive for minimum x and y values and exclusive for maximum x and y values.
// grClipWindow (rdp.scissor.ul_x?rdp.scissor.ul_x+1:0, rdp.scissor.ul_y?rdp.scissor.ul_y+1:0, rdp.scissor.lr_x, rdp.scissor.lr_y); // grClipWindow (rdp.scissor.ul_x?rdp.scissor.ul_x+1:0, rdp.scissor.ul_y?rdp.scissor.ul_y+1:0, rdp.scissor.lr_x, rdp.scissor.lr_y);
grClipWindow(rdp.scissor.ul_x, rdp.scissor.ul_y, rdp.scissor.lr_x, rdp.scissor.lr_y); grClipWindow(rdp.scissor.ul_x, rdp.scissor.ul_y, rdp.scissor.lr_x, rdp.scissor.lr_y);
FRDP(" |- scissor - (%d, %d) -> (%d, %d)\n", rdp.scissor.ul_x, rdp.scissor.ul_y, rdp.scissor.lr_x, rdp.scissor.lr_y); WriteTrace(TraceRDP, TraceDebug, " |- scissor - (%d, %d) -> (%d, %d)", rdp.scissor.ul_x, rdp.scissor.ul_y, rdp.scissor.lr_x, rdp.scissor.lr_y);
} }
} }
@ -1814,12 +1768,12 @@ typedef struct
void update() void update()
{ {
LRDP("-+ update called\n"); WriteTrace(TraceRDP, TraceDebug, "-+ update called");
// Check for rendermode changes // Check for rendermode changes
// Z buffer // Z buffer
if (rdp.render_mode_changed & 0x00000C30) if (rdp.render_mode_changed & 0x00000C30)
{ {
FRDP(" |- render_mode_changed zbuf - decal: %s, update: %s, compare: %s\n", WriteTrace(TraceRDP, TraceDebug, " |- render_mode_changed zbuf - decal: %s, update: %s, compare: %s",
str_yn[(rdp.othermode_l & 0x00000400) ? 1 : 0], str_yn[(rdp.othermode_l & 0x00000400) ? 1 : 0],
str_yn[(rdp.othermode_l & 0x00000020) ? 1 : 0], str_yn[(rdp.othermode_l & 0x00000020) ? 1 : 0],
str_yn[(rdp.othermode_l & 0x00000010) ? 1 : 0]); str_yn[(rdp.othermode_l & 0x00000010) ? 1 : 0]);
@ -1843,7 +1797,7 @@ void update()
// Alpha compare // Alpha compare
if (rdp.render_mode_changed & 0x00001000) if (rdp.render_mode_changed & 0x00001000)
{ {
FRDP(" |- render_mode_changed alpha compare - on: %s\n", WriteTrace(TraceRDP, TraceDebug, " |- render_mode_changed alpha compare - on: %s",
str_yn[(rdp.othermode_l & 0x00001000) ? 1 : 0]); str_yn[(rdp.othermode_l & 0x00001000) ? 1 : 0]);
rdp.render_mode_changed &= ~0x00001000; rdp.render_mode_changed &= ~0x00001000;
rdp.update |= UPDATE_ALPHA_COMPARE; rdp.update |= UPDATE_ALPHA_COMPARE;
@ -1856,7 +1810,7 @@ void update()
if (rdp.render_mode_changed & 0x00002000) // alpha cvg sel if (rdp.render_mode_changed & 0x00002000) // alpha cvg sel
{ {
FRDP(" |- render_mode_changed alpha cvg sel - on: %s\n", WriteTrace(TraceRDP, TraceDebug, " |- render_mode_changed alpha cvg sel - on: %s",
str_yn[(rdp.othermode_l & 0x00002000) ? 1 : 0]); str_yn[(rdp.othermode_l & 0x00002000) ? 1 : 0]);
rdp.render_mode_changed &= ~0x00002000; rdp.render_mode_changed &= ~0x00002000;
rdp.update |= UPDATE_COMBINE; rdp.update |= UPDATE_COMBINE;
@ -1866,7 +1820,7 @@ void update()
// Force blend // Force blend
if (rdp.render_mode_changed & 0xFFFF0000) if (rdp.render_mode_changed & 0xFFFF0000)
{ {
FRDP(" |- render_mode_changed force_blend - %08lx\n", rdp.othermode_l & 0xFFFF0000); WriteTrace(TraceRDP, TraceDebug, " |- render_mode_changed force_blend - %08lx", rdp.othermode_l & 0xFFFF0000);
rdp.render_mode_changed &= 0x0000FFFF; rdp.render_mode_changed &= 0x0000FFFF;
rdp.fbl_a0 = (uint8_t)((rdp.othermode_l >> 30) & 0x3); rdp.fbl_a0 = (uint8_t)((rdp.othermode_l >> 30) & 0x3);
@ -1892,7 +1846,7 @@ void update()
rdp.aTBuffTex[0] = aTBuff[0]; rdp.aTBuffTex[0] = aTBuff[0];
rdp.aTBuffTex[1] = aTBuff[1]; rdp.aTBuffTex[1] = aTBuff[1];
LRDP(" |-+ update_combine\n"); WriteTrace(TraceRDP, TraceDebug, " |-+ update_combine");
Combine(); Combine();
} }
@ -1969,7 +1923,7 @@ void update()
uint8_t reference = (uint8_t)(rdp.blend_color & 0xFF); uint8_t reference = (uint8_t)(rdp.blend_color & 0xFF);
grAlphaTestFunction(reference ? GR_CMP_GEQUAL : GR_CMP_GREATER); grAlphaTestFunction(reference ? GR_CMP_GEQUAL : GR_CMP_GREATER);
grAlphaTestReferenceValue(reference); grAlphaTestReferenceValue(reference);
FRDP(" |- alpha compare: blend: %02lx\n", reference); WriteTrace(TraceRDP, TraceDebug, " |- alpha compare: blend: %02lx", reference);
} }
else else
{ {
@ -1979,7 +1933,7 @@ void update()
{ {
grAlphaTestFunction(GR_CMP_GEQUAL); grAlphaTestFunction(GR_CMP_GEQUAL);
grAlphaTestReferenceValue(0x20);//0xA0); grAlphaTestReferenceValue(0x20);//0xA0);
LRDP(" |- alpha compare: 0x20\n"); WriteTrace(TraceRDP, TraceDebug, " |- alpha compare: 0x20");
} }
else else
{ {
@ -1987,19 +1941,19 @@ void update()
if (rdp.acmp == 3) if (rdp.acmp == 3)
{ {
grAlphaTestReferenceValue((uint8_t)(rdp.blend_color & 0xFF)); grAlphaTestReferenceValue((uint8_t)(rdp.blend_color & 0xFF));
FRDP(" |- alpha compare: blend: %02lx\n", rdp.blend_color & 0xFF); WriteTrace(TraceRDP, TraceDebug, " |- alpha compare: blend: %02lx", rdp.blend_color & 0xFF);
} }
else else
{ {
grAlphaTestReferenceValue(0x00); grAlphaTestReferenceValue(0x00);
LRDP(" |- alpha compare: 0x00\n"); WriteTrace(TraceRDP, TraceDebug, " |- alpha compare: 0x00");
} }
} }
} }
else else
{ {
grAlphaTestFunction(GR_CMP_ALWAYS); grAlphaTestFunction(GR_CMP_ALWAYS);
LRDP(" |- alpha compare: none\n"); WriteTrace(TraceRDP, TraceDebug, " |- alpha compare: none");
} }
} }
if (rdp.acmp == 3 && rdp.cycle_mode < 2) if (rdp.acmp == 3 && rdp.cycle_mode < 2)
@ -2007,7 +1961,7 @@ void update()
if (grStippleModeExt != 0) if (grStippleModeExt != 0)
{ {
if (g_settings->old_style_adither || rdp.alpha_dither_mode != 3) { if (g_settings->old_style_adither || rdp.alpha_dither_mode != 3) {
LRDP(" |- alpha compare: dither\n"); WriteTrace(TraceRDP, TraceDebug, " |- alpha compare: dither");
grStippleModeExt(g_settings->stipple_mode); grStippleModeExt(g_settings->stipple_mode);
} }
else else
@ -2018,7 +1972,7 @@ void update()
{ {
if (grStippleModeExt) if (grStippleModeExt)
{ {
//LRDP (" |- alpha compare: dither disabled\n"); //WriteTrace(TraceRDP, TraceDebug, " |- alpha compare: dither disabled");
grStippleModeExt(GR_STIPPLE_DISABLE); grStippleModeExt(GR_STIPPLE_DISABLE);
} }
} }
@ -2028,7 +1982,7 @@ void update()
{ {
rdp.update ^= UPDATE_CULL_MODE; rdp.update ^= UPDATE_CULL_MODE;
uint32_t mode = (rdp.flags & CULLMASK) >> CULLSHIFT; uint32_t mode = (rdp.flags & CULLMASK) >> CULLSHIFT;
FRDP(" |- cull_mode - mode: %s\n", str_cull[mode]); WriteTrace(TraceRDP, TraceDebug, " |- cull_mode - mode: %s", str_cull[mode]);
switch (mode) switch (mode)
{ {
case 0: // cull none case 0: // cull none
@ -2060,11 +2014,11 @@ void update()
grFogColorValue(rdp.fog_color); grFogColorValue(rdp.fog_color);
grFogMode(GR_FOG_WITH_TABLE_ON_FOGCOORD_EXT); grFogMode(GR_FOG_WITH_TABLE_ON_FOGCOORD_EXT);
rdp.fog_mode = RDP::fog_enabled; rdp.fog_mode = RDP::fog_enabled;
LRDP("fog enabled \n"); WriteTrace(TraceRDP, TraceDebug, "fog enabled ");
} }
else else
{ {
LRDP("fog disabled in blender\n"); WriteTrace(TraceRDP, TraceDebug, "fog disabled in blender");
rdp.fog_mode = RDP::fog_disabled; rdp.fog_mode = RDP::fog_disabled;
grFogMode(GR_FOG_DISABLE); grFogMode(GR_FOG_DISABLE);
} }
@ -2074,18 +2028,18 @@ void update()
grFogColorValue(rdp.fog_color); grFogColorValue(rdp.fog_color);
grFogMode(GR_FOG_WITH_TABLE_ON_FOGCOORD_EXT); grFogMode(GR_FOG_WITH_TABLE_ON_FOGCOORD_EXT);
rdp.fog_mode = RDP::fog_blend; rdp.fog_mode = RDP::fog_blend;
LRDP("fog blend \n"); WriteTrace(TraceRDP, TraceDebug, "fog blend ");
} }
else if (blender == 0x04d1) else if (blender == 0x04d1)
{ {
grFogColorValue(rdp.fog_color); grFogColorValue(rdp.fog_color);
grFogMode(GR_FOG_WITH_TABLE_ON_FOGCOORD_EXT); grFogMode(GR_FOG_WITH_TABLE_ON_FOGCOORD_EXT);
rdp.fog_mode = RDP::fog_blend_inverse; rdp.fog_mode = RDP::fog_blend_inverse;
LRDP("fog blend \n"); WriteTrace(TraceRDP, TraceDebug, "fog blend ");
} }
else else
{ {
LRDP("fog disabled\n"); WriteTrace(TraceRDP, TraceDebug, "fog disabled");
rdp.fog_mode = RDP::fog_disabled; rdp.fog_mode = RDP::fog_disabled;
grFogMode(GR_FOG_DISABLE); grFogMode(GR_FOG_DISABLE);
} }
@ -2102,7 +2056,7 @@ void update()
rdp.clip_max_x = minval((rdp.view_trans[0] + scale_x + rdp.offset_x) * rdp.clip_ratio, g_settings->res_x); rdp.clip_max_x = minval((rdp.view_trans[0] + scale_x + rdp.offset_x) * rdp.clip_ratio, g_settings->res_x);
rdp.clip_max_y = minval((rdp.view_trans[1] + scale_y + rdp.offset_y) * rdp.clip_ratio, g_settings->res_y); rdp.clip_max_y = minval((rdp.view_trans[1] + scale_y + rdp.offset_y) * rdp.clip_ratio, g_settings->res_y);
FRDP(" |- viewport - (%d, %d, %d, %d)\n", (uint32_t)rdp.clip_min_x, (uint32_t)rdp.clip_min_y, (uint32_t)rdp.clip_max_x, (uint32_t)rdp.clip_max_y); WriteTrace(TraceRDP, TraceDebug, " |- viewport - (%d, %d, %d, %d)", (uint32_t)rdp.clip_min_x, (uint32_t)rdp.clip_min_y, (uint32_t)rdp.clip_max_x, (uint32_t)rdp.clip_max_y);
if (!rdp.scissor_set) if (!rdp.scissor_set)
{ {
rdp.scissor.ul_x = (uint32_t)rdp.clip_min_x; rdp.scissor.ul_x = (uint32_t)rdp.clip_min_x;
@ -2118,7 +2072,7 @@ void update()
update_scissor(); update_scissor();
} }
LRDP(" + update end\n"); WriteTrace(TraceRDP, TraceDebug, " + update end");
} }
void set_message_combiner() void set_message_combiner()

View File

@ -314,7 +314,7 @@ void microcheck()
uc_crc += ((uint32_t*)microcode)[i]; uc_crc += ((uint32_t*)microcode)[i];
} }
FRDP_E("crc: %08lx\n", uc_crc); WriteTrace(TraceRDP, TraceWarning, "crc: %08lx", uc_crc);
#ifdef LOG_UCODE #ifdef LOG_UCODE
std::ofstream ucf; std::ofstream ucf;
@ -328,7 +328,7 @@ void microcheck()
ucf.close(); ucf.close();
#endif #endif
FRDP("ucode = %08lx\n", uc_crc); WriteTrace(TraceRDP, TraceDebug, "ucode = %08lx", uc_crc);
RegisterSetting(Set_ucodeLookup, Data_DWORD_RDB_Setting, stdstr_f("%08lx", uc_crc).c_str(), "ucode", (unsigned int)-2, NULL); RegisterSetting(Set_ucodeLookup, Data_DWORD_RDB_Setting, stdstr_f("%08lx", uc_crc).c_str(), "ucode", (unsigned int)-2, NULL);
int uc = GetSetting(Set_ucodeLookup); int uc = GetSetting(Set_ucodeLookup);
@ -362,7 +362,7 @@ void microcheck()
{ {
old_ucode = g_settings->ucode; old_ucode = g_settings->ucode;
g_settings->ucode = uc; g_settings->ucode = uc;
FRDP("microcheck: old ucode: %d, new ucode: %d\n", old_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;
@ -421,7 +421,7 @@ static void copyWhiteToRDRAM()
static void CopyFrameBuffer(GrBuffer_t buffer = GR_BUFFER_BACKBUFFER) static void CopyFrameBuffer(GrBuffer_t buffer = GR_BUFFER_BACKBUFFER)
{ {
FRDP("CopyFrameBuffer: %08lx... ", rdp.cimg); WriteTrace(TraceRDP, TraceDebug, "CopyFrameBuffer: %08lx... ", rdp.cimg);
// don't bother to write the stuff in asm... the slow part is the read from video card, // don't bother to write the stuff in asm... the slow part is the read from video card,
// not the copy. // not the copy.
@ -439,7 +439,7 @@ static void CopyFrameBuffer(GrBuffer_t buffer = GR_BUFFER_BACKBUFFER)
if (g_settings->hacks&hack_PPL) if (g_settings->hacks&hack_PPL)
height -= rdp.ci_upper_bound; height -= rdp.ci_upper_bound;
} }
FRDP("width: %d, height: %d... ", width, height); WriteTrace(TraceRDP, TraceDebug, "width: %d, height: %d... ", width, height);
if (rdp.scale_x < 1.1f) if (rdp.scale_x < 1.1f)
{ {
@ -476,11 +476,11 @@ static void CopyFrameBuffer(GrBuffer_t buffer = GR_BUFFER_BACKBUFFER)
ptr_dst32[x + y * width] = RGBA16TO32(c); ptr_dst32[x + y * width] = RGBA16TO32(c);
} }
} }
LRDP("ReadRegion. Framebuffer copy complete.\n"); WriteTrace(TraceRDP, TraceDebug, "ReadRegion. Framebuffer copy complete.");
} }
else else
{ {
LRDP("Framebuffer copy failed.\n"); WriteTrace(TraceRDP, TraceDebug, "Framebuffer copy failed.");
} }
delete[] ptr_src; delete[] ptr_src;
} }
@ -495,7 +495,7 @@ static void CopyFrameBuffer(GrBuffer_t buffer = GR_BUFFER_BACKBUFFER)
float scale_x = (g_settings->scr_res_x - rdp.offset_x*2.0f) / maxval(width, rdp.vi_width); float scale_x = (g_settings->scr_res_x - rdp.offset_x*2.0f) / maxval(width, rdp.vi_width);
float scale_y = (g_settings->scr_res_y - rdp.offset_y*2.0f) / maxval(height, rdp.vi_height); float scale_y = (g_settings->scr_res_y - rdp.offset_y*2.0f) / maxval(height, rdp.vi_height);
FRDP("width: %d, height: %d, ul_y: %d, lr_y: %d, scale_x: %f, scale_y: %f, ci_width: %d, ci_height: %d\n", width, height, rdp.ci_upper_bound, rdp.ci_lower_bound, scale_x, scale_y, rdp.ci_width, rdp.ci_height); WriteTrace(TraceRDP, TraceDebug, "width: %d, height: %d, ul_y: %d, lr_y: %d, scale_x: %f, scale_y: %f, ci_width: %d, ci_height: %d", width, height, rdp.ci_upper_bound, rdp.ci_lower_bound, scale_x, scale_y, rdp.ci_width, rdp.ci_height);
GrLfbInfo_t info; GrLfbInfo_t info;
info.size = sizeof(GrLfbInfo_t); info.size = sizeof(GrLfbInfo_t);
@ -537,11 +537,11 @@ static void CopyFrameBuffer(GrBuffer_t buffer = GR_BUFFER_BACKBUFFER)
// Unlock the backbuffer // Unlock the backbuffer
grLfbUnlock(GR_LFB_READ_ONLY, buffer); grLfbUnlock(GR_LFB_READ_ONLY, buffer);
LRDP("LfbLock. Framebuffer copy complete.\n"); WriteTrace(TraceRDP, TraceDebug, "LfbLock. Framebuffer copy complete.");
} }
else else
{ {
LRDP("Framebuffer copy failed.\n"); WriteTrace(TraceRDP, TraceDebug, "Framebuffer copy failed.");
} }
} }
} }
@ -627,24 +627,6 @@ EXPORT void CALL ProcessDList(void)
if (to_fullscreen) if (to_fullscreen)
GoToFullScreen(); GoToFullScreen();
// Clear out the RDP log
#ifdef RDP_LOGGING
if (g_settings->logging && g_settings->log_clear)
{
CLOSE_RDP_LOG();
OPEN_RDP_LOG();
}
#endif
#ifdef UNIMP_LOG
if (g_settings->log_unk && g_settings->unk_clear)
{
std::ofstream unimp;
unimp.open("unimp.txt");
unimp.close();
}
#endif
//* Set states *// //* Set states *//
if (g_settings->swapmode > 0) if (g_settings->swapmode > 0)
SwapOK = TRUE; SwapOK = TRUE;
@ -694,8 +676,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);
FRDP("--- NEW DLIST --- crc: %08lx, ucode: %d, fbuf: %08lx, fbuf_width: %d, dlist start: %08lx, dlist_length: %d, x_scale: %f, y_scale: %f\n", 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);
FRDP_E("--- NEW DLIST --- crc: %08lx, ucode: %d, fbuf: %08lx\n", uc_crc, g_settings->ucode, *gfx.VI_ORIGIN_REG);
// Do nothing if dlist is empty // Do nothing if dlist is empty
if (dlist_start == 0) if (dlist_start == 0)
@ -706,7 +687,7 @@ EXPORT void CALL ProcessDList(void)
if ((g_settings->hacks&hack_Tonic) && dlist_length < 16) if ((g_settings->hacks&hack_Tonic) && dlist_length < 16)
{ {
rdp_fullsync(); rdp_fullsync();
FRDP_E("DLIST is too short!\n"); WriteTrace(TraceRDP, TraceWarning, "DLIST is too short!");
return; return;
} }
@ -739,9 +720,9 @@ EXPORT void CALL ProcessDList(void)
// Output the address before the command // Output the address before the command
#ifdef LOG_COMMANDS #ifdef LOG_COMMANDS
FRDP("%08lx (c0:%08lx, c1:%08lx): ", a, rdp.cmd0, rdp.cmd1); WriteTrace(TraceRDP, TraceDebug, "%08lx (c0:%08lx, c1:%08lx): ", a, rdp.cmd0, rdp.cmd1);
#else #else
FRDP("%08lx: ", a); WriteTrace(TraceRDP, TraceDebug, "%08lx: ", a);
#endif #endif
// Go to the next instruction // Go to the next instruction
@ -761,14 +742,14 @@ EXPORT void CALL ProcessDList(void)
{ {
rdp.dl_count = -1; rdp.dl_count = -1;
LRDP("End of DL\n"); WriteTrace(TraceRDP, TraceDebug, "End of DL");
rdp.pc_i--; rdp.pc_i--;
} }
} }
#ifdef PERFORMANCE #ifdef PERFORMANCE
perf_next = wxDateTime::UNow(); perf_next = wxDateTime::UNow();
sprintf(out_buf, "perf %08lx: %016I64d\n", a - 8, (perf_next - perf_cur).Format(_T("%l")).mb_str()); sprintf(out_buf, "perf %08lx: %016I64d", a - 8, (perf_next - perf_cur).Format(_T("%l")).mb_str());
rdp_log << out_buf; rdp_log << out_buf;
#endif #endif
} while (!rdp.halt); } while (!rdp.halt);
@ -819,14 +800,13 @@ EXPORT void CALL ProcessDList(void)
newSwapBuffers(); newSwapBuffers();
CI_SET = FALSE; CI_SET = FALSE;
} }
LRDP("ProcessDList end\n"); WriteTrace(TraceRDP, TraceDebug, "ProcessDList end");
} }
// undef - undefined instruction, always ignore // undef - undefined instruction, always ignore
static void undef() static void undef()
{ {
FRDP_E("** undefined ** (%08lx)\n", rdp.cmd0); WriteTrace(TraceRDP, TraceWarning, "** undefined ** (%08lx) - IGNORED", rdp.cmd0);
FRDP("** undefined ** (%08lx) - IGNORED\n", rdp.cmd0);
#ifdef _ENDUSER_RELEASE_ #ifdef _ENDUSER_RELEASE_
*gfx.MI_INTR_REG |= 0x20; *gfx.MI_INTR_REG |= 0x20;
gfx.CheckInterrupts(); gfx.CheckInterrupts();
@ -837,13 +817,13 @@ static void undef()
// spnoop - no operation, always ignore // spnoop - no operation, always ignore
static void spnoop() static void spnoop()
{ {
LRDP("spnoop\n"); WriteTrace(TraceRDP, TraceDebug, "spnoop");
} }
// noop - no operation, always ignore // noop - no operation, always ignore
static void rdp_noop() static void rdp_noop()
{ {
LRDP("noop\n"); WriteTrace(TraceRDP, TraceDebug, "noop");
} }
static void ys_memrect() static void ys_memrect()
@ -860,12 +840,11 @@ static void ys_memrect()
uint32_t off_x = ((rdp.cmd2 & 0xFFFF0000) >> 16) >> 5; uint32_t off_x = ((rdp.cmd2 & 0xFFFF0000) >> 16) >> 5;
uint32_t off_y = (rdp.cmd2 & 0x0000FFFF) >> 5; uint32_t off_y = (rdp.cmd2 & 0x0000FFFF) >> 5;
FRDP("memrect (%d, %d, %d, %d), ci_width: %d", ul_x, ul_y, lr_x, lr_y, rdp.ci_width); WriteTrace(TraceRDP, TraceDebug, "memrect (%d, %d, %d, %d), ci_width: %d", ul_x, ul_y, lr_x, lr_y, rdp.ci_width);
if (off_x > 0) if (off_x > 0)
FRDP(" off_x: %d", off_x); WriteTrace(TraceRDP, TraceDebug, " off_x: %d", off_x);
if (off_y > 0) if (off_y > 0)
FRDP(" off_y: %d", off_y); WriteTrace(TraceRDP, TraceDebug, " off_y: %d", off_y);
LRDP("\n");
uint32_t y, width = lr_x - ul_x; uint32_t y, width = lr_x - ul_x;
uint32_t tex_width = rdp.tiles[tile].line << 3; uint32_t tex_width = rdp.tiles[tile].line << 3;
@ -894,7 +873,7 @@ static void pm_palette_mod()
{ {
dst[i ^ 1] = (rdp.pal_8[i] & 1) ? prim16 : env16; dst[i ^ 1] = (rdp.pal_8[i] & 1) ? prim16 : env16;
} }
LRDP("Texrect palette modification\n"); WriteTrace(TraceRDP, TraceDebug, "Texrect palette modification");
} }
static void pd_zcopy() static void pd_zcopy()
@ -911,7 +890,7 @@ static void pd_zcopy()
c = ptr_src[x]; c = ptr_src[x];
c = ((c << 8) & 0xFF00) | (c >> 8); c = ((c << 8) & 0xFF00) | (c >> 8);
ptr_dst[(ul_x + x) ^ 1] = c; ptr_dst[(ul_x + x) ^ 1] = c;
// FRDP("dst[%d]=%04lx \n", (x + ul_x)^1, c); // WriteTrace(TraceRDP, TraceDebug, "dst[%d]=%04lx ", (x + ul_x)^1, c);
} }
} }
@ -972,15 +951,15 @@ static void rdp_texrect()
} }
else else
{ {
LRDP("Texrect skipped\n"); WriteTrace(TraceRDP, TraceDebug, "Texrect skipped");
} }
return; return;
} }
if ((g_settings->ucode == ucode_CBFD) && rdp.cur_image && rdp.cur_image->format) if ((g_settings->ucode == ucode_CBFD) && rdp.cur_image && rdp.cur_image->format)
{ {
//FRDP("Wrong Texrect. texaddr: %08lx, cimg: %08lx, cimg_end: %08lx\n", 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);
LRDP("Shadow texrect is skipped.\n"); WriteTrace(TraceRDP, TraceDebug, "Shadow texrect is skipped.");
rdp.tri_n += 2; rdp.tri_n += 2;
return; return;
} }
@ -988,7 +967,7 @@ static void rdp_texrect()
if ((g_settings->ucode == ucode_PerfectDark) && rdp.ci_count > 0 && (rdp.frame_buffers[rdp.ci_count - 1].status == ci_zcopy)) if ((g_settings->ucode == ucode_PerfectDark) && rdp.ci_count > 0 && (rdp.frame_buffers[rdp.ci_count - 1].status == ci_zcopy))
{ {
pd_zcopy(); pd_zcopy();
LRDP("Depth buffer copied.\n"); WriteTrace(TraceRDP, TraceDebug, "Depth buffer copied.");
rdp.tri_n += 2; rdp.tri_n += 2;
return; return;
} }
@ -1003,7 +982,7 @@ static void rdp_texrect()
return; return;
} }
// FRDP ("rdp.cycle1 %08lx, rdp.cycle2 %08lx\n", rdp.cycle1, rdp.cycle2); // WriteTrace(TraceRDP, TraceDebug, "rdp.cycle1 %08lx, rdp.cycle2 %08lx", rdp.cycle1, rdp.cycle2);
float ul_x, ul_y, lr_x, lr_y; float ul_x, ul_y, lr_x, lr_y;
if (rdp.cycle_mode == 2) if (rdp.cycle_mode == 2)
@ -1023,7 +1002,7 @@ static void rdp_texrect()
if (ul_x >= lr_x) if (ul_x >= lr_x)
{ {
FRDP("Wrong Texrect: ul_x: %f, lr_x: %f\n", ul_x, lr_x); WriteTrace(TraceRDP, TraceDebug, "Wrong Texrect: ul_x: %f, lr_x: %f", ul_x, lr_x);
return; return;
} }
@ -1046,7 +1025,7 @@ static void rdp_texrect()
//* //*
if (rdp.tbuff_tex && (g_settings->frame_buffer & fb_optimize_texrect)) if (rdp.tbuff_tex && (g_settings->frame_buffer & fb_optimize_texrect))
{ {
LRDP("Attempt to optimize texrect\n"); WriteTrace(TraceRDP, TraceDebug, "Attempt to optimize texrect");
if (!rdp.tbuff_tex->drawn) if (!rdp.tbuff_tex->drawn)
{ {
DRAWIMAGE d; DRAWIMAGE d;
@ -1059,7 +1038,7 @@ static void rdp_texrect()
d.imageH = (uint16_t)rdp.tbuff_tex->height; d.imageH = (uint16_t)rdp.tbuff_tex->height;
d.frameY = (uint16_t)ul_y; d.frameY = (uint16_t)ul_y;
d.frameH = (uint16_t)(rdp.tbuff_tex->height); d.frameH = (uint16_t)(rdp.tbuff_tex->height);
FRDP("texrect. ul_x: %d, ul_y: %d, lr_x: %d, lr_y: %d, width: %d, height: %d\n", ul_x, ul_y, lr_x, lr_y, rdp.tbuff_tex->width, rdp.tbuff_tex->height); WriteTrace(TraceRDP, TraceDebug, "texrect. ul_x: %d, ul_y: %d, lr_x: %d, lr_y: %d, width: %d, height: %d", ul_x, ul_y, lr_x, lr_y, rdp.tbuff_tex->width, rdp.tbuff_tex->height);
d.scaleX = 1.0f; d.scaleX = 1.0f;
d.scaleY = 1.0f; d.scaleY = 1.0f;
DrawHiresImage(d, rdp.tbuff_tex->width == rdp.ci_width); DrawHiresImage(d, rdp.tbuff_tex->width == rdp.ci_width);
@ -1076,7 +1055,7 @@ static void rdp_texrect()
//hack for Zelda MM. it removes black texrects which cover all geometry in "Link meets Zelda" cut scene //hack for Zelda MM. it removes black texrects which cover all geometry in "Link meets Zelda" cut scene
if ((g_settings->hacks&hack_Zelda) && rdp.timg.addr >= rdp.cimg && rdp.timg.addr < rdp.ci_end) if ((g_settings->hacks&hack_Zelda) && rdp.timg.addr >= rdp.cimg && rdp.timg.addr < rdp.ci_end)
{ {
FRDP("Wrong Texrect. texaddr: %08lx, cimg: %08lx, cimg_end: %08lx\n", rdp.cur_cache[0]->addr, rdp.cimg, rdp.cimg + rdp.ci_width*rdp.ci_height * 2); WriteTrace(TraceRDP, TraceDebug, "Wrong Texrect. texaddr: %08lx, cimg: %08lx, cimg_end: %08lx", rdp.cur_cache[0]->addr, rdp.cimg, rdp.cimg + rdp.ci_width*rdp.ci_height * 2);
rdp.tri_n += 2; rdp.tri_n += 2;
return; return;
} }
@ -1095,8 +1074,8 @@ static void rdp_texrect()
if (fb_emulation_enabled) if (fb_emulation_enabled)
if (rdp.ci_count > 0 && rdp.frame_buffers[rdp.ci_count - 1].status == ci_copy_self) if (rdp.ci_count > 0 && rdp.frame_buffers[rdp.ci_count - 1].status == ci_copy_self)
{ {
//FRDP("Wrong Texrect. texaddr: %08lx, cimg: %08lx, cimg_end: %08lx\n", rdp.timg.addr, rdp.maincimg[1], rdp.maincimg[1]+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], rdp.maincimg[1]+rdp.ci_width*rdp.ci_height*rdp.ci_size);
LRDP("Wrong Texrect.\n"); WriteTrace(TraceRDP, TraceDebug, "Wrong Texrect.");
rdp.tri_n += 2; rdp.tri_n += 2;
return; return;
} }
@ -1145,9 +1124,9 @@ 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;
FRDP("texrect (%.2f, %.2f, %.2f, %.2f), tile: %d, #%d, #%d\n", 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, rdp.tri_n, rdp.tri_n + 1);
FRDP("(%f, %f) -> (%f, %f), s: (%d, %d) -> (%d, %d)\n", 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);
FRDP("\toff_x: %f, off_y: %f, dsdx: %f, dtdy: %f\n", 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);
float off_size_x; float off_size_x;
float off_size_y; float off_size_y;
@ -1255,7 +1234,7 @@ static void rdp_texrect()
texUV[i].ul_v *= rdp.aTBuffTex[i]->v_scale; texUV[i].ul_v *= rdp.aTBuffTex[i]->v_scale;
texUV[i].lr_u *= rdp.aTBuffTex[i]->u_scale; texUV[i].lr_u *= rdp.aTBuffTex[i]->u_scale;
texUV[i].lr_v *= rdp.aTBuffTex[i]->v_scale; texUV[i].lr_v *= rdp.aTBuffTex[i]->v_scale;
FRDP("tbuff_tex[%d] ul_u: %f, ul_v: %f, lr_u: %f, lr_v: %f\n", WriteTrace(TraceRDP, TraceDebug, "tbuff_tex[%d] ul_u: %f, ul_v: %f, lr_u: %f, lr_v: %f",
i, texUV[i].ul_u, texUV[i].ul_v, texUV[i].lr_u, texUV[i].lr_v); i, texUV[i].ul_u, texUV[i].ul_v, texUV[i].lr_u, texUV[i].lr_v);
} }
else //common case else //common case
@ -1285,12 +1264,12 @@ static void rdp_texrect()
// **** // ****
FRDP(" scissor: (%d, %d) -> (%d, %d)\n", rdp.scissor.ul_x, rdp.scissor.ul_y, rdp.scissor.lr_x, rdp.scissor.lr_y); WriteTrace(TraceRDP, TraceDebug, " scissor: (%d, %d) -> (%d, %d)", rdp.scissor.ul_x, rdp.scissor.ul_y, rdp.scissor.lr_x, rdp.scissor.lr_y);
CCLIP2(s_ul_x, s_lr_x, texUV[0].ul_u, texUV[0].lr_u, texUV[1].ul_u, texUV[1].lr_u, (float)rdp.scissor.ul_x, (float)rdp.scissor.lr_x); CCLIP2(s_ul_x, s_lr_x, texUV[0].ul_u, texUV[0].lr_u, texUV[1].ul_u, texUV[1].lr_u, (float)rdp.scissor.ul_x, (float)rdp.scissor.lr_x);
CCLIP2(s_ul_y, s_lr_y, texUV[0].ul_v, texUV[0].lr_v, texUV[1].ul_v, texUV[1].lr_v, (float)rdp.scissor.ul_y, (float)rdp.scissor.lr_y); CCLIP2(s_ul_y, s_lr_y, texUV[0].ul_v, texUV[0].lr_v, texUV[1].ul_v, texUV[1].lr_v, (float)rdp.scissor.ul_y, (float)rdp.scissor.lr_y);
FRDP(" draw at: (%f, %f) -> (%f, %f)\n", s_ul_x, s_ul_y, s_lr_x, s_lr_y); WriteTrace(TraceRDP, TraceDebug, " draw at: (%f, %f) -> (%f, %f)", s_ul_x, s_ul_y, s_lr_x, s_lr_y);
VERTEX vstd[4] = { VERTEX vstd[4] = {
{ s_ul_x, s_ul_y, Z, 1.0f, texUV[0].ul_u, texUV[0].ul_v, texUV[1].ul_u, texUV[1].ul_v, { 0, 0, 0, 0 }, 255 }, { s_ul_x, s_ul_y, Z, 1.0f, texUV[0].ul_u, texUV[0].ul_v, texUV[1].ul_u, texUV[1].ul_v, { 0, 0, 0, 0 }, 255 },
@ -1316,7 +1295,7 @@ static void rdp_texrect()
VERTEX *vnew = 0; VERTEX *vnew = 0;
// for (int j =0; j < 4; j++) // for (int j =0; j < 4; j++)
// FRDP("v[%d] u0: %f, v0: %f, u1: %f, v1: %f\n", j, vstd[j].u0, vstd[j].v0, vstd[j].u1, vstd[j].v1); // WriteTrace(TraceRDP, TraceDebug, "v[%d] u0: %f, v0: %f, u1: %f, v1: %f", j, vstd[j].u0, vstd[j].v0, vstd[j].u1, vstd[j].v1);
if (!rdp.aTBuffTex[0] && rdp.cur_cache[0]->splits != 1) if (!rdp.aTBuffTex[0] && rdp.cur_cache[0]->splits != 1)
{ {
@ -1341,7 +1320,7 @@ static void rdp_texrect()
int start_u_256, end_u_256; int start_u_256, end_u_256;
start_u_256 = (int)min_u >> 8; start_u_256 = (int)min_u >> 8;
end_u_256 = (int)max_u >> 8; end_u_256 = (int)max_u >> 8;
//FRDP(" min_u: %f, max_u: %f start: %d, end: %d\n", min_u, max_u, start_u_256, end_u_256); //WriteTrace(TraceRDP, TraceDebug, " min_u: %f, max_u: %f start: %d, end: %d", min_u, max_u, start_u_256, end_u_256);
int splitheight = rdp.cur_cache[0]->splitheight; int splitheight = rdp.cur_cache[0]->splitheight;
@ -1481,17 +1460,17 @@ static void rdp_texrect()
static void rdp_loadsync() static void rdp_loadsync()
{ {
LRDP("loadsync - ignored\n"); WriteTrace(TraceRDP, TraceDebug, "loadsync - ignored");
} }
static void rdp_pipesync() static void rdp_pipesync()
{ {
LRDP("pipesync - ignored\n"); WriteTrace(TraceRDP, TraceDebug, "pipesync - ignored");
} }
static void rdp_tilesync() static void rdp_tilesync()
{ {
LRDP("tilesync - ignored\n"); WriteTrace(TraceRDP, TraceDebug, "tilesync - ignored");
} }
static void rdp_fullsync() static void rdp_fullsync()
@ -1499,7 +1478,7 @@ static void rdp_fullsync()
// Set an interrupt to allow the game to continue // Set an interrupt to allow the game to continue
*gfx.MI_INTR_REG |= 0x20; *gfx.MI_INTR_REG |= 0x20;
gfx.CheckInterrupts(); gfx.CheckInterrupts();
LRDP("fullsync\n"); WriteTrace(TraceRDP, TraceDebug, "fullsync");
} }
static void rdp_setkeygb() static void rdp_setkeygb()
@ -1510,7 +1489,7 @@ static void rdp_setkeygb()
uint32_t cG = (rdp.cmd1 >> 24) & 0xFF; uint32_t cG = (rdp.cmd1 >> 24) & 0xFF;
rdp.SCALE = (rdp.SCALE & 0xFF0000FF) | (sG << 16) | (sB << 8); rdp.SCALE = (rdp.SCALE & 0xFF0000FF) | (sG << 16) | (sB << 8);
rdp.CENTER = (rdp.CENTER & 0xFF0000FF) | (cG << 16) | (cB << 8); rdp.CENTER = (rdp.CENTER & 0xFF0000FF) | (cG << 16) | (cB << 8);
FRDP("setkeygb. cG=%02lx, sG=%02lx, cB=%02lx, sB=%02lx\n", cG, sG, cB, sB); WriteTrace(TraceRDP, TraceDebug, "setkeygb. cG=%02lx, sG=%02lx, cB=%02lx, sB=%02lx", cG, sG, cB, sB);
} }
static void rdp_setkeyr() static void rdp_setkeyr()
@ -1519,7 +1498,7 @@ static void rdp_setkeyr()
uint32_t cR = (rdp.cmd1 >> 8) & 0xFF; uint32_t cR = (rdp.cmd1 >> 8) & 0xFF;
rdp.SCALE = (rdp.SCALE & 0x00FFFFFF) | (sR << 24); rdp.SCALE = (rdp.SCALE & 0x00FFFFFF) | (sR << 24);
rdp.CENTER = (rdp.CENTER & 0x00FFFFFF) | (cR << 24); rdp.CENTER = (rdp.CENTER & 0x00FFFFFF) | (cR << 24);
FRDP("setkeyr. cR=%02lx, sR=%02lx\n", cR, sR); WriteTrace(TraceRDP, TraceDebug, "setkeyr. cR=%02lx, sR=%02lx", cR, sR);
} }
static void rdp_setconvert() static void rdp_setconvert()
@ -1533,8 +1512,7 @@ static void rdp_setconvert()
*/ */
rdp.K4 = (uint8_t)(rdp.cmd1 >> 9) & 0x1FF; rdp.K4 = (uint8_t)(rdp.cmd1 >> 9) & 0x1FF;
rdp.K5 = (uint8_t)(rdp.cmd1 & 0x1FF); rdp.K5 = (uint8_t)(rdp.cmd1 & 0x1FF);
// RDP_E("setconvert - IGNORED\n"); WriteTrace(TraceRDP, TraceDebug, "setconvert. K4=%02lx K5=%02lx", rdp.K4, rdp.K5);
FRDP("setconvert. K4=%02lx K5=%02lx\n", rdp.K4, rdp.K5);
} }
// //
@ -1553,7 +1531,7 @@ static void rdp_setscissor()
rdp.ci_lower_bound = rdp.scissor_o.lr_y; rdp.ci_lower_bound = rdp.scissor_o.lr_y;
rdp.scissor_set = TRUE; rdp.scissor_set = TRUE;
FRDP("setscissor: (%d,%d) -> (%d,%d)\n", rdp.scissor_o.ul_x, rdp.scissor_o.ul_y, WriteTrace(TraceRDP, TraceDebug, "setscissor: (%d,%d) -> (%d,%d)", rdp.scissor_o.ul_x, rdp.scissor_o.ul_y,
rdp.scissor_o.lr_x, rdp.scissor_o.lr_y); rdp.scissor_o.lr_x, rdp.scissor_o.lr_y);
rdp.update |= UPDATE_SCISSOR; rdp.update |= UPDATE_SCISSOR;
@ -1573,7 +1551,7 @@ static void rdp_setprimdepth()
rdp.prim_depth = (uint16_t)((rdp.cmd1 >> 16) & 0x7FFF); rdp.prim_depth = (uint16_t)((rdp.cmd1 >> 16) & 0x7FFF);
rdp.prim_dz = (uint16_t)(rdp.cmd1 & 0x7FFF); rdp.prim_dz = (uint16_t)(rdp.cmd1 & 0x7FFF);
FRDP("setprimdepth: %d\n", rdp.prim_depth); WriteTrace(TraceRDP, TraceDebug, "setprimdepth: %d", rdp.prim_depth);
} }
static void rdp_setothermode() static void rdp_setothermode()
@ -1589,7 +1567,7 @@ static void rdp_setothermode()
gfx_instruction[g_settings->ucode][cmd] (); \ gfx_instruction[g_settings->ucode][cmd] (); \
} }
LRDP("rdp_setothermode\n"); WriteTrace(TraceRDP, TraceDebug, "rdp_setothermode");
if ((g_settings->ucode == ucode_F3DEX2) || (g_settings->ucode == ucode_CBFD)) if ((g_settings->ucode == ucode_F3DEX2) || (g_settings->ucode == ucode_CBFD))
{ {
@ -1607,7 +1585,7 @@ static void rdp_setothermode()
void load_palette(uint32_t addr, uint16_t start, uint16_t count) void load_palette(uint32_t addr, uint16_t start, uint16_t count)
{ {
LRDP("Loading palette... "); WriteTrace(TraceRDP, TraceDebug, "Loading palette... ");
uint16_t *dpal = rdp.pal_8 + start; uint16_t *dpal = rdp.pal_8 + start;
uint16_t end = start + count; uint16_t end = start + count;
#ifdef TEXTURE_FILTER #ifdef TEXTURE_FILTER
@ -1619,13 +1597,13 @@ void load_palette(uint32_t addr, uint16_t start, uint16_t count)
*(dpal++) = *(uint16_t *)(gfx.RDRAM + (addr ^ 2)); *(dpal++) = *(uint16_t *)(gfx.RDRAM + (addr ^ 2));
addr += 2; addr += 2;
#ifdef TLUT_LOGGING WriteTrace(TraceTLUT, TraceDebug, "%d: %08lx", i, *(uint16_t *)(gfx.RDRAM + (addr ^ 2)));
FRDP("%d: %08lx\n", i, *(uint16_t *)(gfx.RDRAM + (addr ^ 2)));
#endif
} }
#ifdef TEXTURE_FILTER #ifdef TEXTURE_FILTER
if (g_settings->ghq_hirs) if (g_settings->ghq_hirs)
{
memcpy((uint8_t*)(rdp.pal_8_rice + start), spal, count << 1); memcpy((uint8_t*)(rdp.pal_8_rice + start), spal, count << 1);
}
#endif #endif
start >>= 4; start >>= 4;
end = start + (count >> 4); end = start + (count >> 4);
@ -1636,7 +1614,7 @@ void load_palette(uint32_t addr, uint16_t start, uint16_t count)
rdp.pal_8_crc[p] = CRC32(0xFFFFFFFF, &rdp.pal_8[(p << 4)], 32); rdp.pal_8_crc[p] = CRC32(0xFFFFFFFF, &rdp.pal_8[(p << 4)], 32);
} }
rdp.pal_256_crc = CRC32(0xFFFFFFFF, rdp.pal_8_crc, 64); rdp.pal_256_crc = CRC32(0xFFFFFFFF, rdp.pal_8_crc, 64);
LRDP("Done.\n"); WriteTrace(TraceRDP, TraceDebug, "Done.");
} }
static void rdp_loadtlut() static void rdp_loadtlut()
@ -1651,7 +1629,7 @@ static void rdp_loadtlut()
if (start + count > 256) count = 256 - start; if (start + count > 256) count = 256 - start;
FRDP("loadtlut: tile: %d, start: %d, count: %d, from: %08lx\n", tile, start, count, WriteTrace(TraceRDP, TraceDebug, "loadtlut: tile: %d, start: %d, count: %d, from: %08lx", tile, start, count,
rdp.timg.addr); rdp.timg.addr);
load_palette(rdp.timg.addr, start, count); load_palette(rdp.timg.addr, start, count);
@ -1730,22 +1708,22 @@ static void rdp_settilesize()
rdp.first = 1; rdp.first = 1;
FRDP("settilesize: tile: %d, ul_s: %d, ul_t: %d, lr_s: %d, lr_t: %d, f_ul_s: %f, f_ul_t: %f\n", WriteTrace(TraceRDP, TraceDebug, "settilesize: tile: %d, ul_s: %d, ul_t: %d, lr_s: %d, lr_t: %d, f_ul_s: %f, f_ul_t: %f",
tile, ul_s, ul_t, lr_s, lr_t, rdp.tiles[tile].f_ul_s, rdp.tiles[tile].f_ul_t); tile, ul_s, ul_t, lr_s, lr_t, rdp.tiles[tile].f_ul_s, rdp.tiles[tile].f_ul_t);
} }
void setTBufTex(uint16_t t_mem, uint32_t cnt) void setTBufTex(uint16_t t_mem, uint32_t cnt)
{ {
FRDP("setTBufTex t_mem=%d, cnt=%d\n", t_mem, cnt); WriteTrace(TraceRDP, TraceDebug, "setTBufTex t_mem=%d, cnt=%d", t_mem, cnt);
TBUFF_COLOR_IMAGE * pTbufTex = rdp.tbuff_tex; TBUFF_COLOR_IMAGE * pTbufTex = rdp.tbuff_tex;
for (int i = 0; i < 2; i++) for (int i = 0; i < 2; i++)
{ {
LRDP("Before: "); WriteTrace(TraceRDP, TraceDebug, "Before: ");
if (rdp.aTBuffTex[i]) { if (rdp.aTBuffTex[i]) {
FRDP("rdp.aTBuffTex[%d]: tmu=%d t_mem=%d tile=%d\n", i, rdp.aTBuffTex[i]->tmu, rdp.aTBuffTex[i]->t_mem, rdp.aTBuffTex[i]->tile); WriteTrace(TraceRDP, TraceDebug, "rdp.aTBuffTex[%d]: tmu=%d t_mem=%d tile=%d", i, rdp.aTBuffTex[i]->tmu, rdp.aTBuffTex[i]->t_mem, rdp.aTBuffTex[i]->tile);
} }
else { else {
FRDP("rdp.aTBuffTex[%d]=0\n", i); WriteTrace(TraceRDP, TraceDebug, "rdp.aTBuffTex[%d]=0", i);
} }
if ((rdp.aTBuffTex[i] == 0 && rdp.aTBuffTex[i ^ 1] != pTbufTex) || (rdp.aTBuffTex[i] && rdp.aTBuffTex[i]->t_mem >= t_mem && rdp.aTBuffTex[i]->t_mem < t_mem + cnt)) if ((rdp.aTBuffTex[i] == 0 && rdp.aTBuffTex[i ^ 1] != pTbufTex) || (rdp.aTBuffTex[i] && rdp.aTBuffTex[i]->t_mem >= t_mem && rdp.aTBuffTex[i]->t_mem < t_mem + cnt))
{ {
@ -1754,12 +1732,12 @@ void setTBufTex(uint16_t t_mem, uint32_t cnt)
rdp.aTBuffTex[i] = pTbufTex; rdp.aTBuffTex[i] = pTbufTex;
rdp.aTBuffTex[i]->t_mem = t_mem; rdp.aTBuffTex[i]->t_mem = t_mem;
pTbufTex = 0; pTbufTex = 0;
FRDP("rdp.aTBuffTex[%d] tmu=%d t_mem=%d\n", i, rdp.aTBuffTex[i]->tmu, rdp.aTBuffTex[i]->t_mem); WriteTrace(TraceRDP, TraceDebug, "rdp.aTBuffTex[%d] tmu=%d t_mem=%d", i, rdp.aTBuffTex[i]->tmu, rdp.aTBuffTex[i]->t_mem);
} }
else else
{ {
rdp.aTBuffTex[i] = 0; rdp.aTBuffTex[i] = 0;
FRDP("rdp.aTBuffTex[%d]=0\n", i); WriteTrace(TraceRDP, TraceDebug, "rdp.aTBuffTex[%d]=0", i);
} }
} }
} }
@ -1890,7 +1868,7 @@ static void rdp_loadblock()
{ {
if (rdp.skip_drawing) if (rdp.skip_drawing)
{ {
LRDP("loadblock skipped\n"); WriteTrace(TraceRDP, TraceDebug, "loadblock skipped");
return; return;
} }
uint32_t tile = (uint32_t)((rdp.cmd1 >> 24) & 0x07); uint32_t tile = (uint32_t)((rdp.cmd1 >> 24) & 0x07);
@ -1970,7 +1948,7 @@ static void rdp_loadblock()
rdp.update |= UPDATE_TEXTURE; rdp.update |= UPDATE_TEXTURE;
FRDP("loadblock: tile: %d, ul_s: %d, ul_t: %d, lr_s: %d, dxt: %08lx -> %08lx\n", WriteTrace(TraceRDP, TraceDebug, "loadblock: tile: %d, ul_s: %d, ul_t: %d, lr_s: %d, dxt: %08lx -> %08lx",
tile, ul_s, ul_t, lr_s, tile, ul_s, ul_t, lr_s,
dxt, _dxt); dxt, _dxt);
@ -2107,7 +2085,7 @@ static void rdp_loadtile()
{ {
if (rdp.skip_drawing) if (rdp.skip_drawing)
{ {
LRDP("loadtile skipped\n"); WriteTrace(TraceRDP, TraceDebug, "loadtile skipped");
return; return;
} }
rdp.timg.set_by = 1; // load tile rdp.timg.set_by = 1; // load tile
@ -2138,7 +2116,7 @@ static void rdp_loadtile()
if (rdp.tbuff_tex)// && (rdp.tiles[tile].format == 0)) if (rdp.tbuff_tex)// && (rdp.tiles[tile].format == 0))
{ {
FRDP("loadtile: tbuff_tex ul_s: %d, ul_t:%d\n", ul_s, ul_t); WriteTrace(TraceRDP, TraceDebug, "loadtile: tbuff_tex ul_s: %d, ul_t:%d", ul_s, ul_t);
rdp.tbuff_tex->tile_uls = ul_s; rdp.tbuff_tex->tile_uls = ul_s;
rdp.tbuff_tex->tile_ult = ul_t; rdp.tbuff_tex->tile_ult = ul_t;
} }
@ -2194,7 +2172,7 @@ static void rdp_loadtile()
unsigned char *end = ((unsigned char *)rdp.tmem) + 4096 - (wid_64 << 3); unsigned char *end = ((unsigned char *)rdp.tmem) + 4096 - (wid_64 << 3);
loadTile((uint32_t *)gfx.RDRAM, (uint32_t *)dst, wid_64, height, line_n, offs, (uint32_t *)end); loadTile((uint32_t *)gfx.RDRAM, (uint32_t *)dst, wid_64, height, line_n, offs, (uint32_t *)end);
} }
FRDP("loadtile: tile: %d, ul_s: %d, ul_t: %d, lr_s: %d, lr_t: %d\n", tile, WriteTrace(TraceRDP, TraceDebug, "loadtile: tile: %d, ul_s: %d, ul_t: %d, lr_s: %d, lr_t: %d", tile,
ul_s, ul_t, lr_s, lr_t); ul_s, ul_t, lr_s, lr_t);
if (fb_hwfbe_enabled) if (fb_hwfbe_enabled)
@ -2226,9 +2204,9 @@ static void rdp_settile()
rdp.update |= UPDATE_TEXTURE; rdp.update |= UPDATE_TEXTURE;
FRDP("settile: tile: %d, format: %s, size: %s, line: %d, " WriteTrace(TraceRDP, TraceDebug, "settile: tile: %d, format: %s, size: %s, line: %d, "
"t_mem: %08lx, palette: %d, clamp_t/mirror_t: %s, mask_t: %d, " "t_mem: %08lx, palette: %d, clamp_t/mirror_t: %s, mask_t: %d, "
"shift_t: %d, clamp_s/mirror_s: %s, mask_s: %d, shift_s: %d\n", "shift_t: %d, clamp_s/mirror_s: %s, mask_s: %d, shift_s: %d",
rdp.last_tile, str_format[tile->format], str_size[tile->size], tile->line, rdp.last_tile, str_format[tile->format], str_size[tile->size], tile->line,
tile->t_mem, tile->palette, str_cm[(tile->clamp_t << 1) | tile->mirror_t], tile->mask_t, tile->t_mem, tile->palette, str_cm[(tile->clamp_t << 1) | tile->mirror_t], tile->mask_t,
tile->shift_t, str_cm[(tile->clamp_s << 1) | tile->mirror_s], tile->mask_s, tile->shift_s); tile->shift_t, str_cm[(tile->clamp_s << 1) | tile->mirror_s], tile->mask_s, tile->shift_s);
@ -2245,7 +2223,7 @@ static void rdp_settile()
{ {
rdp.aTBuffTex[i]->tile = rdp.last_tile; rdp.aTBuffTex[i]->tile = rdp.last_tile;
rdp.aTBuffTex[i]->info.format = tile->format == 0 ? GR_TEXFMT_RGB_565 : GR_TEXFMT_ALPHA_INTENSITY_88; rdp.aTBuffTex[i]->info.format = tile->format == 0 ? GR_TEXFMT_RGB_565 : GR_TEXFMT_ALPHA_INTENSITY_88;
FRDP("rdp.aTBuffTex[%d] tile=%d, format=%s\n", i, rdp.last_tile, tile->format == 0 ? "RGB565" : "Alpha88"); WriteTrace(TraceRDP, TraceDebug, "rdp.aTBuffTex[%d] tile=%d, format=%s", i, rdp.last_tile, tile->format == 0 ? "RGB565" : "Alpha88");
} }
else else
rdp.aTBuffTex[i] = 0; rdp.aTBuffTex[i] = 0;
@ -2270,13 +2248,13 @@ static void rdp_fillrect()
uint32_t lr_y = ((rdp.cmd0 & 0x00000FFF) >> 2) + 1; uint32_t lr_y = ((rdp.cmd0 & 0x00000FFF) >> 2) + 1;
if ((ul_x > lr_x) || (ul_y > lr_y)) if ((ul_x > lr_x) || (ul_y > lr_y))
{ {
LRDP("Fillrect. Wrong coordinates. Skipped\n"); 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); int pd_multiplayer = (g_settings->ucode == ucode_PerfectDark) && (rdp.cycle_mode == 3) && (rdp.fill_color == 0xFFFCFFFC);
if ((rdp.cimg == rdp.zimg) || (fb_emulation_enabled && rdp.ci_count > 0 && rdp.frame_buffers[rdp.ci_count - 1].status == ci_zimg) || pd_multiplayer) if ((rdp.cimg == rdp.zimg) || (fb_emulation_enabled && rdp.ci_count > 0 && rdp.frame_buffers[rdp.ci_count - 1].status == ci_zimg) || pd_multiplayer)
{ {
LRDP("Fillrect - cleared the depth buffer\n"); WriteTrace(TraceRDP, TraceDebug, "Fillrect - cleared the depth buffer");
if (!(g_settings->hacks&hack_Hyperbike) || rdp.ci_width > 64) //do not clear main depth buffer for aux depth buffers if (!(g_settings->hacks&hack_Hyperbike) || rdp.ci_width > 64) //do not clear main depth buffer for aux depth buffers
{ {
update_scissor(); update_scissor();
@ -2311,7 +2289,7 @@ static void rdp_fillrect()
if (rdp.skip_drawing) if (rdp.skip_drawing)
{ {
LRDP("Fillrect skipped\n"); WriteTrace(TraceRDP, TraceDebug, "Fillrect skipped");
return; return;
} }
@ -2329,7 +2307,7 @@ static void rdp_fillrect()
grBufferClear(color, 0, 0xFFFF); grBufferClear(color, 0, 0xFFFF);
grDepthMask(FXTRUE); grDepthMask(FXTRUE);
rdp.update |= UPDATE_ZBUF_ENABLED; rdp.update |= UPDATE_ZBUF_ENABLED;
LRDP("Fillrect - cleared the texture buffer\n"); WriteTrace(TraceRDP, TraceDebug, "Fillrect - cleared the texture buffer");
return; return;
} }
@ -2340,10 +2318,10 @@ static void rdp_fillrect()
{ {
lr_x--; lr_y--; lr_x--; lr_y--;
} }
FRDP("fillrect (%d,%d) -> (%d,%d), cycle mode: %d, #%d, #%d\n", ul_x, ul_y, lr_x, lr_y, rdp.cycle_mode, WriteTrace(TraceRDP, TraceDebug, "fillrect (%d,%d) -> (%d,%d), cycle mode: %d, #%d, #%d", ul_x, ul_y, lr_x, lr_y, rdp.cycle_mode,
rdp.tri_n, rdp.tri_n + 1); rdp.tri_n, rdp.tri_n + 1);
FRDP("scissor (%d,%d) -> (%d,%d)\n", rdp.scissor.ul_x, rdp.scissor.ul_y, rdp.scissor.lr_x, WriteTrace(TraceRDP, TraceDebug, "scissor (%d,%d) -> (%d,%d)", rdp.scissor.ul_x, rdp.scissor.ul_y, rdp.scissor.lr_x,
rdp.scissor.lr_y); rdp.scissor.lr_y);
// KILL the floating point error with 0.01f // KILL the floating point error with 0.01f
@ -2357,7 +2335,7 @@ static void rdp_fillrect()
if ((uint32_t)s_ul_x > g_settings->res_x) s_ul_x = g_settings->res_x; if ((uint32_t)s_ul_x > g_settings->res_x) s_ul_x = g_settings->res_x;
if ((uint32_t)s_ul_y > g_settings->res_y) s_ul_y = g_settings->res_y; if ((uint32_t)s_ul_y > g_settings->res_y) s_ul_y = g_settings->res_y;
FRDP(" - %d, %d, %d, %d\n", s_ul_x, s_ul_y, s_lr_x, s_lr_y); WriteTrace(TraceRDP, TraceDebug, " - %d, %d, %d, %d", s_ul_x, s_ul_y, s_lr_x, s_lr_y);
grFogMode(GR_FOG_DISABLE); grFogMode(GR_FOG_DISABLE);
@ -2485,7 +2463,7 @@ static void rdp_setfillcolor()
rdp.fill_color = rdp.cmd1; rdp.fill_color = rdp.cmd1;
rdp.update |= UPDATE_ALPHA_COMPARE | UPDATE_COMBINE; rdp.update |= UPDATE_ALPHA_COMPARE | UPDATE_COMBINE;
FRDP("setfillcolor: %08lx\n", rdp.cmd1); WriteTrace(TraceRDP, TraceDebug, "setfillcolor: %08lx", rdp.cmd1);
} }
static void rdp_setfogcolor() static void rdp_setfogcolor()
@ -2493,7 +2471,7 @@ static void rdp_setfogcolor()
rdp.fog_color = rdp.cmd1; rdp.fog_color = rdp.cmd1;
rdp.update |= UPDATE_COMBINE | UPDATE_FOG_ENABLED; rdp.update |= UPDATE_COMBINE | UPDATE_FOG_ENABLED;
FRDP("setfogcolor - %08lx\n", rdp.cmd1); WriteTrace(TraceRDP, TraceDebug, "setfogcolor - %08lx", rdp.cmd1);
} }
static void rdp_setblendcolor() static void rdp_setblendcolor()
@ -2501,7 +2479,7 @@ static void rdp_setblendcolor()
rdp.blend_color = rdp.cmd1; rdp.blend_color = rdp.cmd1;
rdp.update |= UPDATE_COMBINE; rdp.update |= UPDATE_COMBINE;
FRDP("setblendcolor: %08lx\n", rdp.cmd1); WriteTrace(TraceRDP, TraceDebug, "setblendcolor: %08lx", rdp.cmd1);
} }
static void rdp_setprimcolor() static void rdp_setprimcolor()
@ -2511,7 +2489,7 @@ static void rdp_setprimcolor()
rdp.prim_lodfrac = maxval(rdp.cmd0 & 0xFF, rdp.prim_lodmin); rdp.prim_lodfrac = maxval(rdp.cmd0 & 0xFF, rdp.prim_lodmin);
rdp.update |= UPDATE_COMBINE; rdp.update |= UPDATE_COMBINE;
FRDP("setprimcolor: %08lx, lodmin: %d, lodfrac: %d\n", rdp.cmd1, rdp.prim_lodmin, WriteTrace(TraceRDP, TraceDebug, "setprimcolor: %08lx, lodmin: %d, lodfrac: %d", rdp.cmd1, rdp.prim_lodmin,
rdp.prim_lodfrac); rdp.prim_lodfrac);
} }
@ -2520,7 +2498,7 @@ static void rdp_setenvcolor()
rdp.env_color = rdp.cmd1; rdp.env_color = rdp.cmd1;
rdp.update |= UPDATE_COMBINE; rdp.update |= UPDATE_COMBINE;
FRDP("setenvcolor: %08lx\n", rdp.cmd1); WriteTrace(TraceRDP, TraceDebug, "setenvcolor: %08lx", rdp.cmd1);
} }
static void rdp_setcombine() static void rdp_setcombine()
@ -2550,7 +2528,7 @@ static void rdp_setcombine()
rdp.update |= UPDATE_COMBINE; rdp.update |= UPDATE_COMBINE;
FRDP("setcombine\na0=%s b0=%s c0=%s d0=%s\nAa0=%s Ab0=%s Ac0=%s Ad0=%s\na1=%s b1=%s c1=%s d1=%s\nAa1=%s Ab1=%s Ac1=%s Ad1=%s\n", WriteTrace(TraceRDP, TraceDebug, "setcombine\na0=%s b0=%s c0=%s d0=%s\nAa0=%s Ab0=%s Ac0=%s Ad0=%s\na1=%s b1=%s c1=%s d1=%s\nAa1=%s Ab1=%s Ac1=%s Ad1=%s",
Mode0[rdp.c_a0], Mode1[rdp.c_b0], Mode2[rdp.c_c0], Mode3[rdp.c_d0], Mode0[rdp.c_a0], Mode1[rdp.c_b0], Mode2[rdp.c_c0], Mode3[rdp.c_d0],
Alpha0[rdp.c_Aa0], Alpha1[rdp.c_Ab0], Alpha2[rdp.c_Ac0], Alpha3[rdp.c_Ad0], Alpha0[rdp.c_Aa0], Alpha1[rdp.c_Ab0], Alpha2[rdp.c_Ac0], Alpha3[rdp.c_Ad0],
Mode0[rdp.c_a1], Mode1[rdp.c_b1], Mode2[rdp.c_c1], Mode3[rdp.c_d1], Mode0[rdp.c_a1], Mode1[rdp.c_b1], Mode2[rdp.c_c1], Mode3[rdp.c_d1],
@ -2603,7 +2581,7 @@ static void rdp_settextureimage()
if (fb_hwfbe_enabled) //search this texture among drawn texture buffers if (fb_hwfbe_enabled) //search this texture among drawn texture buffers
FindTextureBuffer(rdp.timg.addr, rdp.timg.width); FindTextureBuffer(rdp.timg.addr, rdp.timg.width);
FRDP("settextureimage: format: %s, size: %s, width: %d, addr: %08lx\n", WriteTrace(TraceRDP, TraceDebug, "settextureimage: format: %s, size: %s, width: %d, addr: %08lx",
format[rdp.timg.format], size[rdp.timg.size], format[rdp.timg.format], size[rdp.timg.size],
rdp.timg.width, rdp.timg.addr); rdp.timg.width, rdp.timg.addr);
} }
@ -2612,13 +2590,13 @@ static void rdp_setdepthimage()
{ {
rdp.zimg = segoffset(rdp.cmd1) & BMASK; rdp.zimg = segoffset(rdp.cmd1) & BMASK;
rdp.zi_width = rdp.ci_width; rdp.zi_width = rdp.ci_width;
FRDP("setdepthimage - %08lx\n", rdp.zimg); WriteTrace(TraceRDP, TraceDebug, "setdepthimage - %08lx", rdp.zimg);
} }
int SwapOK = TRUE; int SwapOK = TRUE;
static void RestoreScale() static void RestoreScale()
{ {
FRDP("Return to original scale: x = %f, y = %f\n", rdp.scale_x_bak, rdp.scale_y_bak); WriteTrace(TraceRDP, TraceDebug, "Return to original scale: x = %f, y = %f", rdp.scale_x_bak, rdp.scale_y_bak);
rdp.scale_x = rdp.scale_x_bak; rdp.scale_x = rdp.scale_x_bak;
rdp.scale_y = rdp.scale_y_bak; rdp.scale_y = rdp.scale_y_bak;
// update_scissor(); // update_scissor();
@ -2818,7 +2796,7 @@ static void rdp_setcolorimage()
grTextureAuxBufferExt(rdp.texbufs[0].tmu, rdp.texbufs[0].begin, LOD, LOD, grTextureAuxBufferExt(rdp.texbufs[0].tmu, rdp.texbufs[0].begin, LOD, LOD,
GR_ASPECT_LOG2_1x1, GR_TEXFMT_RGB_565, GR_MIPMAPLEVELMASK_BOTH); GR_ASPECT_LOG2_1x1, GR_TEXFMT_RGB_565, GR_MIPMAPLEVELMASK_BOTH);
grAuxBufferExt(GR_BUFFER_TEXTUREAUXBUFFER_EXT); grAuxBufferExt(GR_BUFFER_TEXTUREAUXBUFFER_EXT);
LRDP("rdp_setcolorimage - set texture depth buffer to TMU0\n"); WriteTrace(TraceRDP, TraceDebug, "rdp_setcolorimage - set texture depth buffer to TMU0");
} }
} }
rdp.skip_drawing = TRUE; rdp.skip_drawing = TRUE;
@ -2913,7 +2891,7 @@ static void rdp_setcolorimage()
} }
if (to_org_res) if (to_org_res)
{ {
LRDP("return to original scale\n"); WriteTrace(TraceRDP, TraceDebug, "return to original scale");
rdp.scale_x = rdp.scale_x_bak; rdp.scale_x = rdp.scale_x_bak;
rdp.scale_y = rdp.scale_y_bak; rdp.scale_y = rdp.scale_y_bak;
if (fb_hwfbe_enabled && !rdp.read_whole_frame) if (fb_hwfbe_enabled && !rdp.read_whole_frame)
@ -2944,8 +2922,8 @@ static void rdp_setcolorimage()
uint32_t format = (rdp.cmd0 >> 21) & 0x7; uint32_t format = (rdp.cmd0 >> 21) & 0x7;
rdp.ci_size = (rdp.cmd0 >> 19) & 0x3; rdp.ci_size = (rdp.cmd0 >> 19) & 0x3;
rdp.ci_end = rdp.cimg + ((rdp.ci_width*rdp.ci_height) << (rdp.ci_size - 1)); rdp.ci_end = rdp.cimg + ((rdp.ci_width*rdp.ci_height) << (rdp.ci_size - 1));
FRDP("setcolorimage - %08lx, width: %d, height: %d, format: %d, size: %d\n", rdp.cmd1, rdp.ci_width, rdp.ci_height, format, rdp.ci_size); WriteTrace(TraceRDP, TraceDebug, "setcolorimage - %08lx, width: %d, height: %d, format: %d, size: %d", rdp.cmd1, rdp.ci_width, rdp.ci_height, format, rdp.ci_size);
FRDP("cimg: %08lx, ocimg: %08lx, SwapOK: %d\n", rdp.cimg, rdp.ocimg, SwapOK); WriteTrace(TraceRDP, TraceDebug, "cimg: %08lx, ocimg: %08lx, SwapOK: %d", rdp.cimg, rdp.ocimg, SwapOK);
if (format != 0) //can't draw into non RGBA buffer if (format != 0) //can't draw into non RGBA buffer
{ {
@ -2987,7 +2965,7 @@ static void rdp_setcolorimage()
if (rdp.copy_ci_index && (rdp.frame_buffers[rdp.ci_count - 1].status != ci_zimg)) if (rdp.copy_ci_index && (rdp.frame_buffers[rdp.ci_count - 1].status != ci_zimg))
{ {
int idx = (rdp.frame_buffers[rdp.ci_count].status == ci_aux_copy) ? rdp.main_ci_index : rdp.copy_ci_index; int idx = (rdp.frame_buffers[rdp.ci_count].status == ci_aux_copy) ? rdp.main_ci_index : rdp.copy_ci_index;
FRDP("attempt open tex buffer. status: %s, addr: %08lx\n", CIStatus[rdp.frame_buffers[idx].status], rdp.frame_buffers[idx].addr); WriteTrace(TraceRDP, TraceDebug, "attempt open tex buffer. status: %s, addr: %08lx", CIStatus[rdp.frame_buffers[idx].status], rdp.frame_buffers[idx].addr);
OpenTextureBuffer(rdp.frame_buffers[idx]); OpenTextureBuffer(rdp.frame_buffers[idx]);
if (rdp.frame_buffers[rdp.copy_ci_index].status == ci_main) //tidal wave if (rdp.frame_buffers[rdp.copy_ci_index].status == ci_main) //tidal wave
rdp.copy_ci_index = 0; rdp.copy_ci_index = 0;
@ -3007,28 +2985,27 @@ static void rsp_reserved0()
{ {
ucode5_texshiftaddr = segoffset(rdp.cmd1); ucode5_texshiftaddr = segoffset(rdp.cmd1);
ucode5_texshiftcount = 0; ucode5_texshiftcount = 0;
FRDP("uc5_texshift. addr: %08lx\n", ucode5_texshiftaddr); WriteTrace(TraceRDP, TraceDebug, "uc5_texshift. addr: %08lx", ucode5_texshiftaddr);
} }
else else
{ {
RDP_E("reserved0 - IGNORED\n"); WriteTrace(TraceRDP, TraceWarning, "reserved0 - IGNORED");
LRDP("reserved0 - IGNORED\n");
} }
} }
static void rsp_reserved1() static void rsp_reserved1()
{ {
LRDP("reserved1 - ignored\n"); WriteTrace(TraceRDP, TraceDebug, "reserved1 - ignored");
} }
static void rsp_reserved2() static void rsp_reserved2()
{ {
LRDP("reserved2\n"); WriteTrace(TraceRDP, TraceDebug, "reserved2");
} }
static void rsp_reserved3() static void rsp_reserved3()
{ {
LRDP("reserved3 - ignored\n"); WriteTrace(TraceRDP, TraceDebug, "reserved3 - ignored");
} }
void SetWireframeCol() void SetWireframeCol()
@ -3130,7 +3107,7 @@ EXPORT void CALL FBRead(uint32_t addr)
} }
cpu_fb_read_called = TRUE; cpu_fb_read_called = TRUE;
uint32_t a = segoffset(addr); uint32_t a = segoffset(addr);
FRDP("FBRead. addr: %08lx\n", a); WriteTrace(TraceRDP, TraceDebug, "FBRead. addr: %08lx", a);
if (!rdp.fb_drawn && (a >= rdp.cimg) && (a < rdp.ci_end)) if (!rdp.fb_drawn && (a >= rdp.cimg) && (a < rdp.ci_end))
{ {
fbreads_back++; fbreads_back++;
@ -3201,7 +3178,7 @@ EXPORT void CALL FBWrite(uint32_t addr, uint32_t /*size*/)
} }
cpu_fb_write_called = TRUE; cpu_fb_write_called = TRUE;
uint32_t a = segoffset(addr); uint32_t a = segoffset(addr);
FRDP("FBWrite. addr: %08lx\n", a); WriteTrace(TraceRDP, TraceDebug, "FBWrite. addr: %08lx", a);
if (a < rdp.cimg || a > rdp.ci_end) if (a < rdp.cimg || a > rdp.ci_end)
return; return;
cpu_fb_write = TRUE; cpu_fb_write = TRUE;
@ -3250,7 +3227,7 @@ EXPORT void CALL FBGetFrameBufferInfo(void *p)
memset(pinfo, 0, sizeof(FrameBufferInfo) * 6); memset(pinfo, 0, sizeof(FrameBufferInfo) * 6);
if (!(g_settings->frame_buffer&fb_get_info)) if (!(g_settings->frame_buffer&fb_get_info))
return; return;
LRDP("FBGetFrameBufferInfo ()\n"); WriteTrace(TraceRDP, TraceDebug, "FBGetFrameBufferInfo ()");
//* //*
if (fb_emulation_enabled) if (fb_emulation_enabled)
{ {
@ -3291,7 +3268,7 @@ EXPORT void CALL FBGetFrameBufferInfo(void *p)
void DetectFrameBufferUsage() void DetectFrameBufferUsage()
{ {
LRDP("DetectFrameBufferUsage\n"); WriteTrace(TraceRDP, TraceDebug, "DetectFrameBufferUsage");
uint32_t dlist_start = *(uint32_t*)(gfx.DMEM + 0xFF0); uint32_t dlist_start = *(uint32_t*)(gfx.DMEM + 0xFF0);
uint32_t a; uint32_t a;
@ -3346,7 +3323,7 @@ void DetectFrameBufferUsage()
{ {
rdp.dl_count = -1; rdp.dl_count = -1;
LRDP("End of DL\n"); WriteTrace(TraceRDP, TraceDebug, "End of DL");
rdp.pc_i--; rdp.pc_i--;
} }
} }
@ -3383,7 +3360,7 @@ void DetectFrameBufferUsage()
rdp.frame_buffers[i].status = ci_aux; rdp.frame_buffers[i].status = ci_aux;
else if (rdp.frame_buffers[i].addr == rdp.frame_buffers[rdp.ci_count - 1].addr) else if (rdp.frame_buffers[i].addr == rdp.frame_buffers[rdp.ci_count - 1].addr)
rdp.frame_buffers[i].status = ci_main; rdp.frame_buffers[i].status = ci_main;
// FRDP("rdp.frame_buffers[%d].status = %d\n", i, rdp.frame_buffers[i].status); // WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = %d", i, rdp.frame_buffers[i].status);
} }
rdp.main_ci_index = rdp.ci_count - 1; rdp.main_ci_index = rdp.ci_count - 1;
} }
@ -3404,10 +3381,10 @@ void DetectFrameBufferUsage()
rdp.frame_buffers[i].status = ci_main; rdp.frame_buffers[i].status = ci_main;
} }
LRDP("detect fb final results: \n"); WriteTrace(TraceRDP, TraceDebug, "detect fb final results: ");
for (i = 0; i < rdp.ci_count; i++) for (i = 0; i < rdp.ci_count; i++)
{ {
FRDP("rdp.frame_buffers[%d].status = %s, addr: %08lx, height: %d\n", i, CIStatus[rdp.frame_buffers[i].status], rdp.frame_buffers[i].addr, rdp.frame_buffers[i].height); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = %s, addr: %08lx, height: %d", i, CIStatus[rdp.frame_buffers[i].status], rdp.frame_buffers[i].addr, rdp.frame_buffers[i].height);
} }
rdp.cimg = ci; rdp.cimg = ci;
@ -3486,7 +3463,7 @@ void DetectFrameBufferUsage()
} }
if (tidal) if (tidal)
{ {
//LRDP("Tidal wave!\n"); //WriteTrace(TraceRDP, TraceDebug, "Tidal wave!");
rdp.copy_ci_index = rdp.main_ci_index; rdp.copy_ci_index = rdp.main_ci_index;
} }
} }
@ -3496,7 +3473,7 @@ void DetectFrameBufferUsage()
rdp.maincimg[0] = rdp.frame_buffers[rdp.main_ci_index]; rdp.maincimg[0] = rdp.frame_buffers[rdp.main_ci_index];
// rdp.scale_x = rdp.scale_x_bak; // rdp.scale_x = rdp.scale_x_bak;
// rdp.scale_y = rdp.scale_y_bak; // rdp.scale_y = rdp.scale_y_bak;
LRDP("DetectFrameBufferUsage End\n"); WriteTrace(TraceRDP, TraceDebug, "DetectFrameBufferUsage End");
} }
/******************************************* /*******************************************
@ -3888,49 +3865,49 @@ static void rdp_triangle(int shade, int texture, int zbuffer)
static void rdp_trifill() static void rdp_trifill()
{ {
rdp_triangle(0, 0, 0); rdp_triangle(0, 0, 0);
LRDP("trifill\n"); WriteTrace(TraceRDP, TraceDebug, "trifill");
} }
static void rdp_trishade() static void rdp_trishade()
{ {
rdp_triangle(1, 0, 0); rdp_triangle(1, 0, 0);
LRDP("trishade\n"); WriteTrace(TraceRDP, TraceDebug, "trishade");
} }
static void rdp_tritxtr() static void rdp_tritxtr()
{ {
rdp_triangle(0, 1, 0); rdp_triangle(0, 1, 0);
LRDP("tritxtr\n"); WriteTrace(TraceRDP, TraceDebug, "tritxtr");
} }
static void rdp_trishadetxtr() static void rdp_trishadetxtr()
{ {
rdp_triangle(1, 1, 0); rdp_triangle(1, 1, 0);
LRDP("trishadetxtr\n"); WriteTrace(TraceRDP, TraceDebug, "trishadetxtr");
} }
static void rdp_trifillz() static void rdp_trifillz()
{ {
rdp_triangle(0, 0, 1); rdp_triangle(0, 0, 1);
LRDP("trifillz\n"); WriteTrace(TraceRDP, TraceDebug, "trifillz");
} }
static void rdp_trishadez() static void rdp_trishadez()
{ {
rdp_triangle(1, 0, 1); rdp_triangle(1, 0, 1);
LRDP("trishadez\n"); WriteTrace(TraceRDP, TraceDebug, "trishadez");
} }
static void rdp_tritxtrz() static void rdp_tritxtrz()
{ {
rdp_triangle(0, 1, 1); rdp_triangle(0, 1, 1);
LRDP("tritxtrz\n"); WriteTrace(TraceRDP, TraceDebug, "tritxtrz");
} }
static void rdp_trishadetxtrz() static void rdp_trishadetxtrz()
{ {
rdp_triangle(1, 1, 1); rdp_triangle(1, 1, 1);
LRDP("trishadetxtrz\n"); WriteTrace(TraceRDP, TraceDebug, "trishadetxtrz");
} }
static rdp_instr rdp_command_table[64] = static rdp_instr rdp_command_table[64] =
@ -4046,7 +4023,7 @@ static void rdphalf_1()
uint32_t cmd = rdp.cmd1 >> 24; uint32_t cmd = rdp.cmd1 >> 24;
if (cmd >= 0xc8 && cmd <= 0xcf) //triangle command if (cmd >= 0xc8 && cmd <= 0xcf) //triangle command
{ {
LRDP("rdphalf_1 - lle triangle\n"); WriteTrace(TraceRDP, TraceDebug, "rdphalf_1 - lle triangle");
rdp_cmd_ptr = 0; rdp_cmd_ptr = 0;
rdp_cmd_cur = 0; rdp_cmd_cur = 0;
uint32_t a; uint32_t a;
@ -4062,7 +4039,7 @@ static void rdphalf_1()
{ {
rdp.dl_count = -1; rdp.dl_count = -1;
LRDP("End of DL\n"); WriteTrace(TraceRDP, TraceDebug, "End of DL");
rdp.pc_i--; rdp.pc_i--;
} }
} }
@ -4092,20 +4069,18 @@ static void rdphalf_1()
} }
else else
{ {
LRDP("rdphalf_1 - IGNORED\n"); WriteTrace(TraceRDP, TraceDebug, "rdphalf_1 - IGNORED");
} }
} }
static void rdphalf_2() static void rdphalf_2()
{ {
RDP_E("rdphalf_2 - IGNORED\n"); WriteTrace(TraceRDP, TraceWarning, "rdphalf_2 - IGNORED");
LRDP("rdphalf_2 - IGNORED\n");
} }
static void rdphalf_cont() static void rdphalf_cont()
{ {
RDP_E("rdphalf_cont - IGNORED\n"); WriteTrace(TraceRDP, TraceWarning, "rdphalf_cont - IGNORED");
LRDP("rdphalf_cont - IGNORED\n");
} }
/****************************************************************** /******************************************************************
@ -4136,7 +4111,7 @@ void CALL ProcessRDPList(void)
rdp_cmd_data[rdp_cmd_ptr++] = READ_RDP_DATA(dp_current + i); rdp_cmd_data[rdp_cmd_ptr++] = READ_RDP_DATA(dp_current + i);
if (rdp_cmd_ptr >= 0x1000) if (rdp_cmd_ptr >= 0x1000)
{ {
FRDP("rdp_process_list: rdp_cmd_ptr overflow %x %x --> %x\n", length, dp_current, dp_end); WriteTrace(TraceRDP, TraceDebug, "rdp_process_list: rdp_cmd_ptr overflow %x %x --> %x", length, dp_current, dp_end);
} }
} }

View File

@ -61,6 +61,8 @@ void SetupTrace(void)
TraceSetModuleName(TraceInterface, "Interface"); TraceSetModuleName(TraceInterface, "Interface");
TraceSetModuleName(TraceResolution, "Resolution"); TraceSetModuleName(TraceResolution, "Resolution");
TraceSetModuleName(TraceGlitch, "Glitch"); TraceSetModuleName(TraceGlitch, "Glitch");
TraceSetModuleName(TraceRDP, "RDP");
TraceSetModuleName(TraceTLUT, "TLUT");
char log_dir[260]; char log_dir[260];
memset(log_dir, 0, sizeof(log_dir)); memset(log_dir, 0, sizeof(log_dir));

View File

@ -10,6 +10,8 @@ enum TraceModuleGlide64
TraceInterface, TraceInterface,
TraceResolution, TraceResolution,
TraceGlitch, TraceGlitch,
TraceRDP,
TraceTLUT,
MaxTraceModuleGlide64, MaxTraceModuleGlide64,
}; };

View File

@ -103,7 +103,7 @@ static void t3dProcessRDP(uint32_t a)
static void t3dLoadGlobState(uint32_t pgstate) static void t3dLoadGlobState(uint32_t pgstate)
{ {
t3dGlobState *gstate = (t3dGlobState*)&gfx.RDRAM[segoffset(pgstate)]; t3dGlobState *gstate = (t3dGlobState*)&gfx.RDRAM[segoffset(pgstate)];
FRDP("Global state. pad0: %04lx, perspNorm: %04lx, flag: %08lx\n", gstate->pad0, gstate->perspNorm, gstate->flag); WriteTrace(TraceRDP, TraceDebug, "Global state. pad0: %04lx, perspNorm: %04lx, flag: %08lx", gstate->pad0, gstate->perspNorm, gstate->flag);
rdp.cmd0 = gstate->othermode0; rdp.cmd0 = gstate->othermode0;
rdp.cmd1 = gstate->othermode1; rdp.cmd1 = gstate->othermode1;
rdp_setothermode(); rdp_setothermode();
@ -111,7 +111,7 @@ static void t3dLoadGlobState(uint32_t pgstate)
for (int s = 0; s < 16; s++) for (int s = 0; s < 16; s++)
{ {
rdp.segment[s] = gstate->segBases[s]; rdp.segment[s] = gstate->segBases[s];
FRDP("segment: %08lx -> seg%d\n", rdp.segment[s], s); WriteTrace(TraceRDP, TraceDebug, "segment: %08lx -> seg%d", rdp.segment[s], s);
} }
short scale_x = gstate->vsacle0 / 4; short scale_x = gstate->vsacle0 / 4;
@ -127,7 +127,7 @@ static void t3dLoadGlobState(uint32_t pgstate)
rdp.view_trans[1] = trans_y * rdp.scale_y; rdp.view_trans[1] = trans_y * rdp.scale_y;
rdp.view_trans[2] = 32.0f * trans_z; rdp.view_trans[2] = 32.0f * trans_z;
rdp.update |= UPDATE_VIEWPORT; rdp.update |= UPDATE_VIEWPORT;
FRDP("viewport scale(%d, %d, %d), trans(%d, %d, %d)\n", scale_x, scale_y, scale_z, WriteTrace(TraceRDP, TraceDebug, "viewport scale(%d, %d, %d), trans(%d, %d, %d)", scale_x, scale_y, scale_z,
trans_x, trans_y, trans_z); trans_x, trans_y, trans_z);
t3dProcessRDP(segoffset(gstate->rdpCmds) >> 2); t3dProcessRDP(segoffset(gstate->rdpCmds) >> 2);
@ -177,27 +177,23 @@ static void t3d_vertex(uint32_t addr, uint32_t v0, uint32_t n)
if (v->y < -v->w) v->scr_off |= 4; if (v->y < -v->w) v->scr_off |= 4;
if (v->y > v->w) v->scr_off |= 8; if (v->y > v->w) v->scr_off |= 8;
if (v->w < 0.1f) v->scr_off |= 16; if (v->w < 0.1f) v->scr_off |= 16;
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "v%d - x: %f, y: %f, z: %f, w: %f, u: %f, v: %f, f: %f, z_w: %f, r=%d, g=%d, b=%d, a=%d", i >> 4, v->x, v->y, v->z, v->w, v->ou*rdp.tiles[rdp.cur_tile].s_scale, v->ov*rdp.tiles[rdp.cur_tile].t_scale, v->f, v->z_w, v->r, v->g, v->b, v->a);
FRDP ("v%d - x: %f, y: %f, z: %f, w: %f, u: %f, v: %f, f: %f, z_w: %f, r=%d, g=%d, b=%d, a=%d\n", i>>4, v->x, v->y, v->z, v->w, v->ou*rdp.tiles[rdp.cur_tile].s_scale, v->ov*rdp.tiles[rdp.cur_tile].t_scale, v->f, v->z_w, v->r, v->g, v->b, v->a);
#endif
} }
} }
static void t3dLoadObject(uint32_t pstate, uint32_t pvtx, uint32_t ptri) static void t3dLoadObject(uint32_t pstate, uint32_t pvtx, uint32_t ptri)
{ {
LRDP("Loading Turbo3D object\n"); WriteTrace(TraceRDP, TraceDebug, "Loading Turbo3D object");
t3dState *ostate = (t3dState*)&gfx.RDRAM[segoffset(pstate)]; t3dState *ostate = (t3dState*)&gfx.RDRAM[segoffset(pstate)];
rdp.cur_tile = (ostate->textureState) & 7; rdp.cur_tile = (ostate->textureState) & 7;
FRDP("tile: %d\n", rdp.cur_tile); WriteTrace(TraceRDP, TraceDebug, "tile: %d", rdp.cur_tile);
if (rdp.tiles[rdp.cur_tile].s_scale < 0.001f) if (rdp.tiles[rdp.cur_tile].s_scale < 0.001f)
rdp.tiles[rdp.cur_tile].s_scale = 0.015625; rdp.tiles[rdp.cur_tile].s_scale = 0.015625;
if (rdp.tiles[rdp.cur_tile].t_scale < 0.001f) if (rdp.tiles[rdp.cur_tile].t_scale < 0.001f)
rdp.tiles[rdp.cur_tile].t_scale = 0.015625; rdp.tiles[rdp.cur_tile].t_scale = 0.015625;
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "renderState: %08lx, textureState: %08lx, othermode0: %08lx, othermode1: %08lx, rdpCmds: %08lx, triCount : %d, v0: %d, vn: %d", ostate->renderState, ostate->textureState,
FRDP("renderState: %08lx, textureState: %08lx, othermode0: %08lx, othermode1: %08lx, rdpCmds: %08lx, triCount : %d, v0: %d, vn: %d\n", ostate->renderState, ostate->textureState,
ostate->othermode0, ostate->othermode1, ostate->rdpCmds, ostate->triCount, ostate->vtxV0, ostate->vtxCount); ostate->othermode0, ostate->othermode1, ostate->rdpCmds, ostate->triCount, ostate->vtxV0, ostate->vtxCount);
#endif
rdp.cmd0 = ostate->othermode0; rdp.cmd0 = ostate->othermode0;
rdp.cmd1 = ostate->othermode1; rdp.cmd1 = ostate->othermode1;
@ -210,12 +206,10 @@ static void t3dLoadObject(uint32_t pstate, uint32_t pvtx, uint32_t ptri)
{ {
uint32_t addr = segoffset(pstate + sizeof(t3dState)) & BMASK; uint32_t addr = segoffset(pstate + sizeof(t3dState)) & BMASK;
load_matrix(rdp.combined, addr); load_matrix(rdp.combined, addr);
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.combined[0][0], rdp.combined[0][1], rdp.combined[0][2], rdp.combined[0][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.combined[0][0], rdp.combined[0][1], rdp.combined[0][2], rdp.combined[0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.combined[1][0], rdp.combined[1][1], rdp.combined[1][2], rdp.combined[1][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.combined[1][0], rdp.combined[1][1], rdp.combined[1][2], rdp.combined[1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.combined[2][0], rdp.combined[2][1], rdp.combined[2][2], rdp.combined[2][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.combined[2][0], rdp.combined[2][1], rdp.combined[2][2], rdp.combined[2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.combined[3][0], rdp.combined[3][1], rdp.combined[3][2], rdp.combined[3][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.combined[3][0], rdp.combined[3][1], rdp.combined[3][2], rdp.combined[3][3]);
#endif
} }
rdp.geom_mode &= ~0x00020000; rdp.geom_mode &= ~0x00020000;
@ -233,7 +227,7 @@ static void t3dLoadObject(uint32_t pstate, uint32_t pvtx, uint32_t ptri)
{ {
t3dTriN * tri = (t3dTriN*)&gfx.RDRAM[a]; t3dTriN * tri = (t3dTriN*)&gfx.RDRAM[a];
a += 4; a += 4;
FRDP("tri #%d - %d, %d, %d\n", t, tri->v0, tri->v1, tri->v2); WriteTrace(TraceRDP, TraceDebug, "tri #%d - %d, %d, %d", t, tri->v0, tri->v1, tri->v2);
VERTEX *v[3] = { &rdp.vtx[tri->v0], &rdp.vtx[tri->v1], &rdp.vtx[tri->v2] }; VERTEX *v[3] = { &rdp.vtx[tri->v0], &rdp.vtx[tri->v1], &rdp.vtx[tri->v2] };
if (cull_tri(v)) if (cull_tri(v))
rdp.tri_n++; rdp.tri_n++;
@ -248,7 +242,7 @@ static void t3dLoadObject(uint32_t pstate, uint32_t pvtx, uint32_t ptri)
static void Turbo3D() static void Turbo3D()
{ {
LRDP("Start Turbo3D microcode\n"); WriteTrace(TraceRDP, TraceDebug, "Start Turbo3D microcode");
g_settings->ucode = ucode_Fast3D; g_settings->ucode = 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 {
@ -257,7 +251,7 @@ static void Turbo3D()
pstate = ((uint32_t*)gfx.RDRAM)[(a >> 2) + 1]; pstate = ((uint32_t*)gfx.RDRAM)[(a >> 2) + 1];
pvtx = ((uint32_t*)gfx.RDRAM)[(a >> 2) + 2]; pvtx = ((uint32_t*)gfx.RDRAM)[(a >> 2) + 2];
ptri = ((uint32_t*)gfx.RDRAM)[(a >> 2) + 3]; ptri = ((uint32_t*)gfx.RDRAM)[(a >> 2) + 3];
FRDP("GlobalState: %08lx, Object: %08lx, Vertices: %08lx, Triangles: %08lx\n", pgstate, pstate, pvtx, ptri); WriteTrace(TraceRDP, TraceDebug, "GlobalState: %08lx, Object: %08lx, Vertices: %08lx, Triangles: %08lx", pgstate, pstate, pvtx, ptri);
if (!pstate) if (!pstate)
{ {
rdp.halt = 1; rdp.halt = 1;

View File

@ -80,7 +80,7 @@ static void rsp_vertex(int v0, int n)
} }
} }
FRDP("rsp:vertex v0:%d, n:%d, from: %08lx\n", v0, n, addr); WriteTrace(TraceRDP, TraceDebug, "rsp:vertex v0:%d, n:%d, from: %08lx", v0, n, addr);
for (i = 0; i < (n << 4); i += 16) for (i = 0; i < (n << 4); i += 16)
{ {
@ -140,9 +140,7 @@ static void rsp_vertex(int v0, int n)
v->g = ((uint8_t*)gfx.RDRAM)[(addr + i + 13) ^ 3]; v->g = ((uint8_t*)gfx.RDRAM)[(addr + i + 13) ^ 3];
v->b = ((uint8_t*)gfx.RDRAM)[(addr + i + 14) ^ 3]; v->b = ((uint8_t*)gfx.RDRAM)[(addr + i + 14) ^ 3];
} }
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "v%d - x: %f, y: %f, z: %f, w: %f, u: %f, v: %f, f: %f, z_w: %f, r=%d, g=%d, b=%d, a=%d", i >> 4, v->x, v->y, v->z, v->w, v->ou*rdp.tiles[rdp.cur_tile].s_scale, v->ov*rdp.tiles[rdp.cur_tile].t_scale, v->f, v->z_w, v->r, v->g, v->b, v->a);
FRDP ("v%d - x: %f, y: %f, z: %f, w: %f, u: %f, v: %f, f: %f, z_w: %f, r=%d, g=%d, b=%d, a=%d\n", i>>4, v->x, v->y, v->z, v->w, v->ou*rdp.tiles[rdp.cur_tile].s_scale, v->ov*rdp.tiles[rdp.cur_tile].t_scale, v->f, v->z_w, v->r, v->g, v->b, v->a);
#endif
} }
} }
@ -216,8 +214,7 @@ void modelview_push()
{ {
if (rdp.model_i == rdp.model_stack_size) if (rdp.model_i == rdp.model_stack_size)
{ {
RDP_E("** Model matrix stack overflow ** too many pushes\n"); WriteTrace(TraceRDP, TraceWarning, "** Model matrix stack overflow ** too many pushes");
LRDP("** Model matrix stack overflow ** too many pushes\n");
return; return;
} }
@ -233,8 +230,7 @@ void modelview_pop(int num = 1)
} }
else else
{ {
RDP_E("** Model matrix stack error ** too many pops\n"); WriteTrace(TraceRDP, TraceWarning, "** Model matrix stack error ** too many pops");
LRDP("** Model matrix stack error ** too many pops\n");
return; return;
} }
memcpy(rdp.model, rdp.model_stack[rdp.model_i], 64); memcpy(rdp.model, rdp.model_stack[rdp.model_i], 64);
@ -270,7 +266,7 @@ void projection_mul(float m[4][4])
void load_matrix(float m[4][4], uint32_t addr) void load_matrix(float m[4][4], uint32_t addr)
{ {
FRDP("matrix - addr: %08lx\n", addr); WriteTrace(TraceRDP, TraceDebug, "matrix - addr: %08lx", addr);
int x, y; // matrix index int x, y; // matrix index
addr >>= 1; addr >>= 1;
uint16_t * src = (uint16_t*)gfx.RDRAM; uint16_t * src = (uint16_t*)gfx.RDRAM;
@ -289,7 +285,7 @@ void load_matrix(float m[4][4], uint32_t addr)
// //
static void uc0_matrix() static void uc0_matrix()
{ {
LRDP("uc0:matrix "); WriteTrace(TraceRDP, TraceDebug, "uc0:matrix ");
// Use segment offset to get the address // Use segment offset to get the address
uint32_t addr = segoffset(rdp.cmd1) & 0x00FFFFFF; uint32_t addr = segoffset(rdp.cmd1) & 0x00FFFFFF;
@ -301,57 +297,54 @@ static void uc0_matrix()
switch (command) switch (command)
{ {
case 0: // modelview mul nopush case 0: // modelview mul nopush
LRDP("modelview mul\n"); WriteTrace(TraceRDP, TraceDebug, "modelview mul");
modelview_mul(m); modelview_mul(m);
break; break;
case 1: // projection mul nopush case 1: // projection mul nopush
case 5: // projection mul push, can't push projection case 5: // projection mul push, can't push projection
LRDP("projection mul\n"); WriteTrace(TraceRDP, TraceDebug, "projection mul");
projection_mul(m); projection_mul(m);
break; break;
case 2: // modelview load nopush case 2: // modelview load nopush
LRDP("modelview load\n"); WriteTrace(TraceRDP, TraceDebug, "modelview load");
modelview_load(m); modelview_load(m);
break; break;
case 3: // projection load nopush case 3: // projection load nopush
case 7: // projection load push, can't push projection case 7: // projection load push, can't push projection
LRDP("projection load\n"); WriteTrace(TraceRDP, TraceDebug, "projection load");
projection_load(m); projection_load(m);
break; break;
case 4: // modelview mul push case 4: // modelview mul push
LRDP("modelview mul push\n"); WriteTrace(TraceRDP, TraceDebug, "modelview mul push");
modelview_mul_push(m); modelview_mul_push(m);
break; break;
case 6: // modelview load push case 6: // modelview load push
LRDP("modelview load push\n"); WriteTrace(TraceRDP, TraceDebug, "modelview load push");
modelview_load_push(m); modelview_load_push(m);
break; break;
default: default:
FRDP_E("Unknown matrix command, %02lx", command); WriteTrace(TraceRDP, TraceWarning, "Unknown matrix command, %02lx", command);
FRDP("Unknown matrix command, %02lx", command);
} }
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", m[0][0], m[0][1], m[0][2], m[0][3]);
FRDP("{%f,%f,%f,%f}\n", m[0][0], m[0][1], m[0][2], m[0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", m[1][0], m[1][1], m[1][2], m[1][3]);
FRDP ("{%f,%f,%f,%f}\n", m[1][0], m[1][1], m[1][2], m[1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", m[2][0], m[2][1], m[2][2], m[2][3]);
FRDP ("{%f,%f,%f,%f}\n", m[2][0], m[2][1], m[2][2], m[2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", m[3][0], m[3][1], m[3][2], m[3][3]);
FRDP ("{%f,%f,%f,%f}\n", m[3][0], m[3][1], m[3][2], m[3][3]); WriteTrace(TraceRDP, TraceVerbose, "\nmodel\n{%f,%f,%f,%f}", rdp.model[0][0], rdp.model[0][1], rdp.model[0][2], rdp.model[0][3]);
FRDP ("\nmodel\n{%f,%f,%f,%f}\n", rdp.model[0][0], rdp.model[0][1], rdp.model[0][2], rdp.model[0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.model[1][0], rdp.model[1][1], rdp.model[1][2], rdp.model[1][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.model[1][0], rdp.model[1][1], rdp.model[1][2], rdp.model[1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.model[2][0], rdp.model[2][1], rdp.model[2][2], rdp.model[2][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.model[2][0], rdp.model[2][1], rdp.model[2][2], rdp.model[2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.model[3][0], rdp.model[3][1], rdp.model[3][2], rdp.model[3][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.model[3][0], rdp.model[3][1], rdp.model[3][2], rdp.model[3][3]); WriteTrace(TraceRDP, TraceVerbose, "\nproj\n{%f,%f,%f,%f}", rdp.proj[0][0], rdp.proj[0][1], rdp.proj[0][2], rdp.proj[0][3]);
FRDP ("\nproj\n{%f,%f,%f,%f}\n", rdp.proj[0][0], rdp.proj[0][1], rdp.proj[0][2], rdp.proj[0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.proj[1][0], rdp.proj[1][1], rdp.proj[1][2], rdp.proj[1][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.proj[1][0], rdp.proj[1][1], rdp.proj[1][2], rdp.proj[1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.proj[2][0], rdp.proj[2][1], rdp.proj[2][2], rdp.proj[2][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.proj[2][0], rdp.proj[2][1], rdp.proj[2][2], rdp.proj[2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.proj[3][0], rdp.proj[3][1], rdp.proj[3][2], rdp.proj[3][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.proj[3][0], rdp.proj[3][1], rdp.proj[3][2], rdp.proj[3][3]);
#endif
} }
// //
@ -359,7 +352,7 @@ static void uc0_matrix()
// //
static void uc0_movemem() static void uc0_movemem()
{ {
LRDP("uc0:movemem "); WriteTrace(TraceRDP, TraceDebug, "uc0:movemem ");
uint32_t i, a; uint32_t i, a;
@ -392,7 +385,7 @@ static void uc0_movemem()
rdp.update |= UPDATE_VIEWPORT; rdp.update |= UPDATE_VIEWPORT;
FRDP("viewport scale(%d, %d, %d), trans(%d, %d, %d), from:%08lx\n", scale_x, scale_y, scale_z, WriteTrace(TraceRDP, TraceDebug, "viewport scale(%d, %d, %d), trans(%d, %d, %d), from:%08lx", scale_x, scale_y, scale_z,
trans_x, trans_y, trans_z, rdp.cmd1); trans_x, trans_y, trans_z, rdp.cmd1);
} }
break; break;
@ -410,7 +403,7 @@ static void uc0_movemem()
rdp.use_lookat = FALSE; rdp.use_lookat = FALSE;
else else
rdp.use_lookat = TRUE; rdp.use_lookat = TRUE;
FRDP("lookat_y (%f, %f, %f)\n", rdp.lookat[1][0], rdp.lookat[1][1], rdp.lookat[1][2]); WriteTrace(TraceRDP, TraceDebug, "lookat_y (%f, %f, %f)", rdp.lookat[1][0], rdp.lookat[1][1], rdp.lookat[1][2]);
} }
break; break;
@ -420,7 +413,7 @@ static void uc0_movemem()
rdp.lookat[0][1] = (float)(((char*)gfx.RDRAM)[(a + 9) ^ 3]) / 127.0f; rdp.lookat[0][1] = (float)(((char*)gfx.RDRAM)[(a + 9) ^ 3]) / 127.0f;
rdp.lookat[0][2] = (float)(((char*)gfx.RDRAM)[(a + 10) ^ 3]) / 127.0f; rdp.lookat[0][2] = (float)(((char*)gfx.RDRAM)[(a + 10) ^ 3]) / 127.0f;
rdp.use_lookat = TRUE; rdp.use_lookat = TRUE;
FRDP("lookat_x (%f, %f, %f)\n", rdp.lookat[1][0], rdp.lookat[1][1], rdp.lookat[1][2]); WriteTrace(TraceRDP, TraceDebug, "lookat_x (%f, %f, %f)", rdp.lookat[1][0], rdp.lookat[1][1], rdp.lookat[1][2]);
break; break;
case 0x86: case 0x86:
@ -449,7 +442,7 @@ static void uc0_movemem()
//rdp.update |= UPDATE_LIGHTS; //rdp.update |= UPDATE_LIGHTS;
FRDP("light: n: %d, r: %.3f, g: %.3f, b: %.3f, x: %.3f, y: %.3f, z: %.3f\n", WriteTrace(TraceRDP, TraceDebug, "light: n: %d, r: %.3f, g: %.3f, b: %.3f, x: %.3f, y: %.3f, z: %.3f",
i, rdp.light[i].r, rdp.light[i].g, rdp.light[i].b, i, rdp.light[i].r, rdp.light[i].g, rdp.light[i].b,
rdp.light_vector[i][0], rdp.light_vector[i][1], rdp.light_vector[i][2]); rdp.light_vector[i][0], rdp.light_vector[i][1], rdp.light_vector[i][2]);
break; break;
@ -465,36 +458,31 @@ static void uc0_movemem()
addr = rdp.pc[rdp.pc_i] & BMASK; addr = rdp.pc[rdp.pc_i] & BMASK;
rdp.pc[rdp.pc_i] = (addr + 24) & BMASK; //skip next 3 command, b/c they all are part of gSPForceMatrix rdp.pc[rdp.pc_i] = (addr + 24) & BMASK; //skip next 3 command, b/c they all are part of gSPForceMatrix
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.combined[0][0], rdp.combined[0][1], rdp.combined[0][2], rdp.combined[0][3]);
FRDP("{%f,%f,%f,%f}\n", rdp.combined[0][0], rdp.combined[0][1], rdp.combined[0][2], rdp.combined[0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.combined[1][0], rdp.combined[1][1], rdp.combined[1][2], rdp.combined[1][3]);
FRDP("{%f,%f,%f,%f}\n", rdp.combined[1][0], rdp.combined[1][1], rdp.combined[1][2], rdp.combined[1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.combined[2][0], rdp.combined[2][1], rdp.combined[2][2], rdp.combined[2][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.combined[2][0], rdp.combined[2][1], rdp.combined[2][2], rdp.combined[2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.combined[3][0], rdp.combined[3][1], rdp.combined[3][2], rdp.combined[3][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.combined[3][0], rdp.combined[3][1], rdp.combined[3][2], rdp.combined[3][3]);
#endif
} }
break; break;
//next 3 command should never appear since they will be skipped in previous command //next 3 command should never appear since they will be skipped in previous command
case 0x98: case 0x98:
RDP_E("uc0:movemem matrix 0 - ERROR!\n"); WriteTrace(TraceRDP, TraceWarning, "matrix 0 - IGNORED");
LRDP("matrix 0 - IGNORED\n");
break; break;
case 0x9A: case 0x9A:
RDP_E("uc0:movemem matrix 1 - ERROR!\n"); WriteTrace(TraceRDP, TraceWarning, "matrix 1 - IGNORED");
LRDP("matrix 1 - IGNORED\n");
break; break;
case 0x9C: case 0x9C:
RDP_E("uc0:movemem matrix 2 - ERROR!\n"); WriteTrace(TraceRDP, TraceWarning, "matrix 2 - IGNORED");
LRDP("matrix 2 - IGNORED\n");
break; break;
default: default:
FRDP_E("uc0:movemem unknown (index: 0x%08lx)\n", (rdp.cmd0 >> 16) & 0xFF); WriteTrace(TraceRDP, TraceWarning, "uc0:movemem unknown (index: 0x%08lx)", (rdp.cmd0 >> 16) & 0xFF);
FRDP("unknown (index: 0x%08lx)\n", (rdp.cmd0 >> 16) & 0xFF); WriteTrace(TraceRDP, TraceDebug, "unknown (index: 0x%08lx)", (rdp.cmd0 >> 16) & 0xFF);
}
} }
}
// //
// uc0:displaylist - makes a call to another section of code // uc0:displaylist - makes a call to another section of code
@ -504,19 +492,19 @@ static void uc0_displaylist()
uint32_t addr = segoffset(rdp.cmd1) & 0x00FFFFFF; uint32_t addr = segoffset(rdp.cmd1) & 0x00FFFFFF;
// This fixes partially Gauntlet: Legends // This fixes partially Gauntlet: Legends
if (addr == rdp.pc[rdp.pc_i] - 8) { LRDP("display list not executed!\n"); return; } if (addr == rdp.pc[rdp.pc_i] - 8) { WriteTrace(TraceRDP, TraceDebug, "display list not executed!"); return; }
uint32_t push = (rdp.cmd0 >> 16) & 0xFF; // push the old location? uint32_t push = (rdp.cmd0 >> 16) & 0xFF; // push the old location?
FRDP("uc0:displaylist: %08lx, push:%s", addr, push ? "no" : "yes"); WriteTrace(TraceRDP, TraceDebug, "uc0:displaylist: %08lx, push:%s", addr, push ? "no" : "yes");
FRDP(" (seg %d, offset %08lx)\n", (rdp.cmd1 >> 24) & 0x0F, rdp.cmd1 & 0x00FFFFFF); WriteTrace(TraceRDP, TraceDebug, " (seg %d, offset %08lx)", (rdp.cmd1 >> 24) & 0x0F, rdp.cmd1 & 0x00FFFFFF);
switch (push) switch (push)
{ {
case 0: // push case 0: // push
if (rdp.pc_i >= 9) { if (rdp.pc_i >= 9)
RDP_E("** DL stack overflow **"); {
LRDP("** DL stack overflow **\n"); WriteTrace(TraceRDP, TraceWarning, "** DL stack overflow **");
return; return;
} }
rdp.pc_i++; // go to the next PC in the stack rdp.pc_i++; // go to the next PC in the stack
@ -528,8 +516,7 @@ static void uc0_displaylist()
break; break;
default: default:
RDP_E("Unknown displaylist operation\n"); WriteTrace(TraceRDP, TraceWarning, "Unknown displaylist operation");
LRDP("Unknown displaylist operation\n");
} }
} }
@ -538,7 +525,7 @@ static void uc0_displaylist()
// //
static void uc0_tri1() static void uc0_tri1()
{ {
FRDP("uc0:tri1 #%d - %d, %d, %d\n", rdp.tri_n, WriteTrace(TraceRDP, TraceDebug, "uc0:tri1 #%d - %d, %d, %d", rdp.tri_n,
((rdp.cmd1 >> 16) & 0xFF) / 10, ((rdp.cmd1 >> 16) & 0xFF) / 10,
((rdp.cmd1 >> 8) & 0xFF) / 10, ((rdp.cmd1 >> 8) & 0xFF) / 10,
(rdp.cmd1 & 0xFF) / 10); (rdp.cmd1 & 0xFF) / 10);
@ -568,11 +555,11 @@ static void uc0_tri1()
// //
static void uc0_enddl() static void uc0_enddl()
{ {
LRDP("uc0:enddl\n"); WriteTrace(TraceRDP, TraceDebug, "uc0:enddl");
if (rdp.pc_i == 0) if (rdp.pc_i == 0)
{ {
LRDP("RDP end\n"); WriteTrace(TraceRDP, TraceDebug, "RDP end");
// Halt execution here // Halt execution here
rdp.halt = 1; rdp.halt = 1;
@ -588,7 +575,7 @@ static void uc0_culldl()
uint32_t cond = 0; uint32_t cond = 0;
VERTEX *v; VERTEX *v;
FRDP("uc0:culldl start: %d, end: %d\n", vStart, vEnd); WriteTrace(TraceRDP, TraceDebug, "uc0:culldl start: %d, end: %d", vStart, vEnd);
if (vEnd < vStart) return; if (vEnd < vStart) return;
for (uint16_t i = vStart; i <= vEnd; i++) for (uint16_t i = vStart; i <= vEnd; i++)
@ -610,13 +597,13 @@ static void uc0_culldl()
return; return;
} }
LRDP(" - "); // specify that the enddl is not a real command WriteTrace(TraceRDP, TraceDebug, " - "); // specify that the enddl is not a real command
uc0_enddl(); uc0_enddl();
} }
static void uc0_popmatrix() static void uc0_popmatrix()
{ {
LRDP("uc0:popmatrix\n"); WriteTrace(TraceRDP, TraceDebug, "uc0:popmatrix");
uint32_t param = rdp.cmd1; uint32_t param = rdp.cmd1;
@ -630,8 +617,7 @@ static void uc0_popmatrix()
break; break;
default: default:
FRDP_E("Unknown uc0:popmatrix command: 0x%08lx\n", param); WriteTrace(TraceRDP, TraceWarning, "Unknown uc0:popmatrix command: 0x%08lx", param);
FRDP("Unknown uc0:popmatrix command: 0x%08lx\n", param);
} }
} }
@ -654,7 +640,7 @@ static void uc0_modifyvtx(uint8_t where, uint16_t vtx, uint32_t val)
v->a = (uint8_t)(val & 0xFF); v->a = (uint8_t)(val & 0xFF);
v->shade_mod = 0; v->shade_mod = 0;
FRDP("RGBA: %d, %d, %d, %d\n", v->r, v->g, v->b, v->a); WriteTrace(TraceRDP, TraceDebug, "RGBA: %d, %d, %d, %d", v->r, v->g, v->b, v->a);
break; break;
case 0x14: // ST case 0x14: // ST
@ -665,7 +651,7 @@ static void uc0_modifyvtx(uint8_t where, uint16_t vtx, uint32_t val)
v->uv_calculated = 0xFFFFFFFF; v->uv_calculated = 0xFFFFFFFF;
v->uv_scaled = 1; v->uv_scaled = 1;
} }
FRDP("u/v: (%04lx, %04lx), (%f, %f)\n", (short)(val >> 16), (short)(val & 0xFFFF), WriteTrace(TraceRDP, TraceDebug, "u/v: (%04lx, %04lx), (%f, %f)", (short)(val >> 16), (short)(val & 0xFFFF),
v->ou, v->ov); v->ou, v->ov);
break; break;
@ -691,7 +677,7 @@ static void uc0_modifyvtx(uint8_t where, uint16_t vtx, uint32_t val)
if (scr_y > rdp.vi_height) v->scr_off |= 8; if (scr_y > rdp.vi_height) v->scr_off |= 8;
if (v->w < 0.1f) v->scr_off |= 16; if (v->w < 0.1f) v->scr_off |= 16;
FRDP("x/y: (%f, %f)\n", scr_x, scr_y); WriteTrace(TraceRDP, TraceDebug, "x/y: (%f, %f)", scr_x, scr_y);
} }
break; break;
@ -700,12 +686,12 @@ static void uc0_modifyvtx(uint8_t where, uint16_t vtx, uint32_t val)
float scr_z = (float)((short)(val >> 16)); float scr_z = (float)((short)(val >> 16));
v->z_w = (scr_z - rdp.view_trans[2]) / rdp.view_scale[2]; v->z_w = (scr_z - rdp.view_trans[2]) / rdp.view_scale[2];
v->z = v->z_w * v->w; v->z = v->z_w * v->w;
FRDP("z: %f\n", scr_z); WriteTrace(TraceRDP, TraceDebug, "z: %f", scr_z);
} }
break; break;
default: default:
LRDP("UNKNOWN\n"); WriteTrace(TraceRDP, TraceDebug, "UNKNOWN");
break; break;
} }
} }
@ -715,14 +701,13 @@ static void uc0_modifyvtx(uint8_t where, uint16_t vtx, uint32_t val)
// //
static void uc0_moveword() static void uc0_moveword()
{ {
LRDP("uc0:moveword "); WriteTrace(TraceRDP, TraceDebug, "uc0:moveword ");
// Find which command this is (lowest byte of cmd0) // Find which command this is (lowest byte of cmd0)
switch (rdp.cmd0 & 0xFF) switch (rdp.cmd0 & 0xFF)
{ {
case 0x00: case 0x00:
RDP_E("uc0:moveword matrix - IGNORED\n"); WriteTrace(TraceRDP, TraceWarning, "matrix - IGNORED");
LRDP("matrix - IGNORED\n");
break; break;
case 0x02: case 0x02:
@ -730,7 +715,7 @@ static void uc0_moveword()
if (rdp.num_lights > 8) rdp.num_lights = 0; if (rdp.num_lights > 8) rdp.num_lights = 0;
rdp.update |= UPDATE_LIGHTS; rdp.update |= UPDATE_LIGHTS;
FRDP("numlights: %d\n", rdp.num_lights); WriteTrace(TraceRDP, TraceDebug, "numlights: %d", rdp.num_lights);
break; break;
case 0x04: case 0x04:
@ -739,11 +724,11 @@ static void uc0_moveword()
rdp.clip_ratio = sqrt((float)rdp.cmd1); rdp.clip_ratio = sqrt((float)rdp.cmd1);
rdp.update |= UPDATE_VIEWPORT; rdp.update |= UPDATE_VIEWPORT;
} }
FRDP("clip %08lx, %08lx\n", rdp.cmd0, rdp.cmd1); WriteTrace(TraceRDP, TraceDebug, "clip %08lx, %08lx", rdp.cmd0, rdp.cmd1);
break; break;
case 0x06: // segment case 0x06: // segment
FRDP("segment: %08lx -> seg%d\n", rdp.cmd1, (rdp.cmd0 >> 10) & 0x0F); WriteTrace(TraceRDP, TraceDebug, "segment: %08lx -> seg%d", rdp.cmd1, (rdp.cmd0 >> 10) & 0x0F);
if ((rdp.cmd1&BMASK) < BMASK) if ((rdp.cmd1&BMASK) < BMASK)
rdp.segment[(rdp.cmd0 >> 10) & 0x0F] = rdp.cmd1; rdp.segment[(rdp.cmd0 >> 10) & 0x0F] = rdp.cmd1;
break; break;
@ -752,14 +737,14 @@ static void uc0_moveword()
{ {
rdp.fog_multiplier = (short)(rdp.cmd1 >> 16); rdp.fog_multiplier = (short)(rdp.cmd1 >> 16);
rdp.fog_offset = (short)(rdp.cmd1 & 0x0000FFFF); rdp.fog_offset = (short)(rdp.cmd1 & 0x0000FFFF);
FRDP("fog: multiplier: %f, offset: %f\n", rdp.fog_multiplier, rdp.fog_offset); WriteTrace(TraceRDP, TraceDebug, "fog: multiplier: %f, offset: %f", rdp.fog_multiplier, rdp.fog_offset);
} }
break; break;
case 0x0a: // moveword LIGHTCOL case 0x0a: // moveword LIGHTCOL
{ {
int n = (rdp.cmd0 & 0xE000) >> 13; int n = (rdp.cmd0 & 0xE000) >> 13;
FRDP("lightcol light:%d, %08lx\n", n, rdp.cmd1); WriteTrace(TraceRDP, TraceDebug, "lightcol light:%d, %08lx", n, rdp.cmd1);
rdp.light[n].r = (float)((rdp.cmd1 >> 24) & 0xFF) / 255.0f; rdp.light[n].r = (float)((rdp.cmd1 >> 24) & 0xFF) / 255.0f;
rdp.light[n].g = (float)((rdp.cmd1 >> 16) & 0xFF) / 255.0f; rdp.light[n].g = (float)((rdp.cmd1 >> 16) & 0xFF) / 255.0f;
@ -774,17 +759,16 @@ static void uc0_moveword()
uint16_t vtx = val / 40; uint16_t vtx = val / 40;
uint8_t where = val % 40; uint8_t where = val % 40;
uc0_modifyvtx(where, vtx, rdp.cmd1); uc0_modifyvtx(where, vtx, rdp.cmd1);
FRDP("uc0:modifyvtx: vtx: %d, where: 0x%02lx, val: %08lx - ", vtx, where, rdp.cmd1); WriteTrace(TraceRDP, TraceDebug, "uc0:modifyvtx: vtx: %d, where: 0x%02lx, val: %08lx - ", vtx, where, rdp.cmd1);
} }
break; break;
case 0x0e: case 0x0e:
LRDP("perspnorm - IGNORED\n"); WriteTrace(TraceRDP, TraceDebug, "perspnorm - IGNORED");
break; break;
default: default:
FRDP_E("uc0:moveword unknown (index: 0x%08lx)\n", rdp.cmd0 & 0xFF); WriteTrace(TraceRDP, TraceWarning, "uc0:moveword unknown (index: 0x%08lx)", rdp.cmd0 & 0xFF);
FRDP("unknown (index: 0x%08lx)\n", rdp.cmd0 & 0xFF);
} }
} }
@ -812,19 +796,19 @@ static void uc0_texture()
rdp.update |= UPDATE_TEXTURE; rdp.update |= UPDATE_TEXTURE;
FRDP("uc0:texture: tile: %d, mipmap_lvl: %d, on: %d, s_scale: %f, t_scale: %f\n", WriteTrace(TraceRDP, TraceDebug, "uc0:texture: tile: %d, mipmap_lvl: %d, on: %d, s_scale: %f, t_scale: %f",
tile, rdp.mipmap_level, on, tmp_tile->s_scale, tmp_tile->t_scale); tile, rdp.mipmap_level, on, tmp_tile->s_scale, tmp_tile->t_scale);
} }
else else
{ {
LRDP("uc0:texture skipped b/c of off\n"); WriteTrace(TraceRDP, TraceDebug, "uc0:texture skipped b/c of off");
rdp.tiles[tile].on = 0; rdp.tiles[tile].on = 0;
} }
} }
static void uc0_setothermode_h() static void uc0_setothermode_h()
{ {
LRDP("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 == ucode_F3DEX2) || (g_settings->ucode == ucode_CBFD))
@ -851,58 +835,58 @@ static void uc0_setothermode_h()
if (mask & 0x00000030) // alpha dither mode if (mask & 0x00000030) // alpha dither mode
{ {
rdp.alpha_dither_mode = (rdp.othermode_h >> 4) & 0x3; rdp.alpha_dither_mode = (rdp.othermode_h >> 4) & 0x3;
FRDP("alpha dither mode: %s\n", str_dither[rdp.alpha_dither_mode]); WriteTrace(TraceRDP, TraceDebug, "alpha dither mode: %s", str_dither[rdp.alpha_dither_mode]);
} }
if (mask & 0x000000C0) // rgb dither mode if (mask & 0x000000C0) // rgb dither mode
{ {
uint32_t dither_mode = (rdp.othermode_h >> 6) & 0x3; uint32_t dither_mode = (rdp.othermode_h >> 6) & 0x3;
FRDP("rgb dither mode: %s\n", str_dither[dither_mode]); WriteTrace(TraceRDP, TraceDebug, "rgb dither mode: %s", str_dither[dither_mode]);
} }
if (mask & 0x00003000) // filter mode if (mask & 0x00003000) // filter mode
{ {
rdp.filter_mode = (int)((rdp.othermode_h & 0x00003000) >> 12); rdp.filter_mode = (int)((rdp.othermode_h & 0x00003000) >> 12);
rdp.update |= UPDATE_TEXTURE; rdp.update |= UPDATE_TEXTURE;
FRDP("filter mode: %s\n", str_filter[rdp.filter_mode]); WriteTrace(TraceRDP, TraceDebug, "filter mode: %s", str_filter[rdp.filter_mode]);
} }
if (mask & 0x0000C000) // tlut mode if (mask & 0x0000C000) // tlut mode
{ {
rdp.tlut_mode = (uint8_t)((rdp.othermode_h & 0x0000C000) >> 14); rdp.tlut_mode = (uint8_t)((rdp.othermode_h & 0x0000C000) >> 14);
FRDP("tlut mode: %s\n", str_tlut[rdp.tlut_mode]); WriteTrace(TraceRDP, TraceDebug, "tlut mode: %s", str_tlut[rdp.tlut_mode]);
} }
if (mask & 0x00300000) // cycle type if (mask & 0x00300000) // cycle type
{ {
rdp.cycle_mode = (uint8_t)((rdp.othermode_h & 0x00300000) >> 20); rdp.cycle_mode = (uint8_t)((rdp.othermode_h & 0x00300000) >> 20);
rdp.update |= UPDATE_ZBUF_ENABLED; rdp.update |= UPDATE_ZBUF_ENABLED;
FRDP("cycletype: %d\n", rdp.cycle_mode); WriteTrace(TraceRDP, TraceDebug, "cycletype: %d", rdp.cycle_mode);
} }
if (mask & 0x00010000) // LOD enable if (mask & 0x00010000) // LOD enable
{ {
rdp.LOD_en = (rdp.othermode_h & 0x00010000) ? TRUE : FALSE; rdp.LOD_en = (rdp.othermode_h & 0x00010000) ? TRUE : FALSE;
FRDP("LOD_en: %d\n", rdp.LOD_en); WriteTrace(TraceRDP, TraceDebug, "LOD_en: %d", rdp.LOD_en);
} }
if (mask & 0x00080000) // Persp enable if (mask & 0x00080000) // Persp enable
{ {
if (rdp.persp_supported) if (rdp.persp_supported)
rdp.Persp_en = (rdp.othermode_h & 0x00080000) ? TRUE : FALSE; rdp.Persp_en = (rdp.othermode_h & 0x00080000) ? TRUE : FALSE;
FRDP("Persp_en: %d\n", rdp.Persp_en); WriteTrace(TraceRDP, TraceDebug, "Persp_en: %d", rdp.Persp_en);
} }
uint32_t unk = mask & 0x0FFC60F0F; uint32_t unk = mask & 0x0FFC60F0F;
if (unk) // unknown portions, LARGE if (unk) // unknown portions, LARGE
{ {
FRDP("UNKNOWN PORTIONS: shift: %d, len: %d, unknowns: %08lx\n", shift, len, unk); WriteTrace(TraceRDP, TraceDebug, "UNKNOWN PORTIONS: shift: %d, len: %d, unknowns: %08lx", shift, len, unk);
} }
} }
static void uc0_setothermode_l() static void uc0_setothermode_l()
{ {
LRDP("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 == ucode_F3DEX2) || (g_settings->ucode == ucode_CBFD))
@ -930,15 +914,15 @@ static void uc0_setothermode_l()
if (mask & 0x00000003) // alpha compare if (mask & 0x00000003) // alpha compare
{ {
rdp.acmp = rdp.othermode_l & 0x00000003; rdp.acmp = rdp.othermode_l & 0x00000003;
FRDP("alpha compare %s\n", ACmp[rdp.acmp]); WriteTrace(TraceRDP, TraceDebug, "alpha compare %s", ACmp[rdp.acmp]);
rdp.update |= UPDATE_ALPHA_COMPARE; rdp.update |= UPDATE_ALPHA_COMPARE;
} }
if (mask & 0x00000004) // z-src selection if (mask & 0x00000004) // z-src selection
{ {
rdp.zsrc = (rdp.othermode_l & 0x00000004) >> 2; rdp.zsrc = (rdp.othermode_l & 0x00000004) >> 2;
FRDP("z-src sel: %s\n", str_zs[rdp.zsrc]); WriteTrace(TraceRDP, TraceDebug, "z-src sel: %s", str_zs[rdp.zsrc]);
FRDP("z-src sel: %08lx\n", rdp.zsrc); WriteTrace(TraceRDP, TraceDebug, "z-src sel: %08lx", rdp.zsrc);
rdp.update |= UPDATE_ZBUF_ENABLED; rdp.update |= UPDATE_ZBUF_ENABLED;
} }
@ -949,7 +933,7 @@ static void uc0_setothermode_l()
rdp.rm = rdp.othermode_l; rdp.rm = rdp.othermode_l;
if (g_settings->flame_corona && (rdp.rm == 0x00504341)) //hack for flame's corona if (g_settings->flame_corona && (rdp.rm == 0x00504341)) //hack for flame's corona
rdp.othermode_l |= /*0x00000020 |*/ 0x00000010; rdp.othermode_l |= /*0x00000020 |*/ 0x00000010;
FRDP("rendermode: %08lx\n", rdp.othermode_l); // just output whole othermode_l WriteTrace(TraceRDP, TraceDebug, "rendermode: %08lx", rdp.othermode_l); // just output whole othermode_l
} }
// there is not one setothermode_l that's not handled :) // there is not one setothermode_l that's not handled :)
@ -958,7 +942,7 @@ static void uc0_setothermode_l()
static void uc0_setgeometrymode() static void uc0_setgeometrymode()
{ {
rdp.geom_mode |= rdp.cmd1; rdp.geom_mode |= rdp.cmd1;
FRDP("uc0:setgeometrymode %08lx; result: %08lx\n", rdp.cmd1, rdp.geom_mode); WriteTrace(TraceRDP, TraceDebug, "uc0:setgeometrymode %08lx; result: %08lx", rdp.cmd1, rdp.geom_mode);
if (rdp.cmd1 & 0x00000001) // Z-Buffer enable if (rdp.cmd1 & 0x00000001) // Z-Buffer enable
{ {
@ -998,7 +982,7 @@ static void uc0_setgeometrymode()
static void uc0_cleargeometrymode() static void uc0_cleargeometrymode()
{ {
FRDP("uc0:cleargeometrymode %08lx\n", rdp.cmd1); WriteTrace(TraceRDP, TraceDebug, "uc0:cleargeometrymode %08lx", rdp.cmd1);
rdp.geom_mode &= (~rdp.cmd1); rdp.geom_mode &= (~rdp.cmd1);
@ -1057,7 +1041,7 @@ static void uc0_line3d()
rdp.flags |= cull_mode << CULLSHIFT; rdp.flags |= cull_mode << CULLSHIFT;
rdp.update |= UPDATE_CULL_MODE; rdp.update |= UPDATE_CULL_MODE;
FRDP("uc0:line3d v0:%d, v1:%d, width:%d\n", v0, v1, width); WriteTrace(TraceRDP, TraceDebug, "uc0:line3d v0:%d, v1:%d, width:%d", v0, v1, width);
} }
static void uc0_tri4() static void uc0_tri4()
@ -1065,8 +1049,8 @@ static void uc0_tri4()
// c0: 0000 0123, c1: 456789ab // c0: 0000 0123, c1: 456789ab
// becomes: 405 617 829 a3b // becomes: 405 617 829 a3b
LRDP("uc0:tri4"); WriteTrace(TraceRDP, TraceDebug, "uc0:tri4");
FRDP(" #%d, #%d, #%d, #%d - %d, %d, %d - %d, %d, %d - %d, %d, %d - %d, %d, %d\n", rdp.tri_n, rdp.tri_n + 1, rdp.tri_n + 2, rdp.tri_n + 3, WriteTrace(TraceRDP, TraceDebug, " #%d, #%d, #%d, #%d - %d, %d, %d - %d, %d, %d - %d, %d, %d - %d, %d, %d", rdp.tri_n, rdp.tri_n + 1, rdp.tri_n + 2, rdp.tri_n + 3,
(rdp.cmd1 >> 28) & 0xF, (rdp.cmd1 >> 28) & 0xF,
(rdp.cmd0 >> 12) & 0xF, (rdp.cmd0 >> 12) & 0xF,
(rdp.cmd1 >> 24) & 0xF, (rdp.cmd1 >> 24) & 0xF,

View File

@ -56,10 +56,10 @@ static void uc1_tri1()
{ {
if (rdp.skip_drawing) if (rdp.skip_drawing)
{ {
LRDP("uc1:tri1. skipped\n"); WriteTrace(TraceRDP, TraceDebug, "uc1:tri1. skipped");
return; return;
} }
FRDP("uc1:tri1 #%d - %d, %d, %d - %08lx - %08lx\n", rdp.tri_n, WriteTrace(TraceRDP, TraceDebug, "uc1:tri1 #%d - %d, %d, %d - %08lx - %08lx", rdp.tri_n,
((rdp.cmd1 >> 17) & 0x7F), ((rdp.cmd1 >> 17) & 0x7F),
((rdp.cmd1 >> 9) & 0x7F), ((rdp.cmd1 >> 9) & 0x7F),
((rdp.cmd1 >> 1) & 0x7F), rdp.cmd0, rdp.cmd1); ((rdp.cmd1 >> 1) & 0x7F), rdp.cmd0, rdp.cmd1);
@ -77,12 +77,12 @@ static void uc1_tri2()
{ {
if (rdp.skip_drawing) if (rdp.skip_drawing)
{ {
LRDP("uc1:tri2. skipped\n"); WriteTrace(TraceRDP, TraceDebug, "uc1:tri2. skipped");
return; return;
} }
LRDP("uc1:tri2"); WriteTrace(TraceRDP, TraceDebug, "uc1:tri2");
FRDP(" #%d, #%d - %d, %d, %d - %d, %d, %d\n", rdp.tri_n, rdp.tri_n + 1, WriteTrace(TraceRDP, TraceDebug, " #%d, #%d - %d, %d, %d - %d, %d, %d", rdp.tri_n, rdp.tri_n + 1,
((rdp.cmd0 >> 17) & 0x7F), ((rdp.cmd0 >> 17) & 0x7F),
((rdp.cmd0 >> 9) & 0x7F), ((rdp.cmd0 >> 9) & 0x7F),
((rdp.cmd0 >> 1) & 0x7F), ((rdp.cmd0 >> 1) & 0x7F),
@ -108,7 +108,7 @@ static void uc1_line3d()
{ {
uint16_t width = (uint16_t)(rdp.cmd1 & 0xFF) + 3; uint16_t width = (uint16_t)(rdp.cmd1 & 0xFF) + 3;
FRDP("uc1:line3d width: %d #%d, #%d - %d, %d\n", width, rdp.tri_n, rdp.tri_n + 1, WriteTrace(TraceRDP, TraceDebug, "uc1:line3d width: %d #%d, #%d - %d, %d", width, rdp.tri_n, rdp.tri_n + 1,
(rdp.cmd1 >> 17) & 0x7F, (rdp.cmd1 >> 17) & 0x7F,
(rdp.cmd1 >> 9) & 0x7F); (rdp.cmd1 >> 9) & 0x7F);
@ -127,7 +127,7 @@ static void uc1_line3d()
} }
else else
{ {
FRDP("uc1:quad3d #%d, #%d\n", rdp.tri_n, rdp.tri_n + 1); WriteTrace(TraceRDP, TraceDebug, "uc1:quad3d #%d, #%d", rdp.tri_n, rdp.tri_n + 1);
VERTEX *v[6] = { VERTEX *v[6] = {
&rdp.vtx[(rdp.cmd1 >> 25) & 0x7F], &rdp.vtx[(rdp.cmd1 >> 25) & 0x7F],
@ -146,7 +146,7 @@ uint32_t branch_dl = 0;
static void uc1_rdphalf_1() static void uc1_rdphalf_1()
{ {
LRDP("uc1:rdphalf_1\n"); WriteTrace(TraceRDP, TraceDebug, "uc1:rdphalf_1");
branch_dl = rdp.cmd1; branch_dl = rdp.cmd1;
rdphalf_1(); rdphalf_1();
} }
@ -154,7 +154,7 @@ static void uc1_rdphalf_1()
static void uc1_branch_z() static void uc1_branch_z()
{ {
uint32_t addr = segoffset(branch_dl); uint32_t addr = segoffset(branch_dl);
FRDP("uc1:branch_less_z, addr: %08lx\n", addr); WriteTrace(TraceRDP, TraceDebug, "uc1:branch_less_z, addr: %08lx", addr);
uint32_t vtx = (rdp.cmd0 & 0xFFF) >> 1; uint32_t vtx = (rdp.cmd0 & 0xFFF) >> 1;
if (fabs(rdp.vtx[vtx].z) <= (rdp.cmd1/*&0xFFFF*/)) if (fabs(rdp.vtx[vtx].z) <= (rdp.cmd1/*&0xFFFF*/))
{ {

View File

@ -51,9 +51,7 @@ static void calc_point_light(VERTEX *v, float * vpos)
lvec[2] -= vpos[2]; lvec[2] -= vpos[2];
float light_len2 = lvec[0] * lvec[0] + lvec[1] * lvec[1] + lvec[2] * lvec[2]; float light_len2 = lvec[0] * lvec[0] + lvec[1] * lvec[1] + lvec[2] * lvec[2];
float light_len = sqrtf(light_len2); float light_len = sqrtf(light_len2);
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "calc_point_light: len: %f, len2: %f", light_len, light_len2);
FRDP ("calc_point_light: len: %f, len2: %f\n", light_len, light_len2);
#endif
float at = rdp.light[l].ca + light_len / 65535.0f*rdp.light[l].la + light_len2 / 65535.0f*rdp.light[l].qa; float at = rdp.light[l].ca + light_len / 65535.0f*rdp.light[l].la + light_len2 / 65535.0f*rdp.light[l].qa;
if (at > 0.0f) if (at > 0.0f)
light_intensity = 1 / at;//DotProduct (lvec, nvec) / (light_len * normal_len * at); light_intensity = 1 / at;//DotProduct (lvec, nvec) / (light_len * normal_len * at);
@ -116,12 +114,11 @@ static void uc2_vertex()
rdp.vn = n = (rdp.cmd0 >> 12) & 0xFF; rdp.vn = n = (rdp.cmd0 >> 12) & 0xFF;
rdp.v0 = v0 = ((rdp.cmd0 >> 1) & 0x7F) - n; rdp.v0 = v0 = ((rdp.cmd0 >> 1) & 0x7F) - n;
FRDP("uc2:vertex n: %d, v0: %d, from: %08lx\n", n, v0, addr); WriteTrace(TraceRDP, TraceDebug, "uc2:vertex n: %d, v0: %d, from: %08lx", n, v0, addr);
if (v0 < 0) if (v0 < 0)
{ {
RDP_E("** ERROR: uc2:vertex v0 < 0\n"); WriteTrace(TraceRDP, TraceWarning, "** ERROR: uc2:vertex v0 < 0");
LRDP("** ERROR: uc2:vertex v0 < 0\n");
return; return;
} }
@ -172,7 +169,7 @@ static void uc2_vertex()
v->vec[0] = ((char*)gfx.RDRAM)[(addr + i + 12) ^ 3]; v->vec[0] = ((char*)gfx.RDRAM)[(addr + i + 12) ^ 3];
v->vec[1] = ((char*)gfx.RDRAM)[(addr + i + 13) ^ 3]; v->vec[1] = ((char*)gfx.RDRAM)[(addr + i + 13) ^ 3];
v->vec[2] = ((char*)gfx.RDRAM)[(addr + i + 14) ^ 3]; v->vec[2] = ((char*)gfx.RDRAM)[(addr + i + 14) ^ 3];
// FRDP("Calc light. x: %f, y: %f z: %f\n", v->vec[0], v->vec[1], v->vec[2]); // WriteTrace(TraceRDP, TraceDebug, "Calc light. x: %f, y: %f z: %f", v->vec[0], v->vec[1], v->vec[2]);
// if (!(rdp.geom_mode & 0x800000)) // if (!(rdp.geom_mode & 0x800000))
{ {
if (rdp.geom_mode & 0x40000) if (rdp.geom_mode & 0x40000)
@ -180,16 +177,12 @@ static void uc2_vertex()
if (rdp.geom_mode & 0x80000) if (rdp.geom_mode & 0x80000)
{ {
calc_linear(v); calc_linear(v);
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "calc linear: v%d - u: %f, v: %f", i >> 4, v->ou, v->ov);
FRDP ("calc linear: v%d - u: %f, v: %f\n", i>>4, v->ou, v->ov);
#endif
} }
else else
{ {
calc_sphere(v); calc_sphere(v);
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "calc sphere: v%d - u: %f, v: %f", i >> 4, v->ou, v->ov);
FRDP ("calc sphere: v%d - u: %f, v: %f\n", i>>4, v->ou, v->ov);
#endif
} }
} }
} }
@ -210,9 +203,7 @@ static void uc2_vertex()
v->g = ((uint8_t*)gfx.RDRAM)[(addr + i + 13) ^ 3]; v->g = ((uint8_t*)gfx.RDRAM)[(addr + i + 13) ^ 3];
v->b = ((uint8_t*)gfx.RDRAM)[(addr + i + 14) ^ 3]; v->b = ((uint8_t*)gfx.RDRAM)[(addr + i + 14) ^ 3];
} }
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "v%d - x: %f, y: %f, z: %f, w: %f, u: %f, v: %f, f: %f, z_w: %f, r=%d, g=%d, b=%d, a=%d", i >> 4, v->x, v->y, v->z, v->w, v->ou*rdp.tiles[rdp.cur_tile].s_scale, v->ov*rdp.tiles[rdp.cur_tile].t_scale, v->f, v->z_w, v->r, v->g, v->b, v->a);
FRDP ("v%d - x: %f, y: %f, z: %f, w: %f, u: %f, v: %f, f: %f, z_w: %f, r=%d, g=%d, b=%d, a=%d\n", i>>4, v->x, v->y, v->z, v->w, v->ou*rdp.tiles[rdp.cur_tile].s_scale, v->ov*rdp.tiles[rdp.cur_tile].t_scale, v->f, v->z_w, v->r, v->g, v->b, v->a);
#endif
} }
rdp.geom_mode = geom_mode; rdp.geom_mode = geom_mode;
} }
@ -222,7 +213,7 @@ static void uc2_modifyvtx()
uint8_t where = (uint8_t)((rdp.cmd0 >> 16) & 0xFF); uint8_t where = (uint8_t)((rdp.cmd0 >> 16) & 0xFF);
uint16_t vtx = (uint16_t)((rdp.cmd0 >> 1) & 0xFFFF); uint16_t vtx = (uint16_t)((rdp.cmd0 >> 1) & 0xFFFF);
FRDP("uc2:modifyvtx: vtx: %d, where: 0x%02lx, val: %08lx - ", vtx, where, rdp.cmd1); WriteTrace(TraceRDP, TraceDebug, "uc2:modifyvtx: vtx: %d, where: 0x%02lx, val: %08lx - ", vtx, where, rdp.cmd1);
uc0_modifyvtx(where, vtx, rdp.cmd1); uc0_modifyvtx(where, vtx, rdp.cmd1);
} }
@ -231,7 +222,7 @@ static void uc2_culldl()
uint16_t vStart = (uint16_t)(rdp.cmd0 & 0xFFFF) >> 1; uint16_t vStart = (uint16_t)(rdp.cmd0 & 0xFFFF) >> 1;
uint16_t vEnd = (uint16_t)(rdp.cmd1 & 0xFFFF) >> 1; uint16_t vEnd = (uint16_t)(rdp.cmd1 & 0xFFFF) >> 1;
uint32_t cond = 0; uint32_t cond = 0;
FRDP("uc2:culldl start: %d, end: %d\n", vStart, vEnd); WriteTrace(TraceRDP, TraceDebug, "uc2:culldl start: %d, end: %d", vStart, vEnd);
if (vEnd < vStart) return; if (vEnd < vStart) return;
for (uint16_t i = vStart; i <= vEnd; i++) for (uint16_t i = vStart; i <= vEnd; i++)
@ -254,16 +245,14 @@ static void uc2_culldl()
return; return;
//*/ //*/
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, " v[%d] = (%02f, %02f, %02f, 0x%02lx)", i, rdp.vtx[i].x, rdp.vtx[i].y, rdp.vtx[i].w, rdp.vtx[i].scr_off);
FRDP (" v[%d] = (%02f, %02f, %02f, 0x%02lx)\n", i, rdp.vtx[i].x, rdp.vtx[i].y, rdp.vtx[i].w, rdp.vtx[i].scr_off);
#endif
cond |= (~rdp.vtx[i].scr_off) & 0x1F; cond |= (~rdp.vtx[i].scr_off) & 0x1F;
if (cond == 0x1F) if (cond == 0x1F)
return; return;
} }
LRDP(" - "); // specify that the enddl is not a real command WriteTrace(TraceRDP, TraceDebug, " - "); // specify that the enddl is not a real command
uc0_enddl(); uc0_enddl();
} }
@ -278,11 +267,11 @@ static void uc2_tri1()
} }
if (rdp.skip_drawing) if (rdp.skip_drawing)
{ {
LRDP("uc2:tri1. skipped\n"); WriteTrace(TraceRDP, TraceDebug, "uc2:tri1. skipped");
return; return;
} }
FRDP("uc2:tri1 #%d - %d, %d, %d\n", rdp.tri_n, WriteTrace(TraceRDP, TraceDebug, "uc2:tri1 #%d - %d, %d, %d", rdp.tri_n,
((rdp.cmd0 >> 17) & 0x7F), ((rdp.cmd0 >> 17) & 0x7F),
((rdp.cmd0 >> 9) & 0x7F), ((rdp.cmd0 >> 9) & 0x7F),
((rdp.cmd0 >> 1) & 0x7F)); ((rdp.cmd0 >> 1) & 0x7F));
@ -318,13 +307,13 @@ static void uc2_quad()
if (rdp.skip_drawing) if (rdp.skip_drawing)
{ {
LRDP("uc2_quad. skipped\n"); WriteTrace(TraceRDP, TraceDebug, "uc2_quad. skipped");
return; return;
} }
LRDP("uc2:quad"); WriteTrace(TraceRDP, TraceDebug, "uc2:quad");
FRDP(" #%d, #%d - %d, %d, %d - %d, %d, %d\n", rdp.tri_n, rdp.tri_n + 1, WriteTrace(TraceRDP, TraceDebug, " #%d, #%d - %d, %d, %d - %d, %d, %d", rdp.tri_n, rdp.tri_n + 1,
((rdp.cmd0 >> 17) & 0x7F), ((rdp.cmd0 >> 17) & 0x7F),
((rdp.cmd0 >> 9) & 0x7F), ((rdp.cmd0 >> 9) & 0x7F),
((rdp.cmd0 >> 1) & 0x7F), ((rdp.cmd0 >> 1) & 0x7F),
@ -352,7 +341,7 @@ static void uc2_line3d()
uc6_ldtx_rect_r(); uc6_ldtx_rect_r();
else else
{ {
FRDP("uc2:line3d #%d, #%d - %d, %d\n", rdp.tri_n, rdp.tri_n + 1, WriteTrace(TraceRDP, TraceDebug, "uc2:line3d #%d, #%d - %d, %d", rdp.tri_n, rdp.tri_n + 1,
(rdp.cmd0 >> 17) & 0x7F, (rdp.cmd0 >> 17) & 0x7F,
(rdp.cmd0 >> 9) & 0x7F); (rdp.cmd0 >> 9) & 0x7F);
@ -374,22 +363,22 @@ static void uc2_line3d()
static void uc2_special3() static void uc2_special3()
{ {
LRDP("uc2:special3\n"); WriteTrace(TraceRDP, TraceDebug, "uc2:special3");
} }
static void uc2_special2() static void uc2_special2()
{ {
LRDP("uc2:special2\n"); WriteTrace(TraceRDP, TraceDebug, "uc2:special2");
} }
static void uc2_dma_io() static void uc2_dma_io()
{ {
LRDP("uc2:dma_io\n"); WriteTrace(TraceRDP, TraceDebug, "uc2:dma_io");
} }
static void uc2_pop_matrix() static void uc2_pop_matrix()
{ {
FRDP("uc2:pop_matrix %08lx, %08lx\n", rdp.cmd0, rdp.cmd1); WriteTrace(TraceRDP, TraceDebug, "uc2:pop_matrix %08lx, %08lx", rdp.cmd0, rdp.cmd1);
// Just pop the modelview matrix // Just pop the modelview matrix
modelview_pop(rdp.cmd1 >> 6); modelview_pop(rdp.cmd1 >> 6);
@ -405,12 +394,12 @@ static void uc2_geom_mode()
((rdp.cmd1 & 0x00000600) << 3) | ((rdp.cmd1 & 0x00000600) << 3) |
((rdp.cmd1 & 0x00200000) >> 12); ((rdp.cmd1 & 0x00200000) >> 12);
FRDP("uc2:geom_mode c:%08lx, s:%08lx ", clr_mode, set_mode); WriteTrace(TraceRDP, TraceDebug, "uc2:geom_mode c:%08lx, s:%08lx ", clr_mode, set_mode);
rdp.geom_mode &= clr_mode; rdp.geom_mode &= clr_mode;
rdp.geom_mode |= set_mode; rdp.geom_mode |= set_mode;
FRDP("result:%08lx\n", rdp.geom_mode); WriteTrace(TraceRDP, TraceDebug, "result:%08lx", rdp.geom_mode);
if (rdp.geom_mode & 0x00000001) // Z-Buffer enable if (rdp.geom_mode & 0x00000001) // Z-Buffer enable
{ {
@ -490,7 +479,7 @@ static void uc2_matrix()
uc6_obj_rectangle_r(); uc6_obj_rectangle_r();
return; return;
} }
LRDP("uc2:matrix\n"); WriteTrace(TraceRDP, TraceDebug, "uc2:matrix");
DECLAREALIGN16VAR(m[4][4]); DECLAREALIGN16VAR(m[4][4]);
load_matrix(m, segoffset(rdp.cmd1)); load_matrix(m, segoffset(rdp.cmd1));
@ -499,56 +488,53 @@ static void uc2_matrix()
switch (command) switch (command)
{ {
case 0: // modelview mul nopush case 0: // modelview mul nopush
LRDP("modelview mul\n"); WriteTrace(TraceRDP, TraceDebug, "modelview mul");
modelview_mul(m); modelview_mul(m);
break; break;
case 1: // modelview mul push case 1: // modelview mul push
LRDP("modelview mul push\n"); WriteTrace(TraceRDP, TraceDebug, "modelview mul push");
modelview_mul_push(m); modelview_mul_push(m);
break; break;
case 2: // modelview load nopush case 2: // modelview load nopush
LRDP("modelview load\n"); WriteTrace(TraceRDP, TraceDebug, "modelview load");
modelview_load(m); modelview_load(m);
break; break;
case 3: // modelview load push case 3: // modelview load push
LRDP("modelview load push\n"); WriteTrace(TraceRDP, TraceDebug, "modelview load push");
modelview_load_push(m); modelview_load_push(m);
break; break;
case 4: // projection mul nopush case 4: // projection mul nopush
case 5: // projection mul push, can't push projection case 5: // projection mul push, can't push projection
LRDP("projection mul\n"); WriteTrace(TraceRDP, TraceDebug, "projection mul");
projection_mul(m); projection_mul(m);
break; break;
case 6: // projection load nopush case 6: // projection load nopush
case 7: // projection load push, can't push projection case 7: // projection load push, can't push projection
LRDP("projection load\n"); WriteTrace(TraceRDP, TraceDebug, "projection load");
projection_load(m); projection_load(m);
break; break;
default: default:
FRDP_E("Unknown matrix command, %02lx", command); WriteTrace(TraceRDP, TraceWarning, "Unknown matrix command, %02lx", command);
FRDP("Unknown matrix command, %02lx", command);
} }
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", m[0][0], m[0][1], m[0][2], m[0][3]);
FRDP ("{%f,%f,%f,%f}\n", m[0][0], m[0][1], m[0][2], m[0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", m[1][0], m[1][1], m[1][2], m[1][3]);
FRDP ("{%f,%f,%f,%f}\n", m[1][0], m[1][1], m[1][2], m[1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", m[2][0], m[2][1], m[2][2], m[2][3]);
FRDP ("{%f,%f,%f,%f}\n", m[2][0], m[2][1], m[2][2], m[2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", m[3][0], m[3][1], m[3][2], m[3][3]);
FRDP ("{%f,%f,%f,%f}\n", m[3][0], m[3][1], m[3][2], m[3][3]); WriteTrace(TraceRDP, TraceVerbose, "\nmodel\n{%f,%f,%f,%f}", rdp.model[0][0], rdp.model[0][1], rdp.model[0][2], rdp.model[0][3]);
FRDP ("\nmodel\n{%f,%f,%f,%f}\n", rdp.model[0][0], rdp.model[0][1], rdp.model[0][2], rdp.model[0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.model[1][0], rdp.model[1][1], rdp.model[1][2], rdp.model[1][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.model[1][0], rdp.model[1][1], rdp.model[1][2], rdp.model[1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.model[2][0], rdp.model[2][1], rdp.model[2][2], rdp.model[2][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.model[2][0], rdp.model[2][1], rdp.model[2][2], rdp.model[2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.model[3][0], rdp.model[3][1], rdp.model[3][2], rdp.model[3][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.model[3][0], rdp.model[3][1], rdp.model[3][2], rdp.model[3][3]); WriteTrace(TraceRDP, TraceVerbose, "\nproj\n{%f,%f,%f,%f}", rdp.proj[0][0], rdp.proj[0][1], rdp.proj[0][2], rdp.proj[0][3]);
FRDP ("\nproj\n{%f,%f,%f,%f}\n", rdp.proj[0][0], rdp.proj[0][1], rdp.proj[0][2], rdp.proj[0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.proj[1][0], rdp.proj[1][1], rdp.proj[1][2], rdp.proj[1][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.proj[1][0], rdp.proj[1][1], rdp.proj[1][2], rdp.proj[1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.proj[2][0], rdp.proj[2][1], rdp.proj[2][2], rdp.proj[2][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.proj[2][0], rdp.proj[2][1], rdp.proj[2][2], rdp.proj[2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.proj[3][0], rdp.proj[3][1], rdp.proj[3][2], rdp.proj[3][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.proj[3][0], rdp.proj[3][1], rdp.proj[3][2], rdp.proj[3][3]);
#endif
} }
static void uc2_moveword() static void uc2_moveword()
@ -557,7 +543,7 @@ static void uc2_moveword()
uint16_t offset = (uint16_t)(rdp.cmd0 & 0xFFFF); uint16_t offset = (uint16_t)(rdp.cmd0 & 0xFFFF);
uint32_t data = rdp.cmd1; uint32_t data = rdp.cmd1;
FRDP("uc2:moveword "); WriteTrace(TraceRDP, TraceDebug, "uc2:moveword ");
switch (index) switch (index)
{ {
@ -597,14 +583,14 @@ static void uc2_moveword()
rdp.combined[index_y][index_x + 1] = (short)(rdp.cmd1 & 0xFFFF); rdp.combined[index_y][index_x + 1] = (short)(rdp.cmd1 & 0xFFFF);
} }
LRDP("matrix\n"); WriteTrace(TraceRDP, TraceDebug, "matrix");
} }
break; break;
case 0x02: case 0x02:
rdp.num_lights = data / 24; rdp.num_lights = data / 24;
rdp.update |= UPDATE_LIGHTS; rdp.update |= UPDATE_LIGHTS;
FRDP("numlights: %d\n", rdp.num_lights); WriteTrace(TraceRDP, TraceDebug, "numlights: %d", rdp.num_lights);
break; break;
case 0x04: case 0x04:
@ -613,12 +599,12 @@ static void uc2_moveword()
rdp.clip_ratio = sqrt((float)rdp.cmd1); rdp.clip_ratio = sqrt((float)rdp.cmd1);
rdp.update |= UPDATE_VIEWPORT; rdp.update |= UPDATE_VIEWPORT;
} }
FRDP("mw_clip %08lx, %08lx\n", rdp.cmd0, rdp.cmd1); WriteTrace(TraceRDP, TraceDebug, "mw_clip %08lx, %08lx", rdp.cmd0, rdp.cmd1);
break; break;
case 0x06: // moveword SEGMENT case 0x06: // moveword SEGMENT
{ {
FRDP("SEGMENT %08lx -> seg%d\n", data, offset >> 2); WriteTrace(TraceRDP, TraceDebug, "SEGMENT %08lx -> seg%d", data, offset >> 2);
if ((data&BMASK) < BMASK) if ((data&BMASK) < BMASK)
rdp.segment[(offset >> 2) & 0xF] = data; rdp.segment[(offset >> 2) & 0xF] = data;
} }
@ -628,7 +614,7 @@ static void uc2_moveword()
{ {
rdp.fog_multiplier = (short)(rdp.cmd1 >> 16); rdp.fog_multiplier = (short)(rdp.cmd1 >> 16);
rdp.fog_offset = (short)(rdp.cmd1 & 0x0000FFFF); rdp.fog_offset = (short)(rdp.cmd1 & 0x0000FFFF);
FRDP("fog: multiplier: %f, offset: %f\n", rdp.fog_multiplier, rdp.fog_offset); WriteTrace(TraceRDP, TraceDebug, "fog: multiplier: %f, offset: %f", rdp.fog_multiplier, rdp.fog_offset);
//offset must be 0 for move_fog, but it can be non zero in Nushi Zuri 64 - Shiokaze ni Notte //offset must be 0 for move_fog, but it can be non zero in Nushi Zuri 64 - Shiokaze ni Notte
//low-level display list has setothermode commands in this place, so this is obviously not move_fog. //low-level display list has setothermode commands in this place, so this is obviously not move_fog.
@ -640,7 +626,7 @@ static void uc2_moveword()
case 0x0a: // moveword LIGHTCOL case 0x0a: // moveword LIGHTCOL
{ {
int n = offset / 24; int n = offset / 24;
FRDP("lightcol light:%d, %08lx\n", n, data); WriteTrace(TraceRDP, TraceDebug, "lightcol light:%d, %08lx", n, data);
rdp.light[n].r = (float)((data >> 24) & 0xFF) / 255.0f; rdp.light[n].r = (float)((data >> 24) & 0xFF) / 255.0f;
rdp.light[n].g = (float)((data >> 16) & 0xFF) / 255.0f; rdp.light[n].g = (float)((data >> 16) & 0xFF) / 255.0f;
@ -650,17 +636,15 @@ static void uc2_moveword()
break; break;
case 0x0c: case 0x0c:
RDP_E("uc2:moveword forcemtx - IGNORED\n"); WriteTrace(TraceRDP, TraceWarning, "uc2:moveword forcemtx - IGNORED");
LRDP("forcemtx - IGNORED\n");
break; break;
case 0x0e: case 0x0e:
LRDP("perspnorm - IGNORED\n"); WriteTrace(TraceRDP, TraceDebug, "perspnorm - IGNORED");
break; break;
default: default:
FRDP_E("uc2:moveword unknown (index: 0x%08lx, offset 0x%08lx)\n", index, offset); WriteTrace(TraceRDP, TraceWarning, "uc2:moveword unknown (index: 0x%08lx, offset 0x%08lx)", index, offset);
FRDP("unknown (index: 0x%08lx, offset 0x%08lx)\n", index, offset);
} }
} }
@ -672,7 +656,7 @@ static void uc2_movemem()
uint32_t addr = segoffset(rdp.cmd1); uint32_t addr = segoffset(rdp.cmd1);
int ofs = (rdp.cmd0 >> 5) & 0x7F8; int ofs = (rdp.cmd0 >> 5) & 0x7F8;
FRDP("uc2:movemem ofs:%d ", ofs); WriteTrace(TraceRDP, TraceDebug, "uc2:movemem ofs:%d ", ofs);
switch (idx) switch (idx)
{ {
@ -699,7 +683,7 @@ static void uc2_movemem()
rdp.update |= UPDATE_VIEWPORT; rdp.update |= UPDATE_VIEWPORT;
FRDP("viewport scale(%d, %d, %d), trans(%d, %d, %d), from:%08lx\n", scale_x, scale_y, scale_z, WriteTrace(TraceRDP, TraceDebug, "viewport scale(%d, %d, %d), trans(%d, %d, %d), from:%08lx", scale_x, scale_y, scale_z,
trans_x, trans_y, trans_z, a); trans_x, trans_y, trans_z, a);
} }
break; break;
@ -722,7 +706,7 @@ static void uc2_movemem()
if (!dir_x && !dir_y) if (!dir_x && !dir_y)
rdp.use_lookat = FALSE; rdp.use_lookat = FALSE;
} }
FRDP("lookat_%d (%f, %f, %f)\n", n, rdp.lookat[n][0], rdp.lookat[n][1], rdp.lookat[n][2]); WriteTrace(TraceRDP, TraceDebug, "lookat_%d (%f, %f, %f)", n, rdp.lookat[n][0], rdp.lookat[n][1], rdp.lookat[n][2]);
return; return;
} }
n -= 2; n -= 2;
@ -751,11 +735,9 @@ static void uc2_movemem()
rdp.light[n].ca = (float)(gfx.RDRAM[(addr + 3) ^ 3]) / 16.0f; rdp.light[n].ca = (float)(gfx.RDRAM[(addr + 3) ^ 3]) / 16.0f;
rdp.light[n].la = (float)(gfx.RDRAM[(addr + 7) ^ 3]); rdp.light[n].la = (float)(gfx.RDRAM[(addr + 7) ^ 3]);
rdp.light[n].qa = (float)(gfx.RDRAM[(addr + 14) ^ 3]) / 8.0f; rdp.light[n].qa = (float)(gfx.RDRAM[(addr + 14) ^ 3]) / 8.0f;
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "light: n: %d, pos: x: %f, y: %f, z: %f, ca: %f, la:%f, qa: %f",
FRDP ("light: n: %d, pos: x: %f, y: %f, z: %f, ca: %f, la:%f, qa: %f\n",
n, rdp.light[n].x, rdp.light[n].y, rdp.light[n].z, rdp.light[n].ca, rdp.light[n].la, rdp.light[n].qa); n, rdp.light[n].x, rdp.light[n].y, rdp.light[n].z, rdp.light[n].ca, rdp.light[n].la, rdp.light[n].qa);
#endif WriteTrace(TraceRDP, TraceDebug, "light: n: %d, r: %.3f, g: %.3f, b: %.3f. dir: x: %.3f, y: %.3f, z: %.3f",
FRDP("light: n: %d, r: %.3f, g: %.3f, b: %.3f. dir: x: %.3f, y: %.3f, z: %.3f\n",
n, rdp.light[n].r, rdp.light[n].g, rdp.light[n].b, n, rdp.light[n].r, rdp.light[n].g, rdp.light[n].b,
rdp.light[n].dir_x, rdp.light[n].dir_y, rdp.light[n].dir_z); rdp.light[n].dir_x, rdp.light[n].dir_y, rdp.light[n].dir_z);
} }
@ -767,42 +749,40 @@ static void uc2_movemem()
rdp.update &= ~UPDATE_MULT_MAT; rdp.update &= ~UPDATE_MULT_MAT;
load_matrix(rdp.combined, segoffset(rdp.cmd1)); load_matrix(rdp.combined, segoffset(rdp.cmd1));
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.combined[0][0], rdp.combined[0][1], rdp.combined[0][2], rdp.combined[0][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.combined[0][0], rdp.combined[0][1], rdp.combined[0][2], rdp.combined[0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.combined[1][0], rdp.combined[1][1], rdp.combined[1][2], rdp.combined[1][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.combined[1][0], rdp.combined[1][1], rdp.combined[1][2], rdp.combined[1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.combined[2][0], rdp.combined[2][1], rdp.combined[2][2], rdp.combined[2][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.combined[2][0], rdp.combined[2][1], rdp.combined[2][2], rdp.combined[2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.combined[3][0], rdp.combined[3][1], rdp.combined[3][2], rdp.combined[3][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.combined[3][0], rdp.combined[3][1], rdp.combined[3][2], rdp.combined[3][3]);
#endif
} }
break; break;
default: default:
FRDP("uc2:matrix unknown (%d)\n", idx); WriteTrace(TraceRDP, TraceDebug, "uc2:matrix unknown (%d)", idx);
FRDP("** UNKNOWN %d\n", idx); WriteTrace(TraceRDP, TraceDebug, "** UNKNOWN %d", idx);
} }
} }
static void uc2_load_ucode() static void uc2_load_ucode()
{ {
LRDP("uc2:load_ucode\n"); WriteTrace(TraceRDP, TraceDebug, "uc2:load_ucode");
} }
static void uc2_rdphalf_2() static void uc2_rdphalf_2()
{ {
LRDP("uc2:rdphalf_2\n"); WriteTrace(TraceRDP, TraceDebug, "uc2:rdphalf_2");
} }
static void uc2_dlist_cnt() static void uc2_dlist_cnt()
{ {
uint32_t addr = segoffset(rdp.cmd1) & BMASK; uint32_t addr = segoffset(rdp.cmd1) & BMASK;
int count = rdp.cmd0 & 0x000000FF; int count = rdp.cmd0 & 0x000000FF;
FRDP("dl_count - addr: %08lx, count: %d\n", addr, count); WriteTrace(TraceRDP, TraceDebug, "dl_count - addr: %08lx, count: %d", addr, count);
if (addr == 0) if (addr == 0)
return; return;
if (rdp.pc_i >= 9) { if (rdp.pc_i >= 9)
RDP_E("** DL stack overflow **\n"); {
LRDP("** DL stack overflow **\n"); WriteTrace(TraceRDP, TraceWarning, "** DL stack overflow **");
return; return;
} }
rdp.pc_i++; // go to the next PC in the stack rdp.pc_i++; // go to the next PC in the stack

View File

@ -61,7 +61,7 @@ static void uc3_vertex()
static void uc3_tri1() static void uc3_tri1()
{ {
FRDP("uc3:tri1 #%d - %d, %d, %d - %08lx - %08lx\n", rdp.tri_n, WriteTrace(TraceRDP, TraceDebug, "uc3:tri1 #%d - %d, %d, %d - %08lx - %08lx", rdp.tri_n,
((rdp.cmd1 >> 16) & 0xFF) / 5, ((rdp.cmd1 >> 16) & 0xFF) / 5,
((rdp.cmd1 >> 8) & 0xFF) / 5, ((rdp.cmd1 >> 8) & 0xFF) / 5,
((rdp.cmd1) & 0xFF) / 5, rdp.cmd0, rdp.cmd1); ((rdp.cmd1) & 0xFF) / 5, rdp.cmd0, rdp.cmd1);
@ -77,7 +77,7 @@ static void uc3_tri1()
static void uc3_tri2() static void uc3_tri2()
{ {
FRDP("uc3:tri2 #%d, #%d - %d, %d, %d - %d, %d, %d\n", rdp.tri_n, rdp.tri_n + 1, WriteTrace(TraceRDP, TraceDebug, "uc3:tri2 #%d, #%d - %d, %d, %d - %d, %d, %d", rdp.tri_n, rdp.tri_n + 1,
((rdp.cmd0 >> 16) & 0xFF) / 5, ((rdp.cmd0 >> 16) & 0xFF) / 5,
((rdp.cmd0 >> 8) & 0xFF) / 5, ((rdp.cmd0 >> 8) & 0xFF) / 5,
((rdp.cmd0) & 0xFF) / 5, ((rdp.cmd0) & 0xFF) / 5,
@ -99,7 +99,7 @@ static void uc3_tri2()
static void uc3_quad3d() static void uc3_quad3d()
{ {
FRDP("uc3:quad3d #%d, #%d\n", rdp.tri_n, rdp.tri_n + 1); WriteTrace(TraceRDP, TraceDebug, "uc3:quad3d #%d, #%d", rdp.tri_n, rdp.tri_n + 1);
VERTEX *v[6] = { VERTEX *v[6] = {
&rdp.vtx[((rdp.cmd1 >> 24) & 0xFF) / 5], &rdp.vtx[((rdp.cmd1 >> 24) & 0xFF) / 5],

View File

@ -53,7 +53,7 @@ static void uc4_tri1()
int v1 = ((rdp.cmd1 >> 16) & 0xFF) / 5; int v1 = ((rdp.cmd1 >> 16) & 0xFF) / 5;
int v2 = ((rdp.cmd1 >> 8) & 0xFF) / 5; int v2 = ((rdp.cmd1 >> 8) & 0xFF) / 5;
int v3 = (rdp.cmd1 & 0xFF) / 5; int v3 = (rdp.cmd1 & 0xFF) / 5;
FRDP("uc4:tri1 #%d - %d, %d, %d\n", rdp.tri_n, WriteTrace(TraceRDP, TraceDebug, "uc4:tri1 #%d - %d, %d, %d", rdp.tri_n,
v1, v2, v3); v1, v2, v3);
VERTEX *v[3] = { VERTEX *v[3] = {
@ -67,7 +67,7 @@ static void uc4_tri1()
static void uc4_quad3d() static void uc4_quad3d()
{ {
FRDP("uc4:quad3d #%d, #%d\n", rdp.tri_n, rdp.tri_n + 1); WriteTrace(TraceRDP, TraceDebug, "uc4:quad3d #%d, #%d", rdp.tri_n, rdp.tri_n + 1);
VERTEX *v[6] = { VERTEX *v[6] = {
&rdp.vtx[((rdp.cmd1 >> 24) & 0xFF) / 5], &rdp.vtx[((rdp.cmd1 >> 24) & 0xFF) / 5],

View File

@ -48,7 +48,7 @@ static void uc5_dma_offsets()
dma_offset_mtx = rdp.cmd0 & 0x00FFFFFF; dma_offset_mtx = rdp.cmd0 & 0x00FFFFFF;
dma_offset_vtx = rdp.cmd1 & 0x00FFFFFF; dma_offset_vtx = rdp.cmd1 & 0x00FFFFFF;
vtx_last = 0; vtx_last = 0;
FRDP("uc5:dma_offsets - mtx: %08lx, vtx: %08lx\n", dma_offset_mtx, dma_offset_vtx); WriteTrace(TraceRDP, TraceDebug, "uc5:dma_offsets - mtx: %08lx, vtx: %08lx", dma_offset_mtx, dma_offset_vtx);
} }
static void uc5_matrix() static void uc5_matrix()
@ -71,7 +71,7 @@ static void uc5_matrix()
cur_mtx = n; cur_mtx = n;
FRDP("uc5:matrix - #%d, addr: %08lx\n", n, addr); WriteTrace(TraceRDP, TraceDebug, "uc5:matrix - #%d, addr: %08lx", n, addr);
if (multiply) if (multiply)
{ {
@ -87,21 +87,19 @@ static void uc5_matrix()
} }
rdp.update |= UPDATE_MULT_MAT; rdp.update |= UPDATE_MULT_MAT;
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.dkrproj[n][0][0], rdp.dkrproj[n][0][1], rdp.dkrproj[n][0][2], rdp.dkrproj[n][0][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.dkrproj[n][0][0], rdp.dkrproj[n][0][1], rdp.dkrproj[n][0][2], rdp.dkrproj[n][0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.dkrproj[n][1][0], rdp.dkrproj[n][1][1], rdp.dkrproj[n][1][2], rdp.dkrproj[n][1][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.dkrproj[n][1][0], rdp.dkrproj[n][1][1], rdp.dkrproj[n][1][2], rdp.dkrproj[n][1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.dkrproj[n][2][0], rdp.dkrproj[n][2][1], rdp.dkrproj[n][2][2], rdp.dkrproj[n][2][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.dkrproj[n][2][0], rdp.dkrproj[n][2][1], rdp.dkrproj[n][2][2], rdp.dkrproj[n][2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.dkrproj[n][3][0], rdp.dkrproj[n][3][1], rdp.dkrproj[n][3][2], rdp.dkrproj[n][3][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.dkrproj[n][3][0], rdp.dkrproj[n][3][1], rdp.dkrproj[n][3][2], rdp.dkrproj[n][3][3]);
for (int i=0; i<3; i++) for (int i = 0; i < 3; i++)
{ {
FRDP ("proj %d\n", i); WriteTrace(TraceRDP, TraceVerbose, "proj %d", i);
FRDP ("{%f,%f,%f,%f}\n", rdp.dkrproj[i][0][0], rdp.dkrproj[i][0][1], rdp.dkrproj[i][0][2], rdp.dkrproj[i][0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.dkrproj[i][0][0], rdp.dkrproj[i][0][1], rdp.dkrproj[i][0][2], rdp.dkrproj[i][0][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.dkrproj[i][1][0], rdp.dkrproj[i][1][1], rdp.dkrproj[i][1][2], rdp.dkrproj[i][1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.dkrproj[i][1][0], rdp.dkrproj[i][1][1], rdp.dkrproj[i][1][2], rdp.dkrproj[i][1][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.dkrproj[i][2][0], rdp.dkrproj[i][2][1], rdp.dkrproj[i][2][2], rdp.dkrproj[i][2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.dkrproj[i][2][0], rdp.dkrproj[i][2][1], rdp.dkrproj[i][2][2], rdp.dkrproj[i][2][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.dkrproj[i][3][0], rdp.dkrproj[i][3][1], rdp.dkrproj[i][3][2], rdp.dkrproj[i][3][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.dkrproj[i][3][0], rdp.dkrproj[i][3][1], rdp.dkrproj[i][3][2], rdp.dkrproj[i][3][3]);
} }
#endif
} }
static void uc5_vertex() static void uc5_vertex()
@ -128,7 +126,7 @@ static void uc5_vertex()
vtx_last = 0; vtx_last = 0;
int first = ((rdp.cmd0 >> 9) & 0x1F) + vtx_last; int first = ((rdp.cmd0 >> 9) & 0x1F) + vtx_last;
FRDP("uc5:vertex - addr: %08lx, first: %d, count: %d, matrix: %08lx\n", addr, first, n, cur_mtx); WriteTrace(TraceRDP, TraceDebug, "uc5:vertex - addr: %08lx, first: %d, count: %d, matrix: %08lx", addr, first, n, cur_mtx);
int prj = cur_mtx; int prj = cur_mtx;
@ -179,9 +177,7 @@ static void uc5_vertex()
v->a = ((uint8_t*)gfx.RDRAM)[(addr + start + 9) ^ 3]; v->a = ((uint8_t*)gfx.RDRAM)[(addr + start + 9) ^ 3];
CalculateFog(v); CalculateFog(v);
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "v%d - x: %f, y: %f, z: %f, w: %f, z_w: %f, r=%d, g=%d, b=%d, a=%d", i, v->x, v->y, v->z, v->w, v->z_w, v->r, v->g, v->b, v->a);
FRDP ("v%d - x: %f, y: %f, z: %f, w: %f, z_w: %f, r=%d, g=%d, b=%d, a=%d\n", i, v->x, v->y, v->z, v->w, v->z_w, v->r, v->g, v->b, v->a);
#endif
} }
vtx_last += n; vtx_last += n;
@ -202,7 +198,7 @@ static void uc5_tridma()
uint32_t addr = segoffset(rdp.cmd1) & BMASK; uint32_t addr = segoffset(rdp.cmd1) & BMASK;
int num = (rdp.cmd0 & 0xFFF0) >> 4; int num = (rdp.cmd0 & 0xFFF0) >> 4;
//int num = ((rdp.cmd0 & 0x00F00000) >> 20) + 1; // same thing! //int num = ((rdp.cmd0 & 0x00F00000) >> 20) + 1; // same thing!
FRDP("uc5:tridma #%d - addr: %08lx, count: %d\n", rdp.tri_n, addr, num); WriteTrace(TraceRDP, TraceDebug, "uc5:tridma #%d - addr: %08lx, count: %d", rdp.tri_n, addr, num);
int start, v0, v1, v2, flags; int start, v0, v1, v2, flags;
for (int i = 0; i < num; i++) for (int i = 0; i < num; i++)
@ -212,7 +208,7 @@ static void uc5_tridma()
v1 = gfx.RDRAM[addr + start + 1]; v1 = gfx.RDRAM[addr + start + 1];
v2 = gfx.RDRAM[addr + start + 2]; v2 = gfx.RDRAM[addr + start + 2];
FRDP("tri #%d - %d, %d, %d\n", rdp.tri_n, v0, v1, v2); WriteTrace(TraceRDP, TraceDebug, "tri #%d - %d, %d, %d", rdp.tri_n, v0, v1, v2);
VERTEX *v[3] = { VERTEX *v[3] = {
&rdp.vtx[v0], &rdp.vtx[v0],
@ -266,11 +262,11 @@ static void uc5_dl_in_mem()
{ {
uint32_t addr = segoffset(rdp.cmd1) & BMASK; uint32_t addr = segoffset(rdp.cmd1) & BMASK;
int count = (rdp.cmd0 & 0x00FF0000) >> 16; int count = (rdp.cmd0 & 0x00FF0000) >> 16;
FRDP("uc5:dl_in_mem - addr: %08lx, count: %d\n", addr, count); WriteTrace(TraceRDP, TraceDebug, "uc5:dl_in_mem - addr: %08lx, count: %d", addr, count);
if (rdp.pc_i >= 9) { if (rdp.pc_i >= 9)
RDP_E("** DL stack overflow **\n"); {
LRDP("** DL stack overflow **\n"); WriteTrace(TraceRDP, TraceWarning, "** DL stack overflow **");
return; return;
} }
rdp.pc_i++; // go to the next PC in the stack rdp.pc_i++; // go to the next PC in the stack
@ -280,14 +276,14 @@ static void uc5_dl_in_mem()
static void uc5_moveword() static void uc5_moveword()
{ {
LRDP("uc5:moveword "); WriteTrace(TraceRDP, TraceDebug, "uc5:moveword ");
// Find which command this is (lowest byte of cmd0) // Find which command this is (lowest byte of cmd0)
switch (rdp.cmd0 & 0xFF) switch (rdp.cmd0 & 0xFF)
{ {
case 0x02: // moveword matrix 2 billboard case 0x02: // moveword matrix 2 billboard
billboarding = (rdp.cmd1 & 1); billboarding = (rdp.cmd1 & 1);
FRDP("matrix billboard - %s\n", str_offon[billboarding]); WriteTrace(TraceRDP, TraceDebug, "matrix billboard - %s", str_offon[billboarding]);
break; break;
case 0x04: // clip (verified same) case 0x04: // clip (verified same)
@ -296,11 +292,11 @@ static void uc5_moveword()
rdp.clip_ratio = sqrt((float)rdp.cmd1); rdp.clip_ratio = sqrt((float)rdp.cmd1);
rdp.update |= UPDATE_VIEWPORT; rdp.update |= UPDATE_VIEWPORT;
} }
FRDP("clip %08lx, %08lx\n", rdp.cmd0, rdp.cmd1); WriteTrace(TraceRDP, TraceDebug, "clip %08lx, %08lx", rdp.cmd0, rdp.cmd1);
break; break;
case 0x06: // segment (verified same) case 0x06: // segment (verified same)
FRDP("segment: %08lx -> seg%d\n", rdp.cmd1, (rdp.cmd0 >> 10) & 0x0F); WriteTrace(TraceRDP, TraceDebug, "segment: %08lx -> seg%d", rdp.cmd1, (rdp.cmd0 >> 10) & 0x0F);
rdp.segment[(rdp.cmd0 >> 10) & 0x0F] = rdp.cmd1; rdp.segment[(rdp.cmd0 >> 10) & 0x0F] = rdp.cmd1;
break; break;
@ -308,24 +304,24 @@ static void uc5_moveword()
{ {
rdp.fog_multiplier = (short)(rdp.cmd1 >> 16); rdp.fog_multiplier = (short)(rdp.cmd1 >> 16);
rdp.fog_offset = (short)(rdp.cmd1 & 0x0000FFFF); rdp.fog_offset = (short)(rdp.cmd1 & 0x0000FFFF);
FRDP("fog: multiplier: %f, offset: %f\n", rdp.fog_multiplier, rdp.fog_offset); WriteTrace(TraceRDP, TraceDebug, "fog: multiplier: %f, offset: %f", rdp.fog_multiplier, rdp.fog_offset);
// rdp.update |= UPDATE_FOG_ENABLED; // rdp.update |= UPDATE_FOG_ENABLED;
} }
break; break;
case 0x0a: // moveword matrix select case 0x0a: // moveword matrix select
cur_mtx = (rdp.cmd1 >> 6) & 3; cur_mtx = (rdp.cmd1 >> 6) & 3;
FRDP("matrix select - mtx: %d\n", cur_mtx); WriteTrace(TraceRDP, TraceDebug, "matrix select - mtx: %d", cur_mtx);
break; break;
default: default:
FRDP("(unknown) %02lx - IGNORED\n", rdp.cmd0 & 0xFF); WriteTrace(TraceRDP, TraceDebug, "(unknown) %02lx - IGNORED", rdp.cmd0 & 0xFF);
} }
} }
static void uc5_setgeometrymode() static void uc5_setgeometrymode()
{ {
FRDP("uc0:setgeometrymode %08lx\n", rdp.cmd1); WriteTrace(TraceRDP, TraceDebug, "uc0:setgeometrymode %08lx", rdp.cmd1);
rdp.geom_mode |= rdp.cmd1; rdp.geom_mode |= rdp.cmd1;
@ -351,7 +347,7 @@ static void uc5_setgeometrymode()
static void uc5_cleargeometrymode() static void uc5_cleargeometrymode()
{ {
FRDP("uc0:cleargeometrymode %08lx\n", rdp.cmd1); WriteTrace(TraceRDP, TraceDebug, "uc0:cleargeometrymode %08lx", rdp.cmd1);
rdp.geom_mode &= (~rdp.cmd1); rdp.geom_mode &= (~rdp.cmd1);

View File

@ -70,7 +70,7 @@ static float set_sprite_combine_mode()
{ {
Z = rdp.prim_depth; Z = rdp.prim_depth;
} }
FRDP("prim_depth = %d, prim_dz = %d\n", rdp.prim_depth, rdp.prim_dz); WriteTrace(TraceRDP, TraceDebug, "prim_depth = %d, prim_dz = %d", rdp.prim_depth, rdp.prim_dz);
Z = ScaleZ(Z); Z = ScaleZ(Z);
if (rdp.othermode_l & 0x00000400) if (rdp.othermode_l & 0x00000400)
@ -78,7 +78,7 @@ static float set_sprite_combine_mode()
} }
else else
{ {
LRDP("z compare not used, using 0\n"); WriteTrace(TraceRDP, TraceDebug, "z compare not used, using 0");
} }
grCullMode(GR_CULL_DISABLE); grCullMode(GR_CULL_DISABLE);
@ -250,7 +250,7 @@ void DrawDepthImage(const DRAWIMAGE & d)
return; return;
if (d.imageH > d.imageW) if (d.imageH > d.imageW)
return; return;
LRDP("Depth image write\n"); WriteTrace(TraceRDP, TraceDebug, "Depth image write");
if (fb_hwfbe_enabled) if (fb_hwfbe_enabled)
{ {
DrawHiresDepthImage(d); DrawHiresDepthImage(d);
@ -338,7 +338,7 @@ void DrawImage(DRAWIMAGE & d)
line = 16; line = 16;
break; break;
default: default:
FRDP("DrawImage. unknown image size: %d\n", d.imageSiz); WriteTrace(TraceRDP, TraceDebug, "DrawImage. unknown image size: %d", d.imageSiz);
return; return;
} }
@ -567,7 +567,7 @@ void DrawImage(DRAWIMAGE & d)
else else
{ {
rdp.tri_n += 2; rdp.tri_n += 2;
LRDP("Clipped!\n"); WriteTrace(TraceRDP, TraceDebug, "Clipped!");
} }
// increment whatever caused this split // increment whatever caused this split
@ -606,7 +606,7 @@ void DrawHiresImage(DRAWIMAGE & d, int screensize = FALSE)
rdp.tbuff_tex = &(rdp.texbufs[rdp.cur_tex_buf ^ 1].images[0]); rdp.tbuff_tex = &(rdp.texbufs[rdp.cur_tex_buf ^ 1].images[0]);
else if (rdp.tbuff_tex == 0) else if (rdp.tbuff_tex == 0)
return; return;
FRDP("DrawHiresImage. fb format=%d\n", rdp.tbuff_tex->info.format); WriteTrace(TraceRDP, TraceDebug, "DrawHiresImage. fb format=%d", rdp.tbuff_tex->info.format);
setTBufTex(rdp.tbuff_tex->t_mem, rdp.tbuff_tex->width << rdp.tbuff_tex->size >> 1); setTBufTex(rdp.tbuff_tex->t_mem, rdp.tbuff_tex->width << rdp.tbuff_tex->size >> 1);
@ -737,11 +737,11 @@ static void uc6_read_background_data(DRAWIMAGE & d, bool bReadScale)
int imageYorig = ((int *)gfx.RDRAM)[(addr + 16) >> 1] >> 5; int imageYorig = ((int *)gfx.RDRAM)[(addr + 16) >> 1] >> 5;
rdp.last_bg = d.imagePtr; rdp.last_bg = d.imagePtr;
FRDP("imagePtr: %08lx\n", d.imagePtr); WriteTrace(TraceRDP, TraceDebug, "imagePtr: %08lx", d.imagePtr);
FRDP("frameX: %f, frameW: %d, frameY: %f, frameH: %d\n", d.frameX, d.frameW, d.frameY, d.frameH); WriteTrace(TraceRDP, TraceDebug, "frameX: %f, frameW: %d, frameY: %f, frameH: %d", d.frameX, d.frameW, d.frameY, d.frameH);
FRDP("imageX: %d, imageW: %d, imageY: %d, imageH: %d\n", d.imageX, d.imageW, d.imageY, d.imageH); WriteTrace(TraceRDP, TraceDebug, "imageX: %d, imageW: %d, imageY: %d, imageH: %d", d.imageX, d.imageW, d.imageY, d.imageH);
FRDP("imageYorig: %d, scaleX: %f, scaleY: %f\n", imageYorig, d.scaleX, d.scaleY); WriteTrace(TraceRDP, TraceDebug, "imageYorig: %d, scaleX: %f, scaleY: %f", imageYorig, d.scaleX, d.scaleY);
FRDP("imageFmt: %d, imageSiz: %d, imagePal: %d, imageFlip: %d\n", d.imageFmt, d.imageSiz, d.imagePal, d.flipX); WriteTrace(TraceRDP, TraceDebug, "imageFmt: %d, imageSiz: %d, imagePal: %d, imageFlip: %d", d.imageFmt, d.imageSiz, d.imagePal, d.flipX);
} }
static void uc6_bg(bool bg_1cyc) static void uc6_bg(bool bg_1cyc)
@ -750,10 +750,10 @@ static void uc6_bg(bool bg_1cyc)
const char *strFuncName = bg_1cyc ? strFuncNames[0] : strFuncNames[1]; const char *strFuncName = bg_1cyc ? strFuncNames[0] : strFuncNames[1];
if (rdp.skip_drawing) if (rdp.skip_drawing)
{ {
FRDP("%s skipped\n", strFuncName); WriteTrace(TraceRDP, TraceDebug, "%s skipped", strFuncName);
return; return;
} }
FRDP("%s #%d, #%d\n", strFuncName, rdp.tri_n, rdp.tri_n + 1); WriteTrace(TraceRDP, TraceDebug, "%s #%d, #%d", strFuncName, rdp.tri_n, rdp.tri_n + 1);
DRAWIMAGE d; DRAWIMAGE d;
uc6_read_background_data(d, bg_1cyc); uc6_read_background_data(d, bg_1cyc);
@ -770,7 +770,7 @@ static void uc6_bg(bool bg_1cyc)
DrawImage(d); DrawImage(d);
else else
{ {
FRDP("%s skipped\n", strFuncName); WriteTrace(TraceRDP, TraceDebug, "%s skipped", strFuncName);
} }
} }
else else
@ -1008,10 +1008,10 @@ static void uc6_read_object_data(DRAWOBJECT & d)
if (d.imageH < 0) if (d.imageH < 0)
d.imageH = (short)rdp.scissor_o.lr_y - (short)d.objY - d.imageH; d.imageH = (short)rdp.scissor_o.lr_y - (short)d.objY - d.imageH;
FRDP("#%d, #%d\n" WriteTrace(TraceRDP, TraceDebug, "#%d, #%d"
"objX: %f, scaleW: %f, imageW: %d\n" "objX: %f, scaleW: %f, imageW: %d"
"objY: %f, scaleH: %f, imageH: %d\n" "objY: %f, scaleH: %f, imageH: %d"
"size: %d, format: %d\n", rdp.tri_n, rdp.tri_n + 1, "size: %d, format: %d", rdp.tri_n, rdp.tri_n + 1,
d.objX, d.scaleW, d.imageW, d.objY, d.scaleH, d.imageH, d.imageSiz, d.imageFmt); d.objX, d.scaleW, d.imageW, d.objY, d.scaleH, d.imageH, d.imageSiz, d.imageFmt);
} }
@ -1042,18 +1042,18 @@ static void uc6_init_tile(const DRAWOBJECT & d)
static void uc6_obj_rectangle() static void uc6_obj_rectangle()
{ {
LRDP("uc6:obj_rectangle "); WriteTrace(TraceRDP, TraceDebug, "uc6:obj_rectangle ");
DRAWOBJECT d; DRAWOBJECT d;
uc6_read_object_data(d); uc6_read_object_data(d);
if (d.imageAdrs > 4096) if (d.imageAdrs > 4096)
{ {
FRDP("tmem: %08lx is out of bounds! return\n", d.imageAdrs); WriteTrace(TraceRDP, TraceDebug, "tmem: %08lx is out of bounds! return", d.imageAdrs);
return; return;
} }
if (!rdp.s2dex_tex_loaded) if (!rdp.s2dex_tex_loaded)
{ {
LRDP("Texture was not loaded! return\n"); WriteTrace(TraceRDP, TraceDebug, "Texture was not loaded! return");
return; return;
} }
@ -1111,7 +1111,7 @@ static void uc6_obj_rectangle()
static void uc6_obj_sprite() static void uc6_obj_sprite()
{ {
LRDP("uc6:obj_sprite "); WriteTrace(TraceRDP, TraceDebug, "uc6:obj_sprite ");
DRAWOBJECT d; DRAWOBJECT d;
uc6_read_object_data(d); uc6_read_object_data(d);
uc6_init_tile(d); uc6_init_tile(d);
@ -1150,7 +1150,7 @@ static void uc6_obj_sprite()
ul_v = 0.5f; ul_v = 0.5f;
// Make the vertices // Make the vertices
// FRDP("scale_x: %f, scale_y: %f\n", rdp.cur_cache[0]->scale_x, rdp.cur_cache[0]->scale_y); // WriteTrace(TraceRDP, TraceDebug, "scale_x: %f, scale_y: %f", rdp.cur_cache[0]->scale_x, rdp.cur_cache[0]->scale_y);
VERTEX v[4] = { VERTEX v[4] = {
{ ul_x, ul_y, Z, 1, ul_u, ul_v }, { ul_x, ul_y, Z, 1, ul_u, ul_v },
@ -1172,7 +1172,7 @@ static void uc6_obj_sprite()
static void uc6_obj_movemem() static void uc6_obj_movemem()
{ {
LRDP("uc6:obj_movemem\n"); WriteTrace(TraceRDP, TraceDebug, "uc6:obj_movemem");
int index = rdp.cmd0 & 0xFFFF; int index = rdp.cmd0 & 0xFFFF;
uint32_t addr = segoffset(rdp.cmd1) >> 1; uint32_t addr = segoffset(rdp.cmd1) >> 1;
@ -1187,7 +1187,7 @@ static void uc6_obj_movemem()
mat_2d.BaseScaleX = ((uint16_t*)gfx.RDRAM)[(addr + 10) ^ 1] / 1024.0f; mat_2d.BaseScaleX = ((uint16_t*)gfx.RDRAM)[(addr + 10) ^ 1] / 1024.0f;
mat_2d.BaseScaleY = ((uint16_t*)gfx.RDRAM)[(addr + 11) ^ 1] / 1024.0f; mat_2d.BaseScaleY = ((uint16_t*)gfx.RDRAM)[(addr + 11) ^ 1] / 1024.0f;
FRDP("mat_2d\nA: %f, B: %f, c: %f, D: %f\nX: %f, Y: %f\nBaseScaleX: %f, BaseScaleY: %f\n", WriteTrace(TraceRDP, TraceDebug, "mat_2d\nA: %f, B: %f, c: %f, D: %f\nX: %f, Y: %f\nBaseScaleX: %f, BaseScaleY: %f",
mat_2d.A, mat_2d.B, mat_2d.C, mat_2d.D, mat_2d.X, mat_2d.Y, mat_2d.BaseScaleX, mat_2d.BaseScaleY); mat_2d.A, mat_2d.B, mat_2d.C, mat_2d.D, mat_2d.X, mat_2d.Y, mat_2d.BaseScaleX, mat_2d.BaseScaleY);
} }
else if (index == 2) { // movemem submatrix else if (index == 2) { // movemem submatrix
@ -1196,21 +1196,19 @@ static void uc6_obj_movemem()
mat_2d.BaseScaleX = ((uint16_t*)gfx.RDRAM)[(addr + 2) ^ 1] / 1024.0f; mat_2d.BaseScaleX = ((uint16_t*)gfx.RDRAM)[(addr + 2) ^ 1] / 1024.0f;
mat_2d.BaseScaleY = ((uint16_t*)gfx.RDRAM)[(addr + 3) ^ 1] / 1024.0f; mat_2d.BaseScaleY = ((uint16_t*)gfx.RDRAM)[(addr + 3) ^ 1] / 1024.0f;
FRDP("submatrix\nX: %f, Y: %f\nBaseScaleX: %f, BaseScaleY: %f\n", WriteTrace(TraceRDP, TraceDebug, "submatrix\nX: %f, Y: %f\nBaseScaleX: %f, BaseScaleY: %f",
mat_2d.X, mat_2d.Y, mat_2d.BaseScaleX, mat_2d.BaseScaleY); mat_2d.X, mat_2d.Y, mat_2d.BaseScaleX, mat_2d.BaseScaleY);
} }
} }
static void uc6_select_dl() static void uc6_select_dl()
{ {
LRDP("uc6:select_dl\n"); WriteTrace(TraceRDP, TraceWarning, "uc6:select_dl");
RDP_E("uc6:select_dl\n");
} }
static void uc6_obj_rendermode() static void uc6_obj_rendermode()
{ {
LRDP("uc6:obj_rendermode\n"); WriteTrace(TraceRDP, TraceWarning, "uc6:obj_rendermode");
RDP_E("uc6:obj_rendermode\n");
} }
static uint16_t uc6_yuv_to_rgba(uint8_t y, uint8_t u, uint8_t v) static uint16_t uc6_yuv_to_rgba(uint8_t y, uint8_t u, uint8_t v)
@ -1237,7 +1235,7 @@ static uint16_t uc6_yuv_to_rgba(uint8_t y, uint8_t u, uint8_t v)
static void uc6_DrawYUVImageToFrameBuffer(uint16_t ul_x, uint16_t ul_y, uint16_t lr_x, uint16_t lr_y) static void uc6_DrawYUVImageToFrameBuffer(uint16_t ul_x, uint16_t ul_y, uint16_t lr_x, uint16_t lr_y)
{ {
FRDP("uc6:DrawYUVImageToFrameBuffer ul_x%d, ul_y%d, lr_x%d, lr_y%d\n", ul_x, ul_y, lr_x, lr_y); WriteTrace(TraceRDP, TraceDebug, "uc6:DrawYUVImageToFrameBuffer ul_x%d, ul_y%d, lr_x%d, lr_y%d", ul_x, ul_y, lr_x, lr_y);
uint32_t ci_width = rdp.ci_width; uint32_t ci_width = rdp.ci_width;
uint32_t ci_height = rdp.ci_lower_bound; uint32_t ci_height = rdp.ci_lower_bound;
if (ul_x >= ci_width) if (ul_x >= ci_width)
@ -1274,7 +1272,7 @@ static void uc6_DrawYUVImageToFrameBuffer(uint16_t ul_x, uint16_t ul_y, uint16_t
static void uc6_obj_rectangle_r() static void uc6_obj_rectangle_r()
{ {
LRDP("uc6:obj_rectangle_r "); WriteTrace(TraceRDP, TraceDebug, "uc6:obj_rectangle_r ");
DRAWOBJECT d; DRAWOBJECT d;
uc6_read_object_data(d); uc6_read_object_data(d);
@ -1345,7 +1343,7 @@ static void uc6_obj_rectangle_r()
static void uc6_obj_loadtxtr() static void uc6_obj_loadtxtr()
{ {
LRDP("uc6:obj_loadtxtr "); WriteTrace(TraceRDP, TraceDebug, "uc6:obj_loadtxtr ");
rdp.s2dex_tex_loaded = TRUE; rdp.s2dex_tex_loaded = TRUE;
rdp.update |= UPDATE_TEXTURE; rdp.update |= UPDATE_TEXTURE;
@ -1357,7 +1355,7 @@ static void uc6_obj_loadtxtr()
uint16_t phead = ((uint16_t *)gfx.RDRAM)[(addr + 4) ^ 1] - 256; // 4 uint16_t phead = ((uint16_t *)gfx.RDRAM)[(addr + 4) ^ 1] - 256; // 4
uint16_t pnum = ((uint16_t *)gfx.RDRAM)[(addr + 5) ^ 1] + 1; // 5 uint16_t pnum = ((uint16_t *)gfx.RDRAM)[(addr + 5) ^ 1] + 1; // 5
FRDP("palette addr: %08lx, start: %d, num: %d\n", image, phead, pnum); WriteTrace(TraceRDP, TraceDebug, "palette addr: %08lx, start: %d, num: %d", image, phead, pnum);
load_palette(image, phead, pnum); load_palette(image, phead, pnum);
} }
else if (type == 0x00001033) { // TxtrBlock else if (type == 0x00001033) { // TxtrBlock
@ -1366,7 +1364,7 @@ static void uc6_obj_loadtxtr()
uint16_t tsize = ((uint16_t *)gfx.RDRAM)[(addr + 5) ^ 1]; // 5 uint16_t tsize = ((uint16_t *)gfx.RDRAM)[(addr + 5) ^ 1]; // 5
uint16_t tline = ((uint16_t *)gfx.RDRAM)[(addr + 6) ^ 1]; // 6 uint16_t tline = ((uint16_t *)gfx.RDRAM)[(addr + 6) ^ 1]; // 6
FRDP("addr: %08lx, tmem: %08lx, size: %d\n", image, tmem, tsize); WriteTrace(TraceRDP, TraceDebug, "addr: %08lx, tmem: %08lx, size: %d", image, tmem, tsize);
rdp.timg.addr = image; rdp.timg.addr = image;
rdp.timg.width = 1; rdp.timg.width = 1;
rdp.timg.size = 1; rdp.timg.size = 1;
@ -1384,7 +1382,7 @@ static void uc6_obj_loadtxtr()
uint16_t twidth = ((uint16_t *)gfx.RDRAM)[(addr + 5) ^ 1]; // 5 uint16_t twidth = ((uint16_t *)gfx.RDRAM)[(addr + 5) ^ 1]; // 5
uint16_t theight = ((uint16_t *)gfx.RDRAM)[(addr + 6) ^ 1]; // 6 uint16_t theight = ((uint16_t *)gfx.RDRAM)[(addr + 6) ^ 1]; // 6
FRDP("tile addr: %08lx, tmem: %08lx, twidth: %d, theight: %d\n", image, tmem, twidth, theight); WriteTrace(TraceRDP, TraceDebug, "tile addr: %08lx, tmem: %08lx, twidth: %d, theight: %d", image, tmem, twidth, theight);
int line = (twidth + 1) >> 2; int line = (twidth + 1) >> 2;
@ -1403,14 +1401,13 @@ static void uc6_obj_loadtxtr()
} }
else else
{ {
FRDP("UNKNOWN (0x%08lx)\n", type); WriteTrace(TraceRDP, TraceWarning, "uc6:obj_loadtxtr UNKNOWN (0x%08lx)", type);
FRDP_E("uc6:obj_loadtxtr UNKNOWN (0x%08lx)\n", type);
} }
} }
static void uc6_obj_ldtx_sprite() static void uc6_obj_ldtx_sprite()
{ {
LRDP("uc6:obj_ldtx_sprite\n"); WriteTrace(TraceRDP, TraceDebug, "uc6:obj_ldtx_sprite");
uint32_t addr = rdp.cmd1; uint32_t addr = rdp.cmd1;
uc6_obj_loadtxtr(); uc6_obj_loadtxtr();
@ -1420,7 +1417,7 @@ static void uc6_obj_ldtx_sprite()
static void uc6_obj_ldtx_rect() static void uc6_obj_ldtx_rect()
{ {
LRDP("uc6:obj_ldtx_rect\n"); WriteTrace(TraceRDP, TraceDebug, "uc6:obj_ldtx_rect");
uint32_t addr = rdp.cmd1; uint32_t addr = rdp.cmd1;
uc6_obj_loadtxtr(); uc6_obj_loadtxtr();
@ -1430,7 +1427,7 @@ static void uc6_obj_ldtx_rect()
static void uc6_ldtx_rect_r() static void uc6_ldtx_rect_r()
{ {
LRDP("uc6:ldtx_rect_r\n"); WriteTrace(TraceRDP, TraceDebug, "uc6:ldtx_rect_r");
uint32_t addr = rdp.cmd1; uint32_t addr = rdp.cmd1;
uc6_obj_loadtxtr(); uc6_obj_loadtxtr();
@ -1440,8 +1437,7 @@ static void uc6_ldtx_rect_r()
static void uc6_loaducode() static void uc6_loaducode()
{ {
LRDP("uc6:load_ucode\n"); WriteTrace(TraceRDP, TraceWarning, "uc6:load_ucode");
RDP_E("uc6:load_ucode\n");
// copy the microcode data // copy the microcode data
uint32_t addr = segoffset(rdp.cmd1); uint32_t addr = segoffset(rdp.cmd1);
@ -1458,7 +1454,7 @@ void uc6_sprite2d()
if ((cmd0 >> 24) != 0xBE) if ((cmd0 >> 24) != 0xBE)
return; return;
FRDP("uc6:uc6_sprite2d #%d, #%d\n", rdp.tri_n, rdp.tri_n + 1); WriteTrace(TraceRDP, TraceDebug, "uc6:uc6_sprite2d #%d, #%d", rdp.tri_n, rdp.tri_n + 1);
uint32_t addr = segoffset(rdp.cmd1) >> 1; uint32_t addr = segoffset(rdp.cmd1) >> 1;
DRAWIMAGE d; DRAWIMAGE d;
@ -1531,11 +1527,11 @@ void uc6_sprite2d()
stride *= scaleY; stride *= scaleY;
d.scaleY = 1.0f; d.scaleY = 1.0f;
} }
FRDP("imagePtr: %08lx\n", d.imagePtr); WriteTrace(TraceRDP, TraceDebug, "imagePtr: %08lx", d.imagePtr);
FRDP("frameX: %f, frameW: %d, frameY: %f, frameH: %d\n", d.frameX, d.frameW, d.frameY, d.frameH); WriteTrace(TraceRDP, TraceDebug, "frameX: %f, frameW: %d, frameY: %f, frameH: %d", d.frameX, d.frameW, d.frameY, d.frameH);
FRDP("imageX: %d, imageW: %d, imageY: %d, imageH: %d\n", d.imageX, d.imageW, d.imageY, d.imageH); WriteTrace(TraceRDP, TraceDebug, "imageX: %d, imageW: %d, imageY: %d, imageH: %d", d.imageX, d.imageW, d.imageY, d.imageH);
FRDP("imageFmt: %d, imageSiz: %d, imagePal: %d, imageStride: %d\n", d.imageFmt, d.imageSiz, d.imagePal, stride); WriteTrace(TraceRDP, TraceDebug, "imageFmt: %d, imageSiz: %d, imagePal: %d, imageStride: %d", d.imageFmt, d.imageSiz, d.imagePal, stride);
FRDP("scaleX: %f, scaleY: %f\n", d.scaleX, d.scaleY); WriteTrace(TraceRDP, TraceDebug, "scaleX: %f, scaleY: %f", d.scaleX, d.scaleY);
} }
else else
{ {

View File

@ -47,7 +47,7 @@ uint32_t pd_col_addr = 0;
static void uc7_colorbase() static void uc7_colorbase()
{ {
LRDP("uc7_colorbase\n"); WriteTrace(TraceRDP, TraceDebug, "uc7_colorbase");
pd_col_addr = segoffset(rdp.cmd1); pd_col_addr = segoffset(rdp.cmd1);
} }
@ -91,7 +91,7 @@ static void uc7_vertex()
rdp.v0 = v0 = (rdp.cmd0 & 0x0F0000) >> 16; rdp.v0 = v0 = (rdp.cmd0 & 0x0F0000) >> 16;
rdp.vn = n = ((rdp.cmd0 & 0xF00000) >> 20) + 1; rdp.vn = n = ((rdp.cmd0 & 0xF00000) >> 20) + 1;
FRDP("uc7:vertex n: %d, v0: %d, from: %08lx\n", n, v0, addr); WriteTrace(TraceRDP, TraceDebug, "uc7:vertex n: %d, v0: %d, from: %08lx", n, v0, addr);
vtx_uc7 *vertex = (vtx_uc7 *)&gfx.RDRAM[addr]; vtx_uc7 *vertex = (vtx_uc7 *)&gfx.RDRAM[addr];
@ -106,9 +106,7 @@ static void uc7_vertex()
v->ov = (float)vertex->t; v->ov = (float)vertex->t;
v->uv_scaled = 0; v->uv_scaled = 0;
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "before: v%d - x: %f, y: %f, z: %f, flags: %04lx, ou: %f, ov: %f", i >> 4, x, y, z, v->flags, v->ou, v->ov);
// FRDP ("before: v%d - x: %f, y: %f, z: %f, flags: %04lx, ou: %f, ov: %f\n", i>>4, x, y, z, v->flags, v->ou, v->ov);
#endif
v->x = x*rdp.combined[0][0] + y*rdp.combined[1][0] + z*rdp.combined[2][0] + rdp.combined[3][0]; v->x = x*rdp.combined[0][0] + y*rdp.combined[1][0] + z*rdp.combined[2][0] + rdp.combined[3][0];
v->y = x*rdp.combined[0][1] + y*rdp.combined[1][1] + z*rdp.combined[2][1] + rdp.combined[3][1]; v->y = x*rdp.combined[0][1] + y*rdp.combined[1][1] + z*rdp.combined[2][1] + rdp.combined[3][1];
@ -145,31 +143,25 @@ static void uc7_vertex()
if (rdp.geom_mode & 0x80000) if (rdp.geom_mode & 0x80000)
{ {
calc_linear(v); calc_linear(v);
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "calc linear: v%d - u: %f, v: %f", i >> 4, v->ou, v->ov);
FRDP("calc linear: v%d - u: %f, v: %f\n", i >> 4, v->ou, v->ov);
#endif
} }
else if (rdp.geom_mode & 0x40000) else if (rdp.geom_mode & 0x40000)
{ {
calc_sphere(v); calc_sphere(v);
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "calc sphere: v%d - u: %f, v: %f", i >> 4, v->ou, v->ov);
FRDP("calc sphere: v%d - u: %f, v: %f\n", i >> 4, v->ou, v->ov);
#endif
} }
NormalizeVector(v->vec); NormalizeVector(v->vec);
calc_light(v); calc_light(v);
} }
else else
{ {
v->r = color[3]; v->r = color[3];
v->g = color[2]; v->g = color[2];
v->b = color[1]; v->b = color[1];
} }
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "v%d - x: %f, y: %f, z: %f, w: %f, u: %f, v: %f", i >> 4, v->x, v->y, v->z, v->w, v->ou, v->ov);
FRDP("v%d - x: %f, y: %f, z: %f, w: %f, u: %f, v: %f\n", i >> 4, v->x, v->y, v->z, v->w, v->ou, v->ov);
#endif
vertex++; vertex++;
} }
} }

View File

@ -59,12 +59,11 @@ static void uc8_vertex()
rdp.vn = n = (rdp.cmd0 >> 12) & 0xFF; rdp.vn = n = (rdp.cmd0 >> 12) & 0xFF;
rdp.v0 = v0 = ((rdp.cmd0 >> 1) & 0x7F) - n; rdp.v0 = v0 = ((rdp.cmd0 >> 1) & 0x7F) - n;
FRDP("uc8:vertex n: %d, v0: %d, from: %08lx\n", n, v0, addr); WriteTrace(TraceRDP, TraceDebug, "uc8:vertex n: %d, v0: %d, from: %08lx", n, v0, addr);
if (v0 < 0) if (v0 < 0)
{ {
RDP_E("** ERROR: uc2:vertex v0 < 0\n"); WriteTrace(TraceRDP, TraceWarning, "** ERROR: uc2:vertex v0 < 0");
LRDP("** ERROR: uc2:vertex v0 < 0\n");
return; return;
} }
//* //*
@ -78,9 +77,7 @@ static void uc8_vertex()
{ {
InverseTransformVector(&rdp.light[l].dir_x, rdp.light_vector[l], rdp.model); InverseTransformVector(&rdp.light[l].dir_x, rdp.light_vector[l], rdp.model);
NormalizeVector(rdp.light_vector[l]); NormalizeVector(rdp.light_vector[l]);
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "light_vector[%d] x: %f, y: %f, z: %f", l, rdp.light_vector[l][0], rdp.light_vector[l][1], rdp.light_vector[l][2]);
FRDP("light_vector[%d] x: %f, y: %f, z: %f\n", l, rdp.light_vector[l][0], rdp.light_vector[l][1], rdp.light_vector[l][2]);
#endif
} }
} }
//*/ //*/
@ -96,17 +93,13 @@ static void uc8_vertex()
v->uv_scaled = 0; v->uv_scaled = 0;
v->a = ((uint8_t*)gfx.RDRAM)[(addr + i + 15) ^ 3]; v->a = ((uint8_t*)gfx.RDRAM)[(addr + i + 15) ^ 3];
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "before v%d - x: %f, y: %f, z: %f", i >> 4, x, y, z);
FRDP ("before v%d - x: %f, y: %f, z: %f\n", i>>4, x, y, z);
#endif
v->x = x*rdp.combined[0][0] + y*rdp.combined[1][0] + z*rdp.combined[2][0] + rdp.combined[3][0]; v->x = x*rdp.combined[0][0] + y*rdp.combined[1][0] + z*rdp.combined[2][0] + rdp.combined[3][0];
v->y = x*rdp.combined[0][1] + y*rdp.combined[1][1] + z*rdp.combined[2][1] + rdp.combined[3][1]; v->y = x*rdp.combined[0][1] + y*rdp.combined[1][1] + z*rdp.combined[2][1] + rdp.combined[3][1];
v->z = x*rdp.combined[0][2] + y*rdp.combined[1][2] + z*rdp.combined[2][2] + rdp.combined[3][2]; v->z = x*rdp.combined[0][2] + y*rdp.combined[1][2] + z*rdp.combined[2][2] + rdp.combined[3][2];
v->w = x*rdp.combined[0][3] + y*rdp.combined[1][3] + z*rdp.combined[2][3] + rdp.combined[3][3]; v->w = x*rdp.combined[0][3] + y*rdp.combined[1][3] + z*rdp.combined[2][3] + rdp.combined[3][3];
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "v%d - x: %f, y: %f, z: %f, w: %f, u: %f, v: %f, flags: %d", i >> 4, v->x, v->y, v->z, v->w, v->ou, v->ov, v->flags);
FRDP ("v%d - x: %f, y: %f, z: %f, w: %f, u: %f, v: %f, flags: %d\n", i>>4, v->x, v->y, v->z, v->w, v->ou, v->ov, v->flags);
#endif
if (fabs(v->w) < 0.001) v->w = 0.001f; if (fabs(v->w) < 0.001) v->w = 0.001f;
v->oow = 1.0f / v->w; v->oow = 1.0f / v->w;
@ -128,9 +121,7 @@ static void uc8_vertex()
v->r = ((uint8_t*)gfx.RDRAM)[(addr + i + 12) ^ 3]; v->r = ((uint8_t*)gfx.RDRAM)[(addr + i + 12) ^ 3];
v->g = ((uint8_t*)gfx.RDRAM)[(addr + i + 13) ^ 3]; v->g = ((uint8_t*)gfx.RDRAM)[(addr + i + 13) ^ 3];
v->b = ((uint8_t*)gfx.RDRAM)[(addr + i + 14) ^ 3]; v->b = ((uint8_t*)gfx.RDRAM)[(addr + i + 14) ^ 3];
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "r: %02lx, g: %02lx, b: %02lx, a: %02lx", v->r, v->g, v->b, v->a);
FRDP ("r: %02lx, g: %02lx, b: %02lx, a: %02lx\n", v->r, v->g, v->b, v->a);
#endif
if ((rdp.geom_mode & 0x00020000)) if ((rdp.geom_mode & 0x00020000))
{ {
@ -142,21 +133,16 @@ static void uc8_vertex()
if (rdp.geom_mode & 0x80000) if (rdp.geom_mode & 0x80000)
{ {
calc_linear(v); calc_linear(v);
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "calc linear: v%d - u: %f, v: %f", i >> 4, v->ou, v->ov);
FRDP ("calc linear: v%d - u: %f, v: %f\n", i>>4, v->ou, v->ov);
#endif
} }
else if (rdp.geom_mode & 0x40000) else if (rdp.geom_mode & 0x40000)
{ {
calc_sphere(v); calc_sphere(v);
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "calc sphere: v%d - u: %f, v: %f", i >> 4, v->ou, v->ov);
FRDP ("calc sphere: v%d - u: %f, v: %f\n", i>>4, v->ou, v->ov);
#endif
} }
// FRDP("calc light. r: 0x%02lx, g: 0x%02lx, b: 0x%02lx, nx: %.3f, ny: %.3f, nz: %.3f\n", v->r, v->g, v->b, v->vec[0], v->vec[1], v->vec[2]); WriteTrace(TraceRDP, TraceDebug, "v[%d] calc light. r: 0x%02lx, g: 0x%02lx, b: 0x%02lx", i >> 4, v->r, v->g, v->b);
FRDP("v[%d] calc light. r: 0x%02lx, g: 0x%02lx, b: 0x%02lx\n", i >> 4, v->r, v->g, v->b);
float color[3] = { rdp.light[rdp.num_lights].r, rdp.light[rdp.num_lights].g, rdp.light[rdp.num_lights].b }; float color[3] = { rdp.light[rdp.num_lights].r, rdp.light[rdp.num_lights].g, rdp.light[rdp.num_lights].b };
FRDP("ambient light. r: %f, g: %f, b: %f\n", color[0], color[1], color[2]); WriteTrace(TraceRDP, TraceDebug, "ambient light. r: %f, g: %f, b: %f", color[0], color[1], color[2]);
float light_intensity = 0.0f; float light_intensity = 0.0f;
uint32_t l; uint32_t l;
if (rdp.geom_mode & 0x00400000) if (rdp.geom_mode & 0x00400000)
@ -167,7 +153,7 @@ static void uc8_vertex()
if (!rdp.light[l].nonblack) if (!rdp.light[l].nonblack)
continue; continue;
light_intensity = DotProduct(rdp.light_vector[l], v->vec); light_intensity = DotProduct(rdp.light_vector[l], v->vec);
FRDP("light %d, intensity : %f\n", l, light_intensity); WriteTrace(TraceRDP, TraceDebug, "light %d, intensity : %f", l, light_intensity);
if (light_intensity < 0.0f) if (light_intensity < 0.0f)
continue; continue;
//* //*
@ -181,23 +167,23 @@ static void uc8_vertex()
float p_i = rdp.light[l].ca / len; float p_i = rdp.light[l].ca / len;
if (p_i > 1.0f) p_i = 1.0f; if (p_i > 1.0f) p_i = 1.0f;
light_intensity *= p_i; light_intensity *= p_i;
FRDP("light %d, len: %f, p_intensity : %f\n", l, len, p_i); WriteTrace(TraceRDP, TraceDebug, "light %d, len: %f, p_intensity : %f", l, len, p_i);
} }
//*/ //*/
color[0] += rdp.light[l].r * light_intensity; color[0] += rdp.light[l].r * light_intensity;
color[1] += rdp.light[l].g * light_intensity; color[1] += rdp.light[l].g * light_intensity;
color[2] += rdp.light[l].b * light_intensity; color[2] += rdp.light[l].b * light_intensity;
FRDP("light %d r: %f, g: %f, b: %f\n", l, color[0], color[1], color[2]); WriteTrace(TraceRDP, TraceDebug, "light %d r: %f, g: %f, b: %f", l, color[0], color[1], color[2]);
} }
light_intensity = DotProduct(rdp.light_vector[l], v->vec); light_intensity = DotProduct(rdp.light_vector[l], v->vec);
FRDP("light %d, intensity : %f\n", l, light_intensity); WriteTrace(TraceRDP, TraceDebug, "light %d, intensity : %f", l, light_intensity);
if (light_intensity > 0.0f) if (light_intensity > 0.0f)
{ {
color[0] += rdp.light[l].r * light_intensity; color[0] += rdp.light[l].r * light_intensity;
color[1] += rdp.light[l].g * light_intensity; color[1] += rdp.light[l].g * light_intensity;
color[2] += rdp.light[l].b * light_intensity; color[2] += rdp.light[l].b * light_intensity;
} }
FRDP("light %d r: %f, g: %f, b: %f\n", l, color[0], color[1], color[2]); WriteTrace(TraceRDP, TraceDebug, "light %d r: %f, g: %f, b: %f", l, color[0], color[1], color[2]);
} }
else else
{ {
@ -212,11 +198,11 @@ static void uc8_vertex()
float len = (vx*vx + vy*vy + vz*vz + vw*vw) / 65536.0f; float len = (vx*vx + vy*vy + vz*vz + vw*vw) / 65536.0f;
light_intensity = rdp.light[l].ca / len; light_intensity = rdp.light[l].ca / len;
if (light_intensity > 1.0f) light_intensity = 1.0f; if (light_intensity > 1.0f) light_intensity = 1.0f;
FRDP("light %d, p_intensity : %f\n", l, light_intensity); WriteTrace(TraceRDP, TraceDebug, "light %d, p_intensity : %f", l, light_intensity);
color[0] += rdp.light[l].r * light_intensity; color[0] += rdp.light[l].r * light_intensity;
color[1] += rdp.light[l].g * light_intensity; color[1] += rdp.light[l].g * light_intensity;
color[2] += rdp.light[l].b * light_intensity; color[2] += rdp.light[l].b * light_intensity;
//FRDP("light %d r: %f, g: %f, b: %f\n", l, color[0], color[1], color[2]); //WriteTrace(TraceRDP, TraceDebug, "light %d r: %f, g: %f, b: %f", l, color[0], color[1], color[2]);
} }
} }
} }
@ -226,9 +212,7 @@ static void uc8_vertex()
v->r = (uint8_t)(((float)v->r)*color[0]); v->r = (uint8_t)(((float)v->r)*color[0]);
v->g = (uint8_t)(((float)v->g)*color[1]); v->g = (uint8_t)(((float)v->g)*color[1]);
v->b = (uint8_t)(((float)v->b)*color[2]); v->b = (uint8_t)(((float)v->b)*color[2]);
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "color after light: r: 0x%02lx, g: 0x%02lx, b: 0x%02lx", v->r, v->g, v->b);
FRDP("color after light: r: 0x%02lx, g: 0x%02lx, b: 0x%02lx\n", v->r, v->g, v->b);
#endif
} }
} }
} }
@ -239,7 +223,7 @@ static void uc8_moveword()
uint16_t offset = (uint16_t)(rdp.cmd0 & 0xFFFF); uint16_t offset = (uint16_t)(rdp.cmd0 & 0xFFFF);
uint32_t data = rdp.cmd1; uint32_t data = rdp.cmd1;
FRDP("uc8:moveword "); WriteTrace(TraceRDP, TraceDebug, "uc8:moveword ");
switch (index) switch (index)
{ {
@ -249,7 +233,7 @@ static void uc8_moveword()
case 0x02: case 0x02:
rdp.num_lights = (data / 48); rdp.num_lights = (data / 48);
rdp.update |= UPDATE_LIGHTS; rdp.update |= UPDATE_LIGHTS;
FRDP("numlights: %d\n", rdp.num_lights); WriteTrace(TraceRDP, TraceDebug, "numlights: %d", rdp.num_lights);
break; break;
case 0x04: case 0x04:
@ -258,12 +242,12 @@ static void uc8_moveword()
rdp.clip_ratio = sqrt((float)rdp.cmd1); rdp.clip_ratio = sqrt((float)rdp.cmd1);
rdp.update |= UPDATE_VIEWPORT; rdp.update |= UPDATE_VIEWPORT;
} }
FRDP("mw_clip %08lx, %08lx\n", rdp.cmd0, rdp.cmd1); WriteTrace(TraceRDP, TraceDebug, "mw_clip %08lx, %08lx", rdp.cmd0, rdp.cmd1);
break; break;
case 0x06: // moveword SEGMENT case 0x06: // moveword SEGMENT
{ {
FRDP("SEGMENT %08lx -> seg%d\n", data, offset >> 2); WriteTrace(TraceRDP, TraceDebug, "SEGMENT %08lx -> seg%d", data, offset >> 2);
rdp.segment[(offset >> 2) & 0xF] = data; rdp.segment[(offset >> 2) & 0xF] = data;
} }
break; break;
@ -272,24 +256,24 @@ static void uc8_moveword()
{ {
rdp.fog_multiplier = (short)(rdp.cmd1 >> 16); rdp.fog_multiplier = (short)(rdp.cmd1 >> 16);
rdp.fog_offset = (short)(rdp.cmd1 & 0x0000FFFF); rdp.fog_offset = (short)(rdp.cmd1 & 0x0000FFFF);
FRDP("fog: multiplier: %f, offset: %f\n", rdp.fog_multiplier, rdp.fog_offset); WriteTrace(TraceRDP, TraceDebug, "fog: multiplier: %f, offset: %f", rdp.fog_multiplier, rdp.fog_offset);
} }
break; break;
case 0x0c: case 0x0c:
RDP_E("uc8:moveword forcemtx - IGNORED\n");
LRDP("forcemtx - IGNORED\n"); WriteTrace(TraceRDP, TraceWarning, "uc8:moveword forcemtx - IGNORED");
break; break;
case 0x0e: case 0x0e:
LRDP("perspnorm - IGNORED\n"); WriteTrace(TraceRDP, TraceDebug, "perspnorm - IGNORED");
break; break;
case 0x10: // moveword coord mod case 0x10: // moveword coord mod
{ {
uint8_t n = offset >> 2; uint8_t n = offset >> 2;
FRDP("coord mod:%d, %08lx\n", n, data); WriteTrace(TraceRDP, TraceDebug, "coord mod:%d, %08lx", n, data);
if (rdp.cmd0 & 8) if (rdp.cmd0 & 8)
return; return;
uint32_t idx = (rdp.cmd0 >> 1) & 3; uint32_t idx = (rdp.cmd0 >> 1) & 3;
@ -310,22 +294,19 @@ static void uc8_moveword()
{ {
uc8_coord_mod[8 + idx] = (short)(rdp.cmd1 >> 16); uc8_coord_mod[8 + idx] = (short)(rdp.cmd1 >> 16);
uc8_coord_mod[9 + idx] = (short)(rdp.cmd1 & 0xffff); uc8_coord_mod[9 + idx] = (short)(rdp.cmd1 & 0xffff);
#ifdef EXTREME_LOGGING
if (idx) if (idx)
{ {
for (int k = 8; k < 16; k++) for (int k = 8; k < 16; k++)
{ {
FRDP("coord_mod[%d]=%f\n", k, uc8_coord_mod[k]); WriteTrace(TraceRDP, TraceVerbose, "coord_mod[%d]=%f", k, uc8_coord_mod[k]);
} }
} }
#endif
} }
} }
break; break;
default: default:
FRDP_E("uc8:moveword unknown (index: 0x%08lx, offset 0x%08lx)\n", index, offset); WriteTrace(TraceRDP, TraceWarning, "uc8:moveword unknown (index: 0x%08lx, offset 0x%08lx)", index, offset);
FRDP("unknown (index: 0x%08lx, offset 0x%08lx)\n", index, offset);
} }
} }
@ -335,7 +316,7 @@ static void uc8_movemem()
uint32_t addr = segoffset(rdp.cmd1); uint32_t addr = segoffset(rdp.cmd1);
int ofs = (rdp.cmd0 >> 5) & 0x3FFF; int ofs = (rdp.cmd0 >> 5) & 0x3FFF;
FRDP("uc8:movemem ofs:%d ", ofs); WriteTrace(TraceRDP, TraceDebug, "uc8:movemem ofs:%d ", ofs);
switch (idx) switch (idx)
{ {
@ -357,7 +338,7 @@ static void uc8_movemem()
rdp.update |= UPDATE_VIEWPORT; rdp.update |= UPDATE_VIEWPORT;
FRDP("viewport scale(%d, %d), trans(%d, %d), from:%08lx\n", scale_x, scale_y, WriteTrace(TraceRDP, TraceDebug, "viewport scale(%d, %d), trans(%d, %d), from:%08lx", scale_x, scale_y,
trans_x, trans_y, a); trans_x, trans_y, a);
} }
break; break;
@ -379,7 +360,7 @@ static void uc8_movemem()
if (!dir_x && !dir_y) if (!dir_x && !dir_y)
rdp.use_lookat = FALSE; rdp.use_lookat = FALSE;
} }
FRDP("lookat_%d (%f, %f, %f)\n", n, rdp.lookat[n][0], rdp.lookat[n][1], rdp.lookat[n][2]); WriteTrace(TraceRDP, TraceDebug, "lookat_%d (%f, %f, %f)", n, rdp.lookat[n][0], rdp.lookat[n][1], rdp.lookat[n][2]);
return; return;
} }
n -= 2; n -= 2;
@ -405,57 +386,51 @@ static void uc8_movemem()
rdp.light[n].nonzero = gfx.RDRAM[(addr + 12) ^ 3]; rdp.light[n].nonzero = gfx.RDRAM[(addr + 12) ^ 3];
rdp.light[n].ca = (float)rdp.light[n].nonzero / 16.0f; rdp.light[n].ca = (float)rdp.light[n].nonzero / 16.0f;
//rdp.light[n].la = rdp.light[n].ca * 1.0f; //rdp.light[n].la = rdp.light[n].ca * 1.0f;
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "light: n: %d, pos: x: %f, y: %f, z: %f, w: %f, ca: %f",
FRDP("light: n: %d, pos: x: %f, y: %f, z: %f, w: %f, ca: %f\n",
n, rdp.light[n].x, rdp.light[n].y, rdp.light[n].z, rdp.light[n].w, rdp.light[n].ca); n, rdp.light[n].x, rdp.light[n].y, rdp.light[n].z, rdp.light[n].w, rdp.light[n].ca);
#endif WriteTrace(TraceRDP, TraceDebug, "light: n: %d, r: %f, g: %f, b: %f. dir: x: %.3f, y: %.3f, z: %.3f",
FRDP("light: n: %d, r: %f, g: %f, b: %f. dir: x: %.3f, y: %.3f, z: %.3f\n",
n, rdp.light[n].r, rdp.light[n].g, rdp.light[n].b, n, rdp.light[n].r, rdp.light[n].g, rdp.light[n].b,
rdp.light[n].dir_x, rdp.light[n].dir_y, rdp.light[n].dir_z); rdp.light[n].dir_x, rdp.light[n].dir_y, rdp.light[n].dir_z);
#ifdef EXTREME_LOGGING
for (int t = 0; t < 24; t++) for (int t = 0; t < 24; t++)
{ {
FRDP ("light[%d] = 0x%04lx \n", t, ((uint16_t*)gfx.RDRAM)[(a+t)^1]); WriteTrace(TraceRDP, TraceVerbose, "light[%d] = 0x%04lx ", t, ((uint16_t*)gfx.RDRAM)[(a + t) ^ 1]);
} }
#endif
} }
break; break;
case 14: //Normales case 14: //Normales
{ {
uc8_normale_addr = segoffset(rdp.cmd1); uc8_normale_addr = segoffset(rdp.cmd1);
FRDP("Normale - addr: %08lx\n", uc8_normale_addr); WriteTrace(TraceRDP, TraceVerbose, "Normale - addr: %08lx", uc8_normale_addr);
#ifdef EXTREME_LOGGING
int i; int i;
for (i = 0; i < 32; i++) for (i = 0; i < 32; i++)
{ {
char x = ((char*)gfx.RDRAM)[uc8_normale_addr + ((i<<1) + 0)^3]; char x = ((char*)gfx.RDRAM)[uc8_normale_addr + ((i << 1) + 0) ^ 3];
char y = ((char*)gfx.RDRAM)[uc8_normale_addr + ((i<<1) + 1)^3]; char y = ((char*)gfx.RDRAM)[uc8_normale_addr + ((i << 1) + 1) ^ 3];
FRDP("#%d x = %d, y = %d\n", i, x, y); WriteTrace(TraceRDP, TraceVerbose, "#%d x = %d, y = %d", i, x, y);
} }
uint32_t a = uc8_normale_addr >> 1; uint32_t a = uc8_normale_addr >> 1;
for (i = 0; i < 32; i++) for (i = 0; i < 32; i++)
{ {
FRDP ("n[%d] = 0x%04lx \n", i, ((uint16_t*)gfx.RDRAM)[(a+i)^1]); WriteTrace(TraceRDP, TraceVerbose, "n[%d] = 0x%04lx ", i, ((uint16_t*)gfx.RDRAM)[(a + i) ^ 1]);
} }
#endif
} }
break; break;
default: default:
FRDP("uc8:movemem unknown (%d)\n", idx); WriteTrace(TraceRDP, TraceDebug, "uc8:movemem unknown (%d)", idx);
}
} }
}
static void uc8_tri4() //by Gugaman Apr 19 2002 static void uc8_tri4() //by Gugaman Apr 19 2002
{ {
if (rdp.skip_drawing) if (rdp.skip_drawing)
{ {
LRDP("uc8:tri4. skipped\n"); WriteTrace(TraceRDP, TraceDebug, "uc8:tri4. skipped");
return; return;
} }
FRDP("uc8:tri4 (#%d - #%d), %d-%d-%d, %d-%d-%d, %d-%d-%d, %d-%d-%d\n", WriteTrace(TraceRDP, TraceDebug, "uc8:tri4 (#%d - #%d), %d-%d-%d, %d-%d-%d, %d-%d-%d, %d-%d-%d",
rdp.tri_n, rdp.tri_n,
rdp.tri_n + 3, rdp.tri_n + 3,
((rdp.cmd0 >> 23) & 0x1F), ((rdp.cmd0 >> 23) & 0x1F),

View File

@ -126,7 +126,7 @@ static void uc9_draw_object(uint8_t * addr, uint32_t type)
vsize = 16; vsize = 16;
break; break;
default: default:
FRDP_E("Unknown geometric primitive type %u.\n", type); WriteTrace(TraceRDP, TraceWarning, "Unknown geometric primitive type %u.", type);
textured = vnum = vsize = 0; textured = vnum = vsize = 0;
break; break;
} }
@ -153,12 +153,12 @@ static void uc9_draw_object(uint8_t * addr, uint32_t type)
v.ov = ((short*)addr)[5 ^ 1]; v.ov = ((short*)addr)[5 ^ 1];
v.w = Calc_invw(((int*)addr)[3]) / 31.0f; v.w = Calc_invw(((int*)addr)[3]) / 31.0f;
v.oow = 1.0f / v.w; v.oow = 1.0f / v.w;
FRDP("v%d - sx: %f, sy: %f ou: %f, ov: %f, w: %f, r=%d, g=%d, b=%d, a=%d\n", i, v.sx / rdp.scale_x, v.sy / rdp.scale_y, v.ou*rdp.tiles[rdp.cur_tile].s_scale, v.ov*rdp.tiles[rdp.cur_tile].t_scale, v.w, v.r, v.g, v.b, v.a); WriteTrace(TraceRDP, TraceDebug, "v%d - sx: %f, sy: %f ou: %f, ov: %f, w: %f, r=%d, g=%d, b=%d, a=%d", i, v.sx / rdp.scale_x, v.sy / rdp.scale_y, v.ou*rdp.tiles[rdp.cur_tile].s_scale, v.ov*rdp.tiles[rdp.cur_tile].t_scale, v.w, v.r, v.g, v.b, v.a);
} }
else else
{ {
v.oow = v.w = 1.0f; v.oow = v.w = 1.0f;
FRDP("v%d - sx: %f, sy: %f r=%d, g=%d, b=%d, a=%d\n", i, v.sx / rdp.scale_x, v.sy / rdp.scale_y, v.r, v.g, v.b, v.a); WriteTrace(TraceRDP, TraceDebug, "v%d - sx: %f, sy: %f r=%d, g=%d, b=%d, a=%d", i, v.sx / rdp.scale_x, v.sy / rdp.scale_y, v.r, v.g, v.b, v.a);
} }
addr += vsize; addr += vsize;
} }
@ -171,13 +171,13 @@ static void uc9_draw_object(uint8_t * addr, uint32_t type)
}; };
if (vnum == 3) if (vnum == 3)
{ {
FRDP("uc9:Tri #%d, #%d\n", rdp.tri_n, rdp.tri_n + 1); WriteTrace(TraceRDP, TraceDebug, "uc9:Tri #%d, #%d", rdp.tri_n, rdp.tri_n + 1);
draw_tri(pV, 0); draw_tri(pV, 0);
rdp.tri_n++; rdp.tri_n++;
} }
else else
{ {
FRDP("uc9:Quad #%d, #%d\n", rdp.tri_n, rdp.tri_n + 1); WriteTrace(TraceRDP, TraceDebug, "uc9:Quad #%d, #%d", rdp.tri_n, rdp.tri_n + 1);
draw_tri(pV, 0); draw_tri(pV, 0);
draw_tri(pV + 1, 0); draw_tri(pV + 1, 0);
rdp.tri_n += 2; rdp.tri_n += 2;
@ -237,7 +237,7 @@ static uint32_t uc9_load_object(uint32_t zHeader, uint32_t * rdpcmds)
static void uc9_object() static void uc9_object()
{ {
LRDP("uc9:object\n"); WriteTrace(TraceRDP, TraceDebug, "uc9:object");
uint32_t rdpcmds[3] = { 0, 0, 0 }; uint32_t rdpcmds[3] = { 0, 0, 0 };
uint32_t cmd1 = rdp.cmd1; uint32_t cmd1 = rdp.cmd1;
uint32_t zHeader = segoffset(rdp.cmd0); uint32_t zHeader = segoffset(rdp.cmd0);
@ -250,7 +250,7 @@ static void uc9_object()
static void uc9_mix() static void uc9_mix()
{ {
LRDP("uc9:mix IGNORED\n"); WriteTrace(TraceRDP, TraceDebug, "uc9:mix IGNORED");
} }
static void uc9_fmlight() static void uc9_fmlight()
@ -258,7 +258,7 @@ static void uc9_fmlight()
int mid = rdp.cmd0 & 0xFF; int mid = rdp.cmd0 & 0xFF;
rdp.num_lights = 1 + ((rdp.cmd1 >> 12) & 0xFF); rdp.num_lights = 1 + ((rdp.cmd1 >> 12) & 0xFF);
uint32_t a = -1024 + (rdp.cmd1 & 0xFFF); uint32_t a = -1024 + (rdp.cmd1 & 0xFFF);
FRDP("uc9:fmlight matrix: %d, num: %d, dmem: %04lx\n", mid, rdp.num_lights, a); WriteTrace(TraceRDP, TraceDebug, "uc9:fmlight matrix: %d, num: %d, dmem: %04lx", mid, rdp.num_lights, a);
M44 *m = NULL; M44 *m = NULL;
switch (mid) { switch (mid) {
@ -273,7 +273,7 @@ static void uc9_fmlight()
break; break;
default: default:
m = NULL; /* allowing segfaults to debug in case of PJGlide64 bugs */ m = NULL; /* allowing segfaults to debug in case of PJGlide64 bugs */
FRDP_E("Invalid FM light matrix ID %u.\n", mid); WriteTrace(TraceRDP, TraceWarning, "Invalid FM light matrix ID %u.", mid);
break; break;
} }
@ -281,7 +281,7 @@ static void uc9_fmlight()
rdp.light[rdp.num_lights].g = (float)(((uint8_t*)gfx.DMEM)[(a + 1) ^ 3]) / 255.0f; rdp.light[rdp.num_lights].g = (float)(((uint8_t*)gfx.DMEM)[(a + 1) ^ 3]) / 255.0f;
rdp.light[rdp.num_lights].b = (float)(((uint8_t*)gfx.DMEM)[(a + 2) ^ 3]) / 255.0f; rdp.light[rdp.num_lights].b = (float)(((uint8_t*)gfx.DMEM)[(a + 2) ^ 3]) / 255.0f;
rdp.light[rdp.num_lights].a = 1.0f; rdp.light[rdp.num_lights].a = 1.0f;
FRDP("ambient light: r: %.3f, g: %.3f, b: %.3f\n", rdp.light[rdp.num_lights].r, rdp.light[rdp.num_lights].g, rdp.light[rdp.num_lights].b); WriteTrace(TraceRDP, TraceDebug, "ambient light: r: %.3f, g: %.3f, b: %.3f", rdp.light[rdp.num_lights].r, rdp.light[rdp.num_lights].g, rdp.light[rdp.num_lights].b);
a += 8; a += 8;
uint32_t i; uint32_t i;
for (i = 0; i < rdp.num_lights; i++) for (i = 0; i < rdp.num_lights; i++)
@ -293,13 +293,13 @@ static void uc9_fmlight()
rdp.light[i].dir_x = (float)(((char*)gfx.DMEM)[(a + 8) ^ 3]) / 127.0f; rdp.light[i].dir_x = (float)(((char*)gfx.DMEM)[(a + 8) ^ 3]) / 127.0f;
rdp.light[i].dir_y = (float)(((char*)gfx.DMEM)[(a + 9) ^ 3]) / 127.0f; rdp.light[i].dir_y = (float)(((char*)gfx.DMEM)[(a + 9) ^ 3]) / 127.0f;
rdp.light[i].dir_z = (float)(((char*)gfx.DMEM)[(a + 10) ^ 3]) / 127.0f; rdp.light[i].dir_z = (float)(((char*)gfx.DMEM)[(a + 10) ^ 3]) / 127.0f;
FRDP("light: n: %d, r: %.3f, g: %.3f, b: %.3f, x: %.3f, y: %.3f, z: %.3f\n", WriteTrace(TraceRDP, TraceDebug, "light: n: %d, r: %.3f, g: %.3f, b: %.3f, x: %.3f, y: %.3f, z: %.3f",
i, rdp.light[i].r, rdp.light[i].g, rdp.light[i].b, i, rdp.light[i].r, rdp.light[i].g, rdp.light[i].b,
rdp.light[i].dir_x, rdp.light[i].dir_y, rdp.light[i].dir_z); rdp.light[i].dir_x, rdp.light[i].dir_y, rdp.light[i].dir_z);
// TransformVector(&rdp.light[i].dir_x, rdp.light_vector[i], *m); // TransformVector(&rdp.light[i].dir_x, rdp.light_vector[i], *m);
InverseTransformVector(&rdp.light[i].dir_x, rdp.light_vector[i], *m); InverseTransformVector(&rdp.light[i].dir_x, rdp.light_vector[i], *m);
NormalizeVector(rdp.light_vector[i]); NormalizeVector(rdp.light_vector[i]);
FRDP("light vector: n: %d, x: %.3f, y: %.3f, z: %.3f\n", WriteTrace(TraceRDP, TraceDebug, "light vector: n: %d, x: %.3f, y: %.3f, z: %.3f",
i, rdp.light_vector[i][0], rdp.light_vector[i][1], rdp.light_vector[i][2]); i, rdp.light_vector[i][0], rdp.light_vector[i][1], rdp.light_vector[i][2]);
a += 24; a += 24;
} }
@ -330,7 +330,7 @@ static void uc9_light()
uint32_t tdest = -1024 + (rdp.cmd1 & 0xFFF); uint32_t tdest = -1024 + (rdp.cmd1 & 0xFFF);
int use_material = (csrs != 0x0ff0); int use_material = (csrs != 0x0ff0);
tdest >>= 1; tdest >>= 1;
FRDP("uc9:light n: %d, colsrs: %04lx, normales: %04lx, coldst: %04lx, texdst: %04lx\n", num, csrs, nsrs, cdest, tdest); WriteTrace(TraceRDP, TraceDebug, "uc9:light n: %d, colsrs: %04lx, normales: %04lx, coldst: %04lx, texdst: %04lx", num, csrs, nsrs, cdest, tdest);
VERTEX v; VERTEX v;
for (uint32_t i = 0; i < num; i++) for (uint32_t i = 0; i < num; i++)
{ {
@ -360,22 +360,22 @@ static void uc9_light()
static void uc9_mtxtrnsp() static void uc9_mtxtrnsp()
{ {
LRDP("uc9:mtxtrnsp - ignored\n"); WriteTrace(TraceRDP, TraceDebug, "uc9:mtxtrnsp - ignored");
/* /*
LRDP("uc9:mtxtrnsp "); WriteTrace(TraceRDP, TraceDebug, "uc9:mtxtrnsp ");
M44 *s; M44 *s;
switch (rdp.cmd1&0xF) { switch (rdp.cmd1&0xF) {
case 4: case 4:
s = (M44*)rdp.model; s = (M44*)rdp.model;
LRDP("Model\n"); WriteTrace(TraceRDP, TraceDebug, "Model");
break; break;
case 6: case 6:
s = (M44*)rdp.proj; s = (M44*)rdp.proj;
LRDP("Proj\n"); WriteTrace(TraceRDP, TraceDebug, "Proj");
break; break;
case 8: case 8:
s = (M44*)rdp.combined; s = (M44*)rdp.combined;
LRDP("Comb\n"); WriteTrace(TraceRDP, TraceDebug, "Comb");
break; break;
} }
float m = *s[1][0]; float m = *s[1][0];
@ -392,7 +392,7 @@ static void uc9_mtxtrnsp()
static void uc9_mtxcat() static void uc9_mtxcat()
{ {
LRDP("uc9:mtxcat "); WriteTrace(TraceRDP, TraceDebug, "uc9:mtxcat ");
M44 *s = NULL; M44 *s = NULL;
M44 *t = NULL; M44 *t = NULL;
uint32_t S = rdp.cmd0 & 0xF; uint32_t S = rdp.cmd0 & 0xF;
@ -401,36 +401,36 @@ static void uc9_mtxcat()
switch (S) { switch (S) {
case 4: case 4:
s = (M44*)rdp.model; s = (M44*)rdp.model;
LRDP("Model * "); WriteTrace(TraceRDP, TraceDebug, "Model * ");
break; break;
case 6: case 6:
s = (M44*)rdp.proj; s = (M44*)rdp.proj;
LRDP("Proj * "); WriteTrace(TraceRDP, TraceDebug, "Proj * ");
break; break;
case 8: case 8:
s = (M44*)rdp.combined; s = (M44*)rdp.combined;
LRDP("Comb * "); WriteTrace(TraceRDP, TraceDebug, "Comb * ");
break; break;
default: default:
FRDP_E("Invalid mutex S-coordinate: %u\n", S); WriteTrace(TraceRDP, TraceWarning, "Invalid mutex S-coordinate: %u", S);
s = NULL; /* intentional segfault to alert for bugs in PJGlide64 (cxd4) */ s = NULL; /* intentional segfault to alert for bugs in PJGlide64 (cxd4) */
break; break;
} }
switch (T) { switch (T) {
case 4: case 4:
t = (M44*)rdp.model; t = (M44*)rdp.model;
LRDP("Model -> "); WriteTrace(TraceRDP, TraceDebug, "Model -> ");
break; break;
case 6: case 6:
t = (M44*)rdp.proj; t = (M44*)rdp.proj;
LRDP("Proj -> "); WriteTrace(TraceRDP, TraceDebug, "Proj -> ");
break; break;
case 8: case 8:
LRDP("Comb -> "); WriteTrace(TraceRDP, TraceDebug, "Comb -> ");
t = (M44*)rdp.combined; t = (M44*)rdp.combined;
break; break;
default: default:
FRDP_E("Invalid mutex T-coordinate: %u\n", T); WriteTrace(TraceRDP, TraceWarning, "Invalid mutex T-coordinate: %u", T);
t = NULL; /* intentional segfault to alert for bugs in PJGlide64 (cxd4) */ t = NULL; /* intentional segfault to alert for bugs in PJGlide64 (cxd4) */
break; break;
} }
@ -440,31 +440,29 @@ static void uc9_mtxcat()
switch (D) { switch (D) {
case 4: case 4:
memcpy(rdp.model, m, 64);; memcpy(rdp.model, m, 64);;
LRDP("Model\n"); WriteTrace(TraceRDP, TraceDebug, "Model");
break; break;
case 6: case 6:
memcpy(rdp.proj, m, 64);; memcpy(rdp.proj, m, 64);;
LRDP("Proj\n"); WriteTrace(TraceRDP, TraceDebug, "Proj");
break; break;
case 8: case 8:
memcpy(rdp.combined, m, 64);; memcpy(rdp.combined, m, 64);;
LRDP("Comb\n"); WriteTrace(TraceRDP, TraceDebug, "Comb");
break; break;
} }
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "\nmodel\n{%f,%f,%f,%f}", rdp.model[0][0], rdp.model[0][1], rdp.model[0][2], rdp.model[0][3]);
FRDP ("\nmodel\n{%f,%f,%f,%f}\n", rdp.model[0][0], rdp.model[0][1], rdp.model[0][2], rdp.model[0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.model[1][0], rdp.model[1][1], rdp.model[1][2], rdp.model[1][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.model[1][0], rdp.model[1][1], rdp.model[1][2], rdp.model[1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.model[2][0], rdp.model[2][1], rdp.model[2][2], rdp.model[2][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.model[2][0], rdp.model[2][1], rdp.model[2][2], rdp.model[2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.model[3][0], rdp.model[3][1], rdp.model[3][2], rdp.model[3][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.model[3][0], rdp.model[3][1], rdp.model[3][2], rdp.model[3][3]); WriteTrace(TraceRDP, TraceVerbose, "\nproj\n{%f,%f,%f,%f}", rdp.proj[0][0], rdp.proj[0][1], rdp.proj[0][2], rdp.proj[0][3]);
FRDP ("\nproj\n{%f,%f,%f,%f}\n", rdp.proj[0][0], rdp.proj[0][1], rdp.proj[0][2], rdp.proj[0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.proj[1][0], rdp.proj[1][1], rdp.proj[1][2], rdp.proj[1][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.proj[1][0], rdp.proj[1][1], rdp.proj[1][2], rdp.proj[1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.proj[2][0], rdp.proj[2][1], rdp.proj[2][2], rdp.proj[2][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.proj[2][0], rdp.proj[2][1], rdp.proj[2][2], rdp.proj[2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.proj[3][0], rdp.proj[3][1], rdp.proj[3][2], rdp.proj[3][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.proj[3][0], rdp.proj[3][1], rdp.proj[3][2], rdp.proj[3][3]); WriteTrace(TraceRDP, TraceVerbose, "\ncombined\n{%f,%f,%f,%f}", rdp.combined[0][0], rdp.combined[0][1], rdp.combined[0][2], rdp.combined[0][3]);
FRDP ("\ncombined\n{%f,%f,%f,%f}\n", rdp.combined[0][0], rdp.combined[0][1], rdp.combined[0][2], rdp.combined[0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.combined[1][0], rdp.combined[1][1], rdp.combined[1][2], rdp.combined[1][3]);
FRDP("{%f,%f,%f,%f}\n", rdp.combined[1][0], rdp.combined[1][1], rdp.combined[1][2], rdp.combined[1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.combined[2][0], rdp.combined[2][1], rdp.combined[2][2], rdp.combined[2][3]);
FRDP("{%f,%f,%f,%f}\n", rdp.combined[2][0], rdp.combined[2][1], rdp.combined[2][2], rdp.combined[2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.combined[3][0], rdp.combined[3][1], rdp.combined[3][2], rdp.combined[3][3]);
FRDP("{%f,%f,%f,%f}\n", rdp.combined[3][0], rdp.combined[3][1], rdp.combined[3][2], rdp.combined[3][3]);
#endif
} }
typedef struct { typedef struct {
@ -484,7 +482,7 @@ static void uc9_mult_mpmtx()
int num = 1 + ((rdp.cmd1 >> 24) & 0xFF); int num = 1 + ((rdp.cmd1 >> 24) & 0xFF);
int src = -1024 + ((rdp.cmd1 >> 12) & 0xFFF); int src = -1024 + ((rdp.cmd1 >> 12) & 0xFFF);
int dst = -1024 + (rdp.cmd1 & 0xFFF); int dst = -1024 + (rdp.cmd1 & 0xFFF);
FRDP("uc9:mult_mpmtx from: %04lx to: %04lx n: %d\n", src, dst, num); WriteTrace(TraceRDP, TraceDebug, "uc9:mult_mpmtx from: %04lx to: %04lx n: %d", src, dst, num);
short * saddr = (short*)(gfx.DMEM + src); short * saddr = (short*)(gfx.DMEM + src);
zSortVDest * daddr = (zSortVDest*)(gfx.DMEM + dst); zSortVDest * daddr = (zSortVDest*)(gfx.DMEM + dst);
int idx = 0; int idx = 0;
@ -528,38 +526,38 @@ static void uc9_mult_mpmtx()
daddr[i] = v; daddr[i] = v;
//memcpy(gfx.DMEM+dst+sizeof(zSortVDest)*i, &v, sizeof(zSortVDest)); //memcpy(gfx.DMEM+dst+sizeof(zSortVDest)*i, &v, sizeof(zSortVDest));
// FRDP("v%d x: %d, y: %d, z: %d -> sx: %d, sy: %d, w: %d, xi: %d, yi: %d, wi: %d, fog: %d\n", i, sx, sy, sz, v.sx, v.sy, v.invw, v.xi, v.yi, v.wi, v.fog); // WriteTrace(TraceRDP, TraceDebug, "v%d x: %d, y: %d, z: %d -> sx: %d, sy: %d, w: %d, xi: %d, yi: %d, wi: %d, fog: %d", i, sx, sy, sz, v.sx, v.sy, v.invw, v.xi, v.yi, v.wi, v.fog);
FRDP("v%d x: %d, y: %d, z: %d -> sx: %04lx, sy: %04lx, invw: %08lx - %f, xi: %04lx, yi: %04lx, wi: %04lx, fog: %04lx\n", i, sx, sy, sz, v.sx, v.sy, v.invw, w, v.xi, v.yi, v.wi, v.fog); WriteTrace(TraceRDP, TraceDebug, "v%d x: %d, y: %d, z: %d -> sx: %04lx, sy: %04lx, invw: %08lx - %f, xi: %04lx, yi: %04lx, wi: %04lx, fog: %04lx", i, sx, sy, sz, v.sx, v.sy, v.invw, w, v.xi, v.yi, v.wi, v.fog);
} }
} }
static void uc9_link_subdl() static void uc9_link_subdl()
{ {
LRDP("uc9:link_subdl IGNORED\n"); WriteTrace(TraceRDP, TraceDebug, "uc9:link_subdl IGNORED");
} }
static void uc9_set_subdl() static void uc9_set_subdl()
{ {
LRDP("uc9:set_subdl IGNORED\n"); WriteTrace(TraceRDP, TraceDebug, "uc9:set_subdl IGNORED");
} }
static void uc9_wait_signal() static void uc9_wait_signal()
{ {
LRDP("uc9:wait_signal IGNORED\n"); WriteTrace(TraceRDP, TraceDebug, "uc9:wait_signal IGNORED");
} }
static void uc9_send_signal() static void uc9_send_signal()
{ {
LRDP("uc9:send_signal IGNORED\n"); WriteTrace(TraceRDP, TraceDebug, "uc9:send_signal IGNORED");
} }
void uc9_movemem() void uc9_movemem()
{ {
LRDP("uc9:movemem\n"); WriteTrace(TraceRDP, TraceDebug, "uc9:movemem");
int idx = rdp.cmd0 & 0x0E; int idx = rdp.cmd0 & 0x0E;
int ofs = ((rdp.cmd0 >> 6) & 0x1ff) << 3; int ofs = ((rdp.cmd0 >> 6) & 0x1ff) << 3;
int len = (1 + ((rdp.cmd0 >> 15) & 0x1ff)) << 3; int len = (1 + ((rdp.cmd0 >> 15) & 0x1ff)) << 3;
FRDP("uc9:movemem ofs: %d, len: %d. ", ofs, len); WriteTrace(TraceRDP, TraceDebug, "uc9:movemem ofs: %d, len: %d. ", ofs, len);
int flag = rdp.cmd0 & 0x01; int flag = rdp.cmd0 & 0x01;
uint32_t addr = segoffset(rdp.cmd1); uint32_t addr = segoffset(rdp.cmd1);
switch (idx) switch (idx)
@ -568,13 +566,13 @@ void uc9_movemem()
if (flag == 0) if (flag == 0)
{ {
int dmem_addr = (idx << 3) + ofs; int dmem_addr = (idx << 3) + ofs;
FRDP("Load to DMEM. %08lx -> %08lx\n", addr, dmem_addr); WriteTrace(TraceRDP, TraceDebug, "Load to DMEM. %08lx -> %08lx", addr, dmem_addr);
memcpy(gfx.DMEM + dmem_addr, gfx.RDRAM + addr, len); memcpy(gfx.DMEM + dmem_addr, gfx.RDRAM + addr, len);
} }
else else
{ {
int dmem_addr = (idx << 3) + ofs; int dmem_addr = (idx << 3) + ofs;
FRDP("Load from DMEM. %08lx -> %08lx\n", dmem_addr, addr); WriteTrace(TraceRDP, TraceDebug, "Load from DMEM. %08lx -> %08lx", dmem_addr, addr);
memcpy(gfx.RDRAM + addr, gfx.DMEM + dmem_addr, len); memcpy(gfx.RDRAM + addr, gfx.DMEM + dmem_addr, len);
} }
break; break;
@ -588,38 +586,36 @@ void uc9_movemem()
switch (idx) switch (idx)
{ {
case 4: // model matrix case 4: // model matrix
LRDP("Modelview load\n"); WriteTrace(TraceRDP, TraceDebug, "Modelview load");
modelview_load(m); modelview_load(m);
break; break;
case 6: // projection matrix case 6: // projection matrix
LRDP("Projection load\n"); WriteTrace(TraceRDP, TraceDebug, "Projection load");
projection_load(m); projection_load(m);
break; break;
case 8: // projection matrix case 8: // projection matrix
LRDP("Combined load\n"); WriteTrace(TraceRDP, TraceDebug, "Combined load");
rdp.update &= ~UPDATE_MULT_MAT; rdp.update &= ~UPDATE_MULT_MAT;
memcpy(rdp.combined, m, 64);; memcpy(rdp.combined, m, 64);;
break; break;
} }
#ifdef EXTREME_LOGGING WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", m[0][0], m[0][1], m[0][2], m[0][3]);
FRDP ("{%f,%f,%f,%f}\n", m[0][0], m[0][1], m[0][2], m[0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", m[1][0], m[1][1], m[1][2], m[1][3]);
FRDP ("{%f,%f,%f,%f}\n", m[1][0], m[1][1], m[1][2], m[1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", m[2][0], m[2][1], m[2][2], m[2][3]);
FRDP ("{%f,%f,%f,%f}\n", m[2][0], m[2][1], m[2][2], m[2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", m[3][0], m[3][1], m[3][2], m[3][3]);
FRDP ("{%f,%f,%f,%f}\n", m[3][0], m[3][1], m[3][2], m[3][3]); WriteTrace(TraceRDP, TraceVerbose, "\nmodel\n{%f,%f,%f,%f}", rdp.model[0][0], rdp.model[0][1], rdp.model[0][2], rdp.model[0][3]);
FRDP ("\nmodel\n{%f,%f,%f,%f}\n", rdp.model[0][0], rdp.model[0][1], rdp.model[0][2], rdp.model[0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.model[1][0], rdp.model[1][1], rdp.model[1][2], rdp.model[1][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.model[1][0], rdp.model[1][1], rdp.model[1][2], rdp.model[1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.model[2][0], rdp.model[2][1], rdp.model[2][2], rdp.model[2][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.model[2][0], rdp.model[2][1], rdp.model[2][2], rdp.model[2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.model[3][0], rdp.model[3][1], rdp.model[3][2], rdp.model[3][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.model[3][0], rdp.model[3][1], rdp.model[3][2], rdp.model[3][3]); WriteTrace(TraceRDP, TraceVerbose, "\nproj\n{%f,%f,%f,%f}", rdp.proj[0][0], rdp.proj[0][1], rdp.proj[0][2], rdp.proj[0][3]);
FRDP ("\nproj\n{%f,%f,%f,%f}\n", rdp.proj[0][0], rdp.proj[0][1], rdp.proj[0][2], rdp.proj[0][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.proj[1][0], rdp.proj[1][1], rdp.proj[1][2], rdp.proj[1][3]);
FRDP ("{%f,%f,%f,%f}\n", rdp.proj[1][0], rdp.proj[1][1], rdp.proj[1][2], rdp.proj[1][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.proj[2][0], rdp.proj[2][1], rdp.proj[2][2], rdp.proj[2][3]);
FRDP("{%f,%f,%f,%f}\n", rdp.proj[2][0], rdp.proj[2][1], rdp.proj[2][2], rdp.proj[2][3]); WriteTrace(TraceRDP, TraceVerbose, "{%f,%f,%f,%f}", rdp.proj[3][0], rdp.proj[3][1], rdp.proj[3][2], rdp.proj[3][3]);
FRDP("{%f,%f,%f,%f}\n", rdp.proj[3][0], rdp.proj[3][1], rdp.proj[3][2], rdp.proj[3][3]);
#endif
} }
break; break;
case 10: case 10:
LRDP("Othermode - IGNORED\n"); WriteTrace(TraceRDP, TraceDebug, "Othermode - IGNORED");
break; break;
case 12: // VIEWPORT case 12: // VIEWPORT
@ -659,14 +655,14 @@ void uc9_movemem()
rdp.geom_mode |= 0x0200; rdp.geom_mode |= 0x0200;
FRDP("viewport scale(%d, %d, %d), trans(%d, %d, %d), from:%08lx\n", scale_x, scale_y, scale_z, WriteTrace(TraceRDP, TraceDebug, "viewport scale(%d, %d, %d), trans(%d, %d, %d), from:%08lx", scale_x, scale_y, scale_z,
trans_x, trans_y, trans_z, a); trans_x, trans_y, trans_z, a);
FRDP("fog: multiplier: %f, offset: %f\n", rdp.fog_multiplier, rdp.fog_offset); WriteTrace(TraceRDP, TraceDebug, "fog: multiplier: %f, offset: %f", rdp.fog_multiplier, rdp.fog_offset);
} }
break; break;
default: default:
FRDP("** UNKNOWN %d\n", idx); WriteTrace(TraceRDP, TraceDebug, "** UNKNOWN %d", idx);
} }
} }

View File

@ -44,7 +44,7 @@
void uc9_rpdcmd() void uc9_rpdcmd()
{ {
uint32_t a = segoffset(rdp.cmd1) >> 2; uint32_t a = segoffset(rdp.cmd1) >> 2;
FRDP("uc9:rdpcmd addr: %08lx\n", a); WriteTrace(TraceRDP, TraceDebug, "uc9:rdpcmd addr: %08lx", a);
if (a) if (a)
{ {
rdp.LLE = 1; rdp.LLE = 1;

View File

@ -69,7 +69,7 @@ static void fb_bg_copy()
uint8_t imageFmt = ((uint8_t *)gfx.RDRAM)[(((addr + 11) << 1) + 0) ^ 3]; uint8_t imageFmt = ((uint8_t *)gfx.RDRAM)[(((addr + 11) << 1) + 0) ^ 3];
uint8_t imageSiz = ((uint8_t *)gfx.RDRAM)[(((addr + 11) << 1) + 1) ^ 3]; uint8_t imageSiz = ((uint8_t *)gfx.RDRAM)[(((addr + 11) << 1) + 1) ^ 3];
uint32_t imagePtr = segoffset(((uint32_t*)gfx.RDRAM)[(addr + 8) >> 1]); uint32_t imagePtr = segoffset(((uint32_t*)gfx.RDRAM)[(addr + 8) >> 1]);
FRDP("fb_bg_copy. fmt: %d, size: %d, imagePtr %08lx, main_ci: %08lx, cur_ci: %08lx \n", imageFmt, imageSiz, imagePtr, rdp.main_ci, rdp.frame_buffers[rdp.ci_count - 1].addr); WriteTrace(TraceRDP, TraceDebug, "fb_bg_copy. fmt: %d, size: %d, imagePtr %08lx, main_ci: %08lx, cur_ci: %08lx ", imageFmt, imageSiz, imagePtr, rdp.main_ci, rdp.frame_buffers[rdp.ci_count - 1].addr);
if (status == ci_main) if (status == ci_main)
{ {
@ -82,7 +82,7 @@ static void fb_bg_copy()
{ {
rdp.copy_ci_index = rdp.ci_count - 1; rdp.copy_ci_index = rdp.ci_count - 1;
rdp.frame_buffers[rdp.copy_ci_index].status = ci_copy; rdp.frame_buffers[rdp.copy_ci_index].status = ci_copy;
FRDP("rdp.frame_buffers[%d].status = ci_copy\n", rdp.copy_ci_index); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_copy", rdp.copy_ci_index);
if (rdp.frame_buffers[rdp.copy_ci_index].addr != rdp.main_ci_bg) if (rdp.frame_buffers[rdp.copy_ci_index].addr != rdp.main_ci_bg)
{ {
@ -91,11 +91,11 @@ static void fb_bg_copy()
} }
else else
{ {
LRDP("motion blur!\n"); WriteTrace(TraceRDP, TraceDebug, "motion blur!");
rdp.motionblur = TRUE; rdp.motionblur = TRUE;
} }
FRDP("Detect FB usage. texture addr is inside framebuffer: %08lx - %08lx \n", imagePtr, rdp.main_ci); WriteTrace(TraceRDP, TraceDebug, "Detect FB usage. texture addr is inside framebuffer: %08lx - %08lx ", imagePtr, rdp.main_ci);
} }
else if (imagePtr == rdp.zimg) else if (imagePtr == rdp.zimg)
{ {
@ -105,7 +105,7 @@ static void fb_bg_copy()
rdp.tmpzimg = rdp.frame_buffers[rdp.ci_count - 1].addr; rdp.tmpzimg = rdp.frame_buffers[rdp.ci_count - 1].addr;
if (!rdp.copy_zi_index) if (!rdp.copy_zi_index)
rdp.copy_zi_index = rdp.ci_count - 1; rdp.copy_zi_index = rdp.ci_count - 1;
FRDP("rdp.frame_buffers[%d].status = ci_zcopy\n", rdp.copy_ci_index); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_zcopy", rdp.copy_ci_index);
} }
} }
} }
@ -123,7 +123,7 @@ static void fb_setscissor()
if (cur_fb.height == 0 || (cur_fb.width >= rdp.scissor_o.lr_x - 1 && cur_fb.width <= rdp.scissor_o.lr_x + 1)) if (cur_fb.height == 0 || (cur_fb.width >= rdp.scissor_o.lr_x - 1 && cur_fb.width <= rdp.scissor_o.lr_x + 1))
cur_fb.height = rdp.scissor_o.lr_y; cur_fb.height = rdp.scissor_o.lr_y;
} }
FRDP("fb_setscissor. lr_x = %d, lr_y = %d, fb_width = %d, fb_height = %d\n", rdp.scissor_o.lr_x, rdp.scissor_o.lr_y, cur_fb.width, cur_fb.height); WriteTrace(TraceRDP, TraceDebug, "fb_setscissor. lr_x = %d, lr_y = %d, fb_width = %d, fb_height = %d", rdp.scissor_o.lr_x, rdp.scissor_o.lr_y, cur_fb.width, cur_fb.height);
} }
} }
@ -159,7 +159,7 @@ static void fb_rect()
uint32_t lr_y = minval(rdp.scissor_o.lr_y, (rdp.cmd0 & 0xFFF) >> 2); uint32_t lr_y = minval(rdp.scissor_o.lr_y, (rdp.cmd0 & 0xFFF) >> 2);
if (rdp.frame_buffers[rdp.ci_count - 1].height < lr_y) if (rdp.frame_buffers[rdp.ci_count - 1].height < lr_y)
{ {
FRDP("fb_rect. ul_x: %d, lr_x: %d, fb_height: %d -> %d\n", ul_x, lr_x, rdp.frame_buffers[rdp.ci_count - 1].height, lr_y); WriteTrace(TraceRDP, TraceDebug, "fb_rect. ul_x: %d, lr_x: %d, fb_height: %d -> %d", ul_x, lr_x, rdp.frame_buffers[rdp.ci_count - 1].height, lr_y);
rdp.frame_buffers[rdp.ci_count - 1].height = lr_y; rdp.frame_buffers[rdp.ci_count - 1].height = lr_y;
} }
} }
@ -183,7 +183,7 @@ static void fb_settextureimage()
uint32_t addr = segoffset(rdp.cmd1); uint32_t addr = segoffset(rdp.cmd1);
if (tex_format == 0) if (tex_format == 0)
{ {
FRDP("fb_settextureimage. fmt: %d, size: %d, imagePtr %08lx, main_ci: %08lx, cur_ci: %08lx \n", ((rdp.cmd0 >> 21) & 0x07), ((rdp.cmd0 >> 19) & 0x03), addr, rdp.main_ci, rdp.frame_buffers[rdp.ci_count - 1].addr); WriteTrace(TraceRDP, TraceDebug, "fb_settextureimage. fmt: %d, size: %d, imagePtr %08lx, main_ci: %08lx, cur_ci: %08lx ", ((rdp.cmd0 >> 21) & 0x07), ((rdp.cmd0 >> 19) & 0x03), addr, rdp.main_ci, rdp.frame_buffers[rdp.ci_count - 1].addr);
if (cur_fb.status == ci_main) if (cur_fb.status == ci_main)
{ {
rdp.main_ci_last_tex_addr = addr; rdp.main_ci_last_tex_addr = addr;
@ -201,7 +201,7 @@ static void fb_settextureimage()
cur_fb.status = ci_copy_self; cur_fb.status = ci_copy_self;
rdp.scale_x = rdp.scale_x_bak; rdp.scale_x = rdp.scale_x_bak;
rdp.scale_y = rdp.scale_y_bak; rdp.scale_y = rdp.scale_y_bak;
FRDP("rdp.frame_buffers[%d].status = ci_copy_self\n", rdp.ci_count - 1); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_copy_self", rdp.ci_count - 1);
} }
else else
{ {
@ -209,11 +209,11 @@ static void fb_settextureimage()
{ {
rdp.copy_ci_index = rdp.ci_count - 1; rdp.copy_ci_index = rdp.ci_count - 1;
cur_fb.status = ci_copy; cur_fb.status = ci_copy;
FRDP("rdp.frame_buffers[%d].status = ci_copy\n", rdp.copy_ci_index); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_copy", rdp.copy_ci_index);
if ((rdp.main_ci_last_tex_addr >= cur_fb.addr) && if ((rdp.main_ci_last_tex_addr >= cur_fb.addr) &&
(rdp.main_ci_last_tex_addr < (cur_fb.addr + cur_fb.width*cur_fb.height*cur_fb.size))) (rdp.main_ci_last_tex_addr < (cur_fb.addr + cur_fb.width*cur_fb.height*cur_fb.size)))
{ {
LRDP("motion blur!\n"); WriteTrace(TraceRDP, TraceDebug, "motion blur!");
rdp.motionblur = TRUE; rdp.motionblur = TRUE;
} }
else else
@ -226,17 +226,17 @@ static void fb_settextureimage()
{ {
rdp.copy_ci_index = rdp.ci_count - 1; rdp.copy_ci_index = rdp.ci_count - 1;
cur_fb.status = ci_aux_copy; cur_fb.status = ci_aux_copy;
FRDP("rdp.frame_buffers[%d].status = ci_aux_copy\n", rdp.copy_ci_index); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_aux_copy", rdp.copy_ci_index);
rdp.scale_x = 1.0f; rdp.scale_x = 1.0f;
rdp.scale_y = 1.0f; rdp.scale_y = 1.0f;
} }
else else
{ {
cur_fb.status = ci_aux; cur_fb.status = ci_aux;
FRDP("rdp.frame_buffers[%d].status = ci_aux\n", rdp.copy_ci_index); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_aux", rdp.copy_ci_index);
} }
} }
FRDP("Detect FB usage. texture addr is inside framebuffer: %08lx - %08lx \n", addr, rdp.main_ci); WriteTrace(TraceRDP, TraceDebug, "Detect FB usage. texture addr is inside framebuffer: %08lx - %08lx ", addr, rdp.main_ci);
} }
///* ///*
else if ((cur_fb.status != ci_main) && (addr >= rdp.zimg && addr < rdp.zimg_end)) else if ((cur_fb.status != ci_main) && (addr >= rdp.zimg && addr < rdp.zimg_end))
@ -244,7 +244,7 @@ static void fb_settextureimage()
cur_fb.status = ci_zcopy; cur_fb.status = ci_zcopy;
if (!rdp.copy_zi_index) if (!rdp.copy_zi_index)
rdp.copy_zi_index = rdp.ci_count - 1; rdp.copy_zi_index = rdp.ci_count - 1;
FRDP("fb_settextureimage. rdp.frame_buffers[%d].status = ci_zcopy\n", rdp.ci_count - 1); WriteTrace(TraceRDP, TraceDebug, "fb_settextureimage. rdp.frame_buffers[%d].status = ci_zcopy", rdp.ci_count - 1);
} }
//*/ //*/
else if ((rdp.maincimg[0].width > 64) && (addr >= rdp.maincimg[0].addr) && (addr < (rdp.maincimg[0].addr + rdp.maincimg[0].width*rdp.maincimg[0].height * 2))) else if ((rdp.maincimg[0].width > 64) && (addr >= rdp.maincimg[0].addr) && (addr < (rdp.maincimg[0].addr + rdp.maincimg[0].width*rdp.maincimg[0].height * 2)))
@ -252,20 +252,20 @@ static void fb_settextureimage()
if (cur_fb.status != ci_main) if (cur_fb.status != ci_main)
{ {
cur_fb.status = ci_old_copy; cur_fb.status = ci_old_copy;
FRDP("rdp.frame_buffers[%d].status = ci_old_copy 1, addr:%08lx\n", rdp.ci_count - 1, rdp.last_drawn_ci_addr); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_old_copy 1, addr:%08lx", rdp.ci_count - 1, rdp.last_drawn_ci_addr);
} }
rdp.read_previous_ci = TRUE; rdp.read_previous_ci = TRUE;
LRDP("read_previous_ci = TRUE\n"); WriteTrace(TraceRDP, TraceDebug, "read_previous_ci = TRUE");
} }
else if ((addr >= rdp.last_drawn_ci_addr) && (addr < (rdp.last_drawn_ci_addr + rdp.maincimg[0].width*rdp.maincimg[0].height * 2))) else if ((addr >= rdp.last_drawn_ci_addr) && (addr < (rdp.last_drawn_ci_addr + rdp.maincimg[0].width*rdp.maincimg[0].height * 2)))
{ {
if (cur_fb.status != ci_main) if (cur_fb.status != ci_main)
{ {
cur_fb.status = ci_old_copy; cur_fb.status = ci_old_copy;
FRDP("rdp.frame_buffers[%d].status = ci_old_copy 2, addr:%08lx\n", rdp.ci_count - 1, rdp.last_drawn_ci_addr); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_old_copy 2, addr:%08lx", rdp.ci_count - 1, rdp.last_drawn_ci_addr);
} }
rdp.read_previous_ci = TRUE; rdp.read_previous_ci = TRUE;
LRDP("read_previous_ci = TRUE\n"); WriteTrace(TraceRDP, TraceDebug, "read_previous_ci = TRUE");
} }
} }
else if (fb_hwfbe_enabled && (cur_fb.status == ci_main)) else if (fb_hwfbe_enabled && (cur_fb.status == ci_main))
@ -275,14 +275,14 @@ static void fb_settextureimage()
rdp.copy_ci_index = rdp.ci_count - 1; rdp.copy_ci_index = rdp.ci_count - 1;
rdp.black_ci_index = rdp.ci_count - 1; rdp.black_ci_index = rdp.ci_count - 1;
cur_fb.status = ci_copy_self; cur_fb.status = ci_copy_self;
FRDP("rdp.frame_buffers[%d].status = ci_copy_self\n", rdp.ci_count - 1); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_copy_self", rdp.ci_count - 1);
} }
} }
} }
if (cur_fb.status == ci_unknown) if (cur_fb.status == ci_unknown)
{ {
cur_fb.status = ci_aux; cur_fb.status = ci_aux;
FRDP("fb_settextureimage. rdp.frame_buffers[%d].status = ci_aux\n", rdp.ci_count - 1); WriteTrace(TraceRDP, TraceDebug, "fb_settextureimage. rdp.frame_buffers[%d].status = ci_aux", rdp.ci_count - 1);
} }
} }
@ -291,7 +291,7 @@ static void fb_loadtxtr()
if (rdp.frame_buffers[rdp.ci_count - 1].status == ci_unknown) if (rdp.frame_buffers[rdp.ci_count - 1].status == ci_unknown)
{ {
rdp.frame_buffers[rdp.ci_count - 1].status = ci_aux; rdp.frame_buffers[rdp.ci_count - 1].status = ci_aux;
FRDP("rdp.frame_buffers[%d].status = ci_aux\n", rdp.ci_count - 1); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_aux", rdp.ci_count - 1);
} }
} }
@ -299,17 +299,17 @@ static void fb_setdepthimage()
{ {
rdp.zimg = segoffset(rdp.cmd1) & BMASK; rdp.zimg = segoffset(rdp.cmd1) & BMASK;
rdp.zimg_end = rdp.zimg + rdp.ci_width*rdp.ci_height * 2; rdp.zimg_end = rdp.zimg + rdp.ci_width*rdp.ci_height * 2;
FRDP("fb_setdepthimage. addr %08lx - %08lx\n", rdp.zimg, rdp.zimg_end); WriteTrace(TraceRDP, TraceDebug, "fb_setdepthimage. addr %08lx - %08lx", rdp.zimg, rdp.zimg_end);
if (rdp.zimg == rdp.main_ci) //strange, but can happen if (rdp.zimg == rdp.main_ci) //strange, but can happen
{ {
rdp.frame_buffers[rdp.main_ci_index].status = ci_unknown; rdp.frame_buffers[rdp.main_ci_index].status = ci_unknown;
if (rdp.main_ci_index < rdp.ci_count) if (rdp.main_ci_index < rdp.ci_count)
{ {
rdp.frame_buffers[rdp.main_ci_index].status = ci_zimg; rdp.frame_buffers[rdp.main_ci_index].status = ci_zimg;
FRDP("rdp.frame_buffers[%d].status = ci_zimg\n", rdp.main_ci_index); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_zimg", rdp.main_ci_index);
rdp.main_ci_index++; rdp.main_ci_index++;
rdp.frame_buffers[rdp.main_ci_index].status = ci_main; rdp.frame_buffers[rdp.main_ci_index].status = ci_main;
FRDP("rdp.frame_buffers[%d].status = ci_main\n", rdp.main_ci_index); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_main", rdp.main_ci_index);
rdp.main_ci = rdp.frame_buffers[rdp.main_ci_index].addr; rdp.main_ci = rdp.frame_buffers[rdp.main_ci_index].addr;
rdp.main_ci_end = rdp.main_ci + (rdp.frame_buffers[rdp.main_ci_index].width * rdp.frame_buffers[rdp.main_ci_index].height * rdp.frame_buffers[rdp.main_ci_index].size); rdp.main_ci_end = rdp.main_ci + (rdp.frame_buffers[rdp.main_ci_index].width * rdp.frame_buffers[rdp.main_ci_index].height * rdp.frame_buffers[rdp.main_ci_index].size);
for (int i = rdp.main_ci_index + 1; i < rdp.ci_count; i++) for (int i = rdp.main_ci_index + 1; i < rdp.ci_count; i++)
@ -318,7 +318,7 @@ static void fb_setdepthimage()
if (fb.addr == rdp.main_ci) if (fb.addr == rdp.main_ci)
{ {
fb.status = ci_main; fb.status = ci_main;
FRDP("rdp.frame_buffers[%d].status = ci_main\n", i); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_main", i);
} }
} }
} }
@ -333,7 +333,7 @@ static void fb_setdepthimage()
if ((fb.addr == rdp.zimg) && (fb.status == ci_aux || fb.status == ci_useless)) if ((fb.addr == rdp.zimg) && (fb.status == ci_aux || fb.status == ci_useless))
{ {
fb.status = ci_zimg; fb.status = ci_zimg;
FRDP("rdp.frame_buffers[%d].status = ci_zimg\n", i); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_zimg", i);
} }
} }
} }
@ -361,19 +361,19 @@ static void fb_setcolorimage()
if (rdp.frame_buffers[0].addr == rdp.cimg) if (rdp.frame_buffers[0].addr == rdp.cimg)
rdp.frame_buffers[0].height = rdp.scissor_o.lr_y; rdp.frame_buffers[0].height = rdp.scissor_o.lr_y;
*/ */
FRDP("fb_setcolorimage. width: %d, height: %d, fmt: %d, size: %d, addr %08lx\n", cur_fb.width, cur_fb.height, cur_fb.format, cur_fb.size, cur_fb.addr); WriteTrace(TraceRDP, TraceDebug, "fb_setcolorimage. width: %d, height: %d, fmt: %d, size: %d, addr %08lx", cur_fb.width, cur_fb.height, cur_fb.format, cur_fb.size, cur_fb.addr);
if (rdp.cimg == rdp.zimg) if (rdp.cimg == rdp.zimg)
{ {
cur_fb.status = ci_zimg; cur_fb.status = ci_zimg;
rdp.zimg_end = rdp.zimg + cur_fb.width*rdp.scissor_o.lr_y * 2; rdp.zimg_end = rdp.zimg + cur_fb.width*rdp.scissor_o.lr_y * 2;
FRDP("rdp.frame_buffers[%d].status = ci_zimg\n", rdp.ci_count); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_zimg", rdp.ci_count);
} }
else if (rdp.cimg == rdp.tmpzimg) else if (rdp.cimg == rdp.tmpzimg)
{ {
cur_fb.status = ci_zcopy; cur_fb.status = ci_zcopy;
if (!rdp.copy_zi_index) if (!rdp.copy_zi_index)
rdp.copy_zi_index = rdp.ci_count - 1; rdp.copy_zi_index = rdp.ci_count - 1;
FRDP("rdp.frame_buffers[%d].status = ci_zcopy\n", rdp.ci_count); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_zcopy", rdp.ci_count);
} }
else if (rdp.main_ci != 0) else if (rdp.main_ci != 0)
{ {
@ -383,7 +383,7 @@ static void fb_setcolorimage()
rdp.main_ci_index = rdp.ci_count; rdp.main_ci_index = rdp.ci_count;
rdp.main_ci_end = rdp.cimg + ((cur_fb.width * cur_fb.height) << cur_fb.size >> 1); rdp.main_ci_end = rdp.cimg + ((cur_fb.width * cur_fb.height) << cur_fb.size >> 1);
cur_fb.status = ci_main; cur_fb.status = ci_main;
FRDP("rdp.frame_buffers[%d].status = ci_main\n", rdp.ci_count); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_main", rdp.ci_count);
} }
else // status is not known yet else // status is not known yet
{ {
@ -398,7 +398,7 @@ static void fb_setcolorimage()
rdp.main_ci_end = rdp.cimg + ((cur_fb.width * cur_fb.height) << cur_fb.size >> 1); rdp.main_ci_end = rdp.cimg + ((cur_fb.width * cur_fb.height) << cur_fb.size >> 1);
rdp.main_ci_index = rdp.ci_count; rdp.main_ci_index = rdp.ci_count;
cur_fb.status = ci_main; cur_fb.status = ci_main;
FRDP("rdp.frame_buffers[%d].status = ci_main\n", rdp.ci_count); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_main", rdp.ci_count);
} }
else else
{ {
@ -411,7 +411,7 @@ static void fb_setcolorimage()
{ {
rdp.frame_buffers[rdp.ci_count - 1].status = ci_aux; rdp.frame_buffers[rdp.ci_count - 1].status = ci_aux;
rdp.frame_buffers[rdp.ci_count - 1].changed = 0; rdp.frame_buffers[rdp.ci_count - 1].changed = 0;
FRDP("rdp.frame_buffers[%d].status = ci_aux\n", rdp.ci_count - 1); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = ci_aux", rdp.ci_count - 1);
} }
else else
{ {
@ -427,7 +427,7 @@ static void fb_setcolorimage()
} }
} }
//*/ //*/
FRDP("rdp.frame_buffers[%d].status = %s\n", rdp.ci_count - 1, CIStatus[rdp.frame_buffers[rdp.ci_count - 1].status]); WriteTrace(TraceRDP, TraceDebug, "rdp.frame_buffers[%d].status = %s", rdp.ci_count - 1, CIStatus[rdp.frame_buffers[rdp.ci_count - 1].status]);
} }
} }
if (cur_fb.status == ci_main) if (cur_fb.status == ci_main)