mirror of
https://github.com/libretro/ppsspp.git
synced 2025-03-04 22:49:46 +00:00
Merge pull request #1471 from unknownbrackets/gpu-minor
Small optimizations in the emulated GPU
This commit is contained in:
commit
6916e2f1bf
@ -497,6 +497,8 @@ void GLES_GPU::ExecuteOp(u32 op, u32 diff) {
|
||||
case GE_CMD_FRAMEBUFPTR:
|
||||
case GE_CMD_FRAMEBUFWIDTH:
|
||||
case GE_CMD_FRAMEBUFPIXFORMAT:
|
||||
if (diff)
|
||||
gstate_c.framebufChanged = true;
|
||||
break;
|
||||
|
||||
case GE_CMD_TEXADDR0:
|
||||
@ -693,6 +695,10 @@ void GLES_GPU::ExecuteOp(u32 op, u32 diff) {
|
||||
|
||||
case GE_CMD_VIEWPORTX1:
|
||||
case GE_CMD_VIEWPORTY1:
|
||||
if (diff)
|
||||
gstate_c.framebufChanged = true;
|
||||
break;
|
||||
|
||||
case GE_CMD_VIEWPORTX2:
|
||||
case GE_CMD_VIEWPORTY2:
|
||||
case GE_CMD_VIEWPORTZ1:
|
||||
|
@ -290,6 +290,12 @@ void GuessDrawingSize(int &drawing_width, int &drawing_height) {
|
||||
}
|
||||
|
||||
void FramebufferManager::SetRenderFrameBuffer() {
|
||||
if (!gstate_c.framebufChanged && currentRenderVfb_) {
|
||||
currentRenderVfb_->last_frame_used = gpuStats.numFrames;
|
||||
return;
|
||||
}
|
||||
gstate_c.framebufChanged = false;
|
||||
|
||||
// Get parameters
|
||||
u32 fb_address = (gstate.fbptr & 0xFFE000) | ((gstate.fbwidth & 0xFF0000) << 8);
|
||||
int fb_stride = gstate.fbwidth & 0x3C0;
|
||||
|
@ -4,6 +4,7 @@
|
||||
#include "GPUCommon.h"
|
||||
#include "GPUState.h"
|
||||
#include "ChunkFile.h"
|
||||
#include "Core/Config.h"
|
||||
#include "Core/CoreTiming.h"
|
||||
#include "Core/MemMap.h"
|
||||
#include "Core/Host.h"
|
||||
@ -359,12 +360,18 @@ u32 GPUCommon::Break(int mode)
|
||||
|
||||
bool GPUCommon::InterpretList(DisplayList &list)
|
||||
{
|
||||
// Initialized to avoid a race condition with bShowDebugStats changing.
|
||||
double start = 0.0;
|
||||
if (g_Config.bShowDebugStats)
|
||||
{
|
||||
time_update();
|
||||
start = time_now_d();
|
||||
}
|
||||
|
||||
// TODO: This has to be right... but it freezes right now?
|
||||
//if (list.state == PSP_GE_DL_STATE_PAUSED)
|
||||
// return false;
|
||||
|
||||
time_update();
|
||||
double start = time_now_d();
|
||||
currentList = &list;
|
||||
u32 op = 0;
|
||||
gpuState = GPUSTATE_RUNNING;
|
||||
@ -425,8 +432,11 @@ bool GPUCommon::InterpretList(DisplayList &list)
|
||||
|
||||
UpdateCycles(list.pc - 4, list.pc);
|
||||
|
||||
time_update();
|
||||
gpuStats.msProcessingDisplayLists += time_now_d() - start;
|
||||
if (g_Config.bShowDebugStats)
|
||||
{
|
||||
time_update();
|
||||
gpuStats.msProcessingDisplayLists += time_now_d() - start;
|
||||
}
|
||||
return gpuState == GPUSTATE_DONE || gpuState == GPUSTATE_ERROR;
|
||||
}
|
||||
|
||||
|
@ -252,6 +252,7 @@ struct GPUStateCache
|
||||
u32 offsetAddr;
|
||||
|
||||
bool textureChanged;
|
||||
bool framebufChanged;
|
||||
|
||||
int skipDrawReason;
|
||||
|
||||
|
363
GPU/GeDisasm.cpp
363
GPU/GeDisasm.cpp
@ -20,6 +20,61 @@
|
||||
#include "GPUState.h"
|
||||
#include "ge_constants.h"
|
||||
|
||||
void GeDescribeVertexType(u32 op, char *buffer, int len) {
|
||||
bool through = (op & GE_VTYPE_THROUGH_MASK) == GE_VTYPE_THROUGH;
|
||||
int tc = (op & GE_VTYPE_TC_MASK) >> GE_VTYPE_TC_SHIFT;
|
||||
int col = (op & GE_VTYPE_COL_MASK) >> GE_VTYPE_COL_SHIFT;
|
||||
int nrm = (op & GE_VTYPE_NRM_MASK) >> GE_VTYPE_NRM_SHIFT;
|
||||
int pos = (op & GE_VTYPE_POS_MASK) >> GE_VTYPE_POS_SHIFT;
|
||||
int weight = (op & GE_VTYPE_WEIGHT_MASK) >> GE_VTYPE_WEIGHT_SHIFT;
|
||||
int weightCount = (op & GE_VTYPE_WEIGHTCOUNT_MASK) >> GE_VTYPE_WEIGHTCOUNT_SHIFT;
|
||||
int morphCount = (op & GE_VTYPE_MORPHCOUNT_MASK) >> GE_VTYPE_MORPHCOUNT_SHIFT;
|
||||
int idx = (op & GE_VTYPE_IDX_MASK) >> GE_VTYPE_IDX_SHIFT;
|
||||
|
||||
static const char *colorNames[] = {
|
||||
NULL,
|
||||
"unsupported1",
|
||||
"unsupported2",
|
||||
"unsupported3",
|
||||
"BGR 565",
|
||||
"ABGR 1555",
|
||||
"ABGR 4444",
|
||||
"ABGR 8888",
|
||||
};
|
||||
static const char *typeNames[] = {
|
||||
NULL,
|
||||
"u8",
|
||||
"u16",
|
||||
"float",
|
||||
};
|
||||
|
||||
char *w = buffer, *end = buffer + len;
|
||||
if (through)
|
||||
w += snprintf(w, end - w, "through, ");
|
||||
if (typeNames[tc])
|
||||
w += snprintf(w, end - w, "%s UVs, ", typeNames[tc]);
|
||||
if (colorNames[col])
|
||||
w += snprintf(w, end - w, "%s colors, ", colorNames[col]);
|
||||
if (typeNames[nrm])
|
||||
w += snprintf(w, end - w, "%s normals, ", typeNames[nrm]);
|
||||
if (typeNames[pos])
|
||||
w += snprintf(w, end - w, "%s coords, ", typeNames[pos]);
|
||||
if (typeNames[weight])
|
||||
w += snprintf(w, end - w, "%s weights (%d), ", typeNames[weight], weightCount);
|
||||
else if (weightCount > 0)
|
||||
w += snprintf(w, end - w, "unknown weights (%d), ", weightCount);
|
||||
if (morphCount > 0)
|
||||
w += snprintf(w, end - w, "%d morphs, ", morphCount);
|
||||
if (typeNames[idx])
|
||||
w += snprintf(w, end - w, "%s indexes, ", typeNames[idx]);
|
||||
|
||||
if (w < buffer + 2)
|
||||
snprintf(buffer, len, "none");
|
||||
// Otherwise, get rid of the pesky trailing comma.
|
||||
else
|
||||
w[-2] = '\0';
|
||||
}
|
||||
|
||||
void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
u32 cmd = op >> 24;
|
||||
u32 data = op & 0xFFFFFF;
|
||||
@ -27,16 +82,23 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
// Handle control and drawing commands here directly. The others we delegate.
|
||||
switch (cmd)
|
||||
{
|
||||
case GE_CMD_BASE:
|
||||
sprintf(buffer, "BASE: %06x", data & 0xFFFFFF);
|
||||
case GE_CMD_NOP:
|
||||
if (data != 0)
|
||||
sprintf(buffer, "NOP: %06x", data);
|
||||
else
|
||||
sprintf(buffer, "NOP", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_VADDR: /// <<8????
|
||||
sprintf(buffer, "VADDR: %06x", gstate_c.vertexAddr);
|
||||
case GE_CMD_BASE:
|
||||
sprintf(buffer, "BASE: %06x", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_VADDR:
|
||||
sprintf(buffer, "VADDR: %06x => %08x", data, gstate_c.getRelativeAddress(data));
|
||||
break;
|
||||
|
||||
case GE_CMD_IADDR:
|
||||
sprintf(buffer, "IADDR: %06x", gstate_c.indexAddr);
|
||||
sprintf(buffer, "IADDR: %06x => %08x", data, gstate_c.getRelativeAddress(data));
|
||||
break;
|
||||
|
||||
case GE_CMD_PRIM:
|
||||
@ -64,7 +126,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
{
|
||||
int bz_ucount = data & 0xFF;
|
||||
int bz_vcount = (data >> 8) & 0xFF;
|
||||
sprintf(buffer, "DRAW BEZIER: %i x %i", bz_ucount, bz_vcount);
|
||||
if (data & 0xFF0000)
|
||||
sprintf(buffer, "DRAW BEZIER: %i x %i (extra %x)", bz_ucount, bz_vcount, data >> 16);
|
||||
else
|
||||
sprintf(buffer, "DRAW BEZIER: %i x %i", bz_ucount, bz_vcount);
|
||||
}
|
||||
break;
|
||||
|
||||
@ -74,7 +139,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
int sp_vcount = (data >> 8) & 0xFF;
|
||||
int sp_utype = (data >> 16) & 0x3;
|
||||
int sp_vtype = (data >> 18) & 0x3;
|
||||
sprintf(buffer, "DRAW SPLINE: %i x %i, %i x %i", sp_ucount, sp_vcount, sp_utype, sp_vtype);
|
||||
if (data & 0xF00000)
|
||||
sprintf(buffer, "DRAW SPLINE: %i x %i, %i x %i (extra %x)", sp_ucount, sp_vcount, sp_utype, sp_vtype, data >> 20);
|
||||
else
|
||||
sprintf(buffer, "DRAW SPLINE: %i x %i, %i x %i", sp_ucount, sp_vcount, sp_utype, sp_vtype);
|
||||
}
|
||||
break;
|
||||
|
||||
@ -94,7 +162,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_RET:
|
||||
sprintf(buffer, "CMD RET");
|
||||
if (data)
|
||||
sprintf(buffer, "CMD RET: %06x", data);
|
||||
else
|
||||
sprintf(buffer, "CMD RET");
|
||||
break;
|
||||
|
||||
case GE_CMD_SIGNAL:
|
||||
@ -106,57 +177,64 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_END:
|
||||
sprintf(buffer, "CMD END");
|
||||
switch (prev >> 24)
|
||||
{
|
||||
case GE_CMD_SIGNAL:
|
||||
{
|
||||
sprintf(buffer, "CMD END - ");
|
||||
// TODO: see http://code.google.com/p/jpcsp/source/detail?r=2935#
|
||||
int behaviour = (prev >> 16) & 0xFF;
|
||||
int signal = prev & 0xFFFF;
|
||||
int enddata = data & 0xFFFF;
|
||||
int enddata = data & 0xFFFFFF;
|
||||
// We should probably defer to sceGe here, no sense in implementing this stuff in every GPU
|
||||
switch (behaviour) {
|
||||
case 1: // Signal with Wait
|
||||
sprintf(buffer, "Signal with Wait UNIMPLEMENTED! signal/end: %04x %04x", signal, enddata);
|
||||
case 1:
|
||||
sprintf(buffer, "Signal with wait. signal/end: %04x %04x", signal, enddata);
|
||||
break;
|
||||
case 2:
|
||||
sprintf(buffer, "Signal without wait. signal/end: %04x %04x", signal, enddata);
|
||||
break;
|
||||
case 3:
|
||||
sprintf(buffer, "Signal with Pause UNIMPLEMENTED! signal/end: %04x %04x", signal, enddata);
|
||||
sprintf(buffer, "Signal with pause. signal/end: %04x %04x", signal, enddata);
|
||||
break;
|
||||
case 8:
|
||||
sprintf(buffer, "Signal with sync. signal/end: %04x %04x", signal, enddata);
|
||||
break;
|
||||
case 0x10:
|
||||
sprintf(buffer, "Signal with Jump UNIMPLEMENTED! signal/end: %04x %04x", signal, enddata);
|
||||
sprintf(buffer, "Signal with jump. signal/end: %04x %04x", signal, enddata);
|
||||
break;
|
||||
case 0x11:
|
||||
sprintf(buffer, "Signal with Call UNIMPLEMENTED! signal/end: %04x %04x", signal, enddata);
|
||||
sprintf(buffer, "Signal with call. signal/end: %04x %04x", signal, enddata);
|
||||
break;
|
||||
case 0x12:
|
||||
sprintf(buffer, "Signal with Return UNIMPLEMENTED! signal/end: %04x %04x", signal, enddata);
|
||||
sprintf(buffer, "Signal with return. signal/end: %04x %04x", signal, enddata);
|
||||
break;
|
||||
default:
|
||||
sprintf(buffer, "UNKNOWN Signal UNIMPLEMENTED %i ! signal/end: %04x %04x", behaviour, signal, enddata);
|
||||
sprintf(buffer, "UNKNOWN Signal UNIMPLEMENTED %i! signal/end: %04x %04x", behaviour, signal, enddata);
|
||||
break;
|
||||
}
|
||||
}
|
||||
break;
|
||||
case GE_CMD_FINISH:
|
||||
if (data)
|
||||
sprintf(buffer, "CMD END: %06x", data);
|
||||
else
|
||||
sprintf(buffer, "CMD END");
|
||||
break;
|
||||
default:
|
||||
sprintf(buffer, "Ah, not finished: %06x", prev & 0xFFFFFF);
|
||||
sprintf(buffer, "CMD END: %06x, not finished (%08x)", data, prev);
|
||||
break;
|
||||
}
|
||||
break;
|
||||
|
||||
case GE_CMD_BJUMP:
|
||||
// bounding box jump. Let's just not jump, for now.
|
||||
sprintf(buffer, "BBOX JUMP - unimplemented");
|
||||
sprintf(buffer, "BBOX JUMP - unimplemented: %06x", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_BOUNDINGBOX:
|
||||
// bounding box test. Let's do nothing.
|
||||
sprintf(buffer, "BBOX TEST - unimplemented");
|
||||
sprintf(buffer, "BBOX TEST - unimplemented: %06x", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_ORIGIN:
|
||||
@ -164,7 +242,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_VERTEXTYPE:
|
||||
sprintf(buffer, "SetVertexType: %06x", data);
|
||||
{
|
||||
int len = sprintf(buffer, "SetVertexType: ");
|
||||
GeDescribeVertexType(op, buffer + len, 256 - len);
|
||||
}
|
||||
break;
|
||||
|
||||
case GE_CMD_OFFSETADDR:
|
||||
@ -175,8 +256,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
{
|
||||
int x1 = data & 0x3ff;
|
||||
int y1 = data >> 10;
|
||||
//topleft
|
||||
sprintf(buffer, "Region TL: %d %d", x1, y1);
|
||||
if (data & 0xF00000)
|
||||
sprintf(buffer, "Region TL: %d %d (extra %x)", x1, y1, data >> 20);
|
||||
else
|
||||
sprintf(buffer, "Region TL: %d %d", x1, y1);
|
||||
}
|
||||
break;
|
||||
|
||||
@ -184,16 +267,19 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
{
|
||||
int x2 = data & 0x3ff;
|
||||
int y2 = data >> 10;
|
||||
sprintf(buffer, "Region BR: %d %d", x2, y2);
|
||||
if (data & 0xF00000)
|
||||
sprintf(buffer, "Region BR: %d %d (extra %x)", x2, y2, data >> 20);
|
||||
else
|
||||
sprintf(buffer, "Region BR: %d %d", x2, y2);
|
||||
}
|
||||
break;
|
||||
|
||||
case GE_CMD_CLIPENABLE:
|
||||
sprintf(buffer, "Clip Enable: %i", data);
|
||||
sprintf(buffer, "Clip enable: %i", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_CULLFACEENABLE:
|
||||
sprintf(buffer, "CullFace Enable: %i", data);
|
||||
sprintf(buffer, "CullFace enable: %i", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_TEXTUREMAPENABLE:
|
||||
@ -205,11 +291,11 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_FOGENABLE:
|
||||
sprintf(buffer, "Fog Enable: %i", data);
|
||||
sprintf(buffer, "Fog enable: %i", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_DITHERENABLE:
|
||||
sprintf(buffer, "Dither Enable: %i", data);
|
||||
sprintf(buffer, "Dither enable: %i", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_OFFSETX:
|
||||
@ -221,33 +307,39 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_TEXSCALEU:
|
||||
sprintf(buffer, "Texture U Scale: %f", gstate_c.uScale);
|
||||
sprintf(buffer, "Texture U scale: %f", getFloat24(data));
|
||||
break;
|
||||
|
||||
case GE_CMD_TEXSCALEV:
|
||||
sprintf(buffer, "Texture V Scale: %f", gstate_c.vScale);
|
||||
sprintf(buffer, "Texture V scale: %f", getFloat24(data));
|
||||
break;
|
||||
|
||||
case GE_CMD_TEXOFFSETU:
|
||||
sprintf(buffer, "Texture U Offset: %f", gstate_c.uOff);
|
||||
sprintf(buffer, "Texture U offset: %f", getFloat24(data));
|
||||
break;
|
||||
|
||||
case GE_CMD_TEXOFFSETV:
|
||||
sprintf(buffer, "Texture V Offset: %f", gstate_c.vOff);
|
||||
sprintf(buffer, "Texture V offset: %f", getFloat24(data));
|
||||
break;
|
||||
|
||||
case GE_CMD_SCISSOR1:
|
||||
{
|
||||
int x1 = data & 0x3ff;
|
||||
int y1 = data >> 10;
|
||||
sprintf(buffer, "Scissor TL: %i, %i", x1,y1);
|
||||
if (data & 0xF00000)
|
||||
sprintf(buffer, "Scissor TL: %i, %i (extra %x)", x1, y1, data >> 20);
|
||||
else
|
||||
sprintf(buffer, "Scissor TL: %i, %i", x1, y1);
|
||||
}
|
||||
break;
|
||||
case GE_CMD_SCISSOR2:
|
||||
{
|
||||
int x2 = data & 0x3ff;
|
||||
int y2 = data >> 10;
|
||||
sprintf(buffer, "Scissor BR: %i, %i", x2, y2);
|
||||
if (data & 0xF00000)
|
||||
sprintf(buffer, "Scissor BR: %i, %i (extra %x)", x2, y2, data >> 20);
|
||||
else
|
||||
sprintf(buffer, "Scissor BR: %i, %i", x2, y2);
|
||||
}
|
||||
break;
|
||||
|
||||
@ -268,7 +360,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
case GE_CMD_FRAMEBUFPTR:
|
||||
{
|
||||
u32 ptr = op & 0xFFE000;
|
||||
sprintf(buffer, "FramebufPtr: %08x", ptr);
|
||||
if (data & ~0xFFE000)
|
||||
sprintf(buffer, "FramebufPtr: %08x (extra %x)", ptr, data);
|
||||
else
|
||||
sprintf(buffer, "FramebufPtr: %08x", ptr);
|
||||
}
|
||||
break;
|
||||
|
||||
@ -314,7 +409,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
|
||||
case GE_CMD_LOADCLUT:
|
||||
// This could be used to "dirty" textures with clut.
|
||||
sprintf(buffer, "Clut load");
|
||||
if (data)
|
||||
sprintf(buffer, "Clut load: %06x", data);
|
||||
else
|
||||
sprintf(buffer, "Clut load");
|
||||
break;
|
||||
|
||||
case GE_CMD_TEXMAPMODE:
|
||||
@ -327,13 +425,19 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
|
||||
case GE_CMD_CLUTFORMAT:
|
||||
{
|
||||
sprintf(buffer, "Clut format: %06x", data);
|
||||
const char *clutformats[] = {
|
||||
"BGR 5650",
|
||||
"ABGR 1555",
|
||||
"ABGR 4444",
|
||||
"ABGR 8888",
|
||||
};
|
||||
sprintf(buffer, "Clut format: %06x (%s)", data, clutformats[data & 3]);
|
||||
}
|
||||
break;
|
||||
|
||||
case GE_CMD_TRANSFERSRC:
|
||||
{
|
||||
sprintf(buffer, "Block Transfer Src: %06x", data);
|
||||
sprintf(buffer, "Block transfer src: %06x", data);
|
||||
// Nothing to do, the next one prints
|
||||
}
|
||||
break;
|
||||
@ -342,14 +446,17 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
{
|
||||
u32 xferSrc = (gstate.transfersrc & 0x00FFFFFF) | ((data & 0xFF0000) << 8);
|
||||
u32 xferSrcW = gstate.transfersrcw & 1023;
|
||||
sprintf(buffer, "Block Transfer Src: %08x W: %i", xferSrc, xferSrcW);
|
||||
if (data & ~0xFF03FF)
|
||||
sprintf(buffer, "Block transfer src: %08x W: %i (extra %x)", xferSrc, xferSrcW, data);
|
||||
else
|
||||
sprintf(buffer, "Block transfer src: %08x W: %i", xferSrc, xferSrcW);
|
||||
break;
|
||||
}
|
||||
|
||||
case GE_CMD_TRANSFERDST:
|
||||
{
|
||||
// Nothing to do, the next one prints
|
||||
sprintf(buffer, "Block Transfer Dst: %06x", data);
|
||||
sprintf(buffer, "Block transfer dst: %06x", data);
|
||||
}
|
||||
break;
|
||||
|
||||
@ -357,7 +464,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
{
|
||||
u32 xferDst = (gstate.transferdst & 0x00FFFFFF) | ((data & 0xFF0000) << 8);
|
||||
u32 xferDstW = gstate.transferdstw & 1023;
|
||||
sprintf(buffer, "Block Transfer Dest: %08x W: %i", xferDst, xferDstW);
|
||||
if (data & ~0xFF03FF)
|
||||
sprintf(buffer, "Block transfer dest: %08x W: %i (extra %x)", xferDst, xferDstW, data);
|
||||
else
|
||||
sprintf(buffer, "Block transfer dest: %08x W: %i", xferDst, xferDstW);
|
||||
break;
|
||||
}
|
||||
|
||||
@ -365,7 +475,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
{
|
||||
u32 x = (data & 1023)+1;
|
||||
u32 y = ((data>>10) & 1023)+1;
|
||||
sprintf(buffer, "Block Transfer Src Rect TL: %i, %i", x, y);
|
||||
if (data & 0xF00000)
|
||||
sprintf(buffer, "Block transfer src rect TL: %i, %i (extra %x)", x, y, data >> 20);
|
||||
else
|
||||
sprintf(buffer, "Block transfer src rect TL: %i, %i", x, y);
|
||||
break;
|
||||
}
|
||||
|
||||
@ -373,7 +486,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
{
|
||||
u32 x = (data & 1023)+1;
|
||||
u32 y = ((data>>10) & 1023)+1;
|
||||
sprintf(buffer, "Block Transfer Dest Rect TL: %i, %i", x, y);
|
||||
if (data & 0xF00000)
|
||||
sprintf(buffer, "Block transfer dest rect TL: %i, %i (extra %x)", x, y, data >> 20);
|
||||
else
|
||||
sprintf(buffer, "Block transfer dest rect TL: %i, %i", x, y);
|
||||
break;
|
||||
}
|
||||
|
||||
@ -381,15 +497,19 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
{
|
||||
u32 w = (data & 1023)+1;
|
||||
u32 h = ((data>>10) & 1023)+1;
|
||||
sprintf(buffer, "Block Transfer Rect Size: %i x %i", w, h);
|
||||
if (data & 0xF00000)
|
||||
sprintf(buffer, "Block transfer rect size: %i x %i (extra %x)", w, h, data >> 20);
|
||||
else
|
||||
sprintf(buffer, "Block transfer rect size: %i x %i", w, h);
|
||||
break;
|
||||
}
|
||||
|
||||
case GE_CMD_TRANSFERSTART: // Orphis calls this TRXKICK
|
||||
{
|
||||
sprintf(buffer, "Block Transfer Start");
|
||||
break;
|
||||
}
|
||||
if (data)
|
||||
sprintf(buffer, "Block transfer start: %x", data);
|
||||
else
|
||||
sprintf(buffer, "Block transfer start");
|
||||
break;
|
||||
|
||||
case GE_CMD_TEXSIZE0:
|
||||
case GE_CMD_TEXSIZE1:
|
||||
@ -402,49 +522,50 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
{
|
||||
int w = 1 << (data & 0xf);
|
||||
int h = 1 << ((data>>8) & 0xf);
|
||||
sprintf(buffer, "Texture Size %i: %06x, width : %d, height : %d", cmd - GE_CMD_TEXSIZE0, data, w, h);
|
||||
sprintf(buffer, "Texture size %i: %06x, width : %d, height : %d", cmd - GE_CMD_TEXSIZE0, data, w, h);
|
||||
}
|
||||
break;
|
||||
|
||||
case GE_CMD_ZBUFPTR:
|
||||
{
|
||||
u32 ptr = op & 0xFFE000;
|
||||
sprintf(buffer, "Zbuf Ptr: %06x", ptr);
|
||||
if (data & ~0xFFE000)
|
||||
sprintf(buffer, "Zbuf ptr: %06x (extra %x)", ptr, data);
|
||||
else
|
||||
sprintf(buffer, "Zbuf ptr: %06x", ptr);
|
||||
}
|
||||
break;
|
||||
|
||||
case GE_CMD_ZBUFWIDTH:
|
||||
{
|
||||
sprintf(buffer, "Zbuf Width: %06x", data);
|
||||
}
|
||||
sprintf(buffer, "Zbuf width: %06x", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_AMBIENTCOLOR:
|
||||
sprintf(buffer, "Ambient Color: %06x", data);
|
||||
sprintf(buffer, "Ambient color: %06x", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_AMBIENTALPHA:
|
||||
sprintf(buffer, "Ambient Alpha: %06x", data);
|
||||
sprintf(buffer, "Ambient alpha: %06x", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_MATERIALAMBIENT:
|
||||
sprintf(buffer, "Material Ambient Color: %06x", data);
|
||||
sprintf(buffer, "Material ambient color: %06x", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_MATERIALDIFFUSE:
|
||||
sprintf(buffer, "Material Diffuse Color: %06x", data);
|
||||
sprintf(buffer, "Material diffuse color: %06x", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_MATERIALEMISSIVE:
|
||||
sprintf(buffer, "Material Emissive Color: %06x", data);
|
||||
sprintf(buffer, "Material emissive color: %06x", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_MATERIALSPECULAR:
|
||||
sprintf(buffer, "Material Specular Color: %06x", data);
|
||||
sprintf(buffer, "Material specular color: %06x", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_MATERIALALPHA:
|
||||
sprintf(buffer, "Material Alpha Color: %06x", data);
|
||||
sprintf(buffer, "Material alpha color: %06x", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_MATERIALSPECULARCOEF:
|
||||
@ -452,11 +573,17 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_SHADEMODE:
|
||||
sprintf(buffer, "Shade: %06x (%s)", data, data ? "gouraud" : "flat");
|
||||
if (data & ~1)
|
||||
sprintf(buffer, "Shade: %06x (%s, extra %x)", data, data ? "gouraud" : "flat", data);
|
||||
else
|
||||
sprintf(buffer, "Shade: %06x (%s)", data, data ? "gouraud" : "flat");
|
||||
break;
|
||||
|
||||
case GE_CMD_LIGHTMODE:
|
||||
sprintf(buffer, "Lightmode: %06x (%s)", data, data ? "separate spec" : "single color");
|
||||
if (data & ~1)
|
||||
sprintf(buffer, "Lightmode: %06x (%s, extra %x)", data, data ? "separate spec" : "single color", data);
|
||||
else
|
||||
sprintf(buffer, "Lightmode: %06x (%s)", data, data ? "separate spec" : "single color");
|
||||
break;
|
||||
|
||||
case GE_CMD_LIGHTTYPE0:
|
||||
@ -546,14 +673,17 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_CULL:
|
||||
sprintf(buffer, "cull: %06x", data);
|
||||
sprintf(buffer, "Cull: %06x", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_PATCHDIVISION:
|
||||
{
|
||||
int patch_div_s = data & 0xFF;
|
||||
int patch_div_t = (data >> 8) & 0xFF;
|
||||
sprintf(buffer, "Patch subdivision: %i x %i", patch_div_s, patch_div_t);
|
||||
if (data & 0xFF0000)
|
||||
sprintf(buffer, "Patch subdivision: %i x %i (extra %x)", patch_div_s, patch_div_t, data & 0xFF0000);
|
||||
else
|
||||
sprintf(buffer, "Patch subdivision: %i x %i", patch_div_s, patch_div_t);
|
||||
}
|
||||
break;
|
||||
|
||||
@ -570,7 +700,7 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_MATERIALUPDATE:
|
||||
sprintf(buffer, "Material Update: %d", data);
|
||||
sprintf(buffer, "Material update: %d", data);
|
||||
break;
|
||||
|
||||
|
||||
@ -578,7 +708,6 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
// CLEARING
|
||||
//////////////////////////////////////////////////////////////////
|
||||
case GE_CMD_CLEARMODE:
|
||||
// If it becomes a performance problem, check diff&1
|
||||
sprintf(buffer, "Clear mode: %06x", data);
|
||||
break;
|
||||
|
||||
@ -607,7 +736,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_ALPHATEST:
|
||||
sprintf(buffer, "Alpha test settings");
|
||||
{
|
||||
const char *alphaTestFuncs[] = { "#", "#", " != ", " == ", " >= ", " > ", " <= ", " < " }; // never/always don't make sense
|
||||
sprintf(buffer, "Alpha test settings: %x (%s)", data, alphaTestFuncs[data & 7]);
|
||||
}
|
||||
break;
|
||||
|
||||
case GE_CMD_ANTIALIASENABLE:
|
||||
@ -615,11 +747,11 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_PATCHCULLENABLE:
|
||||
sprintf(buffer, "Antialias enable: %d", data);
|
||||
sprintf(buffer, "Patch cull enable: %d", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_COLORTESTENABLE:
|
||||
sprintf(buffer, "Color Test enable: %d", data);
|
||||
sprintf(buffer, "Color test enable: %d", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_LOGICOPENABLE:
|
||||
@ -627,14 +759,32 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_TEXFUNC:
|
||||
sprintf(buffer, "TexFunc %i", data&7);
|
||||
{
|
||||
const char *texfuncs[] = {
|
||||
"modulate",
|
||||
"decal",
|
||||
"blend",
|
||||
"replace",
|
||||
"add",
|
||||
"unsupported1",
|
||||
"unsupported2",
|
||||
"unsupported3",
|
||||
};
|
||||
if (data & ~0x107)
|
||||
sprintf(buffer, "TexFunc %i %s (%s, extra %x)", data & 7, data & 0x100 ? "RGBA" : "RGB", texfuncs[data & 7], data);
|
||||
else
|
||||
sprintf(buffer, "TexFunc %i %s (%s)", data & 7, data & 0x100 ? "RGBA" : "RGB", texfuncs[data & 7]);
|
||||
}
|
||||
break;
|
||||
|
||||
case GE_CMD_TEXFILTER:
|
||||
{
|
||||
int min = data & 7;
|
||||
int mag = (data >> 8) & 1;
|
||||
sprintf(buffer, "TexFilter min: %i mag: %i", min, mag);
|
||||
if (data & ~0x107)
|
||||
sprintf(buffer, "TexFilter min: %i mag: %i (extra %x)", min, mag, data);
|
||||
else
|
||||
sprintf(buffer, "TexFilter min: %i mag: %i", min, mag);
|
||||
}
|
||||
break;
|
||||
|
||||
@ -643,27 +793,56 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_TEXMODE:
|
||||
sprintf(buffer, "TexMode %08x", data);
|
||||
sprintf(buffer, "TexMode %06x (%s)", data, data & 1 ? "swizzle" : "no swizzle");
|
||||
break;
|
||||
|
||||
case GE_CMD_TEXFORMAT:
|
||||
sprintf(buffer, "TexFormat %08x", data);
|
||||
{
|
||||
const char *texformats[] = {
|
||||
"5650",
|
||||
"5551"
|
||||
"4444",
|
||||
"8888",
|
||||
"CLUT4",
|
||||
"CLUT8",
|
||||
"CLUT16",
|
||||
"CLUT32",
|
||||
"DXT1",
|
||||
"DXT3",
|
||||
"DXT5",
|
||||
"unsupported1",
|
||||
"unsupported2",
|
||||
"unsupported3",
|
||||
"unsupported4",
|
||||
"unsupported5",
|
||||
};
|
||||
sprintf(buffer, "TexFormat %06x (%s)", data, texformats[data & 0xF]);
|
||||
}
|
||||
break;
|
||||
|
||||
case GE_CMD_TEXFLUSH:
|
||||
sprintf(buffer, "TexFlush");
|
||||
if (data)
|
||||
sprintf(buffer, "TexFlush: %x", data);
|
||||
else
|
||||
sprintf(buffer, "TexFlush");
|
||||
break;
|
||||
|
||||
case GE_CMD_TEXSYNC:
|
||||
sprintf(buffer, "TexSync");
|
||||
if (data)
|
||||
sprintf(buffer, "TexSync: %x", data);
|
||||
else
|
||||
sprintf(buffer, "TexSync");
|
||||
break;
|
||||
|
||||
case GE_CMD_TEXWRAP:
|
||||
sprintf(buffer, "TexWrap %08x", data);
|
||||
sprintf(buffer, "TexWrap %06x", data);
|
||||
break;
|
||||
|
||||
case GE_CMD_TEXLEVEL:
|
||||
sprintf(buffer, "TexWrap Mode: %i Offset: %i", data&3, data >> 16);
|
||||
if (data & ~0xFF0003)
|
||||
sprintf(buffer, "TexWrap mode: %i Offset: %i (extra %x)", data&3, data >> 16, data);
|
||||
else
|
||||
sprintf(buffer, "TexWrap mode: %i Offset: %i", data&3, data >> 16);
|
||||
break;
|
||||
|
||||
case GE_CMD_FOG1:
|
||||
@ -687,7 +866,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
//////////////////////////////////////////////////////////////////
|
||||
|
||||
case GE_CMD_ZTESTENABLE:
|
||||
sprintf(buffer, "Z test enable: %d", data & 1);
|
||||
if (data & ~1)
|
||||
sprintf(buffer, "Z test enable: %d (extra %x)", data & 1, data);
|
||||
else
|
||||
sprintf(buffer, "Z test enable: %d", data & 1);
|
||||
break;
|
||||
|
||||
case GE_CMD_STENCILOP:
|
||||
@ -757,7 +939,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_WORLDMATRIXNUMBER:
|
||||
sprintf(buffer, "World # %i", data & 0xF);
|
||||
if (data & ~0xF)
|
||||
sprintf(buffer, "World # %i (extra %x)", data & 0xF, data);
|
||||
else
|
||||
sprintf(buffer, "World # %i", data & 0xF);
|
||||
break;
|
||||
|
||||
case GE_CMD_WORLDMATRIXDATA:
|
||||
@ -765,7 +950,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_VIEWMATRIXNUMBER:
|
||||
sprintf(buffer, "VIEW # %i", data & 0xF);
|
||||
if (data & ~0xF)
|
||||
sprintf(buffer, "VIEW # %i (extra %x)", data & 0xF, data);
|
||||
else
|
||||
sprintf(buffer, "VIEW # %i", data & 0xF);
|
||||
break;
|
||||
|
||||
case GE_CMD_VIEWMATRIXDATA:
|
||||
@ -773,7 +961,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_PROJMATRIXNUMBER:
|
||||
sprintf(buffer, "PROJECTION # %i", data & 0xF);
|
||||
if (data & ~0xF)
|
||||
sprintf(buffer, "PROJECTION # %i (extra %x)", data & 0xF, data);
|
||||
else
|
||||
sprintf(buffer, "PROJECTION # %i", data & 0xF);
|
||||
break;
|
||||
|
||||
case GE_CMD_PROJMATRIXDATA:
|
||||
@ -781,7 +972,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_TGENMATRIXNUMBER:
|
||||
sprintf(buffer, "TGEN # %i", data & 0xF);
|
||||
if (data & ~0xF)
|
||||
sprintf(buffer, "TGEN # %i (extra %x)", data & 0xF, data);
|
||||
else
|
||||
sprintf(buffer, "TGEN # %i", data & 0xF);
|
||||
break;
|
||||
|
||||
case GE_CMD_TGENMATRIXDATA:
|
||||
@ -789,7 +983,10 @@ void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer) {
|
||||
break;
|
||||
|
||||
case GE_CMD_BONEMATRIXNUMBER:
|
||||
sprintf(buffer, "BONE #%i", data);
|
||||
if (data & ~0xF)
|
||||
sprintf(buffer, "BONE #%i (extra %x)", data & 0xF, data);
|
||||
else
|
||||
sprintf(buffer, "BONE #%i", data & 0xF);
|
||||
break;
|
||||
|
||||
case GE_CMD_BONEMATRIXDATA:
|
||||
|
@ -17,4 +17,5 @@
|
||||
|
||||
#include "Common/CommonTypes.h"
|
||||
|
||||
void GeDescribeVertexType(u32 op, char *buffer, int len = 256);
|
||||
void GeDisassembleOp(u32 pc, u32 op, u32 prev, char *buffer);
|
||||
|
Loading…
x
Reference in New Issue
Block a user