summaryrefslogtreecommitdiffstats
path: root/src/video_core/shader/shader_ir.cpp
diff options
context:
space:
mode:
authorReinUsesLisp <reinuseslisp@airmail.cc>2018-12-21 02:45:34 +0100
committerReinUsesLisp <reinuseslisp@airmail.cc>2019-01-15 21:54:49 +0100
commit15f431f0cb9f8d9d142ce631c59335ca99eb9ab4 (patch)
treec3302bb20bd5311d10612e1e254444f15bf60543 /src/video_core/shader/shader_ir.cpp
parentshader_ir: Add constant buffer getters (diff)
downloadyuzu-15f431f0cb9f8d9d142ce631c59335ca99eb9ab4.tar
yuzu-15f431f0cb9f8d9d142ce631c59335ca99eb9ab4.tar.gz
yuzu-15f431f0cb9f8d9d142ce631c59335ca99eb9ab4.tar.bz2
yuzu-15f431f0cb9f8d9d142ce631c59335ca99eb9ab4.tar.lz
yuzu-15f431f0cb9f8d9d142ce631c59335ca99eb9ab4.tar.xz
yuzu-15f431f0cb9f8d9d142ce631c59335ca99eb9ab4.tar.zst
yuzu-15f431f0cb9f8d9d142ce631c59335ca99eb9ab4.zip
Diffstat (limited to 'src/video_core/shader/shader_ir.cpp')
-rw-r--r--src/video_core/shader/shader_ir.cpp21
1 files changed, 21 insertions, 0 deletions
diff --git a/src/video_core/shader/shader_ir.cpp b/src/video_core/shader/shader_ir.cpp
index 3bc9f72f5..0c814fc80 100644
--- a/src/video_core/shader/shader_ir.cpp
+++ b/src/video_core/shader/shader_ir.cpp
@@ -88,6 +88,27 @@ Node ShaderIR::GetPredicate(bool immediate) {
return GetPredicate(static_cast<u64>(immediate ? Pred::UnusedIndex : Pred::NeverExecute));
}
+Node ShaderIR::GetInputAttribute(Attribute::Index index, u64 element,
+ const Tegra::Shader::IpaMode& input_mode, Node buffer) {
+ const auto [entry, is_new] =
+ used_input_attributes.emplace(std::make_pair(index, std::set<Tegra::Shader::IpaMode>{}));
+ entry->second.insert(input_mode);
+
+ return StoreNode(AbufNode(index, static_cast<u32>(element), input_mode, buffer));
+}
+
+Node ShaderIR::GetOutputAttribute(Attribute::Index index, u64 element, Node buffer) {
+ if (index == Attribute::Index::ClipDistances0123 ||
+ index == Attribute::Index::ClipDistances4567) {
+ const auto clip_index =
+ static_cast<u32>((index == Attribute::Index::ClipDistances4567 ? 1 : 0) + element);
+ used_clip_distances.at(clip_index) = true;
+ }
+ used_output_attributes.insert(index);
+
+ return StoreNode(AbufNode(index, static_cast<u32>(element), buffer));
+}
+
/*static*/ OperationCode ShaderIR::SignedToUnsignedCode(OperationCode operation_code,
bool is_signed) {
if (is_signed) {