diff options
author | liamwhite <liamwhite@users.noreply.github.com> | 2023-02-01 22:38:00 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-02-01 22:38:00 -0500 |
commit | a9a860a4f7fbf192435107ce9855d84c9fe1f475 (patch) | |
tree | 5063c9bbadfdfa449e590f2d945e55233e9f090a /src/shader_recompiler/backend/glasm | |
parent | 92c5ab33b7d7ff818ace82bc8dabbf4f0291f226 (diff) | |
parent | a63e17566ab32ab05d784f465ef38a7f3f3db919 (diff) |
Merge pull request #9703 from ameerj/txq-ms
shaders: Fix TXQ with MSAA textures
Diffstat (limited to 'src/shader_recompiler/backend/glasm')
-rw-r--r-- | src/shader_recompiler/backend/glasm/emit_glasm_image.cpp | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/src/shader_recompiler/backend/glasm/emit_glasm_image.cpp b/src/shader_recompiler/backend/glasm/emit_glasm_image.cpp index b7bc11416..85ee27333 100644 --- a/src/shader_recompiler/backend/glasm/emit_glasm_image.cpp +++ b/src/shader_recompiler/backend/glasm/emit_glasm_image.cpp @@ -59,6 +59,13 @@ std::string Image(EmitContext& ctx, IR::TextureInstInfo info, } } +bool IsTextureMsaa(EmitContext& ctx, const IR::TextureInstInfo& info) { + if (info.type == TextureType::Buffer) { + return false; + } + return ctx.info.texture_descriptors.at(info.descriptor_index).is_multisample; +} + std::string_view TextureType(IR::TextureInstInfo info, bool is_ms = false) { if (info.is_depth) { switch (info.type) { @@ -535,7 +542,8 @@ void EmitImageQueryDimensions(EmitContext& ctx, IR::Inst& inst, const IR::Value& ScalarS32 lod, [[maybe_unused]] const IR::Value& skip_mips) { const auto info{inst.Flags<IR::TextureInstInfo>()}; const std::string texture{Texture(ctx, info, index)}; - const std::string_view type{TextureType(info)}; + const bool is_msaa{IsTextureMsaa(ctx, info)}; + const std::string_view type{TextureType(info, is_msaa)}; ctx.Add("TXQ {},{},{},{};", inst, lod, texture, type); } |