From: notaz Date: Fri, 4 Feb 2011 22:09:39 +0000 (+0200) Subject: gte: backport fixes from pcsxr X-Git-Tag: r6~18 X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?p=pcsx_rearmed.git;a=commitdiff_plain;h=7384197d8a5fd20a4d94f3517a6462f7fe86dd4c gte: backport fixes from pcsxr shalma: Lego Racers - gte.c - fix mfc2 r30 (and r29) - fixes main menu loading Motor Toon Grand Prix 2 - gte.c - repair mtc2 - r7,r29 - fixes disappearing objects Valkyrie Profile - gte.c - use edgbla value of limH $1000 - fixes world map loading - seems to work, unverified value Tales of Destiny 2 - gte.c - repair SQR - IR output - fixes underwater lighting --- diff --git a/libpcsxcore/gte.c b/libpcsxcore/gte.c index 00e79544..ec173b56 100644 --- a/libpcsxcore/gte.c +++ b/libpcsxcore/gte.c @@ -211,7 +211,7 @@ static inline u32 limE(u32 result) { #define F(a) BOUNDS((a), 0x7fffffff, (1 << 31) | (1 << 16), -(s64)0x80000000, (1 << 31) | (1 << 15)) #define limG1(a) LIM((a), 0x3ff, -0x400, (1 << 31) | (1 << 14)) #define limG2(a) LIM((a), 0x3ff, -0x400, (1 << 31) | (1 << 13)) -#define limH(a) LIM((a), 0xfff, 0x000, (1 << 12)) +#define limH(a) LIM((a), 0x1000, 0x0000, (1 << 12)) #include "gte_divider.h" @@ -240,9 +240,6 @@ static inline u32 MFC2(int reg) { break; case 28: - case 30: - return 0; - case 29: psxRegs.CP2D.r[reg] = LIM(gteIR1 >> 7, 0x1f, 0, 0) | (LIM(gteIR2 >> 7, 0x1f, 0, 0) << 5) | @@ -289,8 +286,6 @@ static inline void MTC2(u32 value, int reg) { } break; - case 7: - case 29: case 31: return; @@ -483,9 +478,9 @@ void gteSQR() { gteMAC1 = A1((gteIR1 * gteIR1) >> shift); gteMAC2 = A2((gteIR2 * gteIR2) >> shift); gteMAC3 = A3((gteIR3 * gteIR3) >> shift); - gteIR1 = limB1(gteMAC1 >> shift, lm); - gteIR2 = limB2(gteMAC2 >> shift, lm); - gteIR3 = limB3(gteMAC3 >> shift, lm); + gteIR1 = limB1(gteMAC1, lm); + gteIR2 = limB2(gteMAC2, lm); + gteIR3 = limB3(gteMAC3, lm); } void gteNCCS() {