Mesa (main): nouveau/nir: Put the UBO offset indirect into the address reg.

GitLab Mirror gitlab-mirror at kemper.freedesktop.org
Fri Apr 29 23:13:23 UTC 2022


Module: Mesa
Branch: main
Commit: 16ead7132f464fefcdd3930cfb683de0a4b8a16c
URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=16ead7132f464fefcdd3930cfb683de0a4b8a16c

Author: Emma Anholt <emma at anholt.net>
Date:   Mon Apr 25 16:32:39 2022 -0700

nouveau/nir: Put the UBO offset indirect into the address reg.

Fixes indirect UBO addressing pre-nvc0.

Reviewed-by: Karol Herbst <kherbst at redhat.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/15949>

---

 src/gallium/drivers/nouveau/codegen/nv50_ir_from_nir.cpp | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/src/gallium/drivers/nouveau/codegen/nv50_ir_from_nir.cpp b/src/gallium/drivers/nouveau/codegen/nv50_ir_from_nir.cpp
index 2895c2bac4a..7572d571643 100644
--- a/src/gallium/drivers/nouveau/codegen/nv50_ir_from_nir.cpp
+++ b/src/gallium/drivers/nouveau/codegen/nv50_ir_from_nir.cpp
@@ -2028,6 +2028,8 @@ Converter::visit(nir_intrinsic_instr *insn)
       Value *indirectOffset;
       uint32_t index = getIndirect(&insn->src[0], 0, indirectIndex) + 1;
       uint32_t offset = getIndirect(&insn->src[1], 0, indirectOffset);
+      if (indirectOffset)
+         indirectOffset = mkOp1v(OP_MOV, TYPE_U32, getSSA(4, FILE_ADDRESS), indirectOffset);
 
       for (uint8_t i = 0u; i < dest_components; ++i) {
          loadFrom(FILE_MEMORY_CONST, index, dType, newDefs[i], offset, i,



More information about the mesa-commit mailing list