diff options
| author | Daniel Dunbar <daniel@zuster.org> | 2009-10-15 15:02:14 +0000 | 
|---|---|---|
| committer | Daniel Dunbar <daniel@zuster.org> | 2009-10-15 15:02:14 +0000 | 
| commit | 1ead150c92d07aceca9f139376cb647feb8ff355 (patch) | |
| tree | bab63bcd10539b25ada12979d52cb24dbfe0d02b | |
| parent | 8da373cf62d8dfdbf5e8a7c226d8a67153fe0013 (diff) | |
| download | external_llvm-1ead150c92d07aceca9f139376cb647feb8ff355.zip external_llvm-1ead150c92d07aceca9f139376cb647feb8ff355.tar.gz external_llvm-1ead150c92d07aceca9f139376cb647feb8ff355.tar.bz2 | |
Revert "Complete Rewrite of AsmPrinter, TargetObjectFile based on new
PIC16Section class", it breaks globals.ll.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@84184 91177308-0d34-0410-b5e6-96231b3b80d8
| -rw-r--r-- | lib/Target/PIC16/AsmPrinter/PIC16AsmPrinter.cpp | 170 | ||||
| -rw-r--r-- | lib/Target/PIC16/AsmPrinter/PIC16AsmPrinter.h | 8 | ||||
| -rw-r--r-- | lib/Target/PIC16/PIC16.h | 267 | ||||
| -rw-r--r-- | lib/Target/PIC16/PIC16ABINames.h | 305 | ||||
| -rw-r--r-- | lib/Target/PIC16/PIC16DebugInfo.cpp | 1 | ||||
| -rw-r--r-- | lib/Target/PIC16/PIC16ISelLowering.cpp | 1 | ||||
| -rw-r--r-- | lib/Target/PIC16/PIC16InstrInfo.cpp | 1 | ||||
| -rw-r--r-- | lib/Target/PIC16/PIC16MCAsmInfo.cpp | 1 | ||||
| -rw-r--r-- | lib/Target/PIC16/PIC16MemSelOpt.cpp | 1 | ||||
| -rw-r--r-- | lib/Target/PIC16/PIC16Section.cpp | 91 | ||||
| -rw-r--r-- | lib/Target/PIC16/PIC16Section.h | 91 | ||||
| -rw-r--r-- | lib/Target/PIC16/PIC16TargetObjectFile.cpp | 471 | ||||
| -rw-r--r-- | lib/Target/PIC16/PIC16TargetObjectFile.h | 159 | 
13 files changed, 689 insertions, 878 deletions
| diff --git a/lib/Target/PIC16/AsmPrinter/PIC16AsmPrinter.cpp b/lib/Target/PIC16/AsmPrinter/PIC16AsmPrinter.cpp index 1afd3ee..3f415af 100644 --- a/lib/Target/PIC16/AsmPrinter/PIC16AsmPrinter.cpp +++ b/lib/Target/PIC16/AsmPrinter/PIC16AsmPrinter.cpp @@ -12,9 +12,8 @@  //  //===----------------------------------------------------------------------===// -#include "PIC16ABINames.h"  #include "PIC16AsmPrinter.h" -#include "PIC16Section.h" +#include "MCSectionPIC16.h"  #include "PIC16MCAsmInfo.h"  #include "llvm/DerivedTypes.h"  #include "llvm/Function.h" @@ -40,7 +39,7 @@ PIC16AsmPrinter::PIC16AsmPrinter(formatted_raw_ostream &O, TargetMachine &TM,  : AsmPrinter(O, TM, T, V), DbgInfo(O, T) {    PTLI = static_cast<PIC16TargetLowering*>(TM.getTargetLowering());    PMAI = static_cast<const PIC16MCAsmInfo*>(T); -  PTOF = (PIC16TargetObjectFile *)&PTLI->getObjFileLowering(); +  PTOF = (PIC16TargetObjectFile*)&PTLI->getObjFileLowering();  }  bool PIC16AsmPrinter::printMachineInstruction(const MachineInstr *MI) { @@ -74,12 +73,11 @@ bool PIC16AsmPrinter::runOnMachineFunction(MachineFunction &MF) {    DbgInfo.BeginFunction(MF);    // Emit the autos section of function. -  // EmitAutos(CurrentFnName); +  EmitAutos(CurrentFnName);    // Now emit the instructions of function in its code section. -  const MCSection *fCodeSection  -    = getObjFileLowering().SectionForCode(CurrentFnName); - +  const MCSection *fCodeSection =  +    getObjFileLowering().getSectionForFunction(CurrentFnName);    // Start the Code Section.    O <<  "\n";    OutStreamer.SwitchSection(fCodeSection); @@ -231,26 +229,12 @@ bool PIC16AsmPrinter::doInitialization(Module &M) {    // Set the section names for all globals.    for (Module::global_iterator I = M.global_begin(), E = M.global_end(); -       I != E; ++I) { - -    // Record External Var Decls. -    if (I->isDeclaration()) { -      ExternalVarDecls.push_back(I); -      continue; -    } - -    // Record Exteranl Var Defs. -    if (I->hasExternalLinkage() || I->hasCommonLinkage()) { -      ExternalVarDefs.push_back(I); -    } - -    // Sectionify actual data. -    if (!I->hasAvailableExternallyLinkage()) { +       I != E; ++I) +    if (!I->isDeclaration() && !I->hasAvailableExternallyLinkage()) {        const MCSection *S = getObjFileLowering().SectionForGlobal(I, Mang, TM); -      I->setSection(((const PIC16Section *)S)->getName()); +      I->setSection(((const MCSectionPIC16*)S)->getName());      } -  }    DbgInfo.BeginModule(M);    EmitFunctionDecls(M); @@ -258,9 +242,7 @@ bool PIC16AsmPrinter::doInitialization(Module &M) {    EmitDefinedVars(M);    EmitIData(M);    EmitUData(M); -  EmitAllAutos(M);    EmitRomData(M); -  EmitUserSections(M);    return Result;  } @@ -305,7 +287,7 @@ void PIC16AsmPrinter::EmitFunctionDecls(Module &M) {  // Emit variables imported from other Modules.  void PIC16AsmPrinter::EmitUndefinedVars(Module &M) { -  std::vector<const GlobalVariable*> Items = ExternalVarDecls; +  std::vector<const GlobalVariable*> Items = PTOF->ExternalVarDecls->Items;    if (!Items.size()) return;    O << "\n" << MAI->getCommentString() << "Imported Variables - BEGIN" << "\n"; @@ -317,7 +299,7 @@ void PIC16AsmPrinter::EmitUndefinedVars(Module &M) {  // Emit variables defined in this module and are available to other modules.  void PIC16AsmPrinter::EmitDefinedVars(Module &M) { -  std::vector<const GlobalVariable*> Items = ExternalVarDefs; +  std::vector<const GlobalVariable*> Items = PTOF->ExternalVarDefs->Items;    if (!Items.size()) return;    O << "\n" << MAI->getCommentString() << "Exported Variables - BEGIN" << "\n"; @@ -330,14 +312,24 @@ void PIC16AsmPrinter::EmitDefinedVars(Module &M) {  // Emit initialized data placed in ROM.  void PIC16AsmPrinter::EmitRomData(Module &M) {    // Print ROM Data section. -  const PIC16Section *ROSection = PTOF->ROMDATASection(); -  if (ROSection == NULL) return;  -  EmitInitializedDataSection(ROSection); +  const std::vector<PIC16Section*> &ROSections = PTOF->ROSections; +  for (unsigned i = 0; i < ROSections.size(); i++) { +    const std::vector<const GlobalVariable*> &Items = ROSections[i]->Items; +    if (!Items.size()) continue; +    O << "\n"; +    OutStreamer.SwitchSection(PTOF->ROSections[i]->S_); +    for (unsigned j = 0; j < Items.size(); j++) { +      O << Mang->getMangledName(Items[j]); +      Constant *C = Items[j]->getInitializer(); +      int AddrSpace = Items[j]->getType()->getAddressSpace(); +      EmitGlobalConstant(C, AddrSpace); +    } +  }  }  bool PIC16AsmPrinter::doFinalization(Module &M) {    printLibcallDecls(); -  // EmitRemainingAutos(); +  EmitRemainingAutos();    DbgInfo.EndModule(M);    O << "\n\t" << "END\n";    return AsmPrinter::doFinalization(M); @@ -351,7 +343,7 @@ void PIC16AsmPrinter::EmitFunctionFrame(MachineFunction &MF) {    O << "\n";     const MCSection *fPDataSection = -    getObjFileLowering().SectionForFrame(CurrentFnName); +    getObjFileLowering().getSectionForFunctionFrame(CurrentFnName);    OutStreamer.SwitchSection(fPDataSection);    // Emit function frame label @@ -387,80 +379,104 @@ void PIC16AsmPrinter::EmitFunctionFrame(MachineFunction &MF) {      O << PAN::getTempdataLabel(CurrentFnName) << " RES  " << TempSize << '\n';  } +void PIC16AsmPrinter::EmitIData(Module &M) { -void PIC16AsmPrinter::EmitInitializedDataSection(const PIC16Section *S) { -  /// Emit Section header. -  OutStreamer.SwitchSection(S); - -    std::vector<const GlobalVariable*> Items = S->Items; +  // Print all IDATA sections. +  const std::vector<PIC16Section*> &IDATASections = PTOF->IDATASections; +  for (unsigned i = 0; i < IDATASections.size(); i++) { +    O << "\n"; +    if (IDATASections[i]->S_->getName().find("llvm.") != std::string::npos) +      continue; +    OutStreamer.SwitchSection(IDATASections[i]->S_); +    std::vector<const GlobalVariable*> Items = IDATASections[i]->Items;      for (unsigned j = 0; j < Items.size(); j++) {        std::string Name = Mang->getMangledName(Items[j]);        Constant *C = Items[j]->getInitializer();        int AddrSpace = Items[j]->getType()->getAddressSpace();        O << Name;        EmitGlobalConstant(C, AddrSpace); -   } +    } +  }  } -void PIC16AsmPrinter::EmitIData(Module &M) { +void PIC16AsmPrinter::EmitUData(Module &M) { +  const TargetData *TD = TM.getTargetData(); -  // Print all IDATA sections. -  const std::vector<PIC16Section *> &IDATASections = PTOF->IDATASections(); -  for (unsigned i = 0; i < IDATASections.size(); i++) { +  // Print all BSS sections. +  const std::vector<PIC16Section*> &BSSSections = PTOF->BSSSections; +  for (unsigned i = 0; i < BSSSections.size(); i++) {      O << "\n"; -    if (IDATASections[i]->getName().find("llvm.") != std::string::npos) -      continue; -     -    EmitInitializedDataSection(IDATASections[i]); -    } -} - -void PIC16AsmPrinter::EmitUninitializedDataSection(const PIC16Section *S) { -    const TargetData *TD = TM.getTargetData(); -    OutStreamer.SwitchSection(S); -    std::vector<const GlobalVariable*> Items = S->Items; +    OutStreamer.SwitchSection(BSSSections[i]->S_); +    std::vector<const GlobalVariable*> Items = BSSSections[i]->Items;      for (unsigned j = 0; j < Items.size(); j++) {        std::string Name = Mang->getMangledName(Items[j]);        Constant *C = Items[j]->getInitializer();        const Type *Ty = C->getType();        unsigned Size = TD->getTypeAllocSize(Ty); +        O << Name << " RES " << Size << "\n";      } -} - -void PIC16AsmPrinter::EmitUData(Module &M) { -  // Print all UDATA sections. -  const std::vector<PIC16Section*> &UDATASections = PTOF->UDATASections(); -  for (unsigned i = 0; i < UDATASections.size(); i++) { -    O << "\n"; -    EmitUninitializedDataSection(UDATASections[i]);    }  } -void PIC16AsmPrinter::EmitUserSections(Module &M) { -  const std::vector<PIC16Section*> &USERSections = PTOF->USERSections(); -  for (unsigned i = 0; i < USERSections.size(); i++) { +void PIC16AsmPrinter::EmitAutos(std::string FunctName) { +  // Section names for all globals are already set. +  const TargetData *TD = TM.getTargetData(); + +  // Now print Autos section for this function. +  std::string SectionName = PAN::getAutosSectionName(FunctName); +  const std::vector<PIC16Section*> &AutosSections = PTOF->AutosSections; +  for (unsigned i = 0; i < AutosSections.size(); i++) {      O << "\n"; -    const PIC16Section *S = USERSections[i]; -    if (S->isUDATA_Type()) { -      EmitUninitializedDataSection(S); -    } else if (S->isIDATA_Type() || S->isROMDATA_Type()) { -      EmitInitializedDataSection(S); -    } else { -      llvm_unreachable ("unknow user section type"); +    if (AutosSections[i]->S_->getName() == SectionName) {  +      // Set the printing status to true +      AutosSections[i]->setPrintedStatus(true); +      OutStreamer.SwitchSection(AutosSections[i]->S_); +      const std::vector<const GlobalVariable*> &Items = AutosSections[i]->Items; +      for (unsigned j = 0; j < Items.size(); j++) { +        std::string VarName = Mang->getMangledName(Items[j]); +        Constant *C = Items[j]->getInitializer(); +        const Type *Ty = C->getType(); +        unsigned Size = TD->getTypeAllocSize(Ty); +        // Emit memory reserve directive. +        O << VarName << "  RES  " << Size << "\n"; +      } +      break;      }    }  } -void PIC16AsmPrinter::EmitAllAutos(Module &M) { -  // Print all AUTO sections. -  const std::vector<PIC16Section*> &AUTOSections = PTOF->AUTOSections(); -  for (unsigned i = 0; i < AUTOSections.size(); i++) { +// Print autos that were not printed during the code printing of functions. +// As the functions might themselves would have got deleted by the optimizer. +void PIC16AsmPrinter::EmitRemainingAutos() { +  const TargetData *TD = TM.getTargetData(); + +  // Now print Autos section for this function. +  std::vector <PIC16Section *>AutosSections = PTOF->AutosSections; +  for (unsigned i = 0; i < AutosSections.size(); i++) { +     +    // if the section is already printed then don't print again +    if (AutosSections[i]->isPrinted())  +      continue; + +    // Set status as printed +    AutosSections[i]->setPrintedStatus(true); +      O << "\n"; -    EmitUninitializedDataSection(AUTOSections[i]); +    OutStreamer.SwitchSection(AutosSections[i]->S_); +    const std::vector<const GlobalVariable*> &Items = AutosSections[i]->Items; +    for (unsigned j = 0; j < Items.size(); j++) { +      std::string VarName = Mang->getMangledName(Items[j]); +      Constant *C = Items[j]->getInitializer(); +      const Type *Ty = C->getType(); +      unsigned Size = TD->getTypeAllocSize(Ty); +      // Emit memory reserve directive. +      O << VarName << "  RES  " << Size << "\n"; +    }    }  } +  extern "C" void LLVMInitializePIC16AsmPrinter() {     RegisterAsmPrinter<PIC16AsmPrinter> X(ThePIC16Target);  } diff --git a/lib/Target/PIC16/AsmPrinter/PIC16AsmPrinter.h b/lib/Target/PIC16/AsmPrinter/PIC16AsmPrinter.h index 686d080..2dd4600 100644 --- a/lib/Target/PIC16/AsmPrinter/PIC16AsmPrinter.h +++ b/lib/Target/PIC16/AsmPrinter/PIC16AsmPrinter.h @@ -53,13 +53,11 @@ namespace llvm {      void EmitDefinedVars (Module &M);      void EmitIData (Module &M);      void EmitUData (Module &M); -    void EmitAllAutos (Module &M); +    void EmitAutos (std::string FunctName); +    void EmitRemainingAutos ();      void EmitRomData (Module &M); -    void EmitUserSections (Module &M);      void EmitFunctionFrame(MachineFunction &MF);      void printLibcallDecls(); -    void EmitUninitializedDataSection(const PIC16Section *S); -    void EmitInitializedDataSection(const PIC16Section *S);    protected:      bool doInitialization(Module &M);      bool doFinalization(Module &M); @@ -76,8 +74,6 @@ namespace llvm {      PIC16DbgInfo DbgInfo;      const PIC16MCAsmInfo *PMAI;      std::list<const char *> LibcallDecls; // List of extern decls. -    std::vector<const GlobalVariable *> ExternalVarDecls; -    std::vector<const GlobalVariable *> ExternalVarDefs;    };  } // end of namespace diff --git a/lib/Target/PIC16/PIC16.h b/lib/Target/PIC16/PIC16.h index e46c9b2..8a3704d 100644 --- a/lib/Target/PIC16/PIC16.h +++ b/lib/Target/PIC16/PIC16.h @@ -42,16 +42,267 @@ namespace PIC16CC {      UGE    };  } - -  enum PIC16SectionType { -      CODE, -      UDATA, -      IDATA, -      ROMDATA, -      UDATA_OVR, -      UDATA_SHR +  // A Central class to manage all ABI naming conventions. +  // PAN - [P]ic16 [A]BI [N]ames +  class PAN { +    public: +    // Map the name of the symbol to its section name. +    // Current ABI: +    // ----------------------------------------------------- +    // ALL Names are prefixed with the symobl '@'. +    // ------------------------------------------------------ +    // Global variables do not have any '.' in their names. +    // These are maily function names and global variable names. +    // Example - @foo,  @i +    // ------------------------------------------------------- +    // Functions and auto variables. +    // Names are mangled as <prefix><funcname>.<tag>.<varname> +    // Where <prefix> is '@' and <tag> is any one of +    // the following +    // .auto. - an automatic var of a function. +    // .temp. - temproray data of a function. +    // .ret.  - return value label for a function. +    // .frame. - Frame label for a function where retval, args +    //           and temps are stored. +    // .args. - Label used to pass arguments to a direct call. +    // Example - Function name:   @foo +    //           Its frame:       @foo.frame. +    //           Its retval:      @foo.ret. +    //           Its local vars:  @foo.auto.a +    //           Its temp data:   @foo.temp. +    //           Its arg passing: @foo.args. +    //---------------------------------------------- +    // Libcall - compiler generated libcall names must start with .lib. +    //           This id will be used to emit extern decls for libcalls. +    // Example - libcall name:   @.lib.sra.i8 +    //           To pass args:   @.lib.sra.i8.args. +    //           To return val:  @.lib.sra.i8.ret. +    //---------------------------------------------- +    // SECTION Names +    // uninitialized globals - @udata.<num>.# +    // initialized globals - @idata.<num>.# +    // Function frame - @<func>.frame_section. +    // Function autos - @<func>.autos_section. +    // Declarations - Enclosed in comments. No section for them. +    //---------------------------------------------------------- +     +    // Tags used to mangle different names.  +    enum TAGS { +      PREFIX_SYMBOL, +      GLOBAL, +      STATIC_LOCAL, +      AUTOS_LABEL, +      FRAME_LABEL, +      RET_LABEL, +      ARGS_LABEL, +      TEMPS_LABEL, +       +      LIBCALL, +       +      FRAME_SECTION, +      AUTOS_SECTION, +      CODE_SECTION      }; +    // Textual names of the tags. +    inline static const char *getTagName(TAGS tag) { +      switch (tag) { +      default: return ""; +      case PREFIX_SYMBOL:    return "@"; +      case AUTOS_LABEL:       return ".auto."; +      case FRAME_LABEL:       return ".frame."; +      case TEMPS_LABEL:       return ".temp."; +      case ARGS_LABEL:       return ".args."; +      case RET_LABEL:       return ".ret."; +      case LIBCALL:       return ".lib."; +      case FRAME_SECTION:       return ".frame_section."; +      case AUTOS_SECTION:       return ".autos_section."; +      case CODE_SECTION:       return ".code_section."; +      } +    } + +    // Get tag type for the Symbol. +    inline static TAGS getSymbolTag(const std::string &Sym) { +      if (Sym.find(getTagName(TEMPS_LABEL)) != std::string::npos) +        return TEMPS_LABEL; + +      if (Sym.find(getTagName(FRAME_LABEL)) != std::string::npos) +        return FRAME_LABEL; + +      if (Sym.find(getTagName(RET_LABEL)) != std::string::npos) +        return RET_LABEL; + +      if (Sym.find(getTagName(ARGS_LABEL)) != std::string::npos) +        return ARGS_LABEL; + +      if (Sym.find(getTagName(AUTOS_LABEL)) != std::string::npos) +        return AUTOS_LABEL; + +      if (Sym.find(getTagName(LIBCALL)) != std::string::npos) +        return LIBCALL; + +      // It does not have any Tag. So its a true global or static local. +      if (Sym.find(".") == std::string::npos)  +        return GLOBAL; +       +      // If a . is there, then it may be static local. +      // We should mangle these as well in clang. +      if (Sym.find(".") != std::string::npos)  +        return STATIC_LOCAL; +  +      assert (0 && "Could not determine Symbol's tag"); +      return PREFIX_SYMBOL; // Silence warning when assertions are turned off. +    } + +    // addPrefix - add prefix symbol to a name if there isn't one already. +    inline static std::string addPrefix (const std::string &Name) { +      std::string prefix = getTagName (PREFIX_SYMBOL); + +      // If this name already has a prefix, nothing to do. +      if (Name.compare(0, prefix.size(), prefix) == 0) +        return Name; + +      return prefix + Name; +    } + +    // Get mangled func name from a mangled sym name. +    // In all cases func name is the first component before a '.'. +    static inline std::string getFuncNameForSym(const std::string &Sym1) { +      assert (getSymbolTag(Sym1) != GLOBAL && "not belongs to a function"); + +      std::string Sym = addPrefix(Sym1); + +      // Position of the . after func name. That's where func name ends. +      size_t func_name_end = Sym.find ('.'); + +      return Sym.substr (0, func_name_end); +    } + +    // Get Frame start label for a func. +    static std::string getFrameLabel(const std::string &Func) { +      std::string Func1 = addPrefix(Func); +      std::string tag = getTagName(FRAME_LABEL); +      return Func1 + tag; +    } + +    static std::string getRetvalLabel(const std::string &Func) { +      std::string Func1 = addPrefix(Func); +      std::string tag = getTagName(RET_LABEL); +      return Func1 + tag; +    } + +    static std::string getArgsLabel(const std::string &Func) { +      std::string Func1 = addPrefix(Func); +      std::string tag = getTagName(ARGS_LABEL); +      return Func1 + tag; +    } + +    static std::string getTempdataLabel(const std::string &Func) { +      std::string Func1 = addPrefix(Func); +      std::string tag = getTagName(TEMPS_LABEL); +      return Func1 + tag; +    } + +    static std::string getFrameSectionName(const std::string &Func) { +      std::string Func1 = addPrefix(Func); +      std::string tag = getTagName(FRAME_SECTION); +      return Func1 + tag + "# UDATA_OVR"; +    } + +    static std::string getAutosSectionName(const std::string &Func) { +      std::string Func1 = addPrefix(Func); +      std::string tag = getTagName(AUTOS_SECTION); +      return Func1 + tag + "# UDATA_OVR"; +    } + +    static std::string getCodeSectionName(const std::string &Func) { +      std::string Func1 = addPrefix(Func); +      std::string tag = getTagName(CODE_SECTION); +      return Func1 + tag + "# CODE"; +    } + +    // udata, romdata and idata section names are generated by a given number. +    // @udata.<num>.#  +    static std::string getUdataSectionName(unsigned num,  +                                           std::string prefix = "") { +       std::ostringstream o; +       o << getTagName(PREFIX_SYMBOL) << prefix << "udata." << num  +         << ".# UDATA";  +       return o.str();  +    } + +    static std::string getRomdataSectionName(unsigned num, +                                             std::string prefix = "") { +       std::ostringstream o; +       o << getTagName(PREFIX_SYMBOL) << prefix << "romdata." << num  +         << ".# ROMDATA"; +       return o.str(); +    } + +    static std::string getIdataSectionName(unsigned num, +                                           std::string prefix = "") { +       std::ostringstream o; +       o << getTagName(PREFIX_SYMBOL) << prefix << "idata." << num  +         << ".# IDATA";  +       return o.str();  +    } + +    inline static bool isLocalName (const std::string &Name) { +      if (getSymbolTag(Name) == AUTOS_LABEL) +        return true; + +      return false; +    } + +    inline static bool isMemIntrinsic (const std::string &Name) { +      if (Name.compare("@memcpy") == 0 || Name.compare("@memset") == 0 || +          Name.compare("@memmove") == 0) { +        return true; +      } +       +      return false; +    } + +    inline static bool isLocalToFunc (std::string &Func, std::string &Var) { +      if (! isLocalName(Var)) return false; + +      std::string Func1 = addPrefix(Func); +      // Extract func name of the varilable. +      const std::string &fname = getFuncNameForSym(Var); + +      if (fname.compare(Func1) == 0) +        return true; + +      return false; +    } + + +    // Get the section for the given external symbol names. +    // This tries to find the type (Tag) of the symbol from its mangled name +    // and return appropriate section name for it. +    static inline std::string getSectionNameForSym(const std::string &Sym1) { +      std::string Sym = addPrefix(Sym1); + +      std::string SectionName; +  +      std::string Fname = getFuncNameForSym (Sym); +      TAGS id = getSymbolTag (Sym); + +      switch (id) { +        default : assert (0 && "Could not determine external symbol type"); +        case FRAME_LABEL: +        case RET_LABEL: +        case TEMPS_LABEL: +        case ARGS_LABEL:  { +          return getFrameSectionName(Fname); +        } +        case AUTOS_LABEL: { +          return getAutosSectionName(Fname); +        } +      } +    } +  }; // class PAN. +    // External symbol names require memory to live till the program end.    // So we have to allocate it and keep. diff --git a/lib/Target/PIC16/PIC16ABINames.h b/lib/Target/PIC16/PIC16ABINames.h deleted file mode 100644 index 00e9e45..0000000 --- a/lib/Target/PIC16/PIC16ABINames.h +++ /dev/null @@ -1,305 +0,0 @@ -//===-- PIC16ABINames.h - PIC16 Naming conventios for ABI----- --*- C++ -*-===// -// -//                     The LLVM Compiler Infrastructure -// -// This file is distributed under the University of Illinois Open Source  -// License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// -// -// This file contains the functions to manage ABI Naming conventions for PIC16.  -//  -// -//===----------------------------------------------------------------------===// - -#ifndef LLVM_TARGET_PIC16ABINAMES_H -#define LLVM_TARGET_PIC16ABINAMES_H - -#include "llvm/Support/ErrorHandling.h" -#include "llvm/Target/TargetMachine.h" -#include <cassert> -#include <sstream> -#include <cstring> -#include <string> - -namespace llvm { -  class PIC16TargetMachine; -  class FunctionPass; -  class MachineCodeEmitter; -  class formatted_raw_ostream; - -  // A Central class to manage all ABI naming conventions. -  // PAN - [P]ic16 [A]BI [N]ames -  class PAN { -    public: -    // Map the name of the symbol to its section name. -    // Current ABI: -    // ----------------------------------------------------- -    // ALL Names are prefixed with the symobl '@'. -    // ------------------------------------------------------ -    // Global variables do not have any '.' in their names. -    // These are maily function names and global variable names. -    // Example - @foo,  @i -    // ------------------------------------------------------- -    // Functions and auto variables. -    // Names are mangled as <prefix><funcname>.<tag>.<varname> -    // Where <prefix> is '@' and <tag> is any one of -    // the following -    // .auto. - an automatic var of a function. -    // .temp. - temproray data of a function. -    // .ret.  - return value label for a function. -    // .frame. - Frame label for a function where retval, args -    //           and temps are stored. -    // .args. - Label used to pass arguments to a direct call. -    // Example - Function name:   @foo -    //           Its frame:       @foo.frame. -    //           Its retval:      @foo.ret. -    //           Its local vars:  @foo.auto.a -    //           Its temp data:   @foo.temp. -    //           Its arg passing: @foo.args. -    //---------------------------------------------- -    // Libcall - compiler generated libcall names must start with .lib. -    //           This id will be used to emit extern decls for libcalls. -    // Example - libcall name:   @.lib.sra.i8 -    //           To pass args:   @.lib.sra.i8.args. -    //           To return val:  @.lib.sra.i8.ret. -    //---------------------------------------------- -    // SECTION Names -    // uninitialized globals - @udata.<num>.# -    // initialized globals - @idata.<num>.# -    // Function frame - @<func>.frame_section. -    // Function autos - @<func>.autos_section. -    // Declarations - Enclosed in comments. No section for them. -    //---------------------------------------------------------- -     -    // Tags used to mangle different names.  -    enum TAGS { -      PREFIX_SYMBOL, -      GLOBAL, -      STATIC_LOCAL, -      AUTOS_LABEL, -      FRAME_LABEL, -      RET_LABEL, -      ARGS_LABEL, -      TEMPS_LABEL, -       -      LIBCALL, -       -      FRAME_SECTION, -      AUTOS_SECTION, -      CODE_SECTION, -      USER_SECTION -    }; - -    // Textual names of the tags. -    inline static const char *getTagName(TAGS tag) { -      switch (tag) { -      default: return ""; -      case PREFIX_SYMBOL:    return "@"; -      case AUTOS_LABEL:       return ".auto."; -      case FRAME_LABEL:       return ".frame."; -      case TEMPS_LABEL:       return ".temp."; -      case ARGS_LABEL:       return ".args."; -      case RET_LABEL:       return ".ret."; -      case LIBCALL:       return ".lib."; -      case FRAME_SECTION:       return ".frame_section."; -      case AUTOS_SECTION:       return ".autos_section."; -      case CODE_SECTION:       return ".code_section."; -      case USER_SECTION:       return ".user_section."; -      } -    } - -    // Get tag type for the Symbol. -    inline static TAGS getSymbolTag(const std::string &Sym) { -      if (Sym.find(getTagName(TEMPS_LABEL)) != std::string::npos) -        return TEMPS_LABEL; - -      if (Sym.find(getTagName(FRAME_LABEL)) != std::string::npos) -        return FRAME_LABEL; - -      if (Sym.find(getTagName(RET_LABEL)) != std::string::npos) -        return RET_LABEL; - -      if (Sym.find(getTagName(ARGS_LABEL)) != std::string::npos) -        return ARGS_LABEL; - -      if (Sym.find(getTagName(AUTOS_LABEL)) != std::string::npos) -        return AUTOS_LABEL; - -      if (Sym.find(getTagName(LIBCALL)) != std::string::npos) -        return LIBCALL; - -      // It does not have any Tag. So its a true global or static local. -      if (Sym.find(".") == std::string::npos)  -        return GLOBAL; -       -      // If a . is there, then it may be static local. -      // We should mangle these as well in clang. -      if (Sym.find(".") != std::string::npos)  -        return STATIC_LOCAL; -  -      assert (0 && "Could not determine Symbol's tag"); -      return PREFIX_SYMBOL; // Silence warning when assertions are turned off. -    } - -    // addPrefix - add prefix symbol to a name if there isn't one already. -    inline static std::string addPrefix (const std::string &Name) { -      std::string prefix = getTagName (PREFIX_SYMBOL); - -      // If this name already has a prefix, nothing to do. -      if (Name.compare(0, prefix.size(), prefix) == 0) -        return Name; - -      return prefix + Name; -    } - -    // Get mangled func name from a mangled sym name. -    // In all cases func name is the first component before a '.'. -    static inline std::string getFuncNameForSym(const std::string &Sym1) { -      assert (getSymbolTag(Sym1) != GLOBAL && "not belongs to a function"); - -      std::string Sym = addPrefix(Sym1); - -      // Position of the . after func name. That's where func name ends. -      size_t func_name_end = Sym.find ('.'); - -      return Sym.substr (0, func_name_end); -    } - -    // Get Frame start label for a func. -    static std::string getFrameLabel(const std::string &Func) { -      std::string Func1 = addPrefix(Func); -      std::string tag = getTagName(FRAME_LABEL); -      return Func1 + tag; -    } - -    static std::string getRetvalLabel(const std::string &Func) { -      std::string Func1 = addPrefix(Func); -      std::string tag = getTagName(RET_LABEL); -      return Func1 + tag; -    } - -    static std::string getArgsLabel(const std::string &Func) { -      std::string Func1 = addPrefix(Func); -      std::string tag = getTagName(ARGS_LABEL); -      return Func1 + tag; -    } - -    static std::string getTempdataLabel(const std::string &Func) { -      std::string Func1 = addPrefix(Func); -      std::string tag = getTagName(TEMPS_LABEL); -      return Func1 + tag; -    } - -    static std::string getFrameSectionName(const std::string &Func) { -      std::string Func1 = addPrefix(Func); -      std::string tag = getTagName(FRAME_SECTION); -      return Func1 + tag + "#"; -    } - -    static std::string getAutosSectionName(const std::string &Func) { -      std::string Func1 = addPrefix(Func); -      std::string tag = getTagName(AUTOS_SECTION); -      return Func1 + tag + "#"; -    } - -    static std::string getCodeSectionName(const std::string &Func) { -      std::string Func1 = addPrefix(Func); -      std::string tag = getTagName(CODE_SECTION); -      return Func1 + tag + "#"; -    } - -    static std::string getUserSectionName(const std::string &Name) { -      std::string sname = addPrefix(Name);; -      std::string tag = getTagName(USER_SECTION); -      return sname + tag + "#"; -    } - -    // udata, romdata and idata section names are generated by a given number. -    // @udata.<num>.#  -    static std::string getUdataSectionName(unsigned num,  -                                           std::string prefix = "") { -       std::ostringstream o; -       o << getTagName(PREFIX_SYMBOL) << prefix << "udata." << num  -         << ".#";  -       return o.str();  -    } - -    static std::string getRomdataSectionName() { -      return "romdata.#"; -    } - -    static std::string getRomdataSectionName(unsigned num, -                                             std::string prefix = "") { -       std::ostringstream o; -       o << getTagName(PREFIX_SYMBOL) << prefix << "romdata." << num  -         << ".#"; -       return o.str(); -    } - -    static std::string getIdataSectionName(unsigned num, -                                           std::string prefix = "") { -       std::ostringstream o; -       o << getTagName(PREFIX_SYMBOL) << prefix << "idata." << num  -         << ".#";  -       return o.str();  -    } - -    inline static bool isLocalName (const std::string &Name) { -      if (getSymbolTag(Name) == AUTOS_LABEL) -        return true; - -      return false; -    } - -    inline static bool isMemIntrinsic (const std::string &Name) { -      if (Name.compare("@memcpy") == 0 || Name.compare("@memset") == 0 || -          Name.compare("@memmove") == 0) { -        return true; -      } -       -      return false; -    } - -    inline static bool isLocalToFunc (std::string &Func, std::string &Var) { -      if (! isLocalName(Var)) return false; - -      std::string Func1 = addPrefix(Func); -      // Extract func name of the varilable. -      const std::string &fname = getFuncNameForSym(Var); - -      if (fname.compare(Func1) == 0) -        return true; - -      return false; -    } - - -    // Get the section for the given external symbol names. -    // This tries to find the type (Tag) of the symbol from its mangled name -    // and return appropriate section name for it. -    static inline std::string getSectionNameForSym(const std::string &Sym1) { -      std::string Sym = addPrefix(Sym1); - -      std::string SectionName; -  -      std::string Fname = getFuncNameForSym (Sym); -      TAGS id = getSymbolTag (Sym); - -      switch (id) { -        default : assert (0 && "Could not determine external symbol type"); -        case FRAME_LABEL: -        case RET_LABEL: -        case TEMPS_LABEL: -        case ARGS_LABEL:  { -          return getFrameSectionName(Fname); -        } -        case AUTOS_LABEL: { -          return getAutosSectionName(Fname); -        } -      } -    } -  }; // class PAN. -} // end namespace llvm; - -#endif diff --git a/lib/Target/PIC16/PIC16DebugInfo.cpp b/lib/Target/PIC16/PIC16DebugInfo.cpp index 0ed44d2..dd20f20 100644 --- a/lib/Target/PIC16/PIC16DebugInfo.cpp +++ b/lib/Target/PIC16/PIC16DebugInfo.cpp @@ -13,7 +13,6 @@  //===----------------------------------------------------------------------===//  #include "PIC16.h" -#include "PIC16ABINames.h"  #include "PIC16DebugInfo.h"   #include "llvm/GlobalVariable.h"  #include "llvm/CodeGen/MachineFunction.h" diff --git a/lib/Target/PIC16/PIC16ISelLowering.cpp b/lib/Target/PIC16/PIC16ISelLowering.cpp index 635befe..bf986b1 100644 --- a/lib/Target/PIC16/PIC16ISelLowering.cpp +++ b/lib/Target/PIC16/PIC16ISelLowering.cpp @@ -12,7 +12,6 @@  //===----------------------------------------------------------------------===//  #define DEBUG_TYPE "pic16-lower" -#include "PIC16ABINames.h"  #include "PIC16ISelLowering.h"  #include "PIC16TargetObjectFile.h"  #include "PIC16TargetMachine.h" diff --git a/lib/Target/PIC16/PIC16InstrInfo.cpp b/lib/Target/PIC16/PIC16InstrInfo.cpp index 87bd3d9..cb0c41b 100644 --- a/lib/Target/PIC16/PIC16InstrInfo.cpp +++ b/lib/Target/PIC16/PIC16InstrInfo.cpp @@ -12,7 +12,6 @@  //===----------------------------------------------------------------------===//  #include "PIC16.h" -#include "PIC16ABINames.h"  #include "PIC16InstrInfo.h"  #include "PIC16TargetMachine.h"  #include "PIC16GenInstrInfo.inc" diff --git a/lib/Target/PIC16/PIC16MCAsmInfo.cpp b/lib/Target/PIC16/PIC16MCAsmInfo.cpp index 827315e..a17d1a8 100644 --- a/lib/Target/PIC16/PIC16MCAsmInfo.cpp +++ b/lib/Target/PIC16/PIC16MCAsmInfo.cpp @@ -16,7 +16,6 @@  // FIXME: Layering violation to get enums and static function, should be moved  // to separate headers.  #include "PIC16.h" -#include "PIC16ABINames.h"  #include "PIC16ISelLowering.h"  using namespace llvm; diff --git a/lib/Target/PIC16/PIC16MemSelOpt.cpp b/lib/Target/PIC16/PIC16MemSelOpt.cpp index a97dc35..c9ebb57 100644 --- a/lib/Target/PIC16/PIC16MemSelOpt.cpp +++ b/lib/Target/PIC16/PIC16MemSelOpt.cpp @@ -21,7 +21,6 @@  #define DEBUG_TYPE "pic16-codegen"  #include "PIC16.h" -#include "PIC16ABINames.h"  #include "PIC16InstrInfo.h"  #include "PIC16MCAsmInfo.h"  #include "PIC16TargetMachine.h" diff --git a/lib/Target/PIC16/PIC16Section.cpp b/lib/Target/PIC16/PIC16Section.cpp deleted file mode 100644 index 7029501..0000000 --- a/lib/Target/PIC16/PIC16Section.cpp +++ /dev/null @@ -1,91 +0,0 @@ -//===-- PIC16Section.cpp - PIC16 Section ----------- --------------------===// -// -//                     The LLVM Compiler Infrastructure -// -// This file is distributed under the University of Illinois Open Source -// License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// - -#include "PIC16.h" -#include "PIC16ABINames.h" -#include "PIC16Section.h" -#include "llvm/MC/MCContext.h" -#include "llvm/Support/raw_ostream.h" -using namespace llvm; - - -// This is the only way to create a PIC16Section. Sections created here -// do not need to be explicitly deleted as they are managed by auto_ptrs. -PIC16Section *PIC16Section::Create(const StringRef &Name, -                                   PIC16SectionType Ty, -                                   const std::string &Address,  -                                   int Color, MCContext &Ctx) { - -  /// Determine the internal SectionKind info. -  /// Users of PIC16Section class should not need to know the internal -  /// SectionKind. They should work only with PIC16SectionType. -  /// -  /// PIC16 Terminology for section kinds is as below. -  /// UDATA - BSS -  /// IDATA - initialized data (equiv to Metadata)  -  /// ROMDATA - ReadOnly. -  /// UDATA_OVR - Sections that can be overlaid. Section of such type is -  ///             used to contain function autos an frame. We can think of -  ///             it as equiv to llvm ThreadBSS) -  /// UDATA_SHR - Shared RAM. Memory area that is mapped to all banks. - -  SectionKind K; -  switch (Ty) { -    default: llvm_unreachable ("can not create unknown section type"); -    case UDATA_OVR: { -      K = SectionKind::getThreadBSS(); -      break; -    } -    case UDATA_SHR: -    case UDATA: { -      K = SectionKind::getBSS(); -      break; -    } -    case ROMDATA: -    case IDATA: { -      K = SectionKind::getMetadata(); -      break; -    } -    case CODE: { -      K = SectionKind::getText(); -      break; -    } -       -  } - -  // Create the Section. -  PIC16Section *S = new (Ctx) PIC16Section(Name, K, Address, Color); -  S->T = Ty; -  return S; -} - -// A generic way to print all types of sections. -void PIC16Section::PrintSwitchToSection(const MCAsmInfo &MAI, -                                          raw_ostream &OS) const { -  // Print name. -  OS << getName() << '\t'; - -  // Print type. -  switch (getType()) { -  default : llvm_unreachable ("unknown section type");  -  case UDATA: OS << "UDATA"; break; -  case IDATA: OS << "IDATA"; break; -  case ROMDATA: OS << "ROMDATA"; break; -  case UDATA_SHR: OS << "UDATA_SHR"; break; -  case UDATA_OVR: OS << "UDATA_OVR"; break; -  case CODE: OS << "CODE"; break; -  } - -  OS << '\t'; - -  // Print Address. -  OS << Address; - -  OS << '\n'; -} diff --git a/lib/Target/PIC16/PIC16Section.h b/lib/Target/PIC16/PIC16Section.h deleted file mode 100644 index 693ac3a..0000000 --- a/lib/Target/PIC16/PIC16Section.h +++ /dev/null @@ -1,91 +0,0 @@ -//===- PIC16Section.h - PIC16-specific section representation -*- C++ -*-===// -// -//                     The LLVM Compiler Infrastructure -// -// This file is distributed under the University of Illinois Open Source -// License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// -// -// This file declares the PIC16Section class. -// -//===----------------------------------------------------------------------===// - -#ifndef LLVM_PIC16SECTION_H -#define LLVM_PIC16SECTION_H - -#include "llvm/MC/MCSection.h" -#include "llvm/GlobalVariable.h" -#include <vector> - -namespace llvm { -  /// PIC16Section - Represents a physical section in PIC16 COFF. -  /// Contains data objects. -  /// -  class PIC16Section : public MCSection { -    /// PIC16 Sections does not really use the SectionKind class to -    /// to distinguish between various types of sections. PIC16 maintain -    /// its own Section Type info. See the PIC16SectionType enum in PIC16.h  -    /// for various section types. -    PIC16SectionType T; - -    /// Name of the section to uniquely identify it. -    std::string Name; - -    /// User can specify an address at which a section should be placed.  -    /// Negative value here means user hasn't specified any.  -    std::string Address;  - -    /// Overlay information - Sections with same color can be overlaid on -    /// one another. -    int Color;  - -    /// Total size of all data objects contained here. -    unsigned Size; -     -    PIC16Section(const StringRef &name, SectionKind K, const std::string &addr,  -                 int color) -      : MCSection(K), Name(name), Address(addr), Color(color) { -    } -     -  public: -    /// Return the name of the section. -    const std::string &getName() const { return Name; } - -    /// Return the Address of the section. -    const std::string &getAddress() const { return Address; } - -    /// Return the Color of the section. -    int getColor() const { return Color; } - -    /// Return the size of the section. -    unsigned getSize() const { return Size; } -    void setSize(unsigned size) { Size = size; } - -    /// Conatined data objects. -    std::vector<const GlobalVariable *>Items; - -    /// Check section type.  -    bool isUDATA_Type() const { return T == UDATA; } -    bool isIDATA_Type() const { return T == IDATA; } -    bool isROMDATA_Type() const { return T == ROMDATA; } -    bool isUDATA_OVR_Type() const { return T == UDATA_OVR; } -    bool isUDATA_SHR_Type() const { return T == UDATA_SHR; } -    bool isCODE_Type() const { return T == CODE; } - -    PIC16SectionType getType() const { return T; } - -    /// This would be the only way to create a section.  -    static PIC16Section *Create(const StringRef &Name, PIC16SectionType Ty,  -                                const std::string &Address, int Color,  -                                MCContext &Ctx); -     -    /// Override this as PIC16 has its own way of printing switching -    /// to a section. -    virtual void PrintSwitchToSection(const MCAsmInfo &MAI, -                                      raw_ostream &OS) const; -  }; - -} // end namespace llvm - -#endif diff --git a/lib/Target/PIC16/PIC16TargetObjectFile.cpp b/lib/Target/PIC16/PIC16TargetObjectFile.cpp index 330722d..a2a4c09 100644 --- a/lib/Target/PIC16/PIC16TargetObjectFile.cpp +++ b/lib/Target/PIC16/PIC16TargetObjectFile.cpp @@ -8,9 +8,9 @@  //===----------------------------------------------------------------------===//  #include "PIC16TargetObjectFile.h" +#include "MCSectionPIC16.h"  #include "PIC16ISelLowering.h"  #include "PIC16TargetMachine.h" -#include "PIC16Section.h"  #include "llvm/DerivedTypes.h"  #include "llvm/Module.h"  #include "llvm/MC/MCSection.h" @@ -19,111 +19,75 @@  using namespace llvm; -PIC16TargetObjectFile::PIC16TargetObjectFile() { +MCSectionPIC16 *MCSectionPIC16::Create(const StringRef &Name, SectionKind K,  +                                       int Address, int Color, MCContext &Ctx) { +  return new (Ctx) MCSectionPIC16(Name, K, Address, Color);  } -/// Find a pic16 section. If not found, create one. -PIC16Section *PIC16TargetObjectFile:: -getPIC16Section(const std::string &Name, PIC16SectionType Ty,  -                const std::string &Address, int Color) const { -  /// Return if we have an already existing one. -  PIC16Section *&Entry = SectionsByName[Name]; -  if (Entry) -    return Entry; - - -  Entry = PIC16Section::Create(Name, Ty, Address, Color, getContext()); -  return Entry; +void MCSectionPIC16::PrintSwitchToSection(const MCAsmInfo &MAI, +                                          raw_ostream &OS) const { +  OS << getName() << '\n';  } -/// Find a standard pic16 data section. If not found, create one and keep -/// track of it by adding it to appropriate std section list. -PIC16Section *PIC16TargetObjectFile:: -getPIC16DataSection(const std::string &Name, PIC16SectionType Ty,  -                    const std::string &Address, int Color) const { - -  /// Return if we have an already existing one. -  PIC16Section *&Entry = SectionsByName[Name]; -  if (Entry) -    return Entry; - -  /// Else create a new one and add it to appropriate section list. -  Entry = PIC16Section::Create(Name, Ty, Address, Color, getContext()); -  switch (Ty) { -  default: llvm_unreachable ("unknow standard section type."); -  case UDATA: UDATASections_.push_back(Entry); break; -  case IDATA: IDATASections_.push_back(Entry); break; -  case ROMDATA: ROMDATASection_ = Entry; break; -  } -  return Entry; +PIC16TargetObjectFile::PIC16TargetObjectFile() +  : ExternalVarDecls(0), ExternalVarDefs(0) {  } -     - -/// Find a standard pic16 autos section. If not found, create one and keep -/// track of it by adding it to appropriate std section list. -PIC16Section *PIC16TargetObjectFile:: -getPIC16AutoSection(const std::string &Name, PIC16SectionType Ty,  -                    const std::string &Address, int Color) const { -  /// Return if we have an already existing one. -  PIC16Section *&Entry = SectionsByName[Name]; +const MCSectionPIC16 *PIC16TargetObjectFile:: +getPIC16Section(const char *Name, SectionKind Kind,  +                int Address, int Color) const { +  MCSectionPIC16 *&Entry = SectionsByName[Name];    if (Entry)      return Entry; - -  /// Else create a new one and add it to appropriate section list. -  Entry = PIC16Section::Create(Name, Ty, Address, Color, getContext()); - -  assert (Ty == UDATA_OVR && "incorrect section type for autos"); -  AUTOSections_.push_back(Entry); - -  return Entry; +  return Entry = MCSectionPIC16::Create(Name, Kind, Address, Color,  +                                        getContext());  } -     -/// Find a pic16 user section. If not found, create one and keep -/// track of it by adding it to appropriate std section list. -PIC16Section *PIC16TargetObjectFile:: -getPIC16UserSection(const std::string &Name, PIC16SectionType Ty,  -                    const std::string &Address, int Color) const { - -  /// Return if we have an already existing one. -  PIC16Section *&Entry = SectionsByName[Name]; -  if (Entry) -    return Entry; - -  /// Else create a new one and add it to appropriate section list. -  Entry = PIC16Section::Create(Name, Ty, Address, Color, getContext()); -  USERSections_.push_back(Entry); - -  return Entry; -} - -/// Do some standard llvm stuff. PIC16 really does not need any of this.  void PIC16TargetObjectFile::Initialize(MCContext &Ctx, const TargetMachine &tm){    TargetLoweringObjectFile::Initialize(Ctx, tm);    TM = &tm; -  // BSSSection = getPIC16DataSection("udata.#", UDATA); -  // ReadOnlySection = getPIC16DataSection("romdata.#", ROMDATA); -  // DataSection = getPIC16DataSection("idata.#", IDATA); +  BSSSection = getPIC16Section("udata.# UDATA", MCSectionPIC16::UDATA_Kind()); +  ReadOnlySection = getPIC16Section("romdata.# ROMDATA",  +                                    MCSectionPIC16::ROMDATA_Kind()); +  DataSection = getPIC16Section("idata.# IDATA", MCSectionPIC16::IDATA_Kind());    // Need because otherwise a .text symbol is emitted by DwarfWriter    // in BeginModule, and gpasm cribbs for that .text symbol. -  // FIXME: below -  // TextSection = getPIC16DataSection("", UDATA); -  ROMDATASection_ = NULL; +  TextSection = getPIC16Section("", SectionKind::getText()); + +  ROSections.push_back(new PIC16Section((MCSectionPIC16*)ReadOnlySection)); +   +  // FIXME: I don't know what the classification of these sections really is. +  // These aren't really objects belonging to any section. Just emit them +  // in AsmPrinter and remove this code from here.  +  ExternalVarDecls = new PIC16Section(getPIC16Section("ExternalVarDecls", +                                      SectionKind::getMetadata())); +  ExternalVarDefs = new PIC16Section(getPIC16Section("ExternalVarDefs", +                                      SectionKind::getMetadata())); +} + +const MCSection *PIC16TargetObjectFile:: +getSectionForFunction(const std::string &FnName) const { +  std::string T = PAN::getCodeSectionName(FnName); +  return getPIC16Section(T.c_str(), SectionKind::getText()); +} + + +const MCSection *PIC16TargetObjectFile:: +getSectionForFunctionFrame(const std::string &FnName) const { +  std::string T = PAN::getFrameSectionName(FnName); +  return getPIC16Section(T.c_str(), SectionKind::getDataRel());  } -/// allocateUDATA - Allocate a un-initialized global to an existing or new UDATA -/// section and return that section.  const MCSection * -PIC16TargetObjectFile::allocateUDATA(const GlobalVariable *GV) const { +PIC16TargetObjectFile::getBSSSectionForGlobal(const GlobalVariable *GV) const {    assert(GV->hasInitializer() && "This global doesn't need space");    Constant *C = GV->getInitializer();    assert(C->isNullValue() && "Unitialized globals has non-zero initializer"); @@ -133,37 +97,41 @@ PIC16TargetObjectFile::allocateUDATA(const GlobalVariable *GV) const {    const Type *Ty = C->getType();     unsigned ValSize = TD->getTypeAllocSize(Ty); -  // Go through all UDATA Sections and assign this variable +  // Go through all BSS Sections and assign this variable    // to the first available section having enough space. -  PIC16Section *Found = NULL; -  for (unsigned i = 0; i < UDATASections_.size(); i++) { -    if (DataBankSize - UDATASections_[i]->getSize() >= ValSize) { -      Found = UDATASections_[i]; +  PIC16Section *FoundBSS = NULL; +  for (unsigned i = 0; i < BSSSections.size(); i++) { +    if (DataBankSize - BSSSections[i]->Size >= ValSize) { +      FoundBSS = BSSSections[i];        break;      }    } -  // No UDATA section spacious enough was found. Crate a new one. -  if (!Found) { -    std::string name = PAN::getUdataSectionName(UDATASections_.size()); -    Found = getPIC16DataSection(name.c_str(), UDATA); +  // No BSS section spacious enough was found. Crate a new one. +  if (!FoundBSS) { +    std::string name = PAN::getUdataSectionName(BSSSections.size()); +    const MCSectionPIC16 *NewSection +      = getPIC16Section(name.c_str(), MCSectionPIC16::UDATA_Kind()); + +    FoundBSS = new PIC16Section(NewSection); + +    // Add this newly created BSS section to the list of BSSSections. +    BSSSections.push_back(FoundBSS);    } -  // Insert the GV into this UDATA section. -  Found->Items.push_back(GV); -  Found->setSize(Found->getSize() + ValSize); -  return Found; +  // Insert the GV into this BSS. +  FoundBSS->Items.push_back(GV); +  FoundBSS->Size += ValSize; +  return FoundBSS->S_;  }  -/// allocateIDATA - allocate an initialized global into an existing -/// or new section and return that section.  const MCSection * -PIC16TargetObjectFile::allocateIDATA(const GlobalVariable *GV) const{ +PIC16TargetObjectFile::getIDATASectionForGlobal(const GlobalVariable *GV) const{    assert(GV->hasInitializer() && "This global doesn't need space");    Constant *C = GV->getInitializer();    assert(!C->isNullValue() && "initialized globals has zero initializer");    assert(GV->getType()->getAddressSpace() == PIC16ISD::RAM_SPACE && -         "can allocate initialized RAM data only"); +         "can split initialized RAM data only");    // Find how much space this global needs.    const TargetData *TD = TM->getTargetData(); @@ -172,47 +140,64 @@ PIC16TargetObjectFile::allocateIDATA(const GlobalVariable *GV) const{    // Go through all IDATA Sections and assign this variable    // to the first available section having enough space. -  PIC16Section *Found = NULL; -  for (unsigned i = 0; i < IDATASections_.size(); i++) { -    if (DataBankSize - IDATASections_[i]->getSize() >= ValSize) { -      Found = IDATASections_[i];  +  PIC16Section *FoundIDATA = NULL; +  for (unsigned i = 0; i < IDATASections.size(); i++) { +    if (DataBankSize - IDATASections[i]->Size >= ValSize) { +      FoundIDATA = IDATASections[i];         break;      }    }    // No IDATA section spacious enough was found. Crate a new one. -  if (!Found) { -    std::string name = PAN::getIdataSectionName(IDATASections_.size()); -    Found = getPIC16DataSection(name.c_str(), IDATA); +  if (!FoundIDATA) { +    std::string name = PAN::getIdataSectionName(IDATASections.size()); +    const MCSectionPIC16 *NewSection = +      getPIC16Section(name.c_str(), MCSectionPIC16::IDATA_Kind()); + +    FoundIDATA = new PIC16Section(NewSection); + +    // Add this newly created IDATA section to the list of IDATASections. +    IDATASections.push_back(FoundIDATA);    }    // Insert the GV into this IDATA. -  Found->Items.push_back(GV); -  Found->setSize(Found->getSize() + ValSize); -  return Found; +  FoundIDATA->Items.push_back(GV); +  FoundIDATA->Size += ValSize; +  return FoundIDATA->S_;  }  -// Allocate a program memory variable into ROMDATA section. -const MCSection * -PIC16TargetObjectFile::allocateROMDATA(const GlobalVariable *GV) const { - -  std::string name = PAN::getRomdataSectionName(); -  PIC16Section *S = getPIC16DataSection(name.c_str(), ROMDATA); - -  S->Items.push_back(GV); -  return S; -} -  // Get the section for an automatic variable of a function.  // For PIC16 they are globals only with mangled names.  const MCSection * -PIC16TargetObjectFile::allocateAUTO(const GlobalVariable *GV) const { +PIC16TargetObjectFile::getSectionForAuto(const GlobalVariable *GV) const {    const std::string name = PAN::getSectionNameForSym(GV->getName()); -  PIC16Section *S = getPIC16AutoSection(name.c_str()); -  S->Items.push_back(GV); -  return S; +  // Go through all Auto Sections and assign this variable +  // to the appropriate section. +  PIC16Section *FoundAutoSec = NULL; +  for (unsigned i = 0; i < AutosSections.size(); i++) { +    if (AutosSections[i]->S_->getName() == name) { +      FoundAutoSec = AutosSections[i]; +      break; +    } +  } + +  // No Auto section was found. Crate a new one. +  if (!FoundAutoSec) { +    const MCSectionPIC16 *NewSection = +      getPIC16Section(name.c_str(), MCSectionPIC16::UDATA_OVR_Kind()); + +    FoundAutoSec = new PIC16Section(NewSection); + +    // Add this newly created autos section to the list of AutosSections. +    AutosSections.push_back(FoundAutoSec); +  } + +  // Insert the auto into this section. +  FoundAutoSec->Items.push_back(GV); + +  return FoundAutoSec->S_;  } @@ -229,50 +214,56 @@ PIC16TargetObjectFile::SelectSectionForGlobal(const GlobalValue *GV1,    if (!GV)      return TargetLoweringObjectFile::SelectSectionForGlobal(GV1, Kind, Mang,TM); +  // Record External Var Decls. +  if (GV->isDeclaration()) { +    ExternalVarDecls->Items.push_back(GV); +    return ExternalVarDecls->S_; +  } +        assert(GV->hasInitializer() && "A def without initializer?");    // First, if this is an automatic variable for a function, get the section    // name for it and return.    std::string name = GV->getName();    if (PAN::isLocalName(name)) -    return allocateAUTO(GV); +    return getSectionForAuto(GV); + +  // Record Exteranl Var Defs. +  if (GV->hasExternalLinkage() || GV->hasCommonLinkage()) +    ExternalVarDefs->Items.push_back(GV);    // See if this is an uninitialized global.    const Constant *C = GV->getInitializer();    if (C->isNullValue())  -    return allocateUDATA(GV); +    return getBSSSectionForGlobal(GV);     // If this is initialized data in RAM. Put it in the correct IDATA section.    if (GV->getType()->getAddressSpace() == PIC16ISD::RAM_SPACE)  -    return allocateIDATA(GV); +    return getIDATASectionForGlobal(GV);    // This is initialized data in rom, put it in the readonly section.    if (GV->getType()->getAddressSpace() == PIC16ISD::ROM_SPACE)  -    return allocateROMDATA(GV); +    return getROSectionForGlobal(GV);    // Else let the default implementation take care of it.    return TargetLoweringObjectFile::SelectSectionForGlobal(GV, Kind, Mang,TM);  }  PIC16TargetObjectFile::~PIC16TargetObjectFile() { -#if 0 -  for (unsigned i = 0; i < UDATASections_.size(); i++) -    delete UDATASections_[i];  -  for (unsigned i = 0; i < IDATASections_.size(); i++) -    delete IDATASections_[i];  -   -  delete ROMDATASection_; - -  for (unsigned i = 0; i < AUTOSections_.size(); i++) -    delete AUTOSections_[i];  - -  for (unsigned i = 0; i < USERSections_.size(); i++) -    delete USERSections_[i]; -#endif +  for (unsigned i = 0; i < BSSSections.size(); i++) +    delete BSSSections[i];  +  for (unsigned i = 0; i < IDATASections.size(); i++) +    delete IDATASections[i];  +  for (unsigned i = 0; i < AutosSections.size(); i++) +    delete AutosSections[i];  +  for (unsigned i = 0; i < ROSections.size(); i++) +    delete ROSections[i]; +  delete ExternalVarDecls; +  delete ExternalVarDefs;  } -/// getExplicitSectionGlobal - Allow the target to completely override +/// getSpecialCasedSectionGlobals - Allow the target to completely override  /// section assignment of a global.  const MCSection *PIC16TargetObjectFile::  getExplicitSectionGlobal(const GlobalValue *GV, SectionKind Kind,  @@ -283,83 +274,167 @@ getExplicitSectionGlobal(const GlobalValue *GV, SectionKind Kind,      std::string SectName = GVar->getSection();      // If address for a variable is specified, get the address and create      // section. -    // FIXME: move this attribute checking in PAN.      std::string AddrStr = "Address=";      if (SectName.compare(0, AddrStr.length(), AddrStr) == 0) {        std::string SectAddr = SectName.substr(AddrStr.length()); -      return allocateAtGivenAddress(GVar, SectAddr); +      return CreateSectionForGlobal(GVar, Mang, SectAddr);      }      // Create the section specified with section attribute.  -    return allocateInGivenSection(GVar); +    return CreateSectionForGlobal(GVar, Mang);    } -  return getPIC16DataSection(GV->getSection().c_str(), UDATA); +  return getPIC16Section(GV->getSection().c_str(), Kind);  } -// Interface used by AsmPrinter to get a code section for a function. -const PIC16Section * -PIC16TargetObjectFile::SectionForCode(const std::string &FnName) const { -  const std::string &sec_name = PAN::getCodeSectionName(FnName); -  return getPIC16Section(sec_name, CODE); -} - -// Interface used by AsmPrinter to get a frame section for a function. -const PIC16Section * -PIC16TargetObjectFile::SectionForFrame(const std::string &FnName) const { -  const std::string &sec_name = PAN::getFrameSectionName(FnName); -  return getPIC16Section(sec_name, UDATA_OVR); -} - -// Allocate a global var in existing or new section of given name. +// Create a new section for global variable. If Addr is given then create +// section at that address else create by name.  const MCSection * -PIC16TargetObjectFile::allocateInGivenSection(const GlobalVariable *GV) const { -  // Determine the type of section that we need to create. -  PIC16SectionType SecTy; - +PIC16TargetObjectFile::CreateSectionForGlobal(const GlobalVariable *GV, +                                              Mangler *Mang, +                                              const std::string &Addr) const {    // See if this is an uninitialized global.    const Constant *C = GV->getInitializer();    if (C->isNullValue()) -    SecTy = UDATA; +    return CreateBSSSectionForGlobal(GV, Addr); +    // If this is initialized data in RAM. Put it in the correct IDATA section. -  else if (GV->getType()->getAddressSpace() == PIC16ISD::RAM_SPACE) -    SecTy = IDATA; +  if (GV->getType()->getAddressSpace() == PIC16ISD::RAM_SPACE) +    return CreateIDATASectionForGlobal(GV, Addr); +    // This is initialized data in rom, put it in the readonly section. -  else if (GV->getType()->getAddressSpace() == PIC16ISD::ROM_SPACE)  -    SecTy = ROMDATA; -  else -    llvm_unreachable ("Could not determine section type for global"); - -  PIC16Section *S = getPIC16UserSection(GV->getSection().c_str(), SecTy); -  S->Items.push_back(GV); -  return S; +  if (GV->getType()->getAddressSpace() == PIC16ISD::ROM_SPACE)  +    return CreateROSectionForGlobal(GV, Addr); + +  // Else let the default implementation take care of it. +  return TargetLoweringObjectFile::SectionForGlobal(GV, Mang, *TM);  } -// Allocate a global var in a new absolute sections at given address. +// Create uninitialized section for a variable.  const MCSection * -PIC16TargetObjectFile::allocateAtGivenAddress(const GlobalVariable *GV, -                                               const std::string &Addr) const { -  // Determine the type of section that we need to create. -  PIC16SectionType SecTy; +PIC16TargetObjectFile::CreateBSSSectionForGlobal(const GlobalVariable *GV, +                                                 std::string Addr) const { +  assert(GV->hasInitializer() && "This global doesn't need space"); +  assert(GV->getInitializer()->isNullValue() && +         "Unitialized global has non-zero initializer"); +  std::string Name; +  // If address is given then create a section at that address else create a +  // section by section name specified in GV. +  PIC16Section *FoundBSS = NULL; +  if (Addr.empty()) {  +    Name = GV->getSection() + " UDATA"; +    for (unsigned i = 0; i < BSSSections.size(); i++) { +      if (BSSSections[i]->S_->getName() == Name) { +        FoundBSS = BSSSections[i]; +        break; +      } +    } +  } else { +    std::string Prefix = GV->getNameStr() + "." + Addr + "."; +    Name = PAN::getUdataSectionName(BSSSections.size(), Prefix) + " " + Addr; +  } +   +  PIC16Section *NewBSS = FoundBSS; +  if (NewBSS == NULL) { +    const MCSectionPIC16 *NewSection = +      getPIC16Section(Name.c_str(), MCSectionPIC16::UDATA_Kind()); +    NewBSS = new PIC16Section(NewSection); +    BSSSections.push_back(NewBSS); +  } -  // See if this is an uninitialized global. -  const Constant *C = GV->getInitializer(); -  if (C->isNullValue()) -    SecTy = UDATA; -  // If this is initialized data in RAM. Put it in the correct IDATA section. -  else if (GV->getType()->getAddressSpace() == PIC16ISD::RAM_SPACE) -    SecTy = IDATA; -  // This is initialized data in rom, put it in the readonly section. -  else if (GV->getType()->getAddressSpace() == PIC16ISD::ROM_SPACE)  -    SecTy = ROMDATA; -  else -    llvm_unreachable ("Could not determine section type for global"); - -  std::string Prefix = GV->getNameStr() + "." + Addr + "."; -  std::string SName = PAN::getUserSectionName(Prefix); -  PIC16Section *S = getPIC16UserSection(SName.c_str(), SecTy, Addr.c_str()); -  S->Items.push_back(GV); -  return S; +  // Insert the GV into this BSS. +  NewBSS->Items.push_back(GV); + +  // We do not want to put any  GV without explicit section into this section +  // so set its size to DatabankSize. +  NewBSS->Size = DataBankSize; +  return NewBSS->S_; +} + +// Get rom section for a variable. Currently there can be only one rom section +// unless a variable explicitly requests a section. +const MCSection * +PIC16TargetObjectFile::getROSectionForGlobal(const GlobalVariable *GV) const { +  ROSections[0]->Items.push_back(GV); +  return ROSections[0]->S_;  } +// Create initialized data section for a variable. +const MCSection * +PIC16TargetObjectFile::CreateIDATASectionForGlobal(const GlobalVariable *GV, +                                                   std::string Addr) const { +  assert(GV->hasInitializer() && "This global doesn't need space"); +  assert(!GV->getInitializer()->isNullValue() && +         "initialized global has zero initializer"); +  assert(GV->getType()->getAddressSpace() == PIC16ISD::RAM_SPACE && +         "can be used for initialized RAM data only"); + +  std::string Name; +  // If address is given then create a section at that address else create a +  // section by section name specified in GV. +  PIC16Section *FoundIDATASec = NULL; +  if (Addr.empty()) { +    Name = GV->getSection() + " IDATA"; +    for (unsigned i = 0; i < IDATASections.size(); i++) { +      if (IDATASections[i]->S_->getName() == Name) { +        FoundIDATASec = IDATASections[i]; +        break; +      } +    } +  } else { +    std::string Prefix = GV->getNameStr() + "." + Addr + "."; +    Name = PAN::getIdataSectionName(IDATASections.size(), Prefix) + " " + Addr; +  } + +  PIC16Section *NewIDATASec = FoundIDATASec; +  if (NewIDATASec == NULL) { +    const MCSectionPIC16 *NewSection = +      getPIC16Section(Name.c_str(), MCSectionPIC16::IDATA_Kind()); +    NewIDATASec = new PIC16Section(NewSection); +    IDATASections.push_back(NewIDATASec); +  } +  // Insert the GV into this IDATA Section. +  NewIDATASec->Items.push_back(GV); +  // We do not want to put any  GV without explicit section into this section  +  // so set its size to DatabankSize. +  NewIDATASec->Size = DataBankSize; +  return NewIDATASec->S_; +} + +// Create a section in rom for a variable. +const MCSection * +PIC16TargetObjectFile::CreateROSectionForGlobal(const GlobalVariable *GV, +                                                std::string Addr) const { +  assert(GV->getType()->getAddressSpace() == PIC16ISD::ROM_SPACE && +         "can be used for ROM data only"); + +  std::string Name; +  // If address is given then create a section at that address else create a +  // section by section name specified in GV. +  PIC16Section *FoundROSec = NULL; +  if (Addr.empty()) { +    Name = GV->getSection() + " ROMDATA"; +    for (unsigned i = 1; i < ROSections.size(); i++) { +      if (ROSections[i]->S_->getName() == Name) { +        FoundROSec = ROSections[i]; +        break; +      } +    } +  } else { +    std::string Prefix = GV->getNameStr() + "." + Addr + "."; +    Name = PAN::getRomdataSectionName(ROSections.size(), Prefix) + " " + Addr; +  } + +  PIC16Section *NewRomSec = FoundROSec; +  if (NewRomSec == NULL) { +    const MCSectionPIC16 *NewSection = +      getPIC16Section(Name.c_str(), MCSectionPIC16::ROMDATA_Kind()); +    NewRomSec = new PIC16Section(NewSection); +    ROSections.push_back(NewRomSec); +  } + +  // Insert the GV into this ROM Section. +  NewRomSec->Items.push_back(GV); +  return NewRomSec->S_; +} diff --git a/lib/Target/PIC16/PIC16TargetObjectFile.h b/lib/Target/PIC16/PIC16TargetObjectFile.h index 6ec5512..75f6cce 100644 --- a/lib/Target/PIC16/PIC16TargetObjectFile.h +++ b/lib/Target/PIC16/PIC16TargetObjectFile.h @@ -10,8 +10,6 @@  #ifndef LLVM_TARGET_PIC16_TARGETOBJECTFILE_H  #define LLVM_TARGET_PIC16_TARGETOBJECTFILE_H -#include "PIC16.h" -#include "PIC16ABINames.h"  #include "llvm/Target/TargetLoweringObjectFile.h"  #include "llvm/ADT/StringMap.h"  #include <vector> @@ -21,7 +19,7 @@ namespace llvm {    class GlobalVariable;    class Module;    class PIC16TargetMachine; -  class PIC16Section; +  class MCSectionPIC16;    enum { DataBankSize = 80 }; @@ -31,124 +29,91 @@ namespace llvm {    /// again and printing only those that match the current section.     /// Keeping values inside the sections make printing a section much easier.    /// -  /// FIXME: MOVE ALL THIS STUFF TO PIC16Section. +  /// FIXME: MOVE ALL THIS STUFF TO MCSectionPIC16.    /// - -  /// PIC16TargetObjectFile - PIC16 Object file. Contains data and code -  /// sections.  -  // PIC16 Object File has two types of sections. -  // 1. Standard Sections -  //    1.1 un-initialized global data  -  //    1.2 initialized global data -  //    1.3 program memory data -  //    1.4 local variables of functions. -  // 2. User defined sections -  //    2.1 Objects placed in a specific section. (By _Section() macro) -  //    2.2 Objects placed at a specific address. (By _Address() macro) +  struct PIC16Section { +    const MCSectionPIC16 *S_; // Connection to actual Section. +    unsigned Size;  // Total size of the objects contained. +    bool SectionPrinted; +    std::vector<const GlobalVariable*> Items; +     +    PIC16Section(const MCSectionPIC16 *s) { +      S_ = s; +      Size = 0; +      SectionPrinted = false; +    } +    bool isPrinted() const { return SectionPrinted; } +    void setPrintedStatus(bool status) { SectionPrinted = status; }  +  }; +      class PIC16TargetObjectFile : public TargetLoweringObjectFile {      /// SectionsByName - Bindings of names to allocated sections. -    mutable StringMap<PIC16Section*> SectionsByName; +    mutable StringMap<MCSectionPIC16*> SectionsByName;      const TargetMachine *TM; -    /// Lists of sections. -    /// Standard Data Sections. -    mutable std::vector<PIC16Section *> UDATASections_; -    mutable std::vector<PIC16Section *> IDATASections_; -    mutable PIC16Section * ROMDATASection_; - -    /// Standard Auto Sections. -    mutable std::vector<PIC16Section *> AUTOSections_; -  -    /// User specified sections. -    mutable std::vector<PIC16Section *> USERSections_; - -     -    /// Find or Create a PIC16 Section, without adding it to any -    /// section list. -    PIC16Section *getPIC16Section(const std::string &Name, -                                   PIC16SectionType Ty,  -                                   const std::string &Address = "",  -                                   int Color = -1) const; - -    /// Convenience functions. These wrappers also take care of adding  -    /// the newly created section to the appropriate sections list. - -    /// Find or Create PIC16 Standard Data Section. -    PIC16Section *getPIC16DataSection(const std::string &Name, -                                       PIC16SectionType Ty,  -                                       const std::string &Address = "",  -                                       int Color = -1) const; - -    /// Find or Create PIC16 Standard Auto Section. -    PIC16Section *getPIC16AutoSection(const std::string &Name, -                                       PIC16SectionType Ty = UDATA_OVR, -                                       const std::string &Address = "",  -                                       int Color = -1) const; - -    /// Find or Create PIC16 Standard Auto Section. -    PIC16Section *getPIC16UserSection(const std::string &Name, -                                       PIC16SectionType Ty,  -                                       const std::string &Address = "",  -                                       int Color = -1) const; - -    /// Allocate Un-initialized data to a standard UDATA section.  -    const MCSection *allocateUDATA(const GlobalVariable *GV) const; +    const MCSectionPIC16 *getPIC16Section(const char *Name, +                                          SectionKind K,  +                                          int Address = -1,  +                                          int Color = -1) const; +  public: +    mutable std::vector<PIC16Section*> BSSSections; +    mutable std::vector<PIC16Section*> IDATASections; +    mutable std::vector<PIC16Section*> AutosSections; +    mutable std::vector<PIC16Section*> ROSections; +    mutable PIC16Section *ExternalVarDecls; +    mutable PIC16Section *ExternalVarDefs; -    /// Allocate Initialized data to a standard IDATA section.  -    const MCSection *allocateIDATA(const GlobalVariable *GV) const; - -    /// Allocate ROM data to the standard ROMDATA section.  -    const MCSection *allocateROMDATA(const GlobalVariable *GV) const; - -    /// Allocate an AUTO variable to an AUTO section. -    const MCSection *allocateAUTO(const GlobalVariable *GV) const; -     -    /// Allocate DATA in user specified section. -    const MCSection *allocateInGivenSection(const GlobalVariable *GV) const; - -    /// Allocate DATA at user specified address. -    const MCSection *allocateAtGivenAddress(const GlobalVariable *GV, -                                            const std::string &Addr) const; -    -    public:      PIC16TargetObjectFile();      ~PIC16TargetObjectFile(); +          void Initialize(MCContext &Ctx, const TargetMachine &TM); -    /// Override section allocations for user specified sections. +          virtual const MCSection *      getExplicitSectionGlobal(const GlobalValue *GV, SectionKind Kind,                                Mangler *Mang, const TargetMachine &TM) const; -    /// Select sections for Data and Auto variables(globals).      virtual const MCSection *SelectSectionForGlobal(const GlobalValue *GV,                                                      SectionKind Kind,                                                      Mangler *Mang,                                                      const TargetMachine&) const; -    /// Return a code section for a function. -    const PIC16Section *SectionForCode (const std::string &FnName) const; - -    /// Return a frame section for a function. -    const PIC16Section *SectionForFrame (const std::string &FnName) const; - -    /// Accessors for various section lists. -    const std::vector<PIC16Section *> &UDATASections() const { -      return UDATASections_; -    } -    const std::vector<PIC16Section *> &IDATASections() const { -      return IDATASections_; +    const MCSection *getSectionForFunction(const std::string &FnName) const; +    const MCSection *getSectionForFunctionFrame(const std::string &FnName)const; +     +     +  private: +    std::string getSectionNameForSym(const std::string &Sym) const; + +    const MCSection *getBSSSectionForGlobal(const GlobalVariable *GV) const; +    const MCSection *getIDATASectionForGlobal(const GlobalVariable *GV) const; +    const MCSection *getSectionForAuto(const GlobalVariable *GV) const; +    const MCSection *CreateBSSSectionForGlobal(const GlobalVariable *GV, +                                               std::string Addr = "") const; +    const MCSection *CreateIDATASectionForGlobal(const GlobalVariable *GV, +                                                 std::string Addr = "") const; +    const MCSection *getROSectionForGlobal(const GlobalVariable *GV) const; +    const MCSection *CreateROSectionForGlobal(const GlobalVariable *GV, +                                              std::string Addr = "") const; +    const MCSection *CreateSectionForGlobal(const GlobalVariable *GV, +                                            Mangler *Mang, +                                            const std::string &Addr = "") const; +  public: +    void SetSectionForGVs(Module &M); +    const std::vector<PIC16Section*> &getBSSSections() const { +      return BSSSections;      } -    const PIC16Section *ROMDATASection() const { -      return ROMDATASection_; +    const std::vector<PIC16Section*> &getIDATASections() const { +      return IDATASections;      } -    const std::vector<PIC16Section *> &AUTOSections() const { -      return AUTOSections_; +    const std::vector<PIC16Section*> &getAutosSections() const { +      return AutosSections;      } -    const std::vector<PIC16Section *> &USERSections() const { -      return USERSections_; +    const std::vector<PIC16Section*> &getROSections() const { +      return ROSections;      } +        };  } // end namespace llvm | 
