mirror of
https://github.com/rt64/rt64.git
synced 2025-01-04 02:50:36 +00:00
eb981eb47b
* Add egbi command to bypass the segment table for K0 CPU addresses to allow extending rdram * Fix capitalization of RDRAM for consistency
519 lines
17 KiB
C
519 lines
17 KiB
C
//
|
|
// RT64
|
|
//
|
|
|
|
#ifndef RT64_EXTENDED_GBI
|
|
#define RT64_EXTENDED_GBI
|
|
|
|
// G_SPNOOP on F3D and F3DEX2.
|
|
#ifdef F3DEX_GBI_2
|
|
# define RT64_HOOK_OPCODE 0xE0
|
|
#else
|
|
# define RT64_HOOK_OPCODE 0x00
|
|
#endif
|
|
|
|
#define RT64_HOOK_OP_GETVERSION 0x0
|
|
#define RT64_HOOK_OP_ENABLE 0x1
|
|
#define RT64_HOOK_OP_DISABLE 0x2
|
|
#define RT64_HOOK_OP_DL 0x3
|
|
#define RT64_HOOK_OP_BRANCH 0x4
|
|
|
|
// 0x5254 for ASCII "RT" followed by 0x64.
|
|
#define RT64_HOOK_MAGIC_NUMBER 0x525464
|
|
|
|
#ifndef RT64_EXTENDED_OPCODE
|
|
// TODO: Define defaults here based on the GBI.
|
|
# define RT64_EXTENDED_OPCODE 0x64
|
|
#endif
|
|
|
|
#define G_EX_VERSION 0x1
|
|
|
|
#define G_EX_NOOP 0x000000
|
|
#define G_EX_PRINT 0x000001
|
|
#define G_EX_TEXRECT_V1 0x000002
|
|
#define G_EX_FILLRECT_V1 0x000003
|
|
#define G_EX_SETVIEWPORT_V1 0x000004
|
|
#define G_EX_SETSCISSOR_V1 0x000005
|
|
#define G_EX_SETRECTALIGN_V1 0x000006
|
|
#define G_EX_SETVIEWPORTALIGN_V1 0x000007
|
|
#define G_EX_SETSCISSORALIGN_V1 0x000008
|
|
#define G_EX_SETREFRESHRATE_V1 0x000009
|
|
#define G_EX_VERTEXZTEST_V1 0x00000A
|
|
#define G_EX_ENDVERTEXZTEST_V1 0x00000B
|
|
#define G_EX_MATRIXGROUP_V1 0x00000C
|
|
#define G_EX_POPMATRIXGROUP_V1 0x00000D
|
|
#define G_EX_FORCEUPSCALE2D_V1 0x00000E
|
|
#define G_EX_FORCETRUEBILERP_V1 0x00000F
|
|
#define G_EX_FORCESCALELOD_V1 0x000010
|
|
#define G_EX_FORCEBRANCH_V1 0x000011
|
|
#define G_EX_SETRENDERTORAM_V1 0x000012
|
|
#define G_EX_EDITGROUPBYADDRESS_V1 0x000013
|
|
#define G_EX_VERTEX_V1 0x000014
|
|
#define G_EX_PUSHVIEWPORT_V1 0x000015
|
|
#define G_EX_POPVIEWPORT_V1 0x000016
|
|
#define G_EX_PUSHSCISSOR_V1 0x000017
|
|
#define G_EX_POPSCISSOR_V1 0x000018
|
|
#define G_EX_PUSHOTHERMODE_V1 0x000019
|
|
#define G_EX_POPOTHERMODE_V1 0x00001A
|
|
#define G_EX_PUSHCOMBINE_V1 0x00001B
|
|
#define G_EX_POPCOMBINE_V1 0x00001C
|
|
#define G_EX_PUSHPROJMATRIX_V1 0x00001D
|
|
#define G_EX_POPPROJMATRIX_V1 0x00001E
|
|
#define G_EX_PUSHENVCOLOR_V1 0x00001F
|
|
#define G_EX_POPENVCOLOR_V1 0x000020
|
|
#define G_EX_PUSHBLENDCOLOR_V1 0x000021
|
|
#define G_EX_POPBLENDCOLOR_V1 0x000022
|
|
#define G_EX_PUSHFOGCOLOR_V1 0x000023
|
|
#define G_EX_POPFOGCOLOR_V1 0x000024
|
|
#define G_EX_PUSHFILLCOLOR_V1 0x000025
|
|
#define G_EX_POPFILLCOLOR_V1 0x000026
|
|
#define G_EX_PUSHPRIMCOLOR_V1 0x000027
|
|
#define G_EX_POPPRIMCOLOR_V1 0x000028
|
|
#define G_EX_PUSHGEOMETRYMODE_V1 0x000029
|
|
#define G_EX_POPGEOMETRYMODE_V1 0x00002A
|
|
#define G_EX_SETDITHERNOISESTRENGTH_V1 0x00002B
|
|
#define G_EX_SETRDRAMEXTENDED_V1 0x00002C
|
|
#define G_EX_MAX 0x00002D
|
|
|
|
#define G_EX_ORIGIN_NONE 0x800
|
|
#define G_EX_ORIGIN_LEFT 0x0
|
|
#define G_EX_ORIGIN_CENTER 0x200
|
|
#define G_EX_ORIGIN_RIGHT 0x400
|
|
|
|
#define G_EX_NOPUSH 0x0
|
|
#define G_EX_PUSH 0x1
|
|
|
|
#define G_EX_ID_IGNORE 0x0
|
|
#define G_EX_ID_AUTO 0xFFFFFFFF
|
|
|
|
#define G_EX_COMPONENT_SKIP 0x0
|
|
#define G_EX_COMPONENT_INTERPOLATE 0x1
|
|
#define G_EX_COMPONENT_AUTO 0x2
|
|
|
|
#define G_EX_INTERPOLATE_SIMPLE 0x0
|
|
#define G_EX_INTERPOLATE_DECOMPOSE 0x1
|
|
|
|
#define G_EX_ORDER_LINEAR 0x0
|
|
#define G_EX_ORDER_AUTO 0x1
|
|
|
|
#define G_EX_EDIT_NONE 0x0
|
|
#define G_EX_EDIT_ALLOW 0x1
|
|
|
|
#define G_EX_BILERP_NONE 0x0
|
|
#define G_EX_BILERP_ONLY 0x1
|
|
#define G_EX_BILERP_ALL 0x2
|
|
|
|
// Represents the 8-byte commands in the F3D microcode family
|
|
typedef union {
|
|
struct {
|
|
unsigned word0;
|
|
unsigned word1;
|
|
} values;
|
|
unsigned long long dummy; // Force to 8-byte alignment
|
|
} GfxCommand;
|
|
|
|
typedef struct {
|
|
short ob[3];
|
|
unsigned short flag;
|
|
short tc[2];
|
|
unsigned char cn[4];
|
|
short obp[3];
|
|
} VertexEXColor;
|
|
|
|
typedef struct {
|
|
short ob[3];
|
|
unsigned short flag;
|
|
short tc[2];
|
|
signed char n[3];
|
|
unsigned char a;
|
|
short obp[3];
|
|
} VertexEXNormal;
|
|
|
|
typedef union {
|
|
VertexEXColor v;
|
|
VertexEXNormal n;
|
|
long long alignment[3];
|
|
} VertexEX;
|
|
|
|
#define PARAM(value, bits, shift) \
|
|
((unsigned) (((unsigned)(value) & ((1U << (bits)) - 1U)) << (shift)))
|
|
|
|
#define DOWHILE(code) \
|
|
do { code } while (0)
|
|
|
|
#define G_EX_WRITECOMMAND(cmd, _word0, _word1) \
|
|
{ \
|
|
cmd->values.word0 = _word0; \
|
|
cmd->values.word1 = _word1; \
|
|
}
|
|
|
|
#define G_EX_COMMAND1(cmd, _word0, _word1) \
|
|
DOWHILE( \
|
|
GfxCommand *_cmd = (GfxCommand*)(cmd); \
|
|
G_EX_WRITECOMMAND((_cmd + 0), _word0, _word1) \
|
|
)
|
|
|
|
#define G_EX_COMMAND2(cmd, _word0, _word1, _word2, _word3) \
|
|
DOWHILE( \
|
|
GfxCommand *_cmd = (GfxCommand*)(cmd); \
|
|
(void)(cmd); \
|
|
G_EX_WRITECOMMAND((_cmd + 0), _word0, _word1) \
|
|
G_EX_WRITECOMMAND((_cmd + 1), _word2, _word3) \
|
|
)
|
|
|
|
#define G_EX_COMMAND3(cmd, _word0, _word1, _word2, _word3, _word4, _word5) \
|
|
DOWHILE( \
|
|
GfxCommand *_cmd = (GfxCommand*)(cmd); \
|
|
(void)(cmd); \
|
|
(void)(cmd); \
|
|
G_EX_WRITECOMMAND((_cmd + 0), _word0, _word1) \
|
|
G_EX_WRITECOMMAND((_cmd + 1), _word2, _word3) \
|
|
G_EX_WRITECOMMAND((_cmd + 2), _word4, _word5) \
|
|
)
|
|
|
|
#define G_EX_COMMAND4(cmd, _word0, _word1, _word2, _word3, _word4, _word5, _word6, _word7) \
|
|
DOWHILE( \
|
|
GfxCommand *_cmd = (GfxCommand*)(cmd); \
|
|
(void)(cmd); \
|
|
(void)(cmd); \
|
|
(void)(cmd); \
|
|
G_EX_WRITECOMMAND(cmd_, _word0, _word1) \
|
|
G_EX_WRITECOMMAND(cmd_, _word2, _word3) \
|
|
G_EX_WRITECOMMAND(cmd_, _word4, _word5) \
|
|
G_EX_WRITECOMMAND(cmd_, _word6, _word7) \
|
|
)
|
|
|
|
#define gEXGetVersion(cmd, ret) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_HOOK_OPCODE, 8, 24) | PARAM(RT64_HOOK_MAGIC_NUMBER, 24, 0), \
|
|
PARAM(RT64_HOOK_OP_GETVERSION, 4, 28) | PARAM(ret, 28, 0))
|
|
|
|
#define gEXEnable(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_HOOK_OPCODE, 8, 24) | PARAM(RT64_HOOK_MAGIC_NUMBER, 24, 0), \
|
|
PARAM(RT64_HOOK_OP_ENABLE, 4, 28) | PARAM(RT64_EXTENDED_OPCODE, 8, 0))
|
|
|
|
#define gEXDisable(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_HOOK_OPCODE, 8, 24) | PARAM(RT64_HOOK_MAGIC_NUMBER, 24, 0), \
|
|
PARAM(RT64_HOOK_OP_DISABLE, 4, 28))
|
|
|
|
#define gEXBranchList(cmd, dlist) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_HOOK_OPCODE, 8, 24) | PARAM(RT64_HOOK_MAGIC_NUMBER, 24, 0), \
|
|
PARAM(RT64_HOOK_OP_BRANCH, 4, 28) | PARAM(dlist, 28, 0))
|
|
|
|
#define gEXDisplayList(cmd, dlist) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_HOOK_OPCODE, 8, 24) | PARAM(RT64_HOOK_MAGIC_NUMBER, 24, 0), \
|
|
PARAM(RT64_HOOK_OP_DL, 4, 28) | PARAM(dlist, 28, 0))
|
|
|
|
#define gEXNoOp(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_NOOP, 24, 0), \
|
|
0)
|
|
|
|
#define gEXPrint(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_PRINT, 24, 0), \
|
|
0)
|
|
|
|
#define gEXTextureRectangle(cmd, lorigin, rorigin, ulx, uly, lrx, lry, tile, s, t, dsdx, dtdy) \
|
|
G_EX_COMMAND3(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_TEXRECT_V1, 24, 0), \
|
|
PARAM(tile, 3, 0) | PARAM(lorigin, 12, 3) | PARAM(rorigin, 12, 15) | PARAM(0, 5, 27), \
|
|
\
|
|
PARAM(ulx, 16, 16) | PARAM(uly, 16, 0), \
|
|
PARAM(lrx, 16, 16) | PARAM(lry, 16, 0), \
|
|
\
|
|
PARAM(s, 16, 16) | PARAM(t, 16, 0), \
|
|
PARAM(dsdx, 16, 16) | PARAM(dtdy, 16, 0) \
|
|
)
|
|
|
|
#define gEXViewport(cmd, origin, vp) \
|
|
G_EX_COMMAND2(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_SETVIEWPORT_V1, 24, 0), \
|
|
PARAM(origin, 12, 0), \
|
|
\
|
|
0, \
|
|
(unsigned)vp \
|
|
)
|
|
|
|
#define gEXSetScissor(cmd, mode, lorigin, rorigin, ulx, uly, lrx, lry) \
|
|
G_EX_COMMAND2(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_SETSCISSOR_V1, 24, 0), \
|
|
PARAM(mode, 2, 0) | PARAM(lorigin, 12, 2) | PARAM(rorigin, 12, 14), \
|
|
\
|
|
PARAM((ulx) * 4, 16, 16) | PARAM((uly) * 4, 16, 0), \
|
|
PARAM((lrx) * 4, 16, 16) | PARAM((lry) * 4, 16, 0) \
|
|
)
|
|
|
|
#define gEXSetRectAlign(cmd, lorigin, rorigin, ulxOffset, ulyOffset, lrxOffset, lryOffset) \
|
|
G_EX_COMMAND2(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_SETRECTALIGN_V1, 24, 0), \
|
|
PARAM(lorigin, 12, 0) | PARAM(rorigin, 12, 12), \
|
|
\
|
|
PARAM((ulxOffset), 16, 16) | PARAM((ulyOffset), 16, 0), \
|
|
PARAM((lrxOffset), 16, 16) | PARAM((lryOffset), 16, 0) \
|
|
)
|
|
|
|
#define gEXSetViewportAlign(cmd, origin, xOffset, yOffset) \
|
|
G_EX_COMMAND2(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_SETVIEWPORTALIGN_V1, 24, 0), \
|
|
PARAM(origin, 12, 0), \
|
|
\
|
|
PARAM((xOffset), 16, 16) | PARAM((yOffset), 16, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXSetScissorAlign(cmd, lorigin, rorigin, ulxOffset, ulyOffset, lrxOffset, lryOffset, ulxBound, ulyBound, lrxBound, lryBound) \
|
|
G_EX_COMMAND3(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_SETSCISSORALIGN_V1, 24, 0), \
|
|
PARAM(lorigin, 12, 0) | PARAM(rorigin, 12, 12), \
|
|
\
|
|
PARAM((ulxOffset) * 4, 16, 16) | PARAM((ulyOffset) * 4, 16, 0), \
|
|
PARAM((lrxOffset) * 4, 16, 16) | PARAM((lryOffset) * 4, 16, 0), \
|
|
\
|
|
PARAM((ulxBound) * 4, 16, 16) | PARAM((ulyBound) * 4, 16, 0), \
|
|
PARAM((lrxBound) * 4, 16, 16) | PARAM((lryBound) * 4, 16, 0) \
|
|
)
|
|
|
|
#define gEXSetRefreshRate(cmd, refresh_rate) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_SETREFRESHRATE_V1, 24, 0), \
|
|
PARAM(refresh_rate, 16, 0) \
|
|
)
|
|
|
|
#define gEXVertexZTest(cmd, vertex_index) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_VERTEXZTEST_V1, 24, 0), \
|
|
PARAM(vertex_index, 8, 0) \
|
|
)
|
|
|
|
#define gEXEndVertexZTest(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_ENDVERTEXZTEST_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXMatrixGroup(cmd, id, mode, push, proj, pos, rot, scale, skew, persp, vert, tile, order, edit) \
|
|
G_EX_COMMAND2(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_MATRIXGROUP_V1, 24, 0), \
|
|
id, \
|
|
PARAM(push, 1, 0) | PARAM((proj) != 0, 1, 1) | PARAM(mode, 1, 2) | PARAM(pos, 2, 3) | PARAM(rot, 2, 5) | PARAM(scale, 2, 7) | PARAM(skew, 2, 9) | PARAM(persp, 2, 11) | PARAM(vert, 2, 13) | PARAM(tile, 2, 15) | PARAM(order, 2, 17) | PARAM(edit, 1, 19), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXMatrixGroupSimple(cmd, id, push, proj, pos, rot, persp, vert, tile, order, edit) \
|
|
gEXMatrixGroup(cmd, id, G_EX_INTERPOLATE_SIMPLE, push, proj, pos, rot, G_EX_COMPONENT_SKIP, G_EX_COMPONENT_SKIP, persp, vert, tile, order, edit)
|
|
|
|
#define gEXMatrixGroupDecomposed(cmd, id, push, proj, pos, rot, scale, skew, persp, vert, tile, order, edit) \
|
|
gEXMatrixGroup(cmd, id, G_EX_INTERPOLATE_DECOMPOSE, push, proj, pos, rot, scale, skew, persp, vert, tile, order, edit)
|
|
|
|
#define gEXMatrixGroupNoInterpolate(cmd, push, proj, edit) \
|
|
gEXMatrixGroup(cmd, G_EX_ID_IGNORE, G_EX_INTERPOLATE_SIMPLE, push, proj, G_EX_COMPONENT_SKIP, G_EX_COMPONENT_SKIP, G_EX_COMPONENT_SKIP, G_EX_COMPONENT_SKIP, G_EX_COMPONENT_SKIP, G_EX_COMPONENT_SKIP, G_EX_COMPONENT_SKIP, G_EX_ORDER_LINEAR, edit)
|
|
|
|
#define gEXPopMatrixGroup(cmd, proj) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_POPMATRIXGROUP_V1, 24, 0), \
|
|
PARAM(1, 8, 0) | PARAM(proj, 1, 8) \
|
|
)
|
|
|
|
#define gEXPopMatrixGroupN(cmd, proj, count) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_POPMATRIXGROUP_V1, 24, 0), \
|
|
PARAM(count, 8, 0) | PARAM(proj, 1, 8) \
|
|
)
|
|
|
|
#define gEXForceUpscale2D(cmd, force) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_FORCEUPSCALE2D_V1, 24, 0), \
|
|
PARAM(force, 1, 0) \
|
|
)
|
|
|
|
#define gEXForceTrueBilerp(cmd, mode) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_FORCETRUEBILERP_V1, 24, 0), \
|
|
PARAM(mode, 2, 0) \
|
|
)
|
|
|
|
#define gEXForceScaleLOD(cmd, force) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_FORCESCALELOD_V1, 24, 0), \
|
|
PARAM(force, 1, 0) \
|
|
)
|
|
|
|
#define gEXForceBranch(cmd, force) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_FORCEBRANCH_V1, 24, 0), \
|
|
PARAM(force, 1, 0) \
|
|
)
|
|
|
|
#define gEXSetRenderToRAM(cmd, render) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_SETRENDERTORAM_V1, 24, 0), \
|
|
PARAM(render, 1, 0) \
|
|
)
|
|
|
|
#define gEXEditGroupByAddress(cmd, address, mode, push, proj, pos, rot, scale, skew, persp, vert, tile, order) \
|
|
G_EX_COMMAND2(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_EDITGROUPBYADDRESS_V1, 24, 0), \
|
|
(unsigned)(address), \
|
|
PARAM(push, 1, 0) | PARAM((proj) != 0, 1, 1) | PARAM(mode, 1, 2) | PARAM(pos, 2, 3) | PARAM(rot, 2, 5) | PARAM(scale, 2, 7) | PARAM(skew, 2, 9) | PARAM(persp, 2, 11) | PARAM(vert, 2, 13) | PARAM(tile, 2, 15) | PARAM(order, 2, 17) | PARAM(G_EX_EDIT_ALLOW, 1, 18), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXVertexV1(cmd, vtx, count, v0) \
|
|
G_EX_COMMAND2(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_VERTEX_V1, 24, 0), \
|
|
PARAM((v0)+(n), 7, 1) | PARAM(n, 8, 12), \
|
|
0, \
|
|
(unsigned)(vtx) \
|
|
)
|
|
|
|
#define gEXPushViewport(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_PUSHVIEWPORT_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPopViewport(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_POPVIEWPORT_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPushScissor(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_PUSHSCISSOR_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPopScissor(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_POPSCISSOR_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPushOtherMode(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_PUSHOTHERMODE_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPopOtherMode(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_POPOTHERMODE_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPushCombineMode(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_PUSHCOMBINE_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPopCombineMode(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_POPCOMBINE_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPushProjectionMatrix(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_PUSHPROJMATRIX_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPopProjectionMatrix(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_POPPROJMATRIX_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPushEnvColor(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_PUSHENVCOLOR_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPopEnvColor(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_POPENVCOLOR_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPushBlendColor(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_PUSHBLENDCOLOR_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPopBlendColor(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_POPBLENDCOLOR_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPushFogColor(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_PUSHFOGCOLOR_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPopFogColor(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_POPFOGCOLOR_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPushFillColor(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_PUSHFILLCOLOR_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPopFillColor(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_POPFILLCOLOR_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPushPrimColor(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_PUSHPRIMCOLOR_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPopPrimColor(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_POPPRIMCOLOR_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPushGeometryMode(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_PUSHGEOMETRYMODE_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXPopGeometryMode(cmd) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_POPGEOMETRYMODE_V1, 24, 0), \
|
|
0 \
|
|
)
|
|
|
|
#define gEXSetDitherNoiseStrength(cmd, value) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_SETDITHERNOISESTRENGTH_V1, 24, 0), \
|
|
PARAM((value) * 1024, 16, 0) \
|
|
)
|
|
|
|
#define gEXSetRDRAMExtended(cmd, isExtended) \
|
|
G_EX_COMMAND1(cmd, \
|
|
PARAM(RT64_EXTENDED_OPCODE, 8, 24) | PARAM(G_EX_SETRDRAMEXTENDED_V1, 24, 0), \
|
|
PARAM(isExtended, 1, 0) \
|
|
)
|
|
|
|
#endif // RT64_EXTENDED_GBI
|