From aa554d508b03ee54f2553200d0d43c78b3982e44 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Marek=20Ol=C5=A1=C3=A1k?= Date: Thu, 2 Sep 2010 10:21:23 +0200 Subject: [PATCH] r300/compiler: disable deadcode elimination for indexed dst operands --- .../dri/r300/compiler/radeon_dataflow_deadcode.c | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/src/mesa/drivers/dri/r300/compiler/radeon_dataflow_deadcode.c b/src/mesa/drivers/dri/r300/compiler/radeon_dataflow_deadcode.c index 701092b625e..9d17b4772ad 100644 --- a/src/mesa/drivers/dri/r300/compiler/radeon_dataflow_deadcode.c +++ b/src/mesa/drivers/dri/r300/compiler/radeon_dataflow_deadcode.c @@ -220,6 +220,18 @@ void rc_dataflow_deadcode(struct radeon_compiler * c, void *user) unsigned has_temp_reladdr_src = 0; rc_dataflow_mark_outputs_fn dce = (rc_dataflow_mark_outputs_fn)user; + /* Give up if there is relative addressing of destination operands. */ + for(struct rc_instruction * inst = c->Program.Instructions.Next; + inst != &c->Program.Instructions; + inst = inst->Next) { + const struct rc_opcode_info *opcode = rc_get_opcode_info(inst->U.I.Opcode); + if (opcode->HasDstReg && + inst->U.I.DstReg.WriteMask && + inst->U.I.DstReg.RelAddr) { + return; + } + } + memset(&s, 0, sizeof(s)); s.C = c; @@ -316,6 +328,7 @@ void rc_dataflow_deadcode(struct radeon_compiler * c, void *user) for (struct rc_instruction *ptr = inst->Prev; ptr != &c->Program.Instructions; ptr = ptr->Prev) { + opcode = rc_get_opcode_info(ptr->U.I.Opcode); if (opcode->HasDstReg && ptr->U.I.DstReg.File == RC_FILE_TEMPORARY && ptr->U.I.DstReg.WriteMask) { @@ -327,6 +340,7 @@ void rc_dataflow_deadcode(struct radeon_compiler * c, void *user) } has_temp_reladdr_src = 1; + break; } } } -- 2.30.2