From b5cb5e29a70e23c6c5bafc44eeffde53d6eb0514 Mon Sep 17 00:00:00 2001 From: Matt Arsenault Date: Fri, 15 Aug 2014 18:42:11 +0000 Subject: [PATCH] R600/SI: Refactor fneg / fabs patterns git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@215746 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Target/R600/SIInstructions.td | 39 ++++++++++++++----------------- 1 file changed, 17 insertions(+), 22 deletions(-) diff --git a/lib/Target/R600/SIInstructions.td b/lib/Target/R600/SIInstructions.td index bbbe18d9369..af8d3b3d080 100644 --- a/lib/Target/R600/SIInstructions.td +++ b/lib/Target/R600/SIInstructions.td @@ -2334,33 +2334,28 @@ def : Pat < (V_OR_B32_e32 $src, (V_MOV_B32_e32 0x80000000)) /* Set sign bit */ >; -def FABS_SI : AMDGPUShaderInst < - (outs VReg_32:$dst), - (ins VSrc_32:$src0), - "FABS_SI $dst, $src0", - [] -> { +class SIUnaryCustomInsertInst : + AMDGPUShaderInst< + (outs dstrc:$dst), + (ins srcrc:$src0), + name#" $dst, $src0", + [(set vt:$dst, (node vt:$src0))]> { let usesCustomInserter = 1; } -def : Pat < - (fabs f32:$src), - (FABS_SI f32:$src) ->; +def FABS_SI : SIUnaryCustomInsertInst<"FABS_SI", fabs, + f32, VReg_32, VSrc_32>; +def FNEG_SI : SIUnaryCustomInsertInst<"FNEG_SI", fneg, + f32, VReg_32, VSrc_32>; -def FNEG_SI : AMDGPUShaderInst < - (outs VReg_32:$dst), - (ins VSrc_32:$src0), - "FNEG_SI $dst, $src0", - [] -> { - let usesCustomInserter = 1; -} +def FABS64_SI : SIUnaryCustomInsertInst<"FABS64_SI", fabs, + f64, VReg_64, VSrc_64>; +def FNEG64_SI : SIUnaryCustomInsertInst<"FNEG64_SI", fneg, + f64, VReg_64, VSrc_64>; -def : Pat < - (fneg f32:$src), - (FNEG_SI f32:$src) ->; /********** ================== **********/ /********** Immediate Patterns **********/