diff options
author | Ilia Mirkin <[email protected]> | 2016-05-25 21:54:39 -0400 |
---|---|---|
committer | Ilia Mirkin <[email protected]> | 2016-05-26 21:23:49 -0400 |
commit | 04ecad97ff7b44bd9afd1bff9108dea199723829 (patch) | |
tree | ac2ef9899856ab1d9c23a43640f0ed12f25cba1b /src/gallium | |
parent | 4f98c94be7e56a535a6b84a5561ae071e052c1e2 (diff) |
nvc0/ir: avoid generating illegal instructions for compute constbuf loads
For user-supplied constbufs, fileIndex is 0. In that case, when we
subtract 1, we'll end up loading from constbuf offset -16. This is
illegal, and there are asserts to avoid it. Normally we'd just DCE it,
but no point in generating the instructions if they're not going to be
used.
Signed-off-by: Ilia Mirkin <[email protected]>
Acked-by: Hans de Goede <[email protected]>
Reviewed-by: Samuel Pitoiset <[email protected]>
Diffstat (limited to 'src/gallium')
-rw-r--r-- | src/gallium/drivers/nouveau/codegen/nv50_ir_lowering_nvc0.cpp | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/src/gallium/drivers/nouveau/codegen/nv50_ir_lowering_nvc0.cpp b/src/gallium/drivers/nouveau/codegen/nv50_ir_lowering_nvc0.cpp index 869040ca562..da2fa4bdf18 100644 --- a/src/gallium/drivers/nouveau/codegen/nv50_ir_lowering_nvc0.cpp +++ b/src/gallium/drivers/nouveau/codegen/nv50_ir_lowering_nvc0.cpp @@ -2180,11 +2180,11 @@ NVC0LoweringPass::handleLDST(Instruction *i) // memory. int8_t fileIndex = i->getSrc(0)->reg.fileIndex - 1; Value *ind = i->getIndirect(0, 1); - Value *ptr = loadUboInfo64(ind, fileIndex * 16); // TODO: clamp the offset to the maximum number of const buf. if (i->src(0).isIndirect(1)) { Value *offset = bld.loadImm(NULL, i->getSrc(0)->reg.data.offset + typeSizeof(i->sType)); + Value *ptr = loadUboInfo64(ind, fileIndex * 16); Value *length = loadUboLength32(ind, fileIndex * 16); Value *pred = new_LValue(func, FILE_PREDICATE); if (i->src(0).isIndirect(0)) { @@ -2200,6 +2200,7 @@ NVC0LoweringPass::handleLDST(Instruction *i) bld.mkMov(i->getDef(0), bld.mkImm(0)); } } else if (fileIndex >= 0) { + Value *ptr = loadUboInfo64(ind, fileIndex * 16); if (i->src(0).isIndirect(0)) { bld.mkOp2(OP_ADD, TYPE_U64, ptr, ptr, i->getIndirect(0, 0)); } |