2021-05-08 20:28:52 +01:00
|
|
|
// Copyright 2021 yuzu Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#include <string_view>
|
|
|
|
|
|
|
|
#include "shader_recompiler/backend/glasm/emit_context.h"
|
|
|
|
#include "shader_recompiler/backend/glasm/emit_glasm_instructions.h"
|
|
|
|
#include "shader_recompiler/frontend/ir/value.h"
|
|
|
|
|
|
|
|
namespace Shader::Backend::GLASM {
|
|
|
|
|
|
|
|
void EmitIAdd32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view a, [[maybe_unused]] std::string_view b) {
|
2021-05-09 00:21:32 +01:00
|
|
|
ctx.Add("ADD.U {},{},{};", inst, a, b);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitIAdd64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view a, [[maybe_unused]] std::string_view b) {
|
2021-05-08 20:28:52 +01:00
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitISub32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view a, [[maybe_unused]] std::string_view b) {
|
2021-05-09 00:21:32 +01:00
|
|
|
ctx.Add("SUB.U {},{},{};", inst, a, b);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitISub64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view a, [[maybe_unused]] std::string_view b) {
|
2021-05-08 20:28:52 +01:00
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitIMul32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view a, [[maybe_unused]] std::string_view b) {
|
2021-05-08 20:28:52 +01:00
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitINeg32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view value) {
|
2021-05-08 20:28:52 +01:00
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitINeg64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view value) {
|
2021-05-08 20:28:52 +01:00
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitIAbs32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view value) {
|
2021-05-08 20:28:52 +01:00
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitIAbs64([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view value) {
|
2021-05-08 20:28:52 +01:00
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
|
|
|
void EmitShiftLeftLogical32([[maybe_unused]] EmitContext& ctx,
|
|
|
|
[[maybe_unused]] std::string_view base,
|
|
|
|
[[maybe_unused]] std::string_view shift) {
|
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
|
|
|
void EmitShiftLeftLogical64([[maybe_unused]] EmitContext& ctx,
|
|
|
|
[[maybe_unused]] std::string_view base,
|
|
|
|
[[maybe_unused]] std::string_view shift) {
|
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
|
|
|
void EmitShiftRightLogical32([[maybe_unused]] EmitContext& ctx,
|
|
|
|
[[maybe_unused]] std::string_view base,
|
|
|
|
[[maybe_unused]] std::string_view shift) {
|
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
|
|
|
void EmitShiftRightLogical64([[maybe_unused]] EmitContext& ctx,
|
|
|
|
[[maybe_unused]] std::string_view base,
|
|
|
|
[[maybe_unused]] std::string_view shift) {
|
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
|
|
|
void EmitShiftRightArithmetic32([[maybe_unused]] EmitContext& ctx,
|
|
|
|
[[maybe_unused]] std::string_view base,
|
|
|
|
[[maybe_unused]] std::string_view shift) {
|
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
|
|
|
void EmitShiftRightArithmetic64([[maybe_unused]] EmitContext& ctx,
|
|
|
|
[[maybe_unused]] std::string_view base,
|
|
|
|
[[maybe_unused]] std::string_view shift) {
|
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
|
|
|
void EmitBitwiseAnd32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view a, [[maybe_unused]] std::string_view b) {
|
2021-05-08 23:59:05 +01:00
|
|
|
ctx.Add("AND {},{},{};", inst, a, b);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void EmitBitwiseOr32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view a, [[maybe_unused]] std::string_view b) {
|
2021-05-08 23:50:10 +01:00
|
|
|
ctx.Add("OR {},{},{};", inst, a, b);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void EmitBitwiseXor32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view a, [[maybe_unused]] std::string_view b) {
|
2021-05-08 23:59:05 +01:00
|
|
|
ctx.Add("XOR {},{},{};", inst, a, b);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitBitFieldInsert(EmitContext& ctx, IR::Inst& inst, std::string_view base,
|
|
|
|
std::string_view insert, std::string_view offset, std::string_view count) {
|
|
|
|
ctx.Add("MOV.U RC.x,{};MOV.U RC.y,{};", count, offset);
|
|
|
|
ctx.Add("BFI.U {},RC,{},{};", inst, insert, base);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitBitFieldSExtract(EmitContext& ctx, IR::Inst& inst, std::string_view base,
|
|
|
|
std::string_view offset, std::string_view count) {
|
|
|
|
ctx.Add("MOV.U RC.x,{};MOV.U RC.y,{};", count, offset);
|
|
|
|
ctx.Add("BFE.S {},RC,{};", inst, base);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitBitFieldUExtract(EmitContext& ctx, IR::Inst& inst, std::string_view base,
|
|
|
|
std::string_view offset, std::string_view count) {
|
|
|
|
ctx.Add("MOV.U RC.x,{};MOV.U RC.y,{};", count, offset);
|
|
|
|
ctx.Add("BFE.U {},RC,{};", inst, base);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitBitReverse32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view value) {
|
|
|
|
ctx.Add("BFR {},{};", inst, value);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitBitCount32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view value) {
|
2021-05-08 20:28:52 +01:00
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitBitwiseNot32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view value) {
|
2021-05-08 23:59:05 +01:00
|
|
|
ctx.Add("NOT {},{};", inst, value);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitFindSMsb32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view value) {
|
2021-05-08 20:28:52 +01:00
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitFindUMsb32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view value) {
|
2021-05-08 20:28:52 +01:00
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitSMin32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view a, [[maybe_unused]] std::string_view b) {
|
2021-05-08 20:28:52 +01:00
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitUMin32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view a, [[maybe_unused]] std::string_view b) {
|
2021-05-08 20:28:52 +01:00
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitSMax32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view a, [[maybe_unused]] std::string_view b) {
|
2021-05-08 20:28:52 +01:00
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitUMax32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view a, [[maybe_unused]] std::string_view b) {
|
2021-05-08 20:28:52 +01:00
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
|
|
|
void EmitSClamp32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view value, [[maybe_unused]] std::string_view min,
|
|
|
|
[[maybe_unused]] std::string_view max) {
|
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
|
|
|
void EmitUClamp32([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view value, [[maybe_unused]] std::string_view min,
|
|
|
|
[[maybe_unused]] std::string_view max) {
|
|
|
|
throw NotImplementedException("GLASM instruction");
|
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitSLessThan([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view lhs, [[maybe_unused]] std::string_view rhs) {
|
|
|
|
ctx.Add("SLT.S {},{},{};", inst, lhs, rhs);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitULessThan([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view lhs, [[maybe_unused]] std::string_view rhs) {
|
|
|
|
ctx.Add("SLT.U {},{},{};", inst, lhs, rhs);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitIEqual([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view lhs, [[maybe_unused]] std::string_view rhs) {
|
|
|
|
ctx.Add("SEQ {},{},{};", inst, lhs, rhs);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitSLessThanEqual([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view lhs,
|
2021-05-08 20:28:52 +01:00
|
|
|
[[maybe_unused]] std::string_view rhs) {
|
2021-05-08 23:50:10 +01:00
|
|
|
ctx.Add("SLE.S {},{},{};", inst, lhs, rhs);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitULessThanEqual([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view lhs,
|
2021-05-08 20:28:52 +01:00
|
|
|
[[maybe_unused]] std::string_view rhs) {
|
2021-05-08 23:50:10 +01:00
|
|
|
ctx.Add("SLE.U {},{},{};", inst, lhs, rhs);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitSGreaterThan([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view lhs,
|
2021-05-08 20:28:52 +01:00
|
|
|
[[maybe_unused]] std::string_view rhs) {
|
2021-05-08 23:50:10 +01:00
|
|
|
ctx.Add("SGT.S {},{},{};", inst, lhs, rhs);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitUGreaterThan([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view lhs,
|
2021-05-08 20:28:52 +01:00
|
|
|
[[maybe_unused]] std::string_view rhs) {
|
2021-05-08 23:50:10 +01:00
|
|
|
ctx.Add("SGT.U {},{},{};", inst, lhs, rhs);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitINotEqual([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view lhs, [[maybe_unused]] std::string_view rhs) {
|
2021-05-08 23:59:05 +01:00
|
|
|
ctx.Add("SNE.U {},{},{};", inst, lhs, rhs);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitSGreaterThanEqual([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view lhs,
|
2021-05-08 20:28:52 +01:00
|
|
|
[[maybe_unused]] std::string_view rhs) {
|
2021-05-08 23:50:10 +01:00
|
|
|
ctx.Add("SGE.S {},{},{};", inst, lhs, rhs);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
2021-05-08 23:50:10 +01:00
|
|
|
void EmitUGreaterThanEqual([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst,
|
|
|
|
[[maybe_unused]] std::string_view lhs,
|
2021-05-08 20:28:52 +01:00
|
|
|
[[maybe_unused]] std::string_view rhs) {
|
2021-05-08 23:50:10 +01:00
|
|
|
ctx.Add("SGE.U {},{},{};", inst, lhs, rhs);
|
2021-05-08 20:28:52 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace Shader::Backend::GLASM
|