summaryrefslogtreecommitdiff
path: root/src/mesa/drivers/dri/i965/brw_fs_dead_code_eliminate.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/mesa/drivers/dri/i965/brw_fs_dead_code_eliminate.cpp')
-rw-r--r--src/mesa/drivers/dri/i965/brw_fs_dead_code_eliminate.cpp9
1 files changed, 9 insertions, 0 deletions
diff --git a/src/mesa/drivers/dri/i965/brw_fs_dead_code_eliminate.cpp b/src/mesa/drivers/dri/i965/brw_fs_dead_code_eliminate.cpp
index 390ac9ada5b..6672f840fc5 100644
--- a/src/mesa/drivers/dri/i965/brw_fs_dead_code_eliminate.cpp
+++ b/src/mesa/drivers/dri/i965/brw_fs_dead_code_eliminate.cpp
@@ -85,6 +85,15 @@ fs_visitor::dead_code_eliminate()
}
}
+ if (inst->dst.file == GRF) {
+ if (!inst->is_partial_write()) {
+ int var = live_intervals->var_from_vgrf[inst->dst.reg];
+ for (int i = 0; i < inst->regs_written; i++) {
+ BITSET_CLEAR(live, var + inst->dst.reg_offset + i);
+ }
+ }
+ }
+
for (int i = 0; i < 3; i++) {
if (inst->src[i].file == GRF) {
int var = live_intervals->var_from_vgrf[inst->src[i].reg];