diff options
| author | José Fonseca <jfonseca@vmware.com> | 2010-09-21 02:16:19 +0200 | 
|---|---|---|
| committer | Jakob Bornecrantz <wallbraker@gmail.com> | 2010-09-21 02:18:43 +0200 | 
| commit | c66f0c46297996613fa8271925e37e594cf5d16b (patch) | |
| tree | 4ea947b6fa54e43a522780414f94a705ddb3bd20 /src | |
| parent | 99907303f6a1e9abe02977664ad8457c122213ce (diff) | |
tgsi: Don't ignore indirect registers in tgsi_check_soa_dependencies
NOTE: This is a candidate for the 7.9 branch.
Diffstat (limited to 'src')
| -rw-r--r-- | src/gallium/auxiliary/tgsi/tgsi_exec.c | 6 | 
1 files changed, 4 insertions, 2 deletions
| diff --git a/src/gallium/auxiliary/tgsi/tgsi_exec.c b/src/gallium/auxiliary/tgsi/tgsi_exec.c index 0757f05dfa..3a71540506 100644 --- a/src/gallium/auxiliary/tgsi/tgsi_exec.c +++ b/src/gallium/auxiliary/tgsi/tgsi_exec.c @@ -605,8 +605,10 @@ tgsi_check_soa_dependencies(const struct tgsi_full_instruction *inst)     for (i = 0; i < inst->Instruction.NumSrcRegs; i++) {        if ((inst->Src[i].Register.File ==             inst->Dst[0].Register.File) && -          (inst->Src[i].Register.Index == -           inst->Dst[0].Register.Index)) { +          ((inst->Src[i].Register.Index == +            inst->Dst[0].Register.Index) || +	   inst->Src[i].Register.Indirect || +	   inst->Dst[0].Register.Indirect)) {           /* loop over dest channels */           uint channelsWritten = 0x0;           FOR_EACH_ENABLED_CHANNEL(*inst, chan) { | 
