mirror of
https://git.suyu.dev/suyu/suyu.git
synced 2024-11-18 04:42:45 +01:00
47 lines
1.8 KiB
C++
47 lines
1.8 KiB
C++
|
// Copyright 2021 yuzu Emulator Project
|
||
|
// Licensed under GPLv2 or any later version
|
||
|
// Refer to the license.txt file included.
|
||
|
|
||
|
#include "shader_recompiler/frontend/maxwell/translate/impl/common_funcs.h"
|
||
|
|
||
|
namespace Shader::Maxwell {
|
||
|
[[nodiscard]] IR::U1 IntegerCompare(TranslatorVisitor& v, const IR::U32& operand_1,
|
||
|
const IR::U32& operand_2, ComparisonOp compare_op,
|
||
|
bool is_signed) {
|
||
|
switch (compare_op) {
|
||
|
case ComparisonOp::False:
|
||
|
return v.ir.Imm1(false);
|
||
|
case ComparisonOp::LessThan:
|
||
|
return v.ir.ILessThan(operand_1, operand_2, is_signed);
|
||
|
case ComparisonOp::Equal:
|
||
|
return v.ir.IEqual(operand_1, operand_2);
|
||
|
case ComparisonOp::LessThanEqual:
|
||
|
return v.ir.ILessThanEqual(operand_1, operand_2, is_signed);
|
||
|
case ComparisonOp::GreaterThan:
|
||
|
return v.ir.IGreaterThan(operand_1, operand_2, is_signed);
|
||
|
case ComparisonOp::NotEqual:
|
||
|
return v.ir.INotEqual(operand_1, operand_2);
|
||
|
case ComparisonOp::GreaterThanEqual:
|
||
|
return v.ir.IGreaterThanEqual(operand_1, operand_2, is_signed);
|
||
|
case ComparisonOp::True:
|
||
|
return v.ir.Imm1(true);
|
||
|
default:
|
||
|
throw NotImplementedException("CMP");
|
||
|
}
|
||
|
}
|
||
|
|
||
|
[[nodiscard]] IR::U1 PredicateCombine(TranslatorVisitor& v, const IR::U1& predicate_1,
|
||
|
const IR::U1& predicate_2, BooleanOp bop) {
|
||
|
switch (bop) {
|
||
|
case BooleanOp::And:
|
||
|
return v.ir.LogicalAnd(predicate_1, predicate_2);
|
||
|
case BooleanOp::Or:
|
||
|
return v.ir.LogicalOr(predicate_1, predicate_2);
|
||
|
case BooleanOp::Xor:
|
||
|
return v.ir.LogicalXor(predicate_1, predicate_2);
|
||
|
default:
|
||
|
throw NotImplementedException("BOP");
|
||
|
}
|
||
|
}
|
||
|
} // namespace Shader::Maxwell
|