diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2016-07-23 20:41:05 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2016-07-23 20:41:05 +0000 | 
| commit | 01095a5d43bbfde13731688ddcf6048ebb8b7721 (patch) | |
| tree | 4def12e759965de927d963ac65840d663ef9d1ea /lib/Target/PowerPC/PPCInstrInfo.h | |
| parent | f0f4822ed4b66e3579e92a89f368f8fb860e218e (diff) | |
Vendor import of llvm release_39 branch r276489:vendor/llvm/llvm-release_39-r276489
Diffstat (limited to 'lib/Target/PowerPC/PPCInstrInfo.h')
| -rw-r--r-- | lib/Target/PowerPC/PPCInstrInfo.h | 65 | 
1 files changed, 32 insertions, 33 deletions
| diff --git a/lib/Target/PowerPC/PPCInstrInfo.h b/lib/Target/PowerPC/PPCInstrInfo.h index c3c3a480a6aa..98baf125bdff 100644 --- a/lib/Target/PowerPC/PPCInstrInfo.h +++ b/lib/Target/PowerPC/PPCInstrInfo.h @@ -73,10 +73,10 @@ class PPCInstrInfo : public PPCGenInstrInfo {                             const TargetRegisterClass *RC,                             SmallVectorImpl<MachineInstr*> &NewMIs,                             bool &NonRI, bool &SpillsVRS) const; -  bool LoadRegFromStackSlot(MachineFunction &MF, DebugLoc DL, +  bool LoadRegFromStackSlot(MachineFunction &MF, const DebugLoc &DL,                              unsigned DestReg, int FrameIdx,                              const TargetRegisterClass *RC, -                            SmallVectorImpl<MachineInstr*> &NewMIs, +                            SmallVectorImpl<MachineInstr *> &NewMIs,                              bool &NonRI, bool &SpillsVRS) const;    virtual void anchor(); @@ -91,8 +91,7 @@ protected:    ///    /// For example, we can commute rlwimi instructions, but only if the    /// rotate amt is zero.  We also have to munge the immediates a bit. -  MachineInstr *commuteInstructionImpl(MachineInstr *MI, -                                       bool NewMI, +  MachineInstr *commuteInstructionImpl(MachineInstr &MI, bool NewMI,                                         unsigned OpIdx1,                                         unsigned OpIdx2) const override; @@ -113,12 +112,12 @@ public:                                       const ScheduleDAG *DAG) const override;    unsigned getInstrLatency(const InstrItineraryData *ItinData, -                           const MachineInstr *MI, +                           const MachineInstr &MI,                             unsigned *PredCost = nullptr) const override;    int getOperandLatency(const InstrItineraryData *ItinData, -                        const MachineInstr *DefMI, unsigned DefIdx, -                        const MachineInstr *UseMI, +                        const MachineInstr &DefMI, unsigned DefIdx, +                        const MachineInstr &UseMI,                          unsigned UseIdx) const override;    int getOperandLatency(const InstrItineraryData *ItinData,                          SDNode *DefNode, unsigned DefIdx, @@ -128,7 +127,7 @@ public:    }    bool hasLowDefLatency(const TargetSchedModel &SchedModel, -                        const MachineInstr *DefMI, +                        const MachineInstr &DefMI,                          unsigned DefIdx) const override {      // Machine LICM should hoist all instructions in low-register-pressure      // situations; none are sufficiently free to justify leaving in a loop @@ -152,12 +151,12 @@ public:    bool isCoalescableExtInstr(const MachineInstr &MI,                               unsigned &SrcReg, unsigned &DstReg,                               unsigned &SubIdx) const override; -  unsigned isLoadFromStackSlot(const MachineInstr *MI, +  unsigned isLoadFromStackSlot(const MachineInstr &MI,                                 int &FrameIndex) const override; -  unsigned isStoreToStackSlot(const MachineInstr *MI, +  unsigned isStoreToStackSlot(const MachineInstr &MI,                                int &FrameIndex) const override; -  bool findCommutedOpIndices(MachineInstr *MI, unsigned &SrcOpIdx1, +  bool findCommutedOpIndices(MachineInstr &MI, unsigned &SrcOpIdx1,                               unsigned &SrcOpIdx2) const override;    void insertNoop(MachineBasicBlock &MBB, @@ -165,25 +164,25 @@ public:    // Branch analysis. -  bool AnalyzeBranch(MachineBasicBlock &MBB, MachineBasicBlock *&TBB, +  bool analyzeBranch(MachineBasicBlock &MBB, MachineBasicBlock *&TBB,                       MachineBasicBlock *&FBB,                       SmallVectorImpl<MachineOperand> &Cond,                       bool AllowModify) const override;    unsigned RemoveBranch(MachineBasicBlock &MBB) const override;    unsigned InsertBranch(MachineBasicBlock &MBB, MachineBasicBlock *TBB,                          MachineBasicBlock *FBB, ArrayRef<MachineOperand> Cond, -                        DebugLoc DL) const override; +                        const DebugLoc &DL) const override;    // Select analysis.    bool canInsertSelect(const MachineBasicBlock &, ArrayRef<MachineOperand> Cond,                         unsigned, unsigned, int &, int &, int &) const override;    void insertSelect(MachineBasicBlock &MBB, MachineBasicBlock::iterator MI, -                    DebugLoc DL, unsigned DstReg, ArrayRef<MachineOperand> Cond, -                    unsigned TrueReg, unsigned FalseReg) const override; +                    const DebugLoc &DL, unsigned DstReg, +                    ArrayRef<MachineOperand> Cond, unsigned TrueReg, +                    unsigned FalseReg) const override; -  void copyPhysReg(MachineBasicBlock &MBB, -                   MachineBasicBlock::iterator I, DebugLoc DL, -                   unsigned DestReg, unsigned SrcReg, +  void copyPhysReg(MachineBasicBlock &MBB, MachineBasicBlock::iterator I, +                   const DebugLoc &DL, unsigned DestReg, unsigned SrcReg,                     bool KillSrc) const override;    void storeRegToStackSlot(MachineBasicBlock &MBB, @@ -201,8 +200,8 @@ public:    bool    ReverseBranchCondition(SmallVectorImpl<MachineOperand> &Cond) const override; -  bool FoldImmediate(MachineInstr *UseMI, MachineInstr *DefMI, -                     unsigned Reg, MachineRegisterInfo *MRI) const override; +  bool FoldImmediate(MachineInstr &UseMI, MachineInstr &DefMI, unsigned Reg, +                     MachineRegisterInfo *MRI) const override;    // If conversion by predication (only supported by some branch instructions).    // All of the profitability checks always return true; it is always @@ -230,37 +229,34 @@ public:    }    // Predication support. -  bool isPredicated(const MachineInstr *MI) const override; +  bool isPredicated(const MachineInstr &MI) const override; -  bool isUnpredicatedTerminator(const MachineInstr *MI) const override; +  bool isUnpredicatedTerminator(const MachineInstr &MI) const override; -  bool PredicateInstruction(MachineInstr *MI, +  bool PredicateInstruction(MachineInstr &MI,                              ArrayRef<MachineOperand> Pred) const override;    bool SubsumesPredicate(ArrayRef<MachineOperand> Pred1,                           ArrayRef<MachineOperand> Pred2) const override; -  bool DefinesPredicate(MachineInstr *MI, +  bool DefinesPredicate(MachineInstr &MI,                          std::vector<MachineOperand> &Pred) const override; -  bool isPredicable(MachineInstr *MI) const override; +  bool isPredicable(MachineInstr &MI) const override;    // Comparison optimization. +  bool analyzeCompare(const MachineInstr &MI, unsigned &SrcReg, +                      unsigned &SrcReg2, int &Mask, int &Value) const override; -  bool analyzeCompare(const MachineInstr *MI, -                      unsigned &SrcReg, unsigned &SrcReg2, -                      int &Mask, int &Value) const override; - -  bool optimizeCompareInstr(MachineInstr *CmpInstr, -                            unsigned SrcReg, unsigned SrcReg2, -                            int Mask, int Value, +  bool optimizeCompareInstr(MachineInstr &CmpInstr, unsigned SrcReg, +                            unsigned SrcReg2, int Mask, int Value,                              const MachineRegisterInfo *MRI) const override;    /// GetInstSize - Return the number of bytes of code the specified    /// instruction may be.  This returns the maximum number of bytes.    /// -  unsigned GetInstSizeInBytes(const MachineInstr *MI) const; +  unsigned GetInstSizeInBytes(const MachineInstr &MI) const;    void getNoopForMachoTarget(MCInst &NopInst) const override; @@ -272,6 +268,9 @@ public:    ArrayRef<std::pair<unsigned, const char *>>    getSerializableBitmaskMachineOperandTargetFlags() const override; + +  // Lower pseudo instructions after register allocation. +  bool expandPostRAPseudo(MachineInstr &MI) const override;  };  } | 
