From ce3ff1be8a6ed688437b24efc536fe484f448d79 Mon Sep 17 00:00:00 2001 From: Anton Korobeynikov Date: Fri, 21 Aug 2009 12:40:50 +0000 Subject: [PATCH] Add nodes & dummy matchers for some v{zip,uzp,trn} instructions llvm-svn: 79622 --- llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp | 30 +++++++++++++++++++++++++ llvm/lib/Target/ARM/ARMISelLowering.cpp | 9 ++++++++ llvm/lib/Target/ARM/ARMInstrNEON.td | 12 ++++++++++ 3 files changed, 51 insertions(+) diff --git a/llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp b/llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp index 3ef15a119af5..3b394b0bf5f7 100644 --- a/llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp +++ b/llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp @@ -1415,6 +1415,36 @@ SDNode *ARMDAGToDAGISel::Select(SDValue Op) { N->getOperand(4), N->getOperand(5), Chain }; return CurDAG->getTargetNode(Opc, dl, MVT::Other, Ops, 8); } + case ARMISD::VZIP16: { + EVT VT = N->getValueType(0); + return CurDAG->getTargetNode(ARM::VZIPd16, dl, VT, VT, + N->getOperand(0), N->getOperand(1)); + } + case ARMISD::VZIP32: { + EVT VT = N->getValueType(0); + return CurDAG->getTargetNode(ARM::VZIPq32, dl, VT, VT, + N->getOperand(0), N->getOperand(1)); + } + case ARMISD::VUZP16: { + EVT VT = N->getValueType(0); + return CurDAG->getTargetNode(ARM::VUZPd16, dl, VT, VT, + N->getOperand(0), N->getOperand(1)); + } + case ARMISD::VUZP32: { + EVT VT = N->getValueType(0); + return CurDAG->getTargetNode(ARM::VUZPq32, dl, VT, VT, + N->getOperand(0), N->getOperand(1)); + } + case ARMISD::VTRN16: { + EVT VT = N->getValueType(0); + return CurDAG->getTargetNode(ARM::VTRNd16, dl, VT, VT, + N->getOperand(0), N->getOperand(1)); + } + case ARMISD::VTRN32: { + EVT VT = N->getValueType(0); + return CurDAG->getTargetNode(ARM::VTRNq32, dl, VT, VT, + N->getOperand(0), N->getOperand(1)); + } } return SelectCode(Op); diff --git a/llvm/lib/Target/ARM/ARMISelLowering.cpp b/llvm/lib/Target/ARM/ARMISelLowering.cpp index c55b7b4a7dc1..2f194d39bafd 100644 --- a/llvm/lib/Target/ARM/ARMISelLowering.cpp +++ b/llvm/lib/Target/ARM/ARMISelLowering.cpp @@ -492,6 +492,15 @@ const char *ARMTargetLowering::getTargetNodeName(unsigned Opcode) const { case ARMISD::VREV64: return "ARMISD::VREV64"; case ARMISD::VREV32: return "ARMISD::VREV32"; case ARMISD::VREV16: return "ARMISD::VREV16"; + case ARMISD::VZIP32: return "ARMISD::VZIP32"; + case ARMISD::VZIP16: return "ARMISD::VZIP16"; + case ARMISD::VZIP8: return "ARMISD::VZIP8"; + case ARMISD::VUZP32: return "ARMISD::VUZP32"; + case ARMISD::VUZP16: return "ARMISD::VUZP16"; + case ARMISD::VUZP8: return "ARMISD::VUZP8"; + case ARMISD::VTRN32: return "ARMISD::VTRN32"; + case ARMISD::VTRN16: return "ARMISD::VTRN16"; + case ARMISD::VTRN8: return "ARMISD::VTRN8"; } } diff --git a/llvm/lib/Target/ARM/ARMInstrNEON.td b/llvm/lib/Target/ARM/ARMInstrNEON.td index 00e6c8a33a02..b893c5859c07 100644 --- a/llvm/lib/Target/ARM/ARMInstrNEON.td +++ b/llvm/lib/Target/ARM/ARMInstrNEON.td @@ -109,6 +109,18 @@ def NEONvrev64 : SDNode<"ARMISD::VREV64", SDTARMVSHUF>; def NEONvrev32 : SDNode<"ARMISD::VREV32", SDTARMVSHUF>; def NEONvrev16 : SDNode<"ARMISD::VREV16", SDTARMVSHUF>; +def SDTARMVSHUF2 : SDTypeProfile<2, 2, [SDTCisVec<0>, SDTCisSameAs<0, 1>, + SDTCisSameAs<0, 2>, SDTCisSameAs<0, 3>]>; +def NEONzip32 : SDNode<"ARMISD::VZIP32", SDTARMVSHUF2>; +def NEONzip16 : SDNode<"ARMISD::VZIP16", SDTARMVSHUF2>; +def NEONzip8 : SDNode<"ARMISD::VZIP8", SDTARMVSHUF2>; +def NEONuzp32 : SDNode<"ARMISD::VUZP32", SDTARMVSHUF2>; +def NEONuzp16 : SDNode<"ARMISD::VUZP16", SDTARMVSHUF2>; +def NEONuzp8 : SDNode<"ARMISD::VUZP16", SDTARMVSHUF2>; +def NEONtrn32 : SDNode<"ARMISD::VTRN32", SDTARMVSHUF2>; +def NEONtrn16 : SDNode<"ARMISD::VTRN16", SDTARMVSHUF2>; +def NEONtrn8 : SDNode<"ARMISD::VTRN8", SDTARMVSHUF2>; + //===----------------------------------------------------------------------===// // NEON operand definitions //===----------------------------------------------------------------------===//