diff options
author | Matt Turner <[email protected]> | 2014-06-23 13:30:15 -0700 |
---|---|---|
committer | Matt Turner <[email protected]> | 2014-06-24 11:51:54 -0700 |
commit | 48f1143c64e46b3d11dc318d7825b6167a2b78e5 (patch) | |
tree | 1542ebb8d12c4a20d75b85e653f5162cdb754e8c | |
parent | b24e1cc6049d997e8f78283dcf6a75e99541faed (diff) |
i965/fs: Don't fix_math_operand() on Gen >= 8.
Reviewed-by: Ben Widawsky <[email protected]>
Reviewed-by: Kenneth Graunke <[email protected]>
Reviewed-by: Ian Romanick <[email protected]>
-rw-r--r-- | src/mesa/drivers/dri/i965/brw_fs.cpp | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/src/mesa/drivers/dri/i965/brw_fs.cpp b/src/mesa/drivers/dri/i965/brw_fs.cpp index d7b969e46c5..185a1f68c08 100644 --- a/src/mesa/drivers/dri/i965/brw_fs.cpp +++ b/src/mesa/drivers/dri/i965/brw_fs.cpp @@ -1386,7 +1386,7 @@ fs_visitor::emit_math(enum opcode opcode, fs_reg dst, fs_reg src) * Gen 6 hardware ignores source modifiers (negate and abs) on math * instructions, so we also move to a temp to set those up. */ - if (brw->gen >= 6) + if (brw->gen == 6 || brw->gen == 7) src = fix_math_operand(src); fs_inst *inst = emit(opcode, dst, src); @@ -1418,7 +1418,9 @@ fs_visitor::emit_math(enum opcode opcode, fs_reg dst, fs_reg src0, fs_reg src1) return NULL; } - if (brw->gen >= 6) { + if (brw->gen >= 8) { + inst = emit(opcode, dst, src0, src1); + } else if (brw->gen >= 6) { src0 = fix_math_operand(src0); src1 = fix_math_operand(src1); |