diff options
author | ameerj <52414509+ameerj@users.noreply.github.com> | 2021-02-27 03:41:46 +0100 |
---|---|---|
committer | ameerj <52414509+ameerj@users.noreply.github.com> | 2021-07-23 03:51:22 +0200 |
commit | a8c41c50d3f7a1c2871487862f68925db8b5e27f (patch) | |
tree | 06c37fb9cb9071b9fdeea4a61518d4b1e11a5968 /src/shader_recompiler/frontend/maxwell/translate/impl/integer_popcount.cpp | |
parent | shader: Implement SHR (diff) | |
download | yuzu-a8c41c50d3f7a1c2871487862f68925db8b5e27f.tar yuzu-a8c41c50d3f7a1c2871487862f68925db8b5e27f.tar.gz yuzu-a8c41c50d3f7a1c2871487862f68925db8b5e27f.tar.bz2 yuzu-a8c41c50d3f7a1c2871487862f68925db8b5e27f.tar.lz yuzu-a8c41c50d3f7a1c2871487862f68925db8b5e27f.tar.xz yuzu-a8c41c50d3f7a1c2871487862f68925db8b5e27f.tar.zst yuzu-a8c41c50d3f7a1c2871487862f68925db8b5e27f.zip |
Diffstat (limited to 'src/shader_recompiler/frontend/maxwell/translate/impl/integer_popcount.cpp')
-rw-r--r-- | src/shader_recompiler/frontend/maxwell/translate/impl/integer_popcount.cpp | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/src/shader_recompiler/frontend/maxwell/translate/impl/integer_popcount.cpp b/src/shader_recompiler/frontend/maxwell/translate/impl/integer_popcount.cpp new file mode 100644 index 000000000..5ece7678d --- /dev/null +++ b/src/shader_recompiler/frontend/maxwell/translate/impl/integer_popcount.cpp @@ -0,0 +1,36 @@ +// Copyright 2021 yuzu Emulator Project +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#include "common/bit_field.h" +#include "common/common_types.h" +#include "shader_recompiler/frontend/maxwell/translate/impl/impl.h" + +namespace Shader::Maxwell { +namespace { +void POPC(TranslatorVisitor& v, u64 insn, const IR::U32& src) { + union { + u64 raw; + BitField<0, 8, IR::Reg> dest_reg; + BitField<40, 1, u64> tilde; + } const popc{insn}; + + const IR::U32 operand = popc.tilde == 0 ? src : v.ir.BitwiseNot(src); + const IR::U32 result = v.ir.BitCount(operand); + v.X(popc.dest_reg, result); +} +} // Anonymous namespace + +void TranslatorVisitor::POPC_reg(u64 insn) { + POPC(*this, insn, GetReg20(insn)); +} + +void TranslatorVisitor::POPC_cbuf(u64 insn) { + POPC(*this, insn, GetCbuf(insn)); +} + +void TranslatorVisitor::POPC_imm(u64 insn) { + POPC(*this, insn, GetImm20(insn)); +} + +} // namespace Shader::Maxwell |