|
|
|
@ -120,10 +120,6 @@ static void ProcessShaderCode(VertexShaderState& state) { |
|
|
|
case OpCode::Type::Arithmetic: |
|
|
|
{ |
|
|
|
bool is_inverted = 0 != (instr.opcode.Value().GetInfo().subtype & OpCode::Info::SrcInversed); |
|
|
|
// TODO: We don't really support this properly: For instance, the address register
|
|
|
|
// offset needs to be applied to SRC2 instead, etc.
|
|
|
|
// For now, we just abort in this situation.
|
|
|
|
ASSERT_MSG(!is_inverted, "Bad condition..."); |
|
|
|
|
|
|
|
const int address_offset = (instr.common.address_register_index == 0) |
|
|
|
? 0 : state.address_registers[instr.common.address_register_index - 1]; |
|
|
|
@ -288,6 +284,16 @@ static void ProcessShaderCode(VertexShaderState& state) { |
|
|
|
break; |
|
|
|
} |
|
|
|
|
|
|
|
case OpCode::Id::SLT: |
|
|
|
case OpCode::Id::SLTI: |
|
|
|
for (int i = 0; i < 4; ++i) { |
|
|
|
if (!swizzle.DestComponentEnabled(i)) |
|
|
|
continue; |
|
|
|
|
|
|
|
dest[i] = (src1[i] < src2[i]) ? float24::FromFloat32(1.0f) : float24::FromFloat32(0.0f); |
|
|
|
} |
|
|
|
break; |
|
|
|
|
|
|
|
case OpCode::Id::CMP: |
|
|
|
for (int i = 0; i < 2; ++i) { |
|
|
|
// TODO: Can you restrict to one compare via dest masking?
|
|
|
|
|