diff options
author | bunnei <bunneidev@gmail.com> | 2020-10-31 09:25:02 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-10-31 09:25:02 +0100 |
commit | 98f68d06f17dd8e7d26c3fec8598683af9f8b32d (patch) | |
tree | 0c34040b73ac68aea8dc8f61b829a9fb500b453c /src/video_core | |
parent | Merge pull request #4872 from jbeich/clang (diff) | |
parent | shader/arithmetic: Implement FCMP immediate + register variant (diff) | |
download | yuzu-98f68d06f17dd8e7d26c3fec8598683af9f8b32d.tar yuzu-98f68d06f17dd8e7d26c3fec8598683af9f8b32d.tar.gz yuzu-98f68d06f17dd8e7d26c3fec8598683af9f8b32d.tar.bz2 yuzu-98f68d06f17dd8e7d26c3fec8598683af9f8b32d.tar.lz yuzu-98f68d06f17dd8e7d26c3fec8598683af9f8b32d.tar.xz yuzu-98f68d06f17dd8e7d26c3fec8598683af9f8b32d.tar.zst yuzu-98f68d06f17dd8e7d26c3fec8598683af9f8b32d.zip |
Diffstat (limited to 'src/video_core')
-rw-r--r-- | src/video_core/engines/shader_bytecode.h | 2 | ||||
-rw-r--r-- | src/video_core/shader/decode/arithmetic.cpp | 3 |
2 files changed, 4 insertions, 1 deletions
diff --git a/src/video_core/engines/shader_bytecode.h b/src/video_core/engines/shader_bytecode.h index d374b73cf..a3c05d1b0 100644 --- a/src/video_core/engines/shader_bytecode.h +++ b/src/video_core/engines/shader_bytecode.h @@ -1893,6 +1893,7 @@ public: ICMP_IMM, FCMP_RR, FCMP_RC, + FCMP_IMMR, MUFU, // Multi-Function Operator RRO_C, // Range Reduction Operator RRO_R, @@ -2205,6 +2206,7 @@ private: INST("0111110-0-------", Id::HSET2_IMM, Type::HalfSet, "HSET2_IMM"), INST("010110111010----", Id::FCMP_RR, Type::Arithmetic, "FCMP_RR"), INST("010010111010----", Id::FCMP_RC, Type::Arithmetic, "FCMP_RC"), + INST("0011011-1010----", Id::FCMP_IMMR, Type::Arithmetic, "FCMP_IMMR"), INST("0101000010000---", Id::MUFU, Type::Arithmetic, "MUFU"), INST("0100110010010---", Id::RRO_C, Type::Arithmetic, "RRO_C"), INST("0101110010010---", Id::RRO_R, Type::Arithmetic, "RRO_R"), diff --git a/src/video_core/shader/decode/arithmetic.cpp b/src/video_core/shader/decode/arithmetic.cpp index 4db329fa5..afef5948d 100644 --- a/src/video_core/shader/decode/arithmetic.cpp +++ b/src/video_core/shader/decode/arithmetic.cpp @@ -137,7 +137,8 @@ u32 ShaderIR::DecodeArithmetic(NodeBlock& bb, u32 pc) { break; } case OpCode::Id::FCMP_RR: - case OpCode::Id::FCMP_RC: { + case OpCode::Id::FCMP_RC: + case OpCode::Id::FCMP_IMMR: { UNIMPLEMENTED_IF(instr.fcmp.ftz == 0); Node op_c = GetRegister(instr.gpr39); Node comp = GetPredicateComparisonFloat(instr.fcmp.cond, std::move(op_c), Immediate(0.0f)); |