From 0f47b426bfa51cb7851bc4cc9e5066fb1864c1db Mon Sep 17 00:00:00 2001 From: Krzysztof Parzyszek Date: Fri, 10 Nov 2017 20:09:46 +0000 Subject: [PATCH] Recommit r317904: [Hexagon] Create HexagonISelDAGToDAG.h, NFC The Windows builder did not reconstruct the HexagonGenDAGISel.inc file after the TableGen binary has changed. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@317921 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Target/Hexagon/HexagonISelDAGToDAG.cpp | 112 +---------------- lib/Target/Hexagon/HexagonISelDAGToDAG.h | 136 +++++++++++++++++++++ 2 files changed, 139 insertions(+), 109 deletions(-) create mode 100644 lib/Target/Hexagon/HexagonISelDAGToDAG.h diff --git a/lib/Target/Hexagon/HexagonISelDAGToDAG.cpp b/lib/Target/Hexagon/HexagonISelDAGToDAG.cpp index b23da692498..2551fe5a140 100644 --- a/lib/Target/Hexagon/HexagonISelDAGToDAG.cpp +++ b/lib/Target/Hexagon/HexagonISelDAGToDAG.cpp @@ -12,6 +12,7 @@ //===----------------------------------------------------------------------===// #include "Hexagon.h" +#include "HexagonISelDAGToDAG.h" #include "HexagonISelLowering.h" #include "HexagonMachineFunctionInfo.h" #include "HexagonTargetMachine.h" @@ -50,115 +51,8 @@ static cl::opt CheckSingleUse("hexagon-isel-su", cl::Hidden, // Instruction Selector Implementation //===----------------------------------------------------------------------===// -//===--------------------------------------------------------------------===// -/// HexagonDAGToDAGISel - Hexagon specific code to select Hexagon machine -/// instructions for SelectionDAG operations. -/// -namespace { -class HexagonDAGToDAGISel : public SelectionDAGISel { - const HexagonSubtarget *HST; - const HexagonInstrInfo *HII; - const HexagonRegisterInfo *HRI; -public: - explicit HexagonDAGToDAGISel(HexagonTargetMachine &tm, - CodeGenOpt::Level OptLevel) - : SelectionDAGISel(tm, OptLevel), HST(nullptr), HII(nullptr), - HRI(nullptr) {} - - bool runOnMachineFunction(MachineFunction &MF) override { - // Reset the subtarget each time through. - HST = &MF.getSubtarget(); - HII = HST->getInstrInfo(); - HRI = HST->getRegisterInfo(); - SelectionDAGISel::runOnMachineFunction(MF); - return true; - } - - bool ComplexPatternFuncMutatesDAG() const override { - return true; - } - void PreprocessISelDAG() override; - void EmitFunctionEntryCode() override; - - void Select(SDNode *N) override; - - // Complex Pattern Selectors. - inline bool SelectAddrGA(SDValue &N, SDValue &R); - inline bool SelectAddrGP(SDValue &N, SDValue &R); - inline bool SelectAnyImm(SDValue &N, SDValue &R); - inline bool SelectAnyInt(SDValue &N, SDValue &R); - bool SelectAnyImmediate(SDValue &N, SDValue &R, uint32_t LogAlign); - bool SelectGlobalAddress(SDValue &N, SDValue &R, bool UseGP, - uint32_t LogAlign); - bool SelectAddrFI(SDValue &N, SDValue &R); - bool DetectUseSxtw(SDValue &N, SDValue &R); - - inline bool SelectAnyImm0(SDValue &N, SDValue &R); - inline bool SelectAnyImm1(SDValue &N, SDValue &R); - inline bool SelectAnyImm2(SDValue &N, SDValue &R); - inline bool SelectAnyImm3(SDValue &N, SDValue &R); - - StringRef getPassName() const override { - return "Hexagon DAG->DAG Pattern Instruction Selection"; - } - - // Generate a machine instruction node corresponding to the circ/brev - // load intrinsic. - MachineSDNode *LoadInstrForLoadIntrinsic(SDNode *IntN); - // Given the circ/brev load intrinsic and the already generated machine - // instruction, generate the appropriate store (that is a part of the - // intrinsic's functionality). - SDNode *StoreInstrForLoadIntrinsic(MachineSDNode *LoadN, SDNode *IntN); - - void SelectFrameIndex(SDNode *N); - /// SelectInlineAsmMemoryOperand - Implement addressing mode selection for - /// inline asm expressions. - bool SelectInlineAsmMemoryOperand(const SDValue &Op, - unsigned ConstraintID, - std::vector &OutOps) override; - bool tryLoadOfLoadIntrinsic(LoadSDNode *N); - void SelectLoad(SDNode *N); - void SelectIndexedLoad(LoadSDNode *LD, const SDLoc &dl); - void SelectIndexedStore(StoreSDNode *ST, const SDLoc &dl); - void SelectStore(SDNode *N); - void SelectSHL(SDNode *N); - void SelectZeroExtend(SDNode *N); - void SelectIntrinsicWChain(SDNode *N); - void SelectIntrinsicWOChain(SDNode *N); - void SelectConstant(SDNode *N); - void SelectConstantFP(SDNode *N); - void SelectBitcast(SDNode *N); - - // Include the pieces autogenerated from the target description. - #include "HexagonGenDAGISel.inc" - -private: - bool keepsLowBits(const SDValue &Val, unsigned NumBits, SDValue &Src); - bool isOrEquivalentToAdd(const SDNode *N) const; - bool isAlignedMemNode(const MemSDNode *N) const; - bool isSmallStackStore(const StoreSDNode *N) const; - bool isPositiveHalfWord(const SDNode *N) const; - bool hasOneUse(const SDNode *N) const; - - // DAG preprocessing functions. - void ppSimplifyOrSelect0(std::vector &&Nodes); - void ppAddrReorderAddShl(std::vector &&Nodes); - void ppAddrRewriteAndSrl(std::vector &&Nodes); - void ppHoistZextI1(std::vector &&Nodes); - - SmallDenseMap RootWeights; - SmallDenseMap RootHeights; - SmallDenseMap GAUsesInFunction; - int getWeight(SDNode *N); - int getHeight(SDNode *N); - SDValue getMultiplierForSHL(SDNode *N); - SDValue factorOutPowerOf2(SDValue V, unsigned Power); - unsigned getUsesInFunction(const Value *V); - SDValue balanceSubTree(SDNode *N, bool Factorize = false); - void rebalanceAddressTrees(); -}; // end HexagonDAGToDAGISel -} // end anonymous namespace - +#define GET_DAGISEL_BODY HexagonDAGToDAGISel +#include "HexagonGenDAGISel.inc" /// createHexagonISelDag - This pass converts a legalized DAG into a /// Hexagon-specific DAG, ready for instruction scheduling. diff --git a/lib/Target/Hexagon/HexagonISelDAGToDAG.h b/lib/Target/Hexagon/HexagonISelDAGToDAG.h new file mode 100644 index 00000000000..4a7f4b79f8f --- /dev/null +++ b/lib/Target/Hexagon/HexagonISelDAGToDAG.h @@ -0,0 +1,136 @@ +//===-- HexagonISelDAGToDAG.h -----------------------------------*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// Hexagon specific code to select Hexagon machine instructions for +// SelectionDAG operations. +//===----------------------------------------------------------------------===// + +#ifndef LLVM_LIB_TARGET_HEXAGON_HEXAGONISELDAGTODAG_H +#define LLVM_LIB_TARGET_HEXAGON_HEXAGONISELDAGTODAG_H + +#include "HexagonSubtarget.h" +#include "HexagonTargetMachine.h" +#include "llvm/ADT/StringRef.h" +#include "llvm/CodeGen/SelectionDAG.h" +#include "llvm/CodeGen/SelectionDAGISel.h" +#include "llvm/Support/CodeGen.h" + +#include + +namespace llvm { +class MachineFunction; +class HexagonInstrInfo; +class HexagonRegisterInfo; + +class HexagonDAGToDAGISel : public SelectionDAGISel { + const HexagonSubtarget *HST; + const HexagonInstrInfo *HII; + const HexagonRegisterInfo *HRI; +public: + explicit HexagonDAGToDAGISel(HexagonTargetMachine &tm, + CodeGenOpt::Level OptLevel) + : SelectionDAGISel(tm, OptLevel), HST(nullptr), HII(nullptr), + HRI(nullptr) {} + + bool runOnMachineFunction(MachineFunction &MF) override { + // Reset the subtarget each time through. + HST = &MF.getSubtarget(); + HII = HST->getInstrInfo(); + HRI = HST->getRegisterInfo(); + SelectionDAGISel::runOnMachineFunction(MF); + return true; + } + + bool ComplexPatternFuncMutatesDAG() const override { + return true; + } + void PreprocessISelDAG() override; + void EmitFunctionEntryCode() override; + + void Select(SDNode *N) override; + + // Complex Pattern Selectors. + inline bool SelectAddrGA(SDValue &N, SDValue &R); + inline bool SelectAddrGP(SDValue &N, SDValue &R); + inline bool SelectAnyImm(SDValue &N, SDValue &R); + inline bool SelectAnyInt(SDValue &N, SDValue &R); + bool SelectAnyImmediate(SDValue &N, SDValue &R, uint32_t LogAlign); + bool SelectGlobalAddress(SDValue &N, SDValue &R, bool UseGP, + uint32_t LogAlign); + bool SelectAddrFI(SDValue &N, SDValue &R); + bool DetectUseSxtw(SDValue &N, SDValue &R); + + inline bool SelectAnyImm0(SDValue &N, SDValue &R); + inline bool SelectAnyImm1(SDValue &N, SDValue &R); + inline bool SelectAnyImm2(SDValue &N, SDValue &R); + inline bool SelectAnyImm3(SDValue &N, SDValue &R); + + StringRef getPassName() const override { + return "Hexagon DAG->DAG Pattern Instruction Selection"; + } + + // Generate a machine instruction node corresponding to the circ/brev + // load intrinsic. + MachineSDNode *LoadInstrForLoadIntrinsic(SDNode *IntN); + // Given the circ/brev load intrinsic and the already generated machine + // instruction, generate the appropriate store (that is a part of the + // intrinsic's functionality). + SDNode *StoreInstrForLoadIntrinsic(MachineSDNode *LoadN, SDNode *IntN); + + void SelectFrameIndex(SDNode *N); + /// SelectInlineAsmMemoryOperand - Implement addressing mode selection for + /// inline asm expressions. + bool SelectInlineAsmMemoryOperand(const SDValue &Op, + unsigned ConstraintID, + std::vector &OutOps) override; + bool tryLoadOfLoadIntrinsic(LoadSDNode *N); + void SelectLoad(SDNode *N); + void SelectIndexedLoad(LoadSDNode *LD, const SDLoc &dl); + void SelectIndexedStore(StoreSDNode *ST, const SDLoc &dl); + void SelectStore(SDNode *N); + void SelectSHL(SDNode *N); + void SelectZeroExtend(SDNode *N); + void SelectIntrinsicWChain(SDNode *N); + void SelectIntrinsicWOChain(SDNode *N); + void SelectConstant(SDNode *N); + void SelectConstantFP(SDNode *N); + void SelectBitcast(SDNode *N); + void SelectVectorShuffle(SDNode *N); + + // Include the pieces autogenerated from the target description. + #define GET_DAGISEL_DECL + #include "HexagonGenDAGISel.inc" + +private: + bool keepsLowBits(const SDValue &Val, unsigned NumBits, SDValue &Src); + bool isOrEquivalentToAdd(const SDNode *N) const; + bool isAlignedMemNode(const MemSDNode *N) const; + bool isSmallStackStore(const StoreSDNode *N) const; + bool isPositiveHalfWord(const SDNode *N) const; + bool hasOneUse(const SDNode *N) const; + + // DAG preprocessing functions. + void ppSimplifyOrSelect0(std::vector &&Nodes); + void ppAddrReorderAddShl(std::vector &&Nodes); + void ppAddrRewriteAndSrl(std::vector &&Nodes); + void ppHoistZextI1(std::vector &&Nodes); + + SmallDenseMap RootWeights; + SmallDenseMap RootHeights; + SmallDenseMap GAUsesInFunction; + int getWeight(SDNode *N); + int getHeight(SDNode *N); + SDValue getMultiplierForSHL(SDNode *N); + SDValue factorOutPowerOf2(SDValue V, unsigned Power); + unsigned getUsesInFunction(const Value *V); + SDValue balanceSubTree(SDNode *N, bool Factorize = false); + void rebalanceAddressTrees(); +}; // end HexagonDAGToDAGISel +} + +#endif // LLVM_LIB_TARGET_HEXAGON_HEXAGONISELDAGTODAG_H