prog_optimize: Set unused regs to PROGRAM_UNDEFINED after CMP->MOV conversion
Leaving the unused registers with other values caused assertion failures and other problems in places that blindly iterate over all sources. brw_vs_emit.c:1381: get_src_reg: Assertion `c->regs[file][index].nr != 0' failed. Fixes i965 piglit: vs-uniform-array-mat[234]-col-row-rd vs-uniform-array-mat[234]-index-col-row-rd vs-uniform-array-mat[234]-index-row-rd vs-uniform-mat[234]-col-row-rd Reviewed-by: Kenneth Graunke <kenneth@whitecape.org> Reviewed-by: Eric Anholt <eric@anholt.net>
This commit is contained in:
parent
f7cd9a858c
commit
fbeb68e880
|
@ -1319,6 +1319,15 @@ _mesa_simplify_cmp(struct gl_program * program)
|
||||||
|
|
||||||
inst->Opcode = OPCODE_MOV;
|
inst->Opcode = OPCODE_MOV;
|
||||||
inst->SrcReg[0] = inst->SrcReg[1];
|
inst->SrcReg[0] = inst->SrcReg[1];
|
||||||
|
|
||||||
|
/* Unused operands are expected to have the file set to
|
||||||
|
* PROGRAM_UNDEFINED. This is how _mesa_init_instructions initializes
|
||||||
|
* all of the sources.
|
||||||
|
*/
|
||||||
|
inst->SrcReg[1].File = PROGRAM_UNDEFINED;
|
||||||
|
inst->SrcReg[1].Swizzle = SWIZZLE_NOOP;
|
||||||
|
inst->SrcReg[2].File = PROGRAM_UNDEFINED;
|
||||||
|
inst->SrcReg[2].Swizzle = SWIZZLE_NOOP;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (dbg) {
|
if (dbg) {
|
||||||
|
|
Loading…
Reference in New Issue