From: Christian Konig Date: Thu, 21 Feb 2013 15:16:53 +0000 (+0000) Subject: R600/SI: rework VOP1_* patterns v2 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=3da7017e812b90e0318baef5cb527e4741db4652;p=platform%2Fupstream%2Fllvm.git R600/SI: rework VOP1_* patterns v2 Fixing asm operation names. v2: use ZERO constant, also add asm operands Signed-off-by: Christian König Reviewed-by: Tom Stellard Reviewed-by: Michel Dänzer llvm-svn: 175748 --- diff --git a/llvm/lib/Target/R600/SIInstrInfo.td b/llvm/lib/Target/R600/SIInstrInfo.td index 8b90d45..2b31307 100644 --- a/llvm/lib/Target/R600/SIInstrInfo.td +++ b/llvm/lib/Target/R600/SIInstrInfo.td @@ -141,29 +141,33 @@ class VOP3_64 op, string opName, list pattern> : VOP3 < opName, pattern >; -class VOP1_Helper op, RegisterClass vrc, RegisterClass arc, - string opName, list pattern> : - VOP1 < - op, (outs vrc:$dst), (ins arc:$src0), opName, pattern - >; +multiclass VOP1_Helper op, RegisterClass drc, RegisterClass src, + string opName, list pattern> { -multiclass VOP1_32 op, string opName, list pattern> { - def _e32: VOP1_Helper ; - def _e64 : VOP3_32 <{1, 1, op{6}, op{5}, op{4}, op{3}, op{2}, op{1}, op{0}}, - opName, [] + def _e32: VOP1 < + op, (outs drc:$dst), (ins src:$src0), + opName#"_e32 $dst, $src0", pattern >; -} -multiclass VOP1_64 op, string opName, list pattern> { - - def _e32 : VOP1_Helper ; - - def _e64 : VOP3_64 < + def _e64 : VOP3 < {1, 1, op{6}, op{5}, op{4}, op{3}, op{2}, op{1}, op{0}}, - opName, [] - >; + (outs drc:$dst), + (ins src:$src0, + i32imm:$abs, i32imm:$clamp, + i32imm:$omod, i32imm:$neg), + opName#"_e64 $dst, $src0, $abs, $clamp, $omod, $neg", [] + > { + let SRC1 = SIOperand.ZERO; + let SRC2 = SIOperand.ZERO; + } } +multiclass VOP1_32 op, string opName, list pattern> + : VOP1_Helper ; + +multiclass VOP1_64 op, string opName, list pattern> + : VOP1_Helper ; + class VOP2_Helper op, RegisterClass vrc, RegisterClass arc, string opName, list pattern> : VOP2 <