pcsxr/libpcsxcore/gte.c

1069 lines
28 KiB
C

/*
* PlayStation Geometry Transformation Engine emulator
*
* Copyright 2003-2013 smf
*
*/
#include "gte.h"
#include "psxmem.h"
#include "pgxp_gte.h"
#include "pgxp_debug.h"
#define GTE_SF(op) ((op >> 19) & 1)
#define GTE_MX(op) ((op >> 17) & 3)
#define GTE_V(op) ((op >> 15) & 3)
#define GTE_CV(op) ((op >> 13) & 3)
#define GTE_LM(op) ((op >> 10) & 1)
#define GTE_FUNCT(op) (op & 63)
#define gteop (psxRegs.code & 0x1ffffff)
#define VX0 (psxRegs.CP2D.p[ 0 ].sw.l)
#define VY0 (psxRegs.CP2D.p[ 0 ].sw.h)
#define VZ0 (psxRegs.CP2D.p[ 1 ].sw.l)
#define VX1 (psxRegs.CP2D.p[ 2 ].w.l)
#define VY1 (psxRegs.CP2D.p[ 2 ].w.h)
#define VZ1 (psxRegs.CP2D.p[ 3 ].w.l)
#define VX2 (psxRegs.CP2D.p[ 4 ].w.l)
#define VY2 (psxRegs.CP2D.p[ 4 ].w.h)
#define VZ2 (psxRegs.CP2D.p[ 5 ].w.l)
#define R (psxRegs.CP2D.p[ 6 ].b.l)
#define G (psxRegs.CP2D.p[ 6 ].b.h)
#define B (psxRegs.CP2D.p[ 6 ].b.h2)
#define CODE (psxRegs.CP2D.p[ 6 ].b.h3)
#define OTZ (psxRegs.CP2D.p[ 7 ].w.l)
#define IR0 (psxRegs.CP2D.p[ 8 ].sw.l)
#define IR1 (psxRegs.CP2D.p[ 9 ].sw.l)
#define IR2 (psxRegs.CP2D.p[ 10 ].sw.l)
#define IR3 (psxRegs.CP2D.p[ 11 ].sw.l)
#define SXY0 (psxRegs.CP2D.p[ 12 ].d)
#define SX0 (psxRegs.CP2D.p[ 12 ].sw.l)
#define SY0 (psxRegs.CP2D.p[ 12 ].sw.h)
#define SXY1 (psxRegs.CP2D.p[ 13 ].d)
#define SX1 (psxRegs.CP2D.p[ 13 ].sw.l)
#define SY1 (psxRegs.CP2D.p[ 13 ].sw.h)
#define SXY2 (psxRegs.CP2D.p[ 14 ].d)
#define SX2 (psxRegs.CP2D.p[ 14 ].sw.l)
#define SY2 (psxRegs.CP2D.p[ 14 ].sw.h)
#define SXYP (psxRegs.CP2D.p[ 15 ].d)
#define SXP (psxRegs.CP2D.p[ 15 ].sw.l)
#define SYP (psxRegs.CP2D.p[ 15 ].sw.h)
#define SZ0 (psxRegs.CP2D.p[ 16 ].w.l)
#define SZ1 (psxRegs.CP2D.p[ 17 ].w.l)
#define SZ2 (psxRegs.CP2D.p[ 18 ].w.l)
#define SZ3 (psxRegs.CP2D.p[ 19 ].w.l)
#define RGB0 (psxRegs.CP2D.p[ 20 ].d)
#define R0 (psxRegs.CP2D.p[ 20 ].b.l)
#define G0 (psxRegs.CP2D.p[ 20 ].b.h)
#define B0 (psxRegs.CP2D.p[ 20 ].b.h2)
#define CD0 (psxRegs.CP2D.p[ 20 ].b.h3)
#define RGB1 (psxRegs.CP2D.p[ 21 ].d)
#define R1 (psxRegs.CP2D.p[ 21 ].b.l)
#define G1 (psxRegs.CP2D.p[ 21 ].b.h)
#define B1 (psxRegs.CP2D.p[ 21 ].b.h2)
#define CD1 (psxRegs.CP2D.p[ 21 ].b.h3)
#define RGB2 (psxRegs.CP2D.p[ 22 ].d)
#define R2 (psxRegs.CP2D.p[ 22 ].b.l)
#define G2 (psxRegs.CP2D.p[ 22 ].b.h)
#define B2 (psxRegs.CP2D.p[ 22 ].b.h2)
#define CD2 (psxRegs.CP2D.p[ 22 ].b.h3)
#define RES1 (psxRegs.CP2D.p[ 23 ].d)
#define MAC0 (psxRegs.CP2D.p[ 24 ].sd)
#define MAC1 (psxRegs.CP2D.p[ 25 ].sd)
#define MAC2 (psxRegs.CP2D.p[ 26 ].sd)
#define MAC3 (psxRegs.CP2D.p[ 27 ].sd)
#define IRGB (psxRegs.CP2D.p[ 28 ].d)
#define ORGB (psxRegs.CP2D.p[ 29 ].d)
#define LZCS (psxRegs.CP2D.p[ 30 ].d)
#define LZCR (psxRegs.CP2D.p[ 31 ].d)
#define R11 (psxRegs.CP2C.p[ 0 ].sw.l)
#define R12 (psxRegs.CP2C.p[ 0 ].sw.h)
#define R13 (psxRegs.CP2C.p[ 1 ].sw.l)
#define R21 (psxRegs.CP2C.p[ 1 ].sw.h)
#define R22 (psxRegs.CP2C.p[ 2 ].sw.l)
#define R23 (psxRegs.CP2C.p[ 2 ].sw.h)
#define R31 (psxRegs.CP2C.p[ 3 ].sw.l)
#define R32 (psxRegs.CP2C.p[ 3 ].sw.h)
#define R33 (psxRegs.CP2C.p[ 4 ].sw.l)
#define TRX (psxRegs.CP2C.p[ 5 ].sd)
#define TRY (psxRegs.CP2C.p[ 6 ].sd)
#define TRZ (psxRegs.CP2C.p[ 7 ].sd)
#define L11 (psxRegs.CP2C.p[ 8 ].sw.l)
#define L12 (psxRegs.CP2C.p[ 8 ].sw.h)
#define L13 (psxRegs.CP2C.p[ 9 ].sw.l)
#define L21 (psxRegs.CP2C.p[ 9 ].sw.h)
#define L22 (psxRegs.CP2C.p[ 10 ].sw.l)
#define L23 (psxRegs.CP2C.p[ 10 ].sw.h)
#define L31 (psxRegs.CP2C.p[ 11 ].sw.l)
#define L32 (psxRegs.CP2C.p[ 11 ].sw.h)
#define L33 (psxRegs.CP2C.p[ 12 ].sw.l)
#define RBK (psxRegs.CP2C.p[ 13 ].sd)
#define GBK (psxRegs.CP2C.p[ 14 ].sd)
#define BBK (psxRegs.CP2C.p[ 15 ].sd)
#define LR1 (psxRegs.CP2C.p[ 16 ].sw.l)
#define LR2 (psxRegs.CP2C.p[ 16 ].sw.h)
#define LR3 (psxRegs.CP2C.p[ 17 ].sw.l)
#define LG1 (psxRegs.CP2C.p[ 17 ].sw.h)
#define LG2 (psxRegs.CP2C.p[ 18 ].sw.l)
#define LG3 (psxRegs.CP2C.p[ 18 ].sw.h)
#define LB1 (psxRegs.CP2C.p[ 19 ].sw.l)
#define LB2 (psxRegs.CP2C.p[ 19 ].sw.h)
#define LB3 (psxRegs.CP2C.p[ 20 ].sw.l)
#define RFC (psxRegs.CP2C.p[ 21 ].sd)
#define GFC (psxRegs.CP2C.p[ 22 ].sd)
#define BFC (psxRegs.CP2C.p[ 23 ].sd)
#define OFX (psxRegs.CP2C.p[ 24 ].sd)
#define OFY (psxRegs.CP2C.p[ 25 ].sd)
#define H (psxRegs.CP2C.p[ 26 ].sw.l)
#define DQA (psxRegs.CP2C.p[ 27 ].sw.l)
#define DQB (psxRegs.CP2C.p[ 28 ].sd)
#define ZSF3 (psxRegs.CP2C.p[ 29 ].sw.l)
#define ZSF4 (psxRegs.CP2C.p[ 30 ].sw.l)
#define FLAG (psxRegs.CP2C.p[ 31 ].d)
#define VX(n) (n < 3 ? psxRegs.CP2D.p[ n << 1 ].sw.l : IR1)
#define VY(n) (n < 3 ? psxRegs.CP2D.p[ n << 1 ].sw.h : IR2)
#define VZ(n) (n < 3 ? psxRegs.CP2D.p[ (n << 1) + 1 ].sw.l : IR3)
#define MX11(n) (n < 3 ? psxRegs.CP2C.p[ (n << 3) ].sw.l : -R << 4)
#define MX12(n) (n < 3 ? psxRegs.CP2C.p[ (n << 3) ].sw.h : R << 4)
#define MX13(n) (n < 3 ? psxRegs.CP2C.p[ (n << 3) + 1 ].sw.l : IR0)
#define MX21(n) (n < 3 ? psxRegs.CP2C.p[ (n << 3) + 1 ].sw.h : R13)
#define MX22(n) (n < 3 ? psxRegs.CP2C.p[ (n << 3) + 2 ].sw.l : R13)
#define MX23(n) (n < 3 ? psxRegs.CP2C.p[ (n << 3) + 2 ].sw.h : R13)
#define MX31(n) (n < 3 ? psxRegs.CP2C.p[ (n << 3) + 3 ].sw.l : R22)
#define MX32(n) (n < 3 ? psxRegs.CP2C.p[ (n << 3) + 3 ].sw.h : R22)
#define MX33(n) (n < 3 ? psxRegs.CP2C.p[ (n << 3) + 4 ].sw.l : R22)
#define CV1(n) (n < 3 ? psxRegs.CP2C.p[ (n << 3) + 5 ].sd : 0)
#define CV2(n) (n < 3 ? psxRegs.CP2C.p[ (n << 3) + 6 ].sd : 0)
#define CV3(n) (n < 3 ? psxRegs.CP2C.p[ (n << 3) + 7 ].sd : 0)
static int m_sf;
static s64 m_mac0;
static s64 m_mac3;
static u32 gte_leadingzerocount(u32 lzcs) {
u32 lzcr = 0;
if((lzcs & 0x80000000) == 0)
lzcs = ~lzcs;
while((lzcs & 0x80000000) != 0) {
lzcr++;
lzcs <<= 1;
}
return lzcr;
}
s32 LIM(s32 value, s32 max, s32 min, u32 flag) {
if(value > max) {
FLAG |= flag;
return max;
}
else if(value < min) {
FLAG |= flag;
return min;
}
return value;
}
static u32 MFC2(int reg) {
switch(reg) {
case 1:
case 3:
case 5:
case 8:
case 9:
case 10:
case 11:
psxRegs.CP2D.p[reg].d = (s32)psxRegs.CP2D.p[reg].sw.l;
break;
case 7:
case 16:
case 17:
case 18:
case 19:
psxRegs.CP2D.p[reg].d = (u32)psxRegs.CP2D.p[reg].w.l;
break;
case 15:
psxRegs.CP2D.p[reg].d = SXY2;
break;
case 28:
case 29:
psxRegs.CP2D.p[reg].d = LIM(IR1 >> 7, 0x1f, 0, 0) | (LIM(IR2 >> 7, 0x1f, 0, 0) << 5) | (LIM(IR3 >> 7, 0x1f, 0, 0) << 10);
break;
}
return psxRegs.CP2D.p[reg].d;
}
static void MTC2(u32 value, int reg) {
switch(reg) {
case 15:
SXY0 = SXY1;
SXY1 = SXY2;
SXY2 = value;
break;
case 28:
IR1 = (value & 0x1f) << 7;
IR2 = (value & 0x3e0) << 2;
IR3 = (value & 0x7c00) >> 3;
break;
case 30:
LZCR = gte_leadingzerocount(value);
break;
case 31:
return;
}
psxRegs.CP2D.p[reg].d = value;
}
static void CTC2(u32 value, int reg) {
switch(reg) {
case 4:
case 12:
case 20:
case 26:
case 27:
case 29:
case 30:
value = (s32)(s16)value;
break;
case 31:
value = value & 0x7ffff000;
if((value & 0x7f87e000) != 0)
value |= 0x80000000;
break;
}
psxRegs.CP2C.p[reg].d = value;
}
void gteMFC2() {
// CPU[Rt] = GTE_D[Rd]
if (!_Rt_) return;
psxRegs.GPR.r[_Rt_] = MFC2(_Rd_);
}
void gteCFC2() {
// CPU[Rt] = GTE_C[Rd]
if (!_Rt_) return;
psxRegs.GPR.r[_Rt_] = psxRegs.CP2C.p[_Rd_].d;
}
void gteMTC2() {
MTC2(psxRegs.GPR.r[_Rt_], _Rd_);
}
void gteCTC2() {
CTC2(psxRegs.GPR.r[_Rt_], _Rd_);
}
#define _oB_ (psxRegs.GPR.r[_Rs_] + _Imm_)
void gteLWC2() {
MTC2(psxMemRead32(_oB_), _Rt_);
}
void gteSWC2() {
psxMemWrite32(_oB_, MFC2(_Rt_));
}
static inline s64 gte_shift(s64 a, int sf) {
if(sf > 0)
return a >> 12;
else if(sf < 0)
return a << 12;
return a;
}
s32 BOUNDS(/*int44*/s64 value, int max_flag, int min_flag) {
if(value/*.positive_overflow()*/ > S64(0x7ffffffffff))
FLAG |= max_flag;
if(value/*.negative_overflow()*/ < S64(-0x80000000000))
FLAG |= min_flag;
return gte_shift(value/*.value()*/, m_sf);
}
u32 gte_divide( u16 numerator, u16 denominator )
{
if( numerator < ( denominator * 2 ) )
{
static u8 table[] =
{
0xff, 0xfd, 0xfb, 0xf9, 0xf7, 0xf5, 0xf3, 0xf1, 0xef, 0xee, 0xec, 0xea, 0xe8, 0xe6, 0xe4, 0xe3,
0xe1, 0xdf, 0xdd, 0xdc, 0xda, 0xd8, 0xd6, 0xd5, 0xd3, 0xd1, 0xd0, 0xce, 0xcd, 0xcb, 0xc9, 0xc8,
0xc6, 0xc5, 0xc3, 0xc1, 0xc0, 0xbe, 0xbd, 0xbb, 0xba, 0xb8, 0xb7, 0xb5, 0xb4, 0xb2, 0xb1, 0xb0,
0xae, 0xad, 0xab, 0xaa, 0xa9, 0xa7, 0xa6, 0xa4, 0xa3, 0xa2, 0xa0, 0x9f, 0x9e, 0x9c, 0x9b, 0x9a,
0x99, 0x97, 0x96, 0x95, 0x94, 0x92, 0x91, 0x90, 0x8f, 0x8d, 0x8c, 0x8b, 0x8a, 0x89, 0x87, 0x86,
0x85, 0x84, 0x83, 0x82, 0x81, 0x7f, 0x7e, 0x7d, 0x7c, 0x7b, 0x7a, 0x79, 0x78, 0x77, 0x75, 0x74,
0x73, 0x72, 0x71, 0x70, 0x6f, 0x6e, 0x6d, 0x6c, 0x6b, 0x6a, 0x69, 0x68, 0x67, 0x66, 0x65, 0x64,
0x63, 0x62, 0x61, 0x60, 0x5f, 0x5e, 0x5d, 0x5d, 0x5c, 0x5b, 0x5a, 0x59, 0x58, 0x57, 0x56, 0x55,
0x54, 0x53, 0x53, 0x52, 0x51, 0x50, 0x4f, 0x4e, 0x4d, 0x4d, 0x4c, 0x4b, 0x4a, 0x49, 0x48, 0x48,
0x47, 0x46, 0x45, 0x44, 0x43, 0x43, 0x42, 0x41, 0x40, 0x3f, 0x3f, 0x3e, 0x3d, 0x3c, 0x3c, 0x3b,
0x3a, 0x39, 0x39, 0x38, 0x37, 0x36, 0x36, 0x35, 0x34, 0x33, 0x33, 0x32, 0x31, 0x31, 0x30, 0x2f,
0x2e, 0x2e, 0x2d, 0x2c, 0x2c, 0x2b, 0x2a, 0x2a, 0x29, 0x28, 0x28, 0x27, 0x26, 0x26, 0x25, 0x24,
0x24, 0x23, 0x22, 0x22, 0x21, 0x20, 0x20, 0x1f, 0x1e, 0x1e, 0x1d, 0x1d, 0x1c, 0x1b, 0x1b, 0x1a,
0x19, 0x19, 0x18, 0x18, 0x17, 0x16, 0x16, 0x15, 0x15, 0x14, 0x14, 0x13, 0x12, 0x12, 0x11, 0x11,
0x10, 0x0f, 0x0f, 0x0e, 0x0e, 0x0d, 0x0d, 0x0c, 0x0c, 0x0b, 0x0a, 0x0a, 0x09, 0x09, 0x08, 0x08,
0x07, 0x07, 0x06, 0x06, 0x05, 0x05, 0x04, 0x04, 0x03, 0x03, 0x02, 0x02, 0x01, 0x01, 0x00, 0x00,
0x00
};
int shift = gte_leadingzerocount( denominator ) - 16;
int r1 = ( denominator << shift ) & 0x7fff;
int r2 = table[ ( ( r1 + 0x40 ) >> 7 ) ] + 0x101;
int r3 = ( ( 0x80 - ( r2 * ( r1 + 0x8000 ) ) ) >> 8 ) & 0x1ffff;
u32 reciprocal = ( ( r2 * r3 ) + 0x80 ) >> 8;
return (u32)( ( ( (u64) reciprocal * ( numerator << shift ) ) + 0x8000 ) >> 16 );
}
return 0xffffffff;
}
/* Setting bits 12 & 19-22 in FLAG does not set bit 31 */
s32 A1(/*int44*/s64 a) { return BOUNDS(a, (1 << 31) | (1 << 30), (1 << 31) | (1 << 27)); }
s32 A2(/*int44*/s64 a) { return BOUNDS(a, (1 << 31) | (1 << 29), (1 << 31) | (1 << 26)); }
s32 A3(/*int44*/s64 a) { m_mac3 = a; return BOUNDS(a, (1 << 31) | (1 << 28), (1 << 31) | (1 << 25)); }
s32 Lm_B1(s32 a, int lm) { return LIM(a, 0x7fff, -0x8000 * !lm, (1 << 31) | (1 << 24)); }
s32 Lm_B2(s32 a, int lm) { return LIM(a, 0x7fff, -0x8000 * !lm, (1 << 31) | (1 << 23)); }
s32 Lm_B3(s32 a, int lm) { return LIM(a, 0x7fff, -0x8000 * !lm, (1 << 22)); }
s32 Lm_B3_sf(s64 value, int sf, int lm) {
s32 value_sf = gte_shift(value, sf);
s32 value_12 = gte_shift(value, 1);
int max = 0x7fff;
int min = 0;
if(lm == 0)
min = -0x8000;
if(value_12 < -0x8000 || value_12 > 0x7fff)
FLAG |= (1 << 22);
if(value_sf > max)
return max;
else if(value_sf < min)
return min;
return value_sf;
}
s32 Lm_C1(s32 a) { return LIM(a, 0x00ff, 0x0000, (1 << 21)); }
s32 Lm_C2(s32 a) { return LIM(a, 0x00ff, 0x0000, (1 << 20)); }
s32 Lm_C3(s32 a) { return LIM(a, 0x00ff, 0x0000, (1 << 19)); }
s32 Lm_D(s64 a, int sf) { return LIM(gte_shift(a, sf), 0xffff, 0x0000, (1 << 31) | (1 << 18)); }
u32 Lm_E(u32 result) {
if(result == 0xffffffff) {
FLAG |= (1 << 31) | (1 << 17);
return 0x1ffff;
}
if(result > 0x1ffff)
return 0x1ffff;
return result;
}
s64 F(s64 a) {
m_mac0 = a;
if(a > S64(0x7fffffff))
FLAG |= (1 << 31) | (1 << 16);
if(a < S64(-0x80000000))
FLAG |= (1 << 31) | (1 << 15);
return a;
}
s32 Lm_G1(s64 a) {
if(a > 0x3ff) {
FLAG |= (1 << 31) | (1 << 14);
return 0x3ff;
}
if(a < -0x400) {
FLAG |= (1 << 31) | (1 << 14);
return -0x400;
}
return a;
}
s32 Lm_G2(s64 a) {
if(a > 0x3ff) {
FLAG |= (1 << 31) | (1 << 13);
return 0x3ff;
}
if(a < -0x400) {
FLAG |= (1 << 31) | (1 << 13);
return -0x400;
}
return a;
}
s32 Lm_G1_ia(s64 a) {
if(a > 0x3ffffff)
return 0x3ffffff;
if(a < -0x4000000)
return -0x4000000;
return a;
}
s32 Lm_G2_ia(s64 a) {
if(a > 0x3ffffff)
return 0x3ffffff;
if(a < -0x4000000)
return -0x4000000;
return a;
}
s32 Lm_H(s64 value, int sf) {
s64 value_sf = gte_shift(value, sf);
s32 value_12 = gte_shift(value, 1);
int max = 0x1000;
int min = 0x0000;
if(value_sf < min || value_sf > max)
FLAG |= (1 << 12);
if(value_12 > max)
return max;
if(value_12 < min)
return min;
return value_12;
}
int docop2(int op) {
int v;
int lm;
int cv;
int mx;
s32 h_over_sz3 = 0;
lm = GTE_LM(gteop);
m_sf = GTE_SF(gteop);
FLAG = 0;
switch(GTE_FUNCT(gteop)) {
case 0x00:
case 0x01:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: RTPS|", op);
#endif
MAC1 = A1(/*int44*/(s64)((s64) TRX << 12) + (R11 * VX0) + (R12 * VY0) + (R13 * VZ0));
MAC2 = A2(/*int44*/(s64)((s64) TRY << 12) + (R21 * VX0) + (R22 * VY0) + (R23 * VZ0));
MAC3 = A3(/*int44*/(s64)((s64) TRZ << 12) + (R31 * VX0) + (R32 * VY0) + (R33 * VZ0));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3_sf(m_mac3, m_sf, lm);
SZ0 = SZ1;
SZ1 = SZ2;
SZ2 = SZ3;
SZ3 = Lm_D(m_mac3, 1);
h_over_sz3 = Lm_E(gte_divide(H, SZ3));
SXY0 = SXY1;
SXY1 = SXY2;
SX2 = Lm_G1(F((s64) OFX + ((s64) IR1 * h_over_sz3) * (Config.Widescreen ? 0.75 : 1)) >> 16);
SY2 = Lm_G2(F((s64) OFY + ((s64) IR2 * h_over_sz3)) >> 16);
PGXP_pushSXYZ2s(Lm_G1_ia((s64)OFX + (s64)(IR1 * h_over_sz3) * (Config.Widescreen ? 0.75 : 1)),
Lm_G2_ia((s64)OFY + (s64)(IR2 * h_over_sz3)),
max(SZ3, H/2), SXY2);
//PGXP_RTPS(0, SXY2);
MAC0 = F((s64) DQB + ((s64) DQA * h_over_sz3));
IR0 = Lm_H(m_mac0, 1);
return 1;
case 0x06:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: NCLIP|", op);
#endif
if (PGXP_NLCIP_valid(SXY0, SXY1, SXY2))
MAC0 = F(PGXP_NCLIP());
else
MAC0 = F((s64) (SX0 * SY1) + (SX1 * SY2) + (SX2 * SY0) - (SX0 * SY2) - (SX1 * SY0) - (SX2 * SY1));
return 1;
case 0x0c:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: OP|", op);
#endif
MAC1 = A1((s64) (R22 * IR3) - (R33 * IR2));
MAC2 = A2((s64) (R33 * IR1) - (R11 * IR3));
MAC3 = A3((s64) (R11 * IR2) - (R22 * IR1));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
return 1;
case 0x10:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: DPCS|", op);
#endif
MAC1 = A1((R << 16) + (IR0 * Lm_B1(A1(((s64) RFC << 12) - (R << 16)), 0)));
MAC2 = A2((G << 16) + (IR0 * Lm_B2(A2(((s64) GFC << 12) - (G << 16)), 0)));
MAC3 = A3((B << 16) + (IR0 * Lm_B3(A3(((s64) BFC << 12) - (B << 16)), 0)));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
RGB0 = RGB1;
RGB1 = RGB2;
CD2 = CODE;
R2 = Lm_C1(MAC1 >> 4);
G2 = Lm_C2(MAC2 >> 4);
B2 = Lm_C3(MAC3 >> 4);
return 1;
case 0x11:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: INTPL|", op);
#endif
MAC1 = A1((IR1 << 12) + (IR0 * Lm_B1(A1(((s64) RFC << 12) - (IR1 << 12)), 0)));
MAC2 = A2((IR2 << 12) + (IR0 * Lm_B2(A2(((s64) GFC << 12) - (IR2 << 12)), 0)));
MAC3 = A3((IR3 << 12) + (IR0 * Lm_B3(A3(((s64) BFC << 12) - (IR3 << 12)), 0)));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
RGB0 = RGB1;
RGB1 = RGB2;
CD2 = CODE;
R2 = Lm_C1(MAC1 >> 4);
G2 = Lm_C2(MAC2 >> 4);
B2 = Lm_C3(MAC3 >> 4);
return 1;
case 0x12:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: MVMVA|", op);
#endif
mx = GTE_MX(gteop);
v = GTE_V(gteop);
cv = GTE_CV(gteop);
switch(cv) {
case 2:
MAC1 = A1((s64) (MX12(mx) * VY(v)) + (MX13(mx) * VZ(v)));
MAC2 = A2((s64) (MX22(mx) * VY(v)) + (MX23(mx) * VZ(v)));
MAC3 = A3((s64) (MX32(mx) * VY(v)) + (MX33(mx) * VZ(v)));
Lm_B1(A1(((s64) CV1(cv) << 12) + (MX11(mx) * VX(v))), 0);
Lm_B2(A2(((s64) CV2(cv) << 12) + (MX21(mx) * VX(v))), 0);
Lm_B3(A3(((s64) CV3(cv) << 12) + (MX31(mx) * VX(v))), 0);
break;
default:
MAC1 = A1(/*int44*/(s64)((s64) CV1(cv) << 12) + (MX11(mx) * VX(v)) + (MX12(mx) * VY(v)) + (MX13(mx) * VZ(v)));
MAC2 = A2(/*int44*/(s64)((s64) CV2(cv) << 12) + (MX21(mx) * VX(v)) + (MX22(mx) * VY(v)) + (MX23(mx) * VZ(v)));
MAC3 = A3(/*int44*/(s64)((s64) CV3(cv) << 12) + (MX31(mx) * VX(v)) + (MX32(mx) * VY(v)) + (MX33(mx) * VZ(v)));
break;
}
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
return 1;
case 0x13:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: NCDS|", op);
#endif
MAC1 = A1((s64) (L11 * VX0) + (L12 * VY0) + (L13 * VZ0));
MAC2 = A2((s64) (L21 * VX0) + (L22 * VY0) + (L23 * VZ0));
MAC3 = A3((s64) (L31 * VX0) + (L32 * VY0) + (L33 * VZ0));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
MAC1 = A1(/*int44*/(s64)((s64) RBK << 12) + (LR1 * IR1) + (LR2 * IR2) + (LR3 * IR3));
MAC2 = A2(/*int44*/(s64)((s64) GBK << 12) + (LG1 * IR1) + (LG2 * IR2) + (LG3 * IR3));
MAC3 = A3(/*int44*/(s64)((s64) BBK << 12) + (LB1 * IR1) + (LB2 * IR2) + (LB3 * IR3));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
MAC1 = A1(((R << 4) * IR1) + (IR0 * Lm_B1(A1(((s64) RFC << 12) - ((R << 4) * IR1)), 0)));
MAC2 = A2(((G << 4) * IR2) + (IR0 * Lm_B2(A2(((s64) GFC << 12) - ((G << 4) * IR2)), 0)));
MAC3 = A3(((B << 4) * IR3) + (IR0 * Lm_B3(A3(((s64) BFC << 12) - ((B << 4) * IR3)), 0)));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
RGB0 = RGB1;
RGB1 = RGB2;
CD2 = CODE;
R2 = Lm_C1(MAC1 >> 4);
G2 = Lm_C2(MAC2 >> 4);
B2 = Lm_C3(MAC3 >> 4);
return 1;
case 0x14:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: CDP|", op);
#endif
MAC1 = A1(/*int44*/(s64)((s64) RBK << 12) + (LR1 * IR1) + (LR2 * IR2) + (LR3 * IR3));
MAC2 = A2(/*int44*/(s64)((s64) GBK << 12) + (LG1 * IR1) + (LG2 * IR2) + (LG3 * IR3));
MAC3 = A3(/*int44*/(s64)((s64) BBK << 12) + (LB1 * IR1) + (LB2 * IR2) + (LB3 * IR3));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
MAC1 = A1(((R << 4) * IR1) + (IR0 * Lm_B1(A1(((s64) RFC << 12) - ((R << 4) * IR1)), 0)));
MAC2 = A2(((G << 4) * IR2) + (IR0 * Lm_B2(A2(((s64) GFC << 12) - ((G << 4) * IR2)), 0)));
MAC3 = A3(((B << 4) * IR3) + (IR0 * Lm_B3(A3(((s64) BFC << 12) - ((B << 4) * IR3)), 0)));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
RGB0 = RGB1;
RGB1 = RGB2;
CD2 = CODE;
R2 = Lm_C1(MAC1 >> 4);
G2 = Lm_C2(MAC2 >> 4);
B2 = Lm_C3(MAC3 >> 4);
return 1;
case 0x16:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: NCDT|", op);
#endif
for(v = 0; v < 3; v++) {
MAC1 = A1((s64) (L11 * VX(v)) + (L12 * VY(v)) + (L13 * VZ(v)));
MAC2 = A2((s64) (L21 * VX(v)) + (L22 * VY(v)) + (L23 * VZ(v)));
MAC3 = A3((s64) (L31 * VX(v)) + (L32 * VY(v)) + (L33 * VZ(v)));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
MAC1 = A1(/*int44*/(s64)((s64) RBK << 12) + (LR1 * IR1) + (LR2 * IR2) + (LR3 * IR3));
MAC2 = A2(/*int44*/(s64)((s64) GBK << 12) + (LG1 * IR1) + (LG2 * IR2) + (LG3 * IR3));
MAC3 = A3(/*int44*/(s64)((s64) BBK << 12) + (LB1 * IR1) + (LB2 * IR2) + (LB3 * IR3));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
MAC1 = A1(((R << 4) * IR1) + (IR0 * Lm_B1(A1(((s64) RFC << 12) - ((R << 4) * IR1)), 0)));
MAC2 = A2(((G << 4) * IR2) + (IR0 * Lm_B2(A2(((s64) GFC << 12) - ((G << 4) * IR2)), 0)));
MAC3 = A3(((B << 4) * IR3) + (IR0 * Lm_B3(A3(((s64) BFC << 12) - ((B << 4) * IR3)), 0)));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
RGB0 = RGB1;
RGB1 = RGB2;
CD2 = CODE;
R2 = Lm_C1(MAC1 >> 4);
G2 = Lm_C2(MAC2 >> 4);
B2 = Lm_C3(MAC3 >> 4);
}
return 1;
case 0x1b:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: NCCS|", op);
#endif
MAC1 = A1((s64) (L11 * VX0) + (L12 * VY0) + (L13 * VZ0));
MAC2 = A2((s64) (L21 * VX0) + (L22 * VY0) + (L23 * VZ0));
MAC3 = A3((s64) (L31 * VX0) + (L32 * VY0) + (L33 * VZ0));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
MAC1 = A1(/*int44*/(s64)((s64) RBK << 12) + (LR1 * IR1) + (LR2 * IR2) + (LR3 * IR3));
MAC2 = A2(/*int44*/(s64)((s64) GBK << 12) + (LG1 * IR1) + (LG2 * IR2) + (LG3 * IR3));
MAC3 = A3(/*int44*/(s64)((s64) BBK << 12) + (LB1 * IR1) + (LB2 * IR2) + (LB3 * IR3));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
MAC1 = A1((R << 4) * IR1);
MAC2 = A2((G << 4) * IR2);
MAC3 = A3((B << 4) * IR3);
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
RGB0 = RGB1;
RGB1 = RGB2;
CD2 = CODE;
R2 = Lm_C1(MAC1 >> 4);
G2 = Lm_C2(MAC2 >> 4);
B2 = Lm_C3(MAC3 >> 4);
return 1;
case 0x1c:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: CC|", op);
#endif
MAC1 = A1(/*int44*/(s64)(((s64) RBK) << 12) + (LR1 * IR1) + (LR2 * IR2) + (LR3 * IR3));
MAC2 = A2(/*int44*/(s64)(((s64) GBK) << 12) + (LG1 * IR1) + (LG2 * IR2) + (LG3 * IR3));
MAC3 = A3(/*int44*/(s64)(((s64) BBK) << 12) + (LB1 * IR1) + (LB2 * IR2) + (LB3 * IR3));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
MAC1 = A1((R << 4) * IR1);
MAC2 = A2((G << 4) * IR2);
MAC3 = A3((B << 4) * IR3);
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
RGB0 = RGB1;
RGB1 = RGB2;
CD2 = CODE;
R2 = Lm_C1(MAC1 >> 4);
G2 = Lm_C2(MAC2 >> 4);
B2 = Lm_C3(MAC3 >> 4);
return 1;
case 0x1e:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: NCS|", op);
#endif
MAC1 = A1((s64) (L11 * VX0) + (L12 * VY0) + (L13 * VZ0));
MAC2 = A2((s64) (L21 * VX0) + (L22 * VY0) + (L23 * VZ0));
MAC3 = A3((s64) (L31 * VX0) + (L32 * VY0) + (L33 * VZ0));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
MAC1 = A1(/*int44*/(s64)((s64) RBK << 12) + (LR1 * IR1) + (LR2 * IR2) + (LR3 * IR3));
MAC2 = A2(/*int44*/(s64)((s64) GBK << 12) + (LG1 * IR1) + (LG2 * IR2) + (LG3 * IR3));
MAC3 = A3(/*int44*/(s64)((s64) BBK << 12) + (LB1 * IR1) + (LB2 * IR2) + (LB3 * IR3));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
RGB0 = RGB1;
RGB1 = RGB2;
CD2 = CODE;
R2 = Lm_C1(MAC1 >> 4);
G2 = Lm_C2(MAC2 >> 4);
B2 = Lm_C3(MAC3 >> 4);
return 1;
case 0x20:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: NCT|", op);
#endif
for(v = 0; v < 3; v++) {
MAC1 = A1((s64) (L11 * VX(v)) + (L12 * VY(v)) + (L13 * VZ(v)));
MAC2 = A2((s64) (L21 * VX(v)) + (L22 * VY(v)) + (L23 * VZ(v)));
MAC3 = A3((s64) (L31 * VX(v)) + (L32 * VY(v)) + (L33 * VZ(v)));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
MAC1 = A1(/*int44*/(s64)((s64) RBK << 12) + (LR1 * IR1) + (LR2 * IR2) + (LR3 * IR3));
MAC2 = A2(/*int44*/(s64)((s64) GBK << 12) + (LG1 * IR1) + (LG2 * IR2) + (LG3 * IR3));
MAC3 = A3(/*int44*/(s64)((s64) BBK << 12) + (LB1 * IR1) + (LB2 * IR2) + (LB3 * IR3));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
RGB0 = RGB1;
RGB1 = RGB2;
CD2 = CODE;
R2 = Lm_C1(MAC1 >> 4);
G2 = Lm_C2(MAC2 >> 4);
B2 = Lm_C3(MAC3 >> 4);
}
return 1;
case 0x28:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: SQR|", op);
#endif
MAC1 = A1(IR1 * IR1);
MAC2 = A2(IR2 * IR2);
MAC3 = A3(IR3 * IR3);
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
return 1;
case 0x29:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: DPCL|", op);
#endif
MAC1 = A1(((R << 4) * IR1) + (IR0 * Lm_B1(A1(((s64) RFC << 12) - ((R << 4) * IR1)), 0)));
MAC2 = A2(((G << 4) * IR2) + (IR0 * Lm_B2(A2(((s64) GFC << 12) - ((G << 4) * IR2)), 0)));
MAC3 = A3(((B << 4) * IR3) + (IR0 * Lm_B3(A3(((s64) BFC << 12) - ((B << 4) * IR3)), 0)));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
RGB0 = RGB1;
RGB1 = RGB2;
CD2 = CODE;
R2 = Lm_C1(MAC1 >> 4);
G2 = Lm_C2(MAC2 >> 4);
B2 = Lm_C3(MAC3 >> 4);
return 1;
case 0x2a:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: DPCT|", op);
#endif
for(v = 0; v < 3; v++) {
MAC1 = A1((R0 << 16) + (IR0 * Lm_B1(A1(((s64) RFC << 12) - (R0 << 16)), 0)));
MAC2 = A2((G0 << 16) + (IR0 * Lm_B2(A2(((s64) GFC << 12) - (G0 << 16)), 0)));
MAC3 = A3((B0 << 16) + (IR0 * Lm_B3(A3(((s64) BFC << 12) - (B0 << 16)), 0)));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
RGB0 = RGB1;
RGB1 = RGB2;
CD2 = CODE;
R2 = Lm_C1(MAC1 >> 4);
G2 = Lm_C2(MAC2 >> 4);
B2 = Lm_C3(MAC3 >> 4);
}
return 1;
case 0x2d:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: AVSZ3|", op);
#endif
MAC0 = F((s64) (ZSF3 * SZ1) + (ZSF3 * SZ2) + (ZSF3 * SZ3));
OTZ = Lm_D(m_mac0, 1);
return 1;
case 0x2e:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: AVSZ4|", op);
#endif
MAC0 = F((s64) (ZSF4 * SZ0) + (ZSF4 * SZ1) + (ZSF4 * SZ2) + (ZSF4 * SZ3));
OTZ = Lm_D(m_mac0, 1);
return 1;
case 0x30:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: RTPT|", op);
#endif
for(v = 0; v < 3; v++) {
MAC1 = A1(/*int44*/(s64)((s64) TRX << 12) + (R11 * VX(v)) + (R12 * VY(v)) + (R13 * VZ(v)));
MAC2 = A2(/*int44*/(s64)((s64) TRY << 12) + (R21 * VX(v)) + (R22 * VY(v)) + (R23 * VZ(v)));
MAC3 = A3(/*int44*/(s64)((s64) TRZ << 12) + (R31 * VX(v)) + (R32 * VY(v)) + (R33 * VZ(v)));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3_sf(m_mac3, m_sf, lm);
SZ0 = SZ1;
SZ1 = SZ2;
SZ2 = SZ3;
SZ3 = Lm_D(m_mac3, 1);
h_over_sz3 = Lm_E(gte_divide(H, SZ3));
SXY0 = SXY1;
SXY1 = SXY2;
SX2 = Lm_G1(F((s64) OFX + ((s64) IR1 * h_over_sz3) * (Config.Widescreen ? 0.75 : 1)) >> 16);
SY2 = Lm_G2(F((s64) OFY + ((s64) IR2 * h_over_sz3)) >> 16);
//float tempMx = MAC1;
//float tempx = IR1;
//float temphow = (float)h_over_sz3 / (float)(1 << 16);
//float tempMz = MAC3;
//float tempZ = SZ3;
//
PGXP_pushSXYZ2s(Lm_G1_ia((s64)OFX + (s64)(IR1 * h_over_sz3) * (Config.Widescreen ? 0.75 : 1)),
Lm_G2_ia((s64)OFY + (s64)(IR2 * h_over_sz3)),
max(SZ3, H/2), SXY2);
//PGXP_RTPS(v, SXY2);
}
MAC0 = F((s64) DQB + ((s64) DQA * h_over_sz3));
IR0 = Lm_H(m_mac0, 1);
return 1;
case 0x3d:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: GPF|", op);
#endif
MAC1 = A1(IR0 * IR1);
MAC2 = A2(IR0 * IR2);
MAC3 = A3(IR0 * IR3);
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
RGB0 = RGB1;
RGB1 = RGB2;
CD2 = CODE;
R2 = Lm_C1(MAC1 >> 4);
G2 = Lm_C2(MAC2 >> 4);
B2 = Lm_C3(MAC3 >> 4);
return 1;
case 0x3e:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: GPL|", op);
#endif
MAC1 = A1(gte_shift(MAC1, -m_sf) + (IR0 * IR1));
MAC2 = A2(gte_shift(MAC2, -m_sf) + (IR0 * IR2));
MAC3 = A3(gte_shift(MAC3, -m_sf) + (IR0 * IR3));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
RGB0 = RGB1;
RGB1 = RGB2;
CD2 = CODE;
R2 = Lm_C1(MAC1 >> 4);
G2 = Lm_C2(MAC2 >> 4);
B2 = Lm_C3(MAC3 >> 4);
return 1;
case 0x3f:
#ifdef GTE_LOG
GTE_LOG("%08x GTE: NCCT|", op);
#endif
for(v = 0; v < 3; v++) {
MAC1 = A1((s64) (L11 * VX(v)) + (L12 * VY(v)) + (L13 * VZ(v)));
MAC2 = A2((s64) (L21 * VX(v)) + (L22 * VY(v)) + (L23 * VZ(v)));
MAC3 = A3((s64) (L31 * VX(v)) + (L32 * VY(v)) + (L33 * VZ(v)));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
MAC1 = A1(/*int44*/(s64)((s64) RBK << 12) + (LR1 * IR1) + (LR2 * IR2) + (LR3 * IR3));
MAC2 = A2(/*int44*/(s64)((s64) GBK << 12) + (LG1 * IR1) + (LG2 * IR2) + (LG3 * IR3));
MAC3 = A3(/*int44*/(s64)((s64) BBK << 12) + (LB1 * IR1) + (LB2 * IR2) + (LB3 * IR3));
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
MAC1 = A1((R << 4) * IR1);
MAC2 = A2((G << 4) * IR2);
MAC3 = A3((B << 4) * IR3);
IR1 = Lm_B1(MAC1, lm);
IR2 = Lm_B2(MAC2, lm);
IR3 = Lm_B3(MAC3, lm);
RGB0 = RGB1;
RGB1 = RGB2;
CD2 = CODE;
R2 = Lm_C1(MAC1 >> 4);
G2 = Lm_C2(MAC2 >> 4);
B2 = Lm_C3(MAC3 >> 4);
}
return 1;
}
return 0;
}
void gteRTPS() {
docop2(gteop);
}
void gteNCLIP() {
docop2(gteop);
}
void gteOP() {
docop2(gteop);
}
void gteDPCS() {
docop2(gteop);
}
void gteINTPL() {
docop2(gteop);
}
void gteMVMVA() {
docop2(gteop);
}
void gteNCDS() {
docop2(gteop);
}
void gteCDP() {
docop2(gteop);
}
void gteNCDT() {
docop2(gteop);
}
void gteNCCS() {
docop2(gteop);
}
void gteCC() {
docop2(gteop);
}
void gteNCS() {
docop2(gteop);
}
void gteNCT() {
docop2(gteop);
}
void gteSQR() {
docop2(gteop);
}
void gteDCPL() {
docop2(gteop);
}
void gteDPCT() {
docop2(gteop);
}
void gteAVSZ3() {
docop2(gteop);
}
void gteAVSZ4() {
docop2(gteop);
}
void gteRTPT() {
docop2(gteop);
}
void gteGPF() {
docop2(gteop);
}
void gteGPL() {
docop2(gteop);
}
void gteNCCT() {
docop2(gteop);
}