1
0
Fork 0
forked from suyu/suyu

Merge pull request #9011 from liamwhite/frog-emoji-moment

shader_recompiler: add extended LDC to GLASM backend
This commit is contained in:
Fernando S 2022-10-05 08:53:26 +02:00 committed by GitHub
commit 4774e32593
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -13,9 +13,6 @@ namespace Shader::Backend::GLASM {
namespace { namespace {
void GetCbuf(EmitContext& ctx, IR::Inst& inst, const IR::Value& binding, ScalarU32 offset, void GetCbuf(EmitContext& ctx, IR::Inst& inst, const IR::Value& binding, ScalarU32 offset,
std::string_view size) { std::string_view size) {
if (!binding.IsImmediate()) {
throw NotImplementedException("Indirect constant buffer loading");
}
const Register ret{ctx.reg_alloc.Define(inst)}; const Register ret{ctx.reg_alloc.Define(inst)};
if (offset.type == Type::U32) { if (offset.type == Type::U32) {
// Avoid reading arrays out of bounds, matching hardware's behavior // Avoid reading arrays out of bounds, matching hardware's behavior
@ -24,7 +21,27 @@ void GetCbuf(EmitContext& ctx, IR::Inst& inst, const IR::Value& binding, ScalarU
return; return;
} }
} }
ctx.Add("LDC.{} {},c{}[{}];", size, ret, binding.U32(), offset);
if (binding.IsImmediate()) {
ctx.Add("LDC.{} {},c{}[{}];", size, ret, binding.U32(), offset);
return;
}
const ScalarU32 idx{ctx.reg_alloc.Consume(binding)};
for (u32 i = 0; i < Info::MAX_INDIRECT_CBUFS; i++) {
ctx.Add("SEQ.S.CC RC.x,{},{};"
"IF NE.x;"
"LDC.{} {},c{}[{}];",
idx, i, size, ret, i, offset);
if (i != Info::MAX_INDIRECT_CBUFS - 1) {
ctx.Add("ELSE;");
}
}
for (u32 i = 0; i < Info::MAX_INDIRECT_CBUFS; i++) {
ctx.Add("ENDIF;");
}
} }
bool IsInputArray(Stage stage) { bool IsInputArray(Stage stage) {