From 369c0c4ce20859448a82c509661cbfe90dcc8d44 Mon Sep 17 00:00:00 2001 From: magumagu Date: Thu, 8 May 2014 15:43:41 -0700 Subject: [PATCH] Opcode decoding: 0xC0 isn't a valid command. Fix our opcode decoders to handle this appropriately. --- Source/Core/VideoBackends/Software/OpcodeDecoder.cpp | 4 ++-- Source/Core/VideoBackends/Software/OpcodeDecoder.h | 2 +- Source/Core/VideoCommon/OpcodeDecoding.cpp | 6 +++--- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/Source/Core/VideoBackends/Software/OpcodeDecoder.cpp b/Source/Core/VideoBackends/Software/OpcodeDecoder.cpp index f9d01b7de5..52bd632e15 100644 --- a/Source/Core/VideoBackends/Software/OpcodeDecoder.cpp +++ b/Source/Core/VideoBackends/Software/OpcodeDecoder.cpp @@ -201,7 +201,7 @@ void DecodeStandard(u32 bufferSize) // draw primitives default: - if (Cmd & 0x80) + if ((Cmd & 0xC0) == 0x80) { u8 vatIndex = Cmd & GX_VAT_MASK; u8 primitiveType = (Cmd & GX_PRIMITIVE_MASK) >> GX_PRIMITIVE_SHIFT; @@ -283,7 +283,7 @@ bool CommandRunnable(u32 iBufferSize) // draw primitives default: - if (Cmd & 0x80) + if ((Cmd & 0xC0) == 0x80) minSize = 3; break; } diff --git a/Source/Core/VideoBackends/Software/OpcodeDecoder.h b/Source/Core/VideoBackends/Software/OpcodeDecoder.h index 3d33b18d40..8fd145ef1d 100644 --- a/Source/Core/VideoBackends/Software/OpcodeDecoder.h +++ b/Source/Core/VideoBackends/Software/OpcodeDecoder.h @@ -23,7 +23,7 @@ namespace OpcodeDecoder #define GX_CMD_CALL_DL 0x40 #define GX_CMD_INVL_VC 0x48 - #define GX_PRIMITIVE_MASK 0x78 + #define GX_PRIMITIVE_MASK 0x38 #define GX_PRIMITIVE_SHIFT 3 #define GX_VAT_MASK 0x07 diff --git a/Source/Core/VideoCommon/OpcodeDecoding.cpp b/Source/Core/VideoCommon/OpcodeDecoding.cpp index 703f691e7e..2500dbdd38 100644 --- a/Source/Core/VideoCommon/OpcodeDecoding.cpp +++ b/Source/Core/VideoCommon/OpcodeDecoding.cpp @@ -201,7 +201,7 @@ u32 FifoCommandRunnable(u32 &command_size) break; default: - if (cmd_byte & 0x80) + if ((cmd_byte & 0xC0) == 0x80) { // check if we can read the header if (buffer_size >= 3) @@ -346,7 +346,7 @@ static void Decode() // draw primitives default: - if (cmd_byte & 0x80) + if ((cmd_byte & 0xC0) == 0x80) { // load vertices (use computed vertex size from FifoCommandRunnable above) u16 numVertices = DataReadU16(); @@ -434,7 +434,7 @@ static void DecodeSemiNop() // draw primitives default: - if (cmd_byte & 0x80) + if ((cmd_byte & 0xC0) == 0x80) { // load vertices (use computed vertex size from FifoCommandRunnable above) u16 numVertices = DataReadU16();