summaryrefslogtreecommitdiff
path: root/src/shader_recompiler/frontend/maxwell/translate/impl/vote.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/shader_recompiler/frontend/maxwell/translate/impl/vote.cpp')
-rw-r--r--src/shader_recompiler/frontend/maxwell/translate/impl/vote.cpp52
1 files changed, 52 insertions, 0 deletions
diff --git a/src/shader_recompiler/frontend/maxwell/translate/impl/vote.cpp b/src/shader_recompiler/frontend/maxwell/translate/impl/vote.cpp
new file mode 100644
index 000000000..a88894a7e
--- /dev/null
+++ b/src/shader_recompiler/frontend/maxwell/translate/impl/vote.cpp
@@ -0,0 +1,52 @@
1// Copyright 2021 yuzu Emulator Project
2// Licensed under GPLv2 or any later version
3// Refer to the license.txt file included.
4
5#include <optional>
6
7#include "common/bit_field.h"
8#include "common/common_types.h"
9#include "shader_recompiler/frontend/maxwell/translate/impl/impl.h"
10
11namespace Shader::Maxwell {
12namespace {
13enum class VoteOp : u64 {
14 ALL,
15 ANY,
16 EQ,
17};
18
19[[nodiscard]] IR::U1 VoteOperation(IR::IREmitter& ir, const IR::U1& pred, VoteOp vote_op) {
20 switch (vote_op) {
21 case VoteOp::ALL:
22 return ir.VoteAll(pred);
23 case VoteOp::ANY:
24 return ir.VoteAny(pred);
25 case VoteOp::EQ:
26 return ir.VoteEqual(pred);
27 default:
28 throw NotImplementedException("Invalid VOTE op {}", vote_op);
29 }
30}
31
32void Vote(TranslatorVisitor& v, u64 insn) {
33 union {
34 u64 insn;
35 BitField<0, 8, IR::Reg> dest_reg;
36 BitField<39, 3, IR::Pred> pred_a;
37 BitField<42, 1, u64> neg_pred_a;
38 BitField<45, 3, IR::Pred> pred_b;
39 BitField<48, 2, VoteOp> vote_op;
40 } const vote{insn};
41
42 const IR::U1 vote_pred{v.ir.GetPred(vote.pred_a, vote.neg_pred_a != 0)};
43 v.ir.SetPred(vote.pred_b, VoteOperation(v.ir, vote_pred, vote.vote_op));
44 v.X(vote.dest_reg, v.ir.SubgroupBallot(vote_pred));
45}
46} // Anonymous namespace
47
48void TranslatorVisitor::VOTE(u64 insn) {
49 Vote(*this, insn);
50}
51
52} // namespace Shader::Maxwell