diff options
Diffstat (limited to 'lib/Target/XCore')
25 files changed, 252 insertions, 238 deletions
| diff --git a/lib/Target/XCore/Disassembler/XCoreDisassembler.cpp b/lib/Target/XCore/Disassembler/XCoreDisassembler.cpp index 9c20abd..7fef796 100644 --- a/lib/Target/XCore/Disassembler/XCoreDisassembler.cpp +++ b/lib/Target/XCore/Disassembler/XCoreDisassembler.cpp @@ -14,6 +14,7 @@  #include "XCore.h"  #include "XCoreRegisterInfo.h" +#include "llvm/MC/MCContext.h"  #include "llvm/MC/MCDisassembler.h"  #include "llvm/MC/MCFixedLenDisassembler.h"  #include "llvm/MC/MCInst.h" @@ -23,16 +24,17 @@  using namespace llvm; +#define DEBUG_TYPE "xcore-disassembler" +  typedef MCDisassembler::DecodeStatus DecodeStatus;  namespace {  /// \brief A disassembler class for XCore.  class XCoreDisassembler : public MCDisassembler { -  OwningPtr<const MCRegisterInfo> RegInfo;  public: -  XCoreDisassembler(const MCSubtargetInfo &STI, const MCRegisterInfo *Info) : -    MCDisassembler(STI), RegInfo(Info) {} +  XCoreDisassembler(const MCSubtargetInfo &STI, MCContext &Ctx) : +    MCDisassembler(STI, Ctx) {}    /// \brief See MCDisassembler.    virtual DecodeStatus getInstruction(MCInst &instr, @@ -40,9 +42,8 @@ public:                                        const MemoryObject ®ion,                                        uint64_t address,                                        raw_ostream &vStream, -                                      raw_ostream &cStream) const; +                                      raw_ostream &cStream) const override; -  const MCRegisterInfo *getRegInfo() const { return RegInfo.get(); }  };  } @@ -81,7 +82,8 @@ static bool readInstruction32(const MemoryObject ®ion,  static unsigned getReg(const void *D, unsigned RC, unsigned RegNo) {    const XCoreDisassembler *Dis = static_cast<const XCoreDisassembler*>(D); -  return *(Dis->getRegInfo()->getRegClass(RC).begin() + RegNo); +  const MCRegisterInfo *RegInfo = Dis->getContext().getRegisterInfo(); +  return *(RegInfo->getRegClass(RC).begin() + RegNo);  }  static DecodeStatus DecodeGRRegsRegisterClass(MCInst &Inst, @@ -788,8 +790,9 @@ namespace llvm {  }  static MCDisassembler *createXCoreDisassembler(const Target &T, -                                               const MCSubtargetInfo &STI) { -  return new XCoreDisassembler(STI, T.createMCRegInfo("")); +                                               const MCSubtargetInfo &STI, +                                               MCContext &Ctx) { +  return new XCoreDisassembler(STI, Ctx);  }  extern "C" void LLVMInitializeXCoreDisassembler() { diff --git a/lib/Target/XCore/InstPrinter/XCoreInstPrinter.cpp b/lib/Target/XCore/InstPrinter/XCoreInstPrinter.cpp index 9ae8c0d..215fe89 100644 --- a/lib/Target/XCore/InstPrinter/XCoreInstPrinter.cpp +++ b/lib/Target/XCore/InstPrinter/XCoreInstPrinter.cpp @@ -11,7 +11,6 @@  //  //===----------------------------------------------------------------------===// -#define DEBUG_TYPE "asm-printer"  #include "XCoreInstPrinter.h"  #include "llvm/ADT/StringExtras.h"  #include "llvm/MC/MCExpr.h" @@ -22,6 +21,8 @@  #include "llvm/Support/raw_ostream.h"  using namespace llvm; +#define DEBUG_TYPE "asm-printer" +  #include "XCoreGenAsmWriter.inc"  void XCoreInstPrinter::printRegName(raw_ostream &OS, unsigned RegNo) const { diff --git a/lib/Target/XCore/InstPrinter/XCoreInstPrinter.h b/lib/Target/XCore/InstPrinter/XCoreInstPrinter.h index 772c515..98e7c98 100644 --- a/lib/Target/XCore/InstPrinter/XCoreInstPrinter.h +++ b/lib/Target/XCore/InstPrinter/XCoreInstPrinter.h @@ -31,8 +31,8 @@ public:    void printInstruction(const MCInst *MI, raw_ostream &O);    static const char *getRegisterName(unsigned RegNo); -  virtual void printRegName(raw_ostream &OS, unsigned RegNo) const; -  virtual void printInst(const MCInst *MI, raw_ostream &O, StringRef Annot); +  void printRegName(raw_ostream &OS, unsigned RegNo) const override; +  void printInst(const MCInst *MI, raw_ostream &O, StringRef Annot) override;  private:    void printInlineJT(const MCInst *MI, int opNum, raw_ostream &O);    void printInlineJT32(const MCInst *MI, int opNum, raw_ostream &O); diff --git a/lib/Target/XCore/MCTargetDesc/XCoreMCAsmInfo.cpp b/lib/Target/XCore/MCTargetDesc/XCoreMCAsmInfo.cpp index f788c59..5665911 100644 --- a/lib/Target/XCore/MCTargetDesc/XCoreMCAsmInfo.cpp +++ b/lib/Target/XCore/MCTargetDesc/XCoreMCAsmInfo.cpp @@ -17,7 +17,7 @@ XCoreMCAsmInfo::XCoreMCAsmInfo(StringRef TT) {    SupportsDebugInformation = true;    Data16bitsDirective = "\t.short\t";    Data32bitsDirective = "\t.long\t"; -  Data64bitsDirective = 0; +  Data64bitsDirective = nullptr;    ZeroDirective = "\t.space\t";    CommentString = "#"; diff --git a/lib/Target/XCore/MCTargetDesc/XCoreMCAsmInfo.h b/lib/Target/XCore/MCTargetDesc/XCoreMCAsmInfo.h index e53c96b..da2689a 100644 --- a/lib/Target/XCore/MCTargetDesc/XCoreMCAsmInfo.h +++ b/lib/Target/XCore/MCTargetDesc/XCoreMCAsmInfo.h @@ -21,7 +21,7 @@ namespace llvm {    class Target;    class XCoreMCAsmInfo : public MCAsmInfoELF { -    virtual void anchor(); +    void anchor() override;    public:      explicit XCoreMCAsmInfo(StringRef TT);    }; diff --git a/lib/Target/XCore/MCTargetDesc/XCoreMCTargetDesc.cpp b/lib/Target/XCore/MCTargetDesc/XCoreMCTargetDesc.cpp index 439d0ab..d54e94f 100644 --- a/lib/Target/XCore/MCTargetDesc/XCoreMCTargetDesc.cpp +++ b/lib/Target/XCore/MCTargetDesc/XCoreMCTargetDesc.cpp @@ -23,6 +23,8 @@  #include "llvm/Support/FormattedStream.h"  #include "llvm/Support/TargetRegistry.h" +using namespace llvm; +  #define GET_INSTRINFO_MC_DESC  #include "XCoreGenInstrInfo.inc" @@ -32,8 +34,6 @@  #define GET_REGINFO_MC_DESC  #include "XCoreGenRegisterInfo.inc" -using namespace llvm; -  static MCInstrInfo *createXCoreMCInstrInfo() {    MCInstrInfo *X = new MCInstrInfo();    InitXCoreMCInstrInfo(X); @@ -58,7 +58,7 @@ static MCAsmInfo *createXCoreMCAsmInfo(const MCRegisterInfo &MRI,    MCAsmInfo *MAI = new XCoreMCAsmInfo(TT);    // Initial state of the frame pointer is SP. -  MCCFIInstruction Inst = MCCFIInstruction::createDefCfa(0, XCore::SP, 0); +  MCCFIInstruction Inst = MCCFIInstruction::createDefCfa(nullptr, XCore::SP, 0);    MAI->addInitialFrameState(Inst);    return MAI; @@ -128,12 +128,11 @@ void XCoreTargetAsmStreamer::emitCCBottomFunction(StringRef Name) {  static MCStreamer *  createXCoreMCAsmStreamer(MCContext &Ctx, formatted_raw_ostream &OS, -                         bool isVerboseAsm, bool useCFI, bool useDwarfDirectory, +                         bool isVerboseAsm, bool useDwarfDirectory,                           MCInstPrinter *InstPrint, MCCodeEmitter *CE,                           MCAsmBackend *TAB, bool ShowInst) { -  MCStreamer *S = -      llvm::createAsmStreamer(Ctx, OS, isVerboseAsm, useCFI, useDwarfDirectory, -                              InstPrint, CE, TAB, ShowInst); +  MCStreamer *S = llvm::createAsmStreamer( +      Ctx, OS, isVerboseAsm, useDwarfDirectory, InstPrint, CE, TAB, ShowInst);    new XCoreTargetAsmStreamer(*S, OS);    return S;  } diff --git a/lib/Target/XCore/XCoreAsmPrinter.cpp b/lib/Target/XCore/XCoreAsmPrinter.cpp index 21acedf..e98d4f9 100644 --- a/lib/Target/XCore/XCoreAsmPrinter.cpp +++ b/lib/Target/XCore/XCoreAsmPrinter.cpp @@ -12,7 +12,6 @@  //  //===----------------------------------------------------------------------===// -#define DEBUG_TYPE "asm-printer"  #include "XCore.h"  #include "InstPrinter/XCoreInstPrinter.h"  #include "XCoreInstrInfo.h" @@ -47,6 +46,8 @@  #include <cctype>  using namespace llvm; +#define DEBUG_TYPE "asm-printer" +  namespace {    class XCoreAsmPrinter : public AsmPrinter {      const XCoreSubtarget &Subtarget; @@ -58,7 +59,7 @@ namespace {        : AsmPrinter(TM, Streamer), Subtarget(TM.getSubtarget<XCoreSubtarget>()),          MCInstLowering(*this) {} -    virtual const char *getPassName() const { +    const char *getPassName() const override {        return "XCore Assembly Printer";      } @@ -70,18 +71,18 @@ namespace {      void printOperand(const MachineInstr *MI, int opNum, raw_ostream &O);      bool PrintAsmOperand(const MachineInstr *MI, unsigned OpNo,                           unsigned AsmVariant, const char *ExtraCode, -                         raw_ostream &O); +                         raw_ostream &O) override;      bool PrintAsmMemoryOperand(const MachineInstr *MI, unsigned OpNum,                                 unsigned AsmVariant, const char *ExtraCode,                                 raw_ostream &O) override;      void emitArrayBound(MCSymbol *Sym, const GlobalVariable *GV); -    virtual void EmitGlobalVariable(const GlobalVariable *GV); +    void EmitGlobalVariable(const GlobalVariable *GV) override; -    void EmitFunctionEntryLabel(); -    void EmitInstruction(const MachineInstr *MI); -    void EmitFunctionBodyStart(); -    void EmitFunctionBodyEnd(); +    void EmitFunctionEntryLabel() override; +    void EmitInstruction(const MachineInstr *MI) override; +    void EmitFunctionBodyStart() override; +    void EmitFunctionBodyEnd() override;    };  } // end of anonymous namespace diff --git a/lib/Target/XCore/XCoreFrameLowering.cpp b/lib/Target/XCore/XCoreFrameLowering.cpp index 954fddf..5499aba 100644 --- a/lib/Target/XCore/XCoreFrameLowering.cpp +++ b/lib/Target/XCore/XCoreFrameLowering.cpp @@ -64,7 +64,8 @@ static void EmitDefCfaRegister(MachineBasicBlock &MBB,                                 MachineModuleInfo *MMI, unsigned DRegNum) {    unsigned CFIIndex = MMI->addFrameInst(        MCCFIInstruction::createDefCfaRegister(nullptr, DRegNum)); -  BuildMI(MBB, MBBI, dl, TII.get(XCore::CFI_INSTRUCTION)).addCFIIndex(CFIIndex); +  BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION)) +      .addCFIIndex(CFIIndex);  }  static void EmitDefCfaOffset(MachineBasicBlock &MBB, @@ -73,7 +74,8 @@ static void EmitDefCfaOffset(MachineBasicBlock &MBB,                               MachineModuleInfo *MMI, int Offset) {    unsigned CFIIndex =        MMI->addFrameInst(MCCFIInstruction::createDefCfaOffset(nullptr, -Offset)); -  BuildMI(MBB, MBBI, dl, TII.get(XCore::CFI_INSTRUCTION)).addCFIIndex(CFIIndex); +  BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION)) +      .addCFIIndex(CFIIndex);  }  static void EmitCfiOffset(MachineBasicBlock &MBB, @@ -82,7 +84,8 @@ static void EmitCfiOffset(MachineBasicBlock &MBB,                            unsigned DRegNum, int Offset) {    unsigned CFIIndex = MMI->addFrameInst(        MCCFIInstruction::createOffset(nullptr, DRegNum, Offset)); -  BuildMI(MBB, MBBI, dl, TII.get(XCore::CFI_INSTRUCTION)).addCFIIndex(CFIIndex); +  BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION)) +      .addCFIIndex(CFIIndex);  }  /// The SP register is moved in steps of 'MaxImmU16' towards the bottom of the @@ -113,7 +116,8 @@ static void IfNeededExtSP(MachineBasicBlock &MBB,  /// IfNeededLDAWSP emits the necessary LDAWSP instructions to move the SP only  /// as far as to make 'OffsetFromTop' reachable using an LDAWSP_lru6.  /// \param OffsetFromTop the spill offset from the top of the frame. -/// \param [in,out] RemainingAdj the current SP offset from the top of the frame. +/// \param [in,out] RemainingAdj the current SP offset from the top of the +/// frame.  static void IfNeededLDAWSP(MachineBasicBlock &MBB,                             MachineBasicBlock::iterator MBBI, DebugLoc dl,                             const TargetInstrInfo &TII, int OffsetFromTop, @@ -346,7 +350,8 @@ void XCoreFrameLowering::emitEpilogue(MachineFunction &MF,    RemainingAdj /= 4;    if (RetOpcode == XCore::EH_RETURN) { -    // 'Restore' the exception info the unwinder has placed into the stack slots. +    // 'Restore' the exception info the unwinder has placed into the stack +    // slots.      SmallVector<StackSlotInfo,2> SpillList;      GetEHSpillList(SpillList, MFI, XFI, MF.getTarget().getTargetLowering());      RestoreSpillList(MBB, MBBI, dl, TII, RemainingAdj, SpillList); @@ -495,7 +500,7 @@ eliminateCallFramePseudoInstr(MachineFunction &MF, MachineBasicBlock &MBB,          errs() << "eliminateCallFramePseudoInstr size too big: "                 << Amount << "\n";  #endif -        llvm_unreachable(0); +        llvm_unreachable(nullptr);        }        MachineInstr *New; @@ -514,7 +519,7 @@ eliminateCallFramePseudoInstr(MachineFunction &MF, MachineBasicBlock &MBB,        MBB.insert(I, New);      }    } -   +    MBB.erase(I);  } diff --git a/lib/Target/XCore/XCoreFrameLowering.h b/lib/Target/XCore/XCoreFrameLowering.h index 6cd90c9..e4f806a 100644 --- a/lib/Target/XCore/XCoreFrameLowering.h +++ b/lib/Target/XCore/XCoreFrameLowering.h @@ -27,29 +27,30 @@ namespace llvm {      /// emitProlog/emitEpilog - These methods insert prolog and epilog code into      /// the function. -    void emitPrologue(MachineFunction &MF) const; -    void emitEpilogue(MachineFunction &MF, MachineBasicBlock &MBB) const; +    void emitPrologue(MachineFunction &MF) const override; +    void emitEpilogue(MachineFunction &MF, +                      MachineBasicBlock &MBB) const override;      bool spillCalleeSavedRegisters(MachineBasicBlock &MBB, -                                   MachineBasicBlock::iterator MI, -                                   const std::vector<CalleeSavedInfo> &CSI, -                                   const TargetRegisterInfo *TRI) const; +                                  MachineBasicBlock::iterator MI, +                                  const std::vector<CalleeSavedInfo> &CSI, +                                  const TargetRegisterInfo *TRI) const override;      bool restoreCalleeSavedRegisters(MachineBasicBlock &MBB, -                                     MachineBasicBlock::iterator MI, -                                     const std::vector<CalleeSavedInfo> &CSI, -                                     const TargetRegisterInfo *TRI) const; +                                  MachineBasicBlock::iterator MI, +                                  const std::vector<CalleeSavedInfo> &CSI, +                                  const TargetRegisterInfo *TRI) const override;      void eliminateCallFramePseudoInstr(MachineFunction &MF, -                                       MachineBasicBlock &MBB, -                                       MachineBasicBlock::iterator I) const; +                                  MachineBasicBlock &MBB, +                                  MachineBasicBlock::iterator I) const override; -    bool hasFP(const MachineFunction &MF) const; +    bool hasFP(const MachineFunction &MF) const override;      void processFunctionBeforeCalleeSavedScan(MachineFunction &MF, -                                              RegScavenger *RS = NULL) const; +                                     RegScavenger *RS = nullptr) const override;      void processFunctionBeforeFrameFinalized(MachineFunction &MF, -                                             RegScavenger *RS = NULL) const; +                                     RegScavenger *RS = nullptr) const override;      //! Stack slot size (4 bytes)      static int stackSlotSize() { diff --git a/lib/Target/XCore/XCoreFrameToArgsOffsetElim.cpp b/lib/Target/XCore/XCoreFrameToArgsOffsetElim.cpp index c18eff9..30c7b59 100644 --- a/lib/Target/XCore/XCoreFrameToArgsOffsetElim.cpp +++ b/lib/Target/XCore/XCoreFrameToArgsOffsetElim.cpp @@ -26,9 +26,9 @@ namespace {      static char ID;      XCoreFTAOElim() : MachineFunctionPass(ID) {} -    virtual bool runOnMachineFunction(MachineFunction &Fn); +    bool runOnMachineFunction(MachineFunction &Fn) override; -    virtual const char *getPassName() const { +    const char *getPassName() const override {        return "XCore FRAME_TO_ARGS_OFFSET Elimination";      }    }; diff --git a/lib/Target/XCore/XCoreISelDAGToDAG.cpp b/lib/Target/XCore/XCoreISelDAGToDAG.cpp index 5b0fcfa..86bc6f2 100644 --- a/lib/Target/XCore/XCoreISelDAGToDAG.cpp +++ b/lib/Target/XCore/XCoreISelDAGToDAG.cpp @@ -44,7 +44,7 @@ namespace {        : SelectionDAGISel(TM, OptLevel),          Subtarget(*TM.getSubtargetImpl()) { } -    SDNode *Select(SDNode *N); +    SDNode *Select(SDNode *N) override;      SDNode *SelectBRIND(SDNode *N);      /// getI32Imm - Return a target constant with the specified value, of type @@ -70,7 +70,7 @@ namespace {      bool SelectInlineAsmMemoryOperand(const SDValue &Op, char ConstraintCode,                                        std::vector<SDValue> &OutOps) override; -    virtual const char *getPassName() const { +    const char *getPassName() const override {        return "XCore DAG->DAG Pattern Instruction Selection";      }  @@ -89,14 +89,14 @@ FunctionPass *llvm::createXCoreISelDag(XCoreTargetMachine &TM,  bool XCoreDAGToDAGISel::SelectADDRspii(SDValue Addr, SDValue &Base,                                         SDValue &Offset) { -  FrameIndexSDNode *FIN = 0; +  FrameIndexSDNode *FIN = nullptr;    if ((FIN = dyn_cast<FrameIndexSDNode>(Addr))) {      Base = CurDAG->getTargetFrameIndex(FIN->getIndex(), MVT::i32);      Offset = CurDAG->getTargetConstant(0, MVT::i32);      return true;    }    if (Addr.getOpcode() == ISD::ADD) { -    ConstantSDNode *CN = 0; +    ConstantSDNode *CN = nullptr;      if ((FIN = dyn_cast<FrameIndexSDNode>(Addr.getOperand(0)))        && (CN = dyn_cast<ConstantSDNode>(Addr.getOperand(1)))        && (CN->getSExtValue() % 4 == 0 && CN->getSExtValue() >= 0)) { @@ -227,8 +227,7 @@ replaceInChain(SelectionDAG *CurDAG, SDValue Chain, SDValue Old, SDValue New)    }    if (!found)      return SDValue(); -  return CurDAG->getNode(ISD::TokenFactor, SDLoc(Chain), MVT::Other, -                         &Ops[0], Ops.size()); +  return CurDAG->getNode(ISD::TokenFactor, SDLoc(Chain), MVT::Other, Ops);  }  SDNode *XCoreDAGToDAGISel::SelectBRIND(SDNode *N) { @@ -237,10 +236,10 @@ SDNode *XCoreDAGToDAGISel::SelectBRIND(SDNode *N) {    SDValue Chain = N->getOperand(0);    SDValue Addr = N->getOperand(1);    if (Addr->getOpcode() != ISD::INTRINSIC_W_CHAIN) -    return 0; +    return nullptr;    unsigned IntNo = cast<ConstantSDNode>(Addr->getOperand(1))->getZExtValue();    if (IntNo != Intrinsic::xcore_checkevent) -    return 0; +    return nullptr;    SDValue nextAddr = Addr->getOperand(2);    SDValue CheckEventChainOut(Addr.getNode(), 1);    if (!CheckEventChainOut.use_empty()) { @@ -252,7 +251,7 @@ SDNode *XCoreDAGToDAGISel::SelectBRIND(SDNode *N) {      SDValue NewChain = replaceInChain(CurDAG, Chain, CheckEventChainOut,                                        CheckEventChainIn);      if (!NewChain.getNode()) -      return 0; +      return nullptr;      Chain = NewChain;    }    // Enable events on the thread using setsr 1 and then disable them immediately diff --git a/lib/Target/XCore/XCoreISelLowering.cpp b/lib/Target/XCore/XCoreISelLowering.cpp index 1b74013..9d78586 100644 --- a/lib/Target/XCore/XCoreISelLowering.cpp +++ b/lib/Target/XCore/XCoreISelLowering.cpp @@ -11,8 +11,6 @@  //  //===----------------------------------------------------------------------===// -#define DEBUG_TYPE "xcore-lower" -  #include "XCoreISelLowering.h"  #include "XCore.h"  #include "XCoreMachineFunctionInfo.h" @@ -41,6 +39,8 @@  using namespace llvm; +#define DEBUG_TYPE "xcore-lower" +  const char *XCoreTargetLowering::  getTargetNodeName(unsigned Opcode) const  { @@ -64,7 +64,7 @@ getTargetNodeName(unsigned Opcode) const      case XCoreISD::FRAME_TO_ARGS_OFFSET : return "XCoreISD::FRAME_TO_ARGS_OFFSET";      case XCoreISD::EH_RETURN         : return "XCoreISD::EH_RETURN";      case XCoreISD::MEMBARRIER        : return "XCoreISD::MEMBARRIER"; -    default                          : return NULL; +    default                          : return nullptr;    }  } @@ -268,21 +268,19 @@ LowerSELECT_CC(SDValue Op, SelectionDAG &DAG) const                       Op.getOperand(1));  } -SDValue XCoreTargetLowering:: -getGlobalAddressWrapper(SDValue GA, const GlobalValue *GV, -                        SelectionDAG &DAG) const -{ +SDValue XCoreTargetLowering::getGlobalAddressWrapper(SDValue GA, +                                                     const GlobalValue *GV, +                                                     SelectionDAG &DAG) const {    // FIXME there is no actual debug info here    SDLoc dl(GA);    const GlobalValue *UnderlyingGV = GV;    // If GV is an alias then use the aliasee to determine the wrapper type    if (const GlobalAlias *GA = dyn_cast<GlobalAlias>(GV)) -    UnderlyingGV = GA->getAliasedGlobal(); +    UnderlyingGV = GA->getAliasee();    if (const GlobalVariable *GVar = dyn_cast<GlobalVariable>(UnderlyingGV)) { -    if (  ( GVar->isConstant() && -            UnderlyingGV->isLocalLinkage(GV->getLinkage()) ) -       || ( GVar->hasSection() && -            StringRef(GVar->getSection()).startswith(".cp.") ) ) +    if ((GVar->isConstant() && GV->hasLocalLinkage()) || +        (GVar->hasSection() && +         StringRef(GVar->getSection()).startswith(".cp.")))        return DAG.getNode(XCoreISD::CPRelativeWrapper, dl, MVT::i32, GA);      return DAG.getNode(XCoreISD::DPRelativeWrapper, dl, MVT::i32, GA);    } @@ -428,13 +426,13 @@ lowerLoadWordFromAlignedBasePlusOffset(SDLoc DL, SDValue Chain, SDValue Base,    Chain = DAG.getNode(ISD::TokenFactor, DL, MVT::Other, Low.getValue(1),                        High.getValue(1));    SDValue Ops[] = { Result, Chain }; -  return DAG.getMergeValues(Ops, 2, DL); +  return DAG.getMergeValues(Ops, DL);  }  static bool isWordAligned(SDValue Value, SelectionDAG &DAG)  {    APInt KnownZero, KnownOne; -  DAG.ComputeMaskedBits(Value, KnownZero, KnownOne); +  DAG.computeKnownBits(Value, KnownZero, KnownOne);    return KnownZero.countTrailingOnes() >= 2;  } @@ -494,7 +492,7 @@ LowerLOAD(SDValue Op, SelectionDAG &DAG) const {      Chain = DAG.getNode(ISD::TokenFactor, DL, MVT::Other, Low.getValue(1),                               High.getValue(1));      SDValue Ops[] = { Result, Chain }; -    return DAG.getMergeValues(Ops, 2, DL); +    return DAG.getMergeValues(Ops, DL);    }    // Lower to a call to __misaligned_load(BasePtr). @@ -506,17 +504,15 @@ LowerLOAD(SDValue Op, SelectionDAG &DAG) const {    Entry.Node = BasePtr;    Args.push_back(Entry); -  TargetLowering::CallLoweringInfo CLI(Chain, IntPtrTy, false, false, -                    false, false, 0, CallingConv::C, /*isTailCall=*/false, -                    /*doesNotRet=*/false, /*isReturnValueUsed=*/true, -                    DAG.getExternalSymbol("__misaligned_load", getPointerTy()), -                    Args, DAG, DL); -  std::pair<SDValue, SDValue> CallResult = LowerCallTo(CLI); - -  SDValue Ops[] = -    { CallResult.first, CallResult.second }; +  TargetLowering::CallLoweringInfo CLI(DAG); +  CLI.setDebugLoc(DL).setChain(Chain) +    .setCallee(CallingConv::C, IntPtrTy, +               DAG.getExternalSymbol("__misaligned_load", getPointerTy()), +               &Args, 0); -  return DAG.getMergeValues(Ops, 2, DL); +  std::pair<SDValue, SDValue> CallResult = LowerCallTo(CLI); +  SDValue Ops[] = { CallResult.first, CallResult.second }; +  return DAG.getMergeValues(Ops, DL);  }  SDValue XCoreTargetLowering:: @@ -568,14 +564,13 @@ LowerSTORE(SDValue Op, SelectionDAG &DAG) const    Entry.Node = Value;    Args.push_back(Entry); -  TargetLowering::CallLoweringInfo CLI(Chain, -                    Type::getVoidTy(*DAG.getContext()), false, false, -                    false, false, 0, CallingConv::C, /*isTailCall=*/false, -                    /*doesNotRet=*/false, /*isReturnValueUsed=*/true, -                    DAG.getExternalSymbol("__misaligned_store", getPointerTy()), -                    Args, DAG, dl); -  std::pair<SDValue, SDValue> CallResult = LowerCallTo(CLI); +  TargetLowering::CallLoweringInfo CLI(DAG); +  CLI.setDebugLoc(dl).setChain(Chain) +    .setCallee(CallingConv::C, Type::getVoidTy(*DAG.getContext()), +               DAG.getExternalSymbol("__misaligned_store", getPointerTy()), +               &Args, 0); +  std::pair<SDValue, SDValue> CallResult = LowerCallTo(CLI);    return CallResult.second;  } @@ -593,7 +588,7 @@ LowerSMUL_LOHI(SDValue Op, SelectionDAG &DAG) const                             LHS, RHS);    SDValue Lo(Hi.getNode(), 1);    SDValue Ops[] = { Lo, Hi }; -  return DAG.getMergeValues(Ops, 2, dl); +  return DAG.getMergeValues(Ops, dl);  }  SDValue XCoreTargetLowering:: @@ -610,7 +605,7 @@ LowerUMUL_LOHI(SDValue Op, SelectionDAG &DAG) const                             Zero, Zero);    SDValue Lo(Hi.getNode(), 1);    SDValue Ops[] = { Lo, Hi }; -  return DAG.getMergeValues(Ops, 2, dl); +  return DAG.getMergeValues(Ops, dl);  }  /// isADDADDMUL - Return whether Op is in a form that is equivalent to @@ -741,7 +736,7 @@ ExpandADDSUB(SDNode *N, SelectionDAG &DAG) const    if (N->getOpcode() == ISD::ADD) {      SDValue Result = TryExpandADDWithMul(N, DAG); -    if (Result.getNode() != 0) +    if (Result.getNode())        return Result;    } @@ -886,7 +881,7 @@ LowerEH_RETURN(SDValue Op, SelectionDAG &DAG) const {      DAG.getCopyToReg(Chain, dl, HandlerReg, Handler)    }; -  Chain = DAG.getNode(ISD::TokenFactor, dl, MVT::Other, OutChains, 2); +  Chain = DAG.getNode(ISD::TokenFactor, dl, MVT::Other, OutChains);    return DAG.getNode(XCoreISD::EH_RETURN, dl, MVT::Other, Chain,                       DAG.getRegister(StackReg, MVT::i32), @@ -952,7 +947,7 @@ LowerINIT_TRAMPOLINE(SDValue Op, SelectionDAG &DAG) const {                                MachinePointerInfo(TrmpAddr, 16), false, false,                                0); -  return DAG.getNode(ISD::TokenFactor, dl, MVT::Other, OutChains, 5); +  return DAG.getNode(ISD::TokenFactor, dl, MVT::Other, OutChains);  }  SDValue XCoreTargetLowering:: @@ -967,7 +962,7 @@ LowerINTRINSIC_WO_CHAIN(SDValue Op, SelectionDAG &DAG) const {                      Op.getOperand(1), Op.getOperand(2) , Op.getOperand(3));        SDValue Crc(Data.getNode(), 1);        SDValue Results[] = { Crc, Data }; -      return DAG.getMergeValues(Results, 2, DL); +      return DAG.getMergeValues(Results, DL);    }    return SDValue();  } @@ -1111,7 +1106,7 @@ LowerCallResult(SDValue Chain, SDValue InFlag,      unsigned index = ResultMemLocs[i].second;      SDVTList VTs = DAG.getVTList(MVT::i32, MVT::Other);      SDValue Ops[] = { Chain, DAG.getConstant(offset / 4, MVT::i32) }; -    SDValue load = DAG.getNode(XCoreISD::LDWSP, dl, VTs, Ops, 2); +    SDValue load = DAG.getNode(XCoreISD::LDWSP, dl, VTs, Ops);      InVals[index] = load;      MemOpChains.push_back(load.getValue(1));    } @@ -1119,8 +1114,7 @@ LowerCallResult(SDValue Chain, SDValue InFlag,    // Transform all loads nodes into one single node because    // all load nodes are independent of each other.    if (!MemOpChains.empty()) -    Chain = DAG.getNode(ISD::TokenFactor, dl, MVT::Other, -                        &MemOpChains[0], MemOpChains.size()); +    Chain = DAG.getNode(ISD::TokenFactor, dl, MVT::Other, MemOpChains);    return Chain;  } @@ -1204,8 +1198,7 @@ XCoreTargetLowering::LowerCCCCallTo(SDValue Chain, SDValue Callee,    // Transform all store nodes into one single node because    // all store nodes are independent of each other.    if (!MemOpChains.empty()) -    Chain = DAG.getNode(ISD::TokenFactor, dl, MVT::Other, -                        &MemOpChains[0], MemOpChains.size()); +    Chain = DAG.getNode(ISD::TokenFactor, dl, MVT::Other, MemOpChains);    // Build a sequence of copy-to-reg nodes chained together with token    // chain and flag operands which copy the outgoing args into registers. @@ -1244,7 +1237,7 @@ XCoreTargetLowering::LowerCCCCallTo(SDValue Chain, SDValue Callee,    if (InFlag.getNode())      Ops.push_back(InFlag); -  Chain  = DAG.getNode(XCoreISD::BL, dl, NodeTys, &Ops[0], Ops.size()); +  Chain  = DAG.getNode(XCoreISD::BL, dl, NodeTys, Ops);    InFlag = Chain.getValue(1);    // Create the CALLSEQ_END node. @@ -1347,7 +1340,7 @@ XCoreTargetLowering::LowerCCCArguments(SDValue Chain,            errs() << "LowerFormalArguments Unhandled argument type: "                   << RegVT.getSimpleVT().SimpleTy << "\n";  #endif -          llvm_unreachable(0); +          llvm_unreachable(nullptr);          }        case MVT::i32:          unsigned VReg = RegInfo.createVirtualRegister(&XCore::GRRegsRegClass); @@ -1384,7 +1377,7 @@ XCoreTargetLowering::LowerCCCArguments(SDValue Chain,    // 1b. CopyFromReg vararg registers.    if (isVarArg) {      // Argument registers -    static const uint16_t ArgRegs[] = { +    static const MCPhysReg ArgRegs[] = {        XCore::R0, XCore::R1, XCore::R2, XCore::R3      };      XCoreFunctionInfo *XFI = MF.getInfo<XCoreFunctionInfo>(); @@ -1422,8 +1415,7 @@ XCoreTargetLowering::LowerCCCArguments(SDValue Chain,    // 2. chain CopyFromReg nodes into a TokenFactor.    if (!CFRegNode.empty()) -    Chain = DAG.getNode(ISD::TokenFactor, dl, MVT::Other, &CFRegNode[0], -                        CFRegNode.size()); +    Chain = DAG.getNode(ISD::TokenFactor, dl, MVT::Other, CFRegNode);    // 3. Memcpy 'byVal' args & push final InVals.    // Aggregates passed "byVal" need to be copied by the callee. @@ -1452,8 +1444,7 @@ XCoreTargetLowering::LowerCCCArguments(SDValue Chain,    // 4, chain mem ops nodes into a TokenFactor.    if (!MemOps.empty()) {      MemOps.push_back(Chain); -    Chain = DAG.getNode(ISD::TokenFactor, dl, MVT::Other, &MemOps[0], -                        MemOps.size()); +    Chain = DAG.getNode(ISD::TokenFactor, dl, MVT::Other, MemOps);    }    return Chain; @@ -1535,8 +1526,7 @@ XCoreTargetLowering::LowerReturn(SDValue Chain,    // Transform all store nodes into one single node because    // all stores are independent of each other.    if (!MemOpChains.empty()) -    Chain = DAG.getNode(ISD::TokenFactor, dl, MVT::Other, -                        &MemOpChains[0], MemOpChains.size()); +    Chain = DAG.getNode(ISD::TokenFactor, dl, MVT::Other, MemOpChains);    // Now handle return values copied to registers.    for (unsigned i = 0, e = RVLocs.size(); i != e; ++i) { @@ -1558,8 +1548,7 @@ XCoreTargetLowering::LowerReturn(SDValue Chain,    if (Flag.getNode())      RetOps.push_back(Flag); -  return DAG.getNode(XCoreISD::RETSP, dl, MVT::Other, -                     &RetOps[0], RetOps.size()); +  return DAG.getNode(XCoreISD::RETSP, dl, MVT::Other, RetOps);  }  //===----------------------------------------------------------------------===// @@ -1696,7 +1685,7 @@ SDValue XCoreTargetLowering::PerformDAGCombine(SDNode *N,        SDValue Result = DAG.getNode(ISD::AND, dl, VT, N2,                                     DAG.getConstant(1, VT));        SDValue Ops[] = { Result, Carry }; -      return DAG.getMergeValues(Ops, 2, dl); +      return DAG.getMergeValues(Ops, dl);      }      // fold (ladd x, 0, y) -> 0, add x, y iff carry is unused and y has only the @@ -1705,12 +1694,12 @@ SDValue XCoreTargetLowering::PerformDAGCombine(SDNode *N,        APInt KnownZero, KnownOne;        APInt Mask = APInt::getHighBitsSet(VT.getSizeInBits(),                                           VT.getSizeInBits() - 1); -      DAG.ComputeMaskedBits(N2, KnownZero, KnownOne); +      DAG.computeKnownBits(N2, KnownZero, KnownOne);        if ((KnownZero & Mask) == Mask) {          SDValue Carry = DAG.getConstant(0, VT);          SDValue Result = DAG.getNode(ISD::ADD, dl, VT, N0, N2);          SDValue Ops[] = { Result, Carry }; -        return DAG.getMergeValues(Ops, 2, dl); +        return DAG.getMergeValues(Ops, dl);        }      }    } @@ -1728,13 +1717,13 @@ SDValue XCoreTargetLowering::PerformDAGCombine(SDNode *N,        APInt KnownZero, KnownOne;        APInt Mask = APInt::getHighBitsSet(VT.getSizeInBits(),                                           VT.getSizeInBits() - 1); -      DAG.ComputeMaskedBits(N2, KnownZero, KnownOne); +      DAG.computeKnownBits(N2, KnownZero, KnownOne);        if ((KnownZero & Mask) == Mask) {          SDValue Borrow = N2;          SDValue Result = DAG.getNode(ISD::SUB, dl, VT,                                       DAG.getConstant(0, VT), N2);          SDValue Ops[] = { Result, Borrow }; -        return DAG.getMergeValues(Ops, 2, dl); +        return DAG.getMergeValues(Ops, dl);        }      } @@ -1744,12 +1733,12 @@ SDValue XCoreTargetLowering::PerformDAGCombine(SDNode *N,        APInt KnownZero, KnownOne;        APInt Mask = APInt::getHighBitsSet(VT.getSizeInBits(),                                           VT.getSizeInBits() - 1); -      DAG.ComputeMaskedBits(N2, KnownZero, KnownOne); +      DAG.computeKnownBits(N2, KnownZero, KnownOne);        if ((KnownZero & Mask) == Mask) {          SDValue Borrow = DAG.getConstant(0, VT);          SDValue Result = DAG.getNode(ISD::SUB, dl, VT, N0, N2);          SDValue Ops[] = { Result, Borrow }; -        return DAG.getMergeValues(Ops, 2, dl); +        return DAG.getMergeValues(Ops, dl);        }      }    } @@ -1775,14 +1764,14 @@ SDValue XCoreTargetLowering::PerformDAGCombine(SDNode *N,        if (N->hasNUsesOfValue(0, 0)) {          SDValue Lo = DAG.getNode(ISD::ADD, dl, VT, N2, N3);          SDValue Ops[] = { Lo, Lo }; -        return DAG.getMergeValues(Ops, 2, dl); +        return DAG.getMergeValues(Ops, dl);        }        // Otherwise fold to ladd(a, b, 0)        SDValue Result =          DAG.getNode(XCoreISD::LADD, dl, DAG.getVTList(VT, VT), N2, N3, N1);        SDValue Carry(Result.getNode(), 1);        SDValue Ops[] = { Carry, Result }; -      return DAG.getMergeValues(Ops, 2, dl); +      return DAG.getMergeValues(Ops, dl);      }    }    break; @@ -1866,11 +1855,11 @@ SDValue XCoreTargetLowering::PerformDAGCombine(SDNode *N,    return SDValue();  } -void XCoreTargetLowering::computeMaskedBitsForTargetNode(const SDValue Op, -                                                         APInt &KnownZero, -                                                         APInt &KnownOne, -                                                         const SelectionDAG &DAG, -                                                         unsigned Depth) const { +void XCoreTargetLowering::computeKnownBitsForTargetNode(const SDValue Op, +                                                        APInt &KnownZero, +                                                        APInt &KnownOne, +                                                        const SelectionDAG &DAG, +                                                        unsigned Depth) const {    KnownZero = KnownOne = APInt(KnownZero.getBitWidth(), 0);    switch (Op.getOpcode()) {    default: break; diff --git a/lib/Target/XCore/XCoreISelLowering.h b/lib/Target/XCore/XCoreISelLowering.h index 65e2bad..d28715b 100644 --- a/lib/Target/XCore/XCoreISelLowering.h +++ b/lib/Target/XCore/XCoreISelLowering.h @@ -97,31 +97,30 @@ namespace llvm {      explicit XCoreTargetLowering(XCoreTargetMachine &TM);      using TargetLowering::isZExtFree; -    virtual bool isZExtFree(SDValue Val, EVT VT2) const; +    bool isZExtFree(SDValue Val, EVT VT2) const override; -    virtual unsigned getJumpTableEncoding() const; -    virtual MVT getScalarShiftAmountTy(EVT LHSTy) const { return MVT::i32; } +    unsigned getJumpTableEncoding() const override; +    MVT getScalarShiftAmountTy(EVT LHSTy) const override { return MVT::i32; }      /// LowerOperation - Provide custom lowering hooks for some operations. -    virtual SDValue LowerOperation(SDValue Op, SelectionDAG &DAG) const; +    SDValue LowerOperation(SDValue Op, SelectionDAG &DAG) const override;      /// ReplaceNodeResults - Replace the results of node with an illegal result      /// type with new values built out of custom code.      /// -    virtual void ReplaceNodeResults(SDNode *N, SmallVectorImpl<SDValue>&Results, -                                    SelectionDAG &DAG) const; +    void ReplaceNodeResults(SDNode *N, SmallVectorImpl<SDValue>&Results, +                            SelectionDAG &DAG) const override;      /// getTargetNodeName - This method returns the name of a target specific      //  DAG node. -    virtual const char *getTargetNodeName(unsigned Opcode) const; +    const char *getTargetNodeName(unsigned Opcode) const override; -    virtual MachineBasicBlock * +    MachineBasicBlock *        EmitInstrWithCustomInserter(MachineInstr *MI, -                                  MachineBasicBlock *MBB) const; +                                  MachineBasicBlock *MBB) const override; -    virtual bool isLegalAddressingMode(const AddrMode &AM, -                                       Type *Ty) const; +    bool isLegalAddressingMode(const AddrMode &AM, Type *Ty) const override;    private:      const XCoreTargetMachine &TM; @@ -176,44 +175,44 @@ namespace llvm {      // Inline asm support      std::pair<unsigned, const TargetRegisterClass*>      getRegForInlineAsmConstraint(const std::string &Constraint, -                                 MVT VT) const; +                                 MVT VT) const override;      // Expand specifics      SDValue TryExpandADDWithMul(SDNode *Op, SelectionDAG &DAG) const;      SDValue ExpandADDSUB(SDNode *Op, SelectionDAG &DAG) const; -    virtual SDValue PerformDAGCombine(SDNode *N, DAGCombinerInfo &DCI) const; +    SDValue PerformDAGCombine(SDNode *N, DAGCombinerInfo &DCI) const override; -    virtual void computeMaskedBitsForTargetNode(const SDValue Op, -                                                APInt &KnownZero, -                                                APInt &KnownOne, -                                                const SelectionDAG &DAG, -                                                unsigned Depth = 0) const; +    void computeKnownBitsForTargetNode(const SDValue Op, +                                       APInt &KnownZero, +                                       APInt &KnownOne, +                                       const SelectionDAG &DAG, +                                       unsigned Depth = 0) const override; -    virtual SDValue +    SDValue        LowerFormalArguments(SDValue Chain,                             CallingConv::ID CallConv,                             bool isVarArg,                             const SmallVectorImpl<ISD::InputArg> &Ins,                             SDLoc dl, SelectionDAG &DAG, -                           SmallVectorImpl<SDValue> &InVals) const; +                           SmallVectorImpl<SDValue> &InVals) const override; -    virtual SDValue +    SDValue        LowerCall(TargetLowering::CallLoweringInfo &CLI, -                SmallVectorImpl<SDValue> &InVals) const; +                SmallVectorImpl<SDValue> &InVals) const override; -    virtual SDValue +    SDValue        LowerReturn(SDValue Chain,                    CallingConv::ID CallConv, bool isVarArg,                    const SmallVectorImpl<ISD::OutputArg> &Outs,                    const SmallVectorImpl<SDValue> &OutVals, -                  SDLoc dl, SelectionDAG &DAG) const; +                  SDLoc dl, SelectionDAG &DAG) const override; -    virtual bool +    bool        CanLowerReturn(CallingConv::ID CallConv, MachineFunction &MF,                       bool isVarArg,                       const SmallVectorImpl<ISD::OutputArg> &ArgsFlags, -                     LLVMContext &Context) const; +                     LLVMContext &Context) const override;    };  } diff --git a/lib/Target/XCore/XCoreInstrInfo.cpp b/lib/Target/XCore/XCoreInstrInfo.cpp index cea3bbf..984f0cd 100644 --- a/lib/Target/XCore/XCoreInstrInfo.cpp +++ b/lib/Target/XCore/XCoreInstrInfo.cpp @@ -26,6 +26,8 @@  #include "llvm/Support/ErrorHandling.h"  #include "llvm/Support/TargetRegistry.h" +using namespace llvm; +  #define GET_INSTRINFO_CTOR_DTOR  #include "XCoreGenInstrInfo.inc" @@ -41,9 +43,6 @@ namespace XCore {  }  } -using namespace llvm; - -  // Pin the vtable to this file.  void XCoreInstrInfo::anchor() {} @@ -289,7 +288,7 @@ XCoreInstrInfo::InsertBranch(MachineBasicBlock &MBB,MachineBasicBlock *TBB,    assert((Cond.size() == 2 || Cond.size() == 0) &&           "Unexpected number of components!"); -  if (FBB == 0) { // One way branch. +  if (!FBB) { // One way branch.      if (Cond.empty()) {        // Unconditional branch        BuildMI(&MBB, DL, get(XCore::BRFU_lu6)).addMBB(TBB); @@ -428,13 +427,21 @@ static inline bool isImmU16(unsigned val) {    return val < (1 << 16);  } +static bool isImmMskBitp(unsigned val) { +  if (!isMask_32(val)) { +    return false; +  } +  int N = Log2_32(val) + 1; +  return (N >= 1 && N <= 8) || N == 16 || N == 24 || N == 32; +} +  MachineBasicBlock::iterator XCoreInstrInfo::loadImmediate(                                                MachineBasicBlock &MBB,                                                MachineBasicBlock::iterator MI,                                                unsigned Reg, uint64_t Value) const {    DebugLoc dl;    if (MI != MBB.end()) dl = MI->getDebugLoc(); -  if (isMask_32(Value)) { +  if (isImmMskBitp(Value)) {      int N = Log2_32(Value) + 1;      return BuildMI(MBB, MI, dl, get(XCore::MKMSK_rus), Reg).addImm(N);    } diff --git a/lib/Target/XCore/XCoreInstrInfo.h b/lib/Target/XCore/XCoreInstrInfo.h index 48c9cb5..e0be96b 100644 --- a/lib/Target/XCore/XCoreInstrInfo.h +++ b/lib/Target/XCore/XCoreInstrInfo.h @@ -32,55 +32,55 @@ public:    /// such, whenever a client has an instance of instruction info, it should    /// always be able to get register info as well (through this method).    /// -  virtual const TargetRegisterInfo &getRegisterInfo() const { return RI; } +  const TargetRegisterInfo &getRegisterInfo() const { return RI; }    /// isLoadFromStackSlot - If the specified machine instruction is a direct    /// load from a stack slot, return the virtual or physical register number of    /// the destination along with the FrameIndex of the loaded stack slot.  If    /// not, return 0.  This predicate must return 0 if the instruction has    /// any side effects other than loading from the stack slot. -  virtual unsigned isLoadFromStackSlot(const MachineInstr *MI, -                                       int &FrameIndex) const; -   +  unsigned isLoadFromStackSlot(const MachineInstr *MI, +                               int &FrameIndex) const override; +    /// isStoreToStackSlot - If the specified machine instruction is a direct    /// store to a stack slot, return the virtual or physical register number of    /// the source reg along with the FrameIndex of the loaded stack slot.  If    /// not, return 0.  This predicate must return 0 if the instruction has    /// any side effects other than storing to the stack slot. -  virtual unsigned isStoreToStackSlot(const MachineInstr *MI, -                                      int &FrameIndex) const; -   -  virtual bool AnalyzeBranch(MachineBasicBlock &MBB, MachineBasicBlock *&TBB, -                             MachineBasicBlock *&FBB, -                             SmallVectorImpl<MachineOperand> &Cond, -                             bool AllowModify) const; -   -  virtual unsigned InsertBranch(MachineBasicBlock &MBB, MachineBasicBlock *TBB, -                                MachineBasicBlock *FBB, -                                const SmallVectorImpl<MachineOperand> &Cond, -                                DebugLoc DL) const; -   -  virtual unsigned RemoveBranch(MachineBasicBlock &MBB) const; - -  virtual void copyPhysReg(MachineBasicBlock &MBB, -                           MachineBasicBlock::iterator I, DebugLoc DL, -                           unsigned DestReg, unsigned SrcReg, -                           bool KillSrc) const; - -  virtual void storeRegToStackSlot(MachineBasicBlock &MBB, -                                   MachineBasicBlock::iterator MI, -                                   unsigned SrcReg, bool isKill, int FrameIndex, -                                   const TargetRegisterClass *RC, -                                   const TargetRegisterInfo *TRI) const; - -  virtual void loadRegFromStackSlot(MachineBasicBlock &MBB, -                                    MachineBasicBlock::iterator MI, -                                    unsigned DestReg, int FrameIndex, -                                    const TargetRegisterClass *RC, -                                    const TargetRegisterInfo *TRI) const; - -  virtual bool ReverseBranchCondition( -                            SmallVectorImpl<MachineOperand> &Cond) const; +  unsigned isStoreToStackSlot(const MachineInstr *MI, +                              int &FrameIndex) const override; + +  bool AnalyzeBranch(MachineBasicBlock &MBB, MachineBasicBlock *&TBB, +                     MachineBasicBlock *&FBB, +                     SmallVectorImpl<MachineOperand> &Cond, +                     bool AllowModify) const override; + +  unsigned InsertBranch(MachineBasicBlock &MBB, MachineBasicBlock *TBB, +                        MachineBasicBlock *FBB, +                        const SmallVectorImpl<MachineOperand> &Cond, +                        DebugLoc DL) const override; + +  unsigned RemoveBranch(MachineBasicBlock &MBB) const override; + +  void copyPhysReg(MachineBasicBlock &MBB, +                   MachineBasicBlock::iterator I, DebugLoc DL, +                   unsigned DestReg, unsigned SrcReg, +                   bool KillSrc) const override; + +  void storeRegToStackSlot(MachineBasicBlock &MBB, +                           MachineBasicBlock::iterator MI, +                           unsigned SrcReg, bool isKill, int FrameIndex, +                           const TargetRegisterClass *RC, +                           const TargetRegisterInfo *TRI) const override; + +  void loadRegFromStackSlot(MachineBasicBlock &MBB, +                            MachineBasicBlock::iterator MI, +                            unsigned DestReg, int FrameIndex, +                            const TargetRegisterClass *RC, +                            const TargetRegisterInfo *TRI) const override; + +  bool ReverseBranchCondition( +                          SmallVectorImpl<MachineOperand> &Cond) const override;    // Emit code before MBBI to load immediate value into physical register Reg.    // Returns an iterator to the new instruction. diff --git a/lib/Target/XCore/XCoreLowerThreadLocal.cpp b/lib/Target/XCore/XCoreLowerThreadLocal.cpp index b398c2d..ac3bae5 100644 --- a/lib/Target/XCore/XCoreLowerThreadLocal.cpp +++ b/lib/Target/XCore/XCoreLowerThreadLocal.cpp @@ -48,7 +48,7 @@ namespace {      bool lowerGlobal(GlobalVariable *GV); -    bool runOnModule(Module &M); +    bool runOnModule(Module &M) override;    };  } @@ -189,13 +189,14 @@ bool XCoreLowerThreadLocal::lowerGlobal(GlobalVariable *GV) {    // Create replacement global.    ArrayType *NewType = createLoweredType(GV->getType()->getElementType()); -  Constant *NewInitializer = 0; +  Constant *NewInitializer = nullptr;    if (GV->hasInitializer())      NewInitializer = createLoweredInitializer(NewType,                                                GV->getInitializer());    GlobalVariable *NewGV =      new GlobalVariable(*M, NewType, GV->isConstant(), GV->getLinkage(), -                       NewInitializer, "", 0, GlobalVariable::NotThreadLocal, +                       NewInitializer, "", nullptr, +                       GlobalVariable::NotThreadLocal,                         GV->getType()->getAddressSpace(),                         GV->isExternallyInitialized()); diff --git a/lib/Target/XCore/XCoreRegisterInfo.cpp b/lib/Target/XCore/XCoreRegisterInfo.cpp index d85d717..316c82c 100644 --- a/lib/Target/XCore/XCoreRegisterInfo.cpp +++ b/lib/Target/XCore/XCoreRegisterInfo.cpp @@ -33,11 +33,13 @@  #include "llvm/Target/TargetMachine.h"  #include "llvm/Target/TargetOptions.h" +using namespace llvm; + +#define DEBUG_TYPE "xcore-reg-info" +  #define GET_REGINFO_TARGET_DESC  #include "XCoreGenRegisterInfo.inc" -using namespace llvm; -  XCoreRegisterInfo::XCoreRegisterInfo()    : XCoreGenRegisterInfo(XCore::LR) {  } @@ -205,16 +207,16 @@ bool XCoreRegisterInfo::needsFrameMoves(const MachineFunction &MF) {      MF.getFunction()->needsUnwindTableEntry();  } -const uint16_t* XCoreRegisterInfo::getCalleeSavedRegs(const MachineFunction *MF) +const MCPhysReg* XCoreRegisterInfo::getCalleeSavedRegs(const MachineFunction *MF)                                                                           const {    // The callee saved registers LR & FP are explicitly handled during    // emitPrologue & emitEpilogue and related functions. -  static const uint16_t CalleeSavedRegs[] = { +  static const MCPhysReg CalleeSavedRegs[] = {      XCore::R4, XCore::R5, XCore::R6, XCore::R7,      XCore::R8, XCore::R9, XCore::R10,      0    }; -  static const uint16_t CalleeSavedRegsFP[] = { +  static const MCPhysReg CalleeSavedRegsFP[] = {      XCore::R4, XCore::R5, XCore::R6, XCore::R7,      XCore::R8, XCore::R9,      0 diff --git a/lib/Target/XCore/XCoreRegisterInfo.h b/lib/Target/XCore/XCoreRegisterInfo.h index 36ba7b4..aa617a0 100644 --- a/lib/Target/XCore/XCoreRegisterInfo.h +++ b/lib/Target/XCore/XCoreRegisterInfo.h @@ -29,22 +29,23 @@ public:    /// Code Generation virtual methods... -  const uint16_t *getCalleeSavedRegs(const MachineFunction *MF = 0) const; +  const MCPhysReg * +  getCalleeSavedRegs(const MachineFunction *MF =nullptr) const override; -  BitVector getReservedRegs(const MachineFunction &MF) const; +  BitVector getReservedRegs(const MachineFunction &MF) const override; -  bool requiresRegisterScavenging(const MachineFunction &MF) const; +  bool requiresRegisterScavenging(const MachineFunction &MF) const override; -  bool trackLivenessAfterRegAlloc(const MachineFunction &MF) const; +  bool trackLivenessAfterRegAlloc(const MachineFunction &MF) const override; -  bool useFPForScavengingIndex(const MachineFunction &MF) const; +  bool useFPForScavengingIndex(const MachineFunction &MF) const override;    void eliminateFrameIndex(MachineBasicBlock::iterator II,                             int SPAdj, unsigned FIOperandNum, -                           RegScavenger *RS = NULL) const; +                           RegScavenger *RS = nullptr) const override;    // Debug information queries. -  unsigned getFrameRegister(const MachineFunction &MF) const; +  unsigned getFrameRegister(const MachineFunction &MF) const override;    //! Return whether to emit frame moves    static bool needsFrameMoves(const MachineFunction &MF); diff --git a/lib/Target/XCore/XCoreSelectionDAGInfo.cpp b/lib/Target/XCore/XCoreSelectionDAGInfo.cpp index 68ede6a..5a6bbe7 100644 --- a/lib/Target/XCore/XCoreSelectionDAGInfo.cpp +++ b/lib/Target/XCore/XCoreSelectionDAGInfo.cpp @@ -11,10 +11,11 @@  //  //===----------------------------------------------------------------------===// -#define DEBUG_TYPE "xcore-selectiondag-info"  #include "XCoreTargetMachine.h"  using namespace llvm; +#define DEBUG_TYPE "xcore-selectiondag-info" +  XCoreSelectionDAGInfo::XCoreSelectionDAGInfo(const XCoreTargetMachine &TM)    : TargetSelectionDAGInfo(TM) {  } @@ -41,13 +42,15 @@ EmitTargetCodeForMemcpy(SelectionDAG &DAG, SDLoc dl, SDValue Chain,      Entry.Node = Src; Args.push_back(Entry);      Entry.Node = Size; Args.push_back(Entry); -    TargetLowering::CallLoweringInfo -    CLI(Chain, Type::getVoidTy(*DAG.getContext()), false, false, false, false, -        0, TLI.getLibcallCallingConv(RTLIB::MEMCPY), /*isTailCall=*/false, -        /*doesNotRet=*/false, /*isReturnValueUsed=*/false, -        DAG.getExternalSymbol("__memcpy_4", TLI.getPointerTy()), Args, DAG, dl); -    std::pair<SDValue,SDValue> CallResult = -      TLI.LowerCallTo(CLI); +    TargetLowering::CallLoweringInfo CLI(DAG); +    CLI.setDebugLoc(dl).setChain(Chain) +      .setCallee(TLI.getLibcallCallingConv(RTLIB::MEMCPY), +                 Type::getVoidTy(*DAG.getContext()), +                 DAG.getExternalSymbol("__memcpy_4", TLI.getPointerTy()), +                 &Args, 0) +      .setDiscardResult(); + +    std::pair<SDValue,SDValue> CallResult = TLI.LowerCallTo(CLI);      return CallResult.second;    } diff --git a/lib/Target/XCore/XCoreSelectionDAGInfo.h b/lib/Target/XCore/XCoreSelectionDAGInfo.h index 31704f3..ea6af98 100644 --- a/lib/Target/XCore/XCoreSelectionDAGInfo.h +++ b/lib/Target/XCore/XCoreSelectionDAGInfo.h @@ -25,14 +25,14 @@ public:    explicit XCoreSelectionDAGInfo(const XCoreTargetMachine &TM);    ~XCoreSelectionDAGInfo(); -  virtual SDValue +  SDValue    EmitTargetCodeForMemcpy(SelectionDAG &DAG, SDLoc dl,                            SDValue Chain,                            SDValue Op1, SDValue Op2,                            SDValue Op3, unsigned Align, bool isVolatile,                            bool AlwaysInline,                            MachinePointerInfo DstPtrInfo, -                          MachinePointerInfo SrcPtrInfo) const; +                          MachinePointerInfo SrcPtrInfo) const override;  };  } diff --git a/lib/Target/XCore/XCoreSubtarget.cpp b/lib/Target/XCore/XCoreSubtarget.cpp index 8cfb770..89ea03a 100644 --- a/lib/Target/XCore/XCoreSubtarget.cpp +++ b/lib/Target/XCore/XCoreSubtarget.cpp @@ -15,12 +15,14 @@  #include "XCore.h"  #include "llvm/Support/TargetRegistry.h" +using namespace llvm; + +#define DEBUG_TYPE "xcore-subtarget" +  #define GET_SUBTARGETINFO_TARGET_DESC  #define GET_SUBTARGETINFO_CTOR  #include "XCoreGenSubtargetInfo.inc" -using namespace llvm; -  void XCoreSubtarget::anchor() { }  XCoreSubtarget::XCoreSubtarget(const std::string &TT, diff --git a/lib/Target/XCore/XCoreTargetMachine.cpp b/lib/Target/XCore/XCoreTargetMachine.cpp index 781a87b..0fb21c5 100644 --- a/lib/Target/XCore/XCoreTargetMachine.cpp +++ b/lib/Target/XCore/XCoreTargetMachine.cpp @@ -46,9 +46,9 @@ public:      return getTM<XCoreTargetMachine>();    } -  virtual bool addPreISel(); -  virtual bool addInstSelector(); -  virtual bool addPreEmitPass(); +  bool addPreISel() override; +  bool addInstSelector() override; +  bool addPreEmitPass() override;  };  } // namespace diff --git a/lib/Target/XCore/XCoreTargetMachine.h b/lib/Target/XCore/XCoreTargetMachine.h index a19a677..a57ca55 100644 --- a/lib/Target/XCore/XCoreTargetMachine.h +++ b/lib/Target/XCore/XCoreTargetMachine.h @@ -37,28 +37,28 @@ public:                       Reloc::Model RM, CodeModel::Model CM,                       CodeGenOpt::Level OL); -  virtual const XCoreInstrInfo *getInstrInfo() const { return &InstrInfo; } -  virtual const XCoreFrameLowering *getFrameLowering() const { +  const XCoreInstrInfo *getInstrInfo() const override { return &InstrInfo; } +  const XCoreFrameLowering *getFrameLowering() const override {      return &FrameLowering;    } -  virtual const XCoreSubtarget *getSubtargetImpl() const { return &Subtarget; } -  virtual const XCoreTargetLowering *getTargetLowering() const { +  const XCoreSubtarget *getSubtargetImpl() const override { return &Subtarget; } +  const XCoreTargetLowering *getTargetLowering() const override {      return &TLInfo;    } -  virtual const XCoreSelectionDAGInfo* getSelectionDAGInfo() const { +  const XCoreSelectionDAGInfo* getSelectionDAGInfo() const override {      return &TSInfo;    } -  virtual const TargetRegisterInfo *getRegisterInfo() const { +  const TargetRegisterInfo *getRegisterInfo() const override {      return &InstrInfo.getRegisterInfo();    } -  virtual const DataLayout       *getDataLayout() const { return &DL; } +  const DataLayout       *getDataLayout() const override { return &DL; }    // Pass Pipeline Configuration -  virtual TargetPassConfig *createPassConfig(PassManagerBase &PM); +  TargetPassConfig *createPassConfig(PassManagerBase &PM) override; -  virtual void addAnalysisPasses(PassManagerBase &PM); +  void addAnalysisPasses(PassManagerBase &PM) override;  };  } // end namespace llvm diff --git a/lib/Target/XCore/XCoreTargetObjectFile.h b/lib/Target/XCore/XCoreTargetObjectFile.h index 733e6d3..34d756e 100644 --- a/lib/Target/XCore/XCoreTargetObjectFile.h +++ b/lib/Target/XCore/XCoreTargetObjectFile.h @@ -22,7 +22,7 @@ static const unsigned CodeModelLargeSize = 256;     const MCSection *ReadOnlySectionLarge;     const MCSection *DataRelROSectionLarge;    public: -    void Initialize(MCContext &Ctx, const TargetMachine &TM); +    void Initialize(MCContext &Ctx, const TargetMachine &TM) override;      const MCSection *        getExplicitSectionGlobal(const GlobalValue *GV, diff --git a/lib/Target/XCore/XCoreTargetTransformInfo.cpp b/lib/Target/XCore/XCoreTargetTransformInfo.cpp index 313d18d..80d193d 100644 --- a/lib/Target/XCore/XCoreTargetTransformInfo.cpp +++ b/lib/Target/XCore/XCoreTargetTransformInfo.cpp @@ -14,7 +14,6 @@  ///  //===----------------------------------------------------------------------===// -#define DEBUG_TYPE "xcoretti"  #include "XCore.h"  #include "llvm/Analysis/TargetTransformInfo.h"  #include "llvm/Support/Debug.h" @@ -22,8 +21,10 @@  #include "llvm/Target/TargetLowering.h"  using namespace llvm; +#define DEBUG_TYPE "xcoretti" +  // Declare the pass initialization routine locally as target-specific passes -// don't havve a target-wide initialization entry point, and so we rely on the +// don't have a target-wide initialization entry point, and so we rely on the  // pass constructor initialization.  namespace llvm {  void initializeXCoreTTIPass(PassRegistry &); | 
