diff options
Diffstat (limited to 'lib/Target/Alpha')
| -rw-r--r-- | lib/Target/Alpha/AlphaJITInfo.cpp | 6 | ||||
| -rw-r--r-- | lib/Target/Alpha/AlphaJITInfo.h | 5 | ||||
| -rw-r--r-- | lib/Target/Alpha/AlphaRegisterInfo.cpp | 4 | ||||
| -rw-r--r-- | lib/Target/Alpha/AlphaRegisterInfo.h | 3 | ||||
| -rw-r--r-- | lib/Target/Alpha/AlphaTargetMachine.cpp | 6 | ||||
| -rw-r--r-- | lib/Target/Alpha/AsmPrinter/AlphaAsmPrinter.cpp | 18 | ||||
| -rw-r--r-- | lib/Target/Alpha/AsmPrinter/CMakeLists.txt | 1 | 
7 files changed, 17 insertions, 26 deletions
| diff --git a/lib/Target/Alpha/AlphaJITInfo.cpp b/lib/Target/Alpha/AlphaJITInfo.cpp index 3fecb19d73b74..ba7478e90ecc8 100644 --- a/lib/Target/Alpha/AlphaJITInfo.cpp +++ b/lib/Target/Alpha/AlphaJITInfo.cpp @@ -19,7 +19,6 @@  #include "llvm/Config/alloca.h"  #include "llvm/Support/Debug.h"  #include <cstdlib> -#include <map>  using namespace llvm;  #define BUILD_OFormatI(Op, RA, LIT, FUN, RC) \ @@ -237,11 +236,6 @@ static long getLower16(long l)  void AlphaJITInfo::relocate(void *Function, MachineRelocation *MR,                              unsigned NumRelocs, unsigned char* GOTBase) { -  //because gpdist are paired and relative to the pc of the first inst, -  //we need to have some state - -  static std::map<std::pair<void*, int>, void*> gpdistmap; -    for (unsigned i = 0; i != NumRelocs; ++i, ++MR) {      unsigned *RelocPos = (unsigned*)Function + MR->getMachineCodeOffset()/4;      long idx = 0; diff --git a/lib/Target/Alpha/AlphaJITInfo.h b/lib/Target/Alpha/AlphaJITInfo.h index edff990dbc244..ecb467fbc5ec9 100644 --- a/lib/Target/Alpha/AlphaJITInfo.h +++ b/lib/Target/Alpha/AlphaJITInfo.h @@ -15,6 +15,7 @@  #define ALPHA_JITINFO_H  #include "llvm/Target/TargetJITInfo.h" +#include <map>  namespace llvm {    class TargetMachine; @@ -22,6 +23,10 @@ namespace llvm {    class AlphaJITInfo : public TargetJITInfo {    protected:      TargetMachine &TM; +     +    //because gpdist are paired and relative to the pc of the first inst, +    //we need to have some state +    std::map<std::pair<void*, int>, void*> gpdistmap;    public:      explicit AlphaJITInfo(TargetMachine &tm) : TM(tm)      { useGOT = true; } diff --git a/lib/Target/Alpha/AlphaRegisterInfo.cpp b/lib/Target/Alpha/AlphaRegisterInfo.cpp index feee6e467f47f..0ff53c7cc309c 100644 --- a/lib/Target/Alpha/AlphaRegisterInfo.cpp +++ b/lib/Target/Alpha/AlphaRegisterInfo.cpp @@ -54,7 +54,7 @@ static long getLower16(long l)  AlphaRegisterInfo::AlphaRegisterInfo(const TargetInstrInfo &tii)    : AlphaGenRegisterInfo(Alpha::ADJUSTSTACKDOWN, Alpha::ADJUSTSTACKUP), -    TII(tii) +    TII(tii), curgpdist(0)  {  } @@ -206,8 +206,6 @@ void AlphaRegisterInfo::emitPrologue(MachineFunction &MF) const {                   MBBI->getDebugLoc() : DebugLoc::getUnknownLoc());    bool FP = hasFP(MF); -  static int curgpdist = 0; -    //handle GOP offset    BuildMI(MBB, MBBI, dl, TII.get(Alpha::LDAHg), Alpha::R29)      .addGlobalAddress(const_cast<Function*>(MF.getFunction())) diff --git a/lib/Target/Alpha/AlphaRegisterInfo.h b/lib/Target/Alpha/AlphaRegisterInfo.h index c4f5f7b421ddd..5012fe8ccd1ec 100644 --- a/lib/Target/Alpha/AlphaRegisterInfo.h +++ b/lib/Target/Alpha/AlphaRegisterInfo.h @@ -60,6 +60,9 @@ struct AlphaRegisterInfo : public AlphaGenRegisterInfo {    int getDwarfRegNum(unsigned RegNum, bool isEH) const;    static std::string getPrettyName(unsigned reg); +   +private: +  mutable int curgpdist;  };  } // end namespace llvm diff --git a/lib/Target/Alpha/AlphaTargetMachine.cpp b/lib/Target/Alpha/AlphaTargetMachine.cpp index cdd4fa4b2445a..10952eb096ae7 100644 --- a/lib/Target/Alpha/AlphaTargetMachine.cpp +++ b/lib/Target/Alpha/AlphaTargetMachine.cpp @@ -27,10 +27,8 @@ static RegisterTarget<AlphaTargetMachine> X("alpha", "Alpha [experimental]");  // No assembler printer by default  AlphaTargetMachine::AsmPrinterCtorFn AlphaTargetMachine::AsmPrinterCtor = 0; -// Force static initialization when called from llvm/InitializeAllTargets.h -namespace llvm { -  void InitializeAlphaTarget() { } -} +// Force static initialization. +extern "C" void LLVMInitializeAlphaTarget() { }  const TargetAsmInfo *AlphaTargetMachine::createTargetAsmInfo() const {    return new AlphaTargetAsmInfo(*this); diff --git a/lib/Target/Alpha/AsmPrinter/AlphaAsmPrinter.cpp b/lib/Target/Alpha/AsmPrinter/AlphaAsmPrinter.cpp index 7b73bb302c38e..e0c0a647f1d85 100644 --- a/lib/Target/Alpha/AsmPrinter/AlphaAsmPrinter.cpp +++ b/lib/Target/Alpha/AsmPrinter/AlphaAsmPrinter.cpp @@ -17,6 +17,7 @@  #include "AlphaInstrInfo.h"  #include "AlphaTargetMachine.h"  #include "llvm/Module.h" +#include "llvm/MDNode.h"  #include "llvm/Type.h"  #include "llvm/Assembly/Writer.h"  #include "llvm/CodeGen/AsmPrinter.h" @@ -121,8 +122,6 @@ void AlphaAsmPrinter::printOp(const MachineOperand &MO, bool IsCallOp) {    case MachineOperand::MO_GlobalAddress: {      GlobalValue *GV = MO.getGlobal();      O << Mang->getValueName(GV); -    if (GV->isDeclaration() && GV->hasExternalWeakLinkage()) -      ExtWeakSymbols.insert(GV);      return;    } @@ -224,6 +223,8 @@ void AlphaAsmPrinter::printModuleLevelGV(const GlobalVariable* GVar) {    std::string name = Mang->getValueName(GVar);    Constant *C = GVar->getInitializer(); +  if (isa<MDNode>(C) || isa<MDString>(C)) +    return;    unsigned Size = TD->getTypeAllocSize(C->getType());    unsigned Align = TD->getPreferredAlignmentLog(GVar); @@ -265,12 +266,6 @@ void AlphaAsmPrinter::printModuleLevelGV(const GlobalVariable* GVar) {    O << name << ":\n"; -  // If the initializer is a extern weak symbol, remember to emit the weak -  // reference! -  if (const GlobalValue *GV = dyn_cast<GlobalValue>(C)) -    if (GV->hasExternalWeakLinkage()) -      ExtWeakSymbols.insert(GV); -    EmitGlobalConstant(C);    O << '\n';  } @@ -304,11 +299,8 @@ bool AlphaAsmPrinter::PrintAsmMemoryOperand(const MachineInstr *MI,    return false;  } -// Force static initialization when called from -// llvm/InitializeAllAsmPrinters.h -namespace llvm { -  void InitializeAlphaAsmPrinter() { } -} +// Force static initialization. +extern "C" void LLVMInitializeAlphaAsmPrinter() { }  namespace {    static struct Register { diff --git a/lib/Target/Alpha/AsmPrinter/CMakeLists.txt b/lib/Target/Alpha/AsmPrinter/CMakeLists.txt index bf047625bac41..992c218131496 100644 --- a/lib/Target/Alpha/AsmPrinter/CMakeLists.txt +++ b/lib/Target/Alpha/AsmPrinter/CMakeLists.txt @@ -3,3 +3,4 @@ include_directories( ${CMAKE_CURRENT_BINARY_DIR}/.. ${CMAKE_CURRENT_SOURCE_DIR}/  add_llvm_library(LLVMAlphaAsmPrinter    AlphaAsmPrinter.cpp    ) +add_dependencies(LLVMAlphaAsmPrinter AlphaCodeGenTable_gen) | 
