diff options
| author | Jim Laskey <jlaskey@mac.com> | 2007-02-01 16:31:34 +0000 | 
|---|---|---|
| committer | Jim Laskey <jlaskey@mac.com> | 2007-02-01 16:31:34 +0000 | 
| commit | c3de9b4b144eb19ff4b34e458d96cb9f18fff97e (patch) | |
| tree | 539f55ed60341d92b7b79371818a0f7415b848dc /llvm/lib | |
| parent | e15a8b7a55eb41cf0ed2f2e0ce2affbe159ff771 (diff) | |
| download | bcm5719-llvm-c3de9b4b144eb19ff4b34e458d96cb9f18fff97e.tar.gz bcm5719-llvm-c3de9b4b144eb19ff4b34e458d96cb9f18fff97e.zip | |
Support for non-landing pad exception handling.
llvm-svn: 33755
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/CodeGen/AsmPrinter.cpp | 4 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/DwarfWriter.cpp | 438 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/MachineModuleInfo.cpp | 3 | ||||
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp | 4 | ||||
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCTargetAsmInfo.cpp | 3 | ||||
| -rw-r--r-- | llvm/lib/Target/TargetAsmInfo.cpp | 2 | 
6 files changed, 281 insertions, 173 deletions
| diff --git a/llvm/lib/CodeGen/AsmPrinter.cpp b/llvm/lib/CodeGen/AsmPrinter.cpp index 27700ba319c..373c3b24ced 100644 --- a/llvm/lib/CodeGen/AsmPrinter.cpp +++ b/llvm/lib/CodeGen/AsmPrinter.cpp @@ -1032,8 +1032,8 @@ void AsmPrinter::printInlineAsm(const MachineInstr *MI) const {  /// printLabel - This method prints a local label used by debug and  /// exception handling tables.  void AsmPrinter::printLabel(const MachineInstr *MI) const { -  if (AsmVerbose) O << "\n"; -  O << TAI->getPrivateGlobalPrefix() +  O << "\n" +    << TAI->getPrivateGlobalPrefix()      << "debug_loc"      << MI->getOperand(0).getImmedValue()      << ":\n"; diff --git a/llvm/lib/CodeGen/DwarfWriter.cpp b/llvm/lib/CodeGen/DwarfWriter.cpp index 2b9cf74f88a..ac82455ef82 100644 --- a/llvm/lib/CodeGen/DwarfWriter.cpp +++ b/llvm/lib/CodeGen/DwarfWriter.cpp @@ -824,62 +824,13 @@ public:    // Accessors.    //    AsmPrinter *getAsm() const { return Asm; } +  MachineModuleInfo *getMMI() const { return MMI; }    const TargetAsmInfo *getTargetAsmInfo() const { return TAI; }    /// ShouldEmitDwarf - Returns true if Dwarf declarations should be made.    ///    bool ShouldEmitDwarf() const { return shouldEmit; } -}; - -//===----------------------------------------------------------------------===// -/// DwarfDebug - Emits Dwarf debug directives.  -/// -class DwarfDebug : public Dwarf { - -private: -  //===--------------------------------------------------------------------===// -  // Attributes used to construct specific Dwarf sections. -  // -   -  /// CompileUnits - All the compile units involved in this build.  The index -  /// of each entry in this vector corresponds to the sources in MMI. -  std::vector<CompileUnit *> CompileUnits; -   -  /// AbbreviationsSet - Used to uniquely define abbreviations. -  /// -  FoldingSet<DIEAbbrev> AbbreviationsSet; - -  /// Abbreviations - A list of all the unique abbreviations in use. -  /// -  std::vector<DIEAbbrev *> Abbreviations; -   -  /// ValuesSet - Used to uniquely define values. -  /// -  FoldingSet<DIEValue> ValuesSet; -   -  /// Values - A list of all the unique values in use. -  /// -  std::vector<DIEValue *> Values; -   -  /// StringPool - A UniqueVector of strings used by indirect references. -  /// -  UniqueVector<std::string> StringPool; - -  /// UnitMap - Map debug information descriptor to compile unit. -  /// -  std::map<DebugInfoDesc *, CompileUnit *> DescToUnitMap; -   -  /// SectionMap - Provides a unique id per text section. -  /// -  UniqueVector<std::string> SectionMap; -   -  /// SectionSourceLines - Tracks line numbers per text section. -  /// -  std::vector<std::vector<SourceLineInfo> > SectionSourceLines; - - -public:    /// PrintLabelName - Print label name in form used by Dwarf writer.    /// @@ -905,24 +856,29 @@ public:    /// EmitReference - Emit a reference to a label.    /// -  void EmitReference(DWLabel Label) const { -    EmitReference(Label.Tag, Label.Number); +  void EmitReference(DWLabel Label, bool IsPCRelative = false) const { +    EmitReference(Label.Tag, Label.Number, IsPCRelative);    } -  void EmitReference(const char *Tag, unsigned Number) const { +  void EmitReference(const char *Tag, unsigned Number, +                     bool IsPCRelative = false) const {      if (TAI->getAddressSize() == sizeof(int32_t))        O << TAI->getData32bitsDirective();      else        O << TAI->getData64bitsDirective();      PrintLabelName(Tag, Number); +     +    if (IsPCRelative) O << "-" << TAI->getPCSymbol();    } -  void EmitReference(const std::string &Name) const { +  void EmitReference(const std::string &Name, bool IsPCRelative = false) const {      if (TAI->getAddressSize() == sizeof(int32_t))        O << TAI->getData32bitsDirective();      else        O << TAI->getData64bitsDirective();      O << Name; +     +    if (IsPCRelative) O << "-" << TAI->getPCSymbol();    }    /// EmitDifference - Emit the difference between two labels.  Some @@ -938,7 +894,7 @@ public:                        const char *TagLo, unsigned NumberLo,                        bool IsSmall = false) const {      if (TAI->needsSet()) { -      static unsigned SetCounter = 0; +      static unsigned SetCounter = 1;        O << "\t.set\t";        PrintLabelName("set", SetCounter); @@ -968,6 +924,151 @@ public:      }    } +  /// EmitFrameMoves - Emit frame instructions to describe the layout of the +  /// frame. +  void EmitFrameMoves(const char *BaseLabel, unsigned BaseLabelID, +                                   std::vector<MachineMove> &Moves) { +    int stackGrowth = +        Asm->TM.getFrameInfo()->getStackGrowthDirection() == +          TargetFrameInfo::StackGrowsUp ? +            TAI->getAddressSize() : -TAI->getAddressSize(); +    bool IsLocal = BaseLabel && strcmp(BaseLabel, "loc") == 0; + +    for (unsigned i = 0, N = Moves.size(); i < N; ++i) { +      MachineMove &Move = Moves[i]; +      unsigned LabelID = Move.getLabelID(); +       +      if (LabelID) { +        LabelID = MMI->MappedLabel(LabelID); +       +        // Throw out move if the label is invalid. +        if (!LabelID) continue; +      } +       +      const MachineLocation &Dst = Move.getDestination(); +      const MachineLocation &Src = Move.getSource(); +       +      // Advance row if new location. +      if (BaseLabel && LabelID && (BaseLabelID != LabelID || !IsLocal)) { +        Asm->EmitInt8(DW_CFA_advance_loc4); +        Asm->EOL("DW_CFA_advance_loc4"); +        EmitDifference("loc", LabelID, BaseLabel, BaseLabelID, true); +        Asm->EOL(""); +         +        BaseLabelID = LabelID; +        BaseLabel = "loc"; +        IsLocal = true; +      } +       +      // If advancing cfa. +      if (Dst.isRegister() && Dst.getRegister() == MachineLocation::VirtualFP) { +        if (!Src.isRegister()) { +          if (Src.getRegister() == MachineLocation::VirtualFP) { +            Asm->EmitInt8(DW_CFA_def_cfa_offset); +            Asm->EOL("DW_CFA_def_cfa_offset"); +          } else { +            Asm->EmitInt8(DW_CFA_def_cfa); +            Asm->EOL("DW_CFA_def_cfa"); +            Asm->EmitULEB128Bytes(RI->getDwarfRegNum(Src.getRegister())); +            Asm->EOL("Register"); +          } +           +          int Offset = -Src.getOffset(); +           +          Asm->EmitULEB128Bytes(Offset); +          Asm->EOL("Offset"); +        } else { +          assert(0 && "Machine move no supported yet."); +        } +      } else if (Src.isRegister() && +        Src.getRegister() == MachineLocation::VirtualFP) { +        if (Dst.isRegister()) { +          Asm->EmitInt8(DW_CFA_def_cfa_register); +          Asm->EOL("DW_CFA_def_cfa_register"); +          Asm->EmitULEB128Bytes(RI->getDwarfRegNum(Dst.getRegister())); +          Asm->EOL("Register"); +        } else { +          assert(0 && "Machine move no supported yet."); +        } +      } else { +        unsigned Reg = RI->getDwarfRegNum(Src.getRegister()); +        int Offset = Dst.getOffset() / stackGrowth; +         +        if (Offset < 0) { +          Asm->EmitInt8(DW_CFA_offset_extended_sf); +          Asm->EOL("DW_CFA_offset_extended_sf"); +          Asm->EmitULEB128Bytes(Reg); +          Asm->EOL("Reg"); +          Asm->EmitSLEB128Bytes(Offset); +          Asm->EOL("Offset"); +        } else if (Reg < 64) { +          Asm->EmitInt8(DW_CFA_offset + Reg); +          Asm->EOL("DW_CFA_offset + Reg"); +          Asm->EmitULEB128Bytes(Offset); +          Asm->EOL("Offset"); +        } else { +          Asm->EmitInt8(DW_CFA_offset_extended); +          Asm->EOL("DW_CFA_offset_extended"); +          Asm->EmitULEB128Bytes(Reg); +          Asm->EOL("Reg"); +          Asm->EmitULEB128Bytes(Offset); +          Asm->EOL("Offset"); +        } +      } +    } +  } + +}; + +//===----------------------------------------------------------------------===// +/// DwarfDebug - Emits Dwarf debug directives.  +/// +class DwarfDebug : public Dwarf { + +private: +  //===--------------------------------------------------------------------===// +  // Attributes used to construct specific Dwarf sections. +  // +   +  /// CompileUnits - All the compile units involved in this build.  The index +  /// of each entry in this vector corresponds to the sources in MMI. +  std::vector<CompileUnit *> CompileUnits; +   +  /// AbbreviationsSet - Used to uniquely define abbreviations. +  /// +  FoldingSet<DIEAbbrev> AbbreviationsSet; + +  /// Abbreviations - A list of all the unique abbreviations in use. +  /// +  std::vector<DIEAbbrev *> Abbreviations; +   +  /// ValuesSet - Used to uniquely define values. +  /// +  FoldingSet<DIEValue> ValuesSet; +   +  /// Values - A list of all the unique values in use. +  /// +  std::vector<DIEValue *> Values; +   +  /// StringPool - A UniqueVector of strings used by indirect references. +  /// +  UniqueVector<std::string> StringPool; + +  /// UnitMap - Map debug information descriptor to compile unit. +  /// +  std::map<DebugInfoDesc *, CompileUnit *> DescToUnitMap; +   +  /// SectionMap - Provides a unique id per text section. +  /// +  UniqueVector<std::string> SectionMap; +   +  /// SectionSourceLines - Tracks line numbers per text section. +  /// +  std::vector<std::vector<SourceLineInfo> > SectionSourceLines; + + +public: +    /// AssignAbbrevNumber - Define a unique number for the abbreviation.    ///      void AssignAbbrevNumber(DIEAbbrev &Abbrev) { @@ -1950,98 +2051,6 @@ private:      SizeAndOffsetDie(Unit->getDie(), Offset, true);    } -  /// EmitFrameMoves - Emit frame instructions to describe the layout of the -  /// frame. -  void EmitFrameMoves(const char *BaseLabel, unsigned BaseLabelID, -                                   std::vector<MachineMove> &Moves) { -    int stackGrowth = -        Asm->TM.getFrameInfo()->getStackGrowthDirection() == -          TargetFrameInfo::StackGrowsUp ? -            TAI->getAddressSize() : -TAI->getAddressSize(); - -    for (unsigned i = 0, N = Moves.size(); i < N; ++i) { -      MachineMove &Move = Moves[i]; -      unsigned LabelID = Move.getLabelID(); -       -      if (LabelID) { -        LabelID = MMI->MappedLabel(LabelID); -       -        // Throw out move if the label is invalid. -        if (!LabelID) continue; -      } -       -      const MachineLocation &Dst = Move.getDestination(); -      const MachineLocation &Src = Move.getSource(); -       -      // Advance row if new location. -      if (BaseLabel && LabelID && BaseLabelID != LabelID) { -        Asm->EmitInt8(DW_CFA_advance_loc4); -        Asm->EOL("DW_CFA_advance_loc4"); -        EmitDifference("loc", LabelID, BaseLabel, BaseLabelID, true); -        Asm->EOL(""); -         -        BaseLabelID = LabelID; -        BaseLabel = "loc"; -      } -       -      // If advancing cfa. -      if (Dst.isRegister() && Dst.getRegister() == MachineLocation::VirtualFP) { -        if (!Src.isRegister()) { -          if (Src.getRegister() == MachineLocation::VirtualFP) { -            Asm->EmitInt8(DW_CFA_def_cfa_offset); -            Asm->EOL("DW_CFA_def_cfa_offset"); -          } else { -            Asm->EmitInt8(DW_CFA_def_cfa); -            Asm->EOL("DW_CFA_def_cfa"); -            Asm->EmitULEB128Bytes(RI->getDwarfRegNum(Src.getRegister())); -            Asm->EOL("Register"); -          } -           -          int Offset = Src.getOffset() / stackGrowth; -           -          Asm->EmitULEB128Bytes(Offset); -          Asm->EOL("Offset"); -        } else { -          assert(0 && "Machine move no supported yet."); -        } -      } else if (Src.isRegister() && -        Src.getRegister() == MachineLocation::VirtualFP) { -        if (Dst.isRegister()) { -          Asm->EmitInt8(DW_CFA_def_cfa_register); -          Asm->EOL("DW_CFA_def_cfa_register"); -          Asm->EmitULEB128Bytes(RI->getDwarfRegNum(Dst.getRegister())); -          Asm->EOL("Register"); -        } else { -          assert(0 && "Machine move no supported yet."); -        } -      } else { -        unsigned Reg = RI->getDwarfRegNum(Src.getRegister()); -        int Offset = Dst.getOffset() / stackGrowth; -         -        if (Offset < 0) { -          Asm->EmitInt8(DW_CFA_offset_extended_sf); -          Asm->EOL("DW_CFA_offset_extended_sf"); -          Asm->EmitULEB128Bytes(Reg); -          Asm->EOL("Reg"); -          Asm->EmitSLEB128Bytes(Offset); -          Asm->EOL("Offset"); -        } else if (Reg < 64) { -          Asm->EmitInt8(DW_CFA_offset + Reg); -          Asm->EOL("DW_CFA_offset + Reg"); -          Asm->EmitULEB128Bytes(Offset); -          Asm->EOL("Offset"); -        } else { -          Asm->EmitInt8(DW_CFA_offset_extended); -          Asm->EOL("DW_CFA_offset_extended"); -          Asm->EmitULEB128Bytes(Reg); -          Asm->EOL("Reg"); -          Asm->EmitULEB128Bytes(Offset); -          Asm->EOL("Offset"); -        } -      } -    } -  } -    /// EmitDebugInfo - Emit the debug info section.    ///    void EmitDebugInfo() const { @@ -2317,7 +2326,7 @@ private:      EmitLabel("frame_begin", SubprogramCount); -    EmitDifference("frame_common", 0, "section_frame", 0, true); +    EmitDifference("frame_common_begin", 0, "section_frame", 0, true);      Asm->EOL("FDE CIE offset");      EmitReference("func_begin", SubprogramCount); @@ -2616,19 +2625,13 @@ public:      EmitLabel("func_begin", ++SubprogramCount);    } -  /// PreExceptionEndFunction - Close off function before exception handling -  /// tables. -  void PreExceptionEndFunction() { -    if (!ShouldEmitDwarf()) return; -     -    // Define end label for subprogram. -    EmitLabel("func_end", SubprogramCount); -  } -    /// EndFunction - Gather and emit post-function debug information.    ///    void EndFunction() {      if (!ShouldEmitDwarf()) return; +     +    // Define end label for subprogram. +    EmitLabel("func_end", SubprogramCount);      // Get function line info.      const std::vector<SourceLineInfo> &LineInfos = MMI->getSourceLines(); @@ -2648,12 +2651,6 @@ public:      // Emit function frame information.      EmitFunctionDebugFrame(); -     -    // Reset the line numbers for the next function. -    MMI->ClearLineInfo(); - -    // Clear function debug information. -    MMI->EndFunction();    }  }; @@ -2662,6 +2659,85 @@ public:  ///  class DwarfException : public Dwarf  { +private: + +  /// EmitInitial - Emit initial exception information. +  /// +  void EmitInitial() { +    int stackGrowth = +        Asm->TM.getFrameInfo()->getStackGrowthDirection() == +          TargetFrameInfo::StackGrowsUp ? +        TAI->getAddressSize() : -TAI->getAddressSize(); + +    Asm->SwitchToTextSection(TAI->getDwarfEHFrameSection()); +    O << "EH_frame:\n"; +    EmitLabel("section_eh_frame", 0); + +    EmitLabel("eh_frame_common", 0); +    EmitDifference("eh_frame_common_end", 0, +                   "eh_frame_common_begin", 0, true); +    Asm->EOL("Length of Common Information Entry"); + +    EmitLabel("eh_frame_common_begin", 0); +    Asm->EmitInt32((int)0); +    Asm->EOL("CIE Identifier Tag"); +    Asm->EmitInt8(DW_CIE_VERSION); +    Asm->EOL("CIE Version"); +    Asm->EmitString("zR"); +    Asm->EOL("CIE Augmentation"); +    Asm->EmitULEB128Bytes(1); +    Asm->EOL("CIE Code Alignment Factor"); +    Asm->EmitSLEB128Bytes(stackGrowth); +    Asm->EOL("CIE Data Alignment Factor");    +    Asm->EmitInt8(RI->getDwarfRegNum(RI->getRARegister())); +    Asm->EOL("CIE RA Column"); +    Asm->EmitULEB128Bytes(1); +    Asm->EOL("Augmentation Size"); +    Asm->EmitULEB128Bytes(DW_EH_PE_pcrel); +    Asm->EOL("FDE Encoding (pcrel)"); +     +    std::vector<MachineMove> Moves; +    RI->getInitialFrameState(Moves); +    EmitFrameMoves(NULL, 0, Moves); + +    Asm->EmitAlignment(2); +    EmitLabel("eh_frame_common_end", 0); +     +    Asm->EOL(""); +     +  } +   +   +  /// EmitEHFrame - Emit initial exception information. +  /// +  void EmitEHFrame() { +    EmitDifference("eh_frame_end", SubprogramCount, +                   "eh_frame_begin", SubprogramCount, true); +    Asm->EOL("Length of Frame Information Entry"); +     +    EmitLabel("eh_frame_begin", SubprogramCount); +     +    EmitDifference("eh_frame_begin", SubprogramCount, +                   "section_eh_frame", 0, true); +    Asm->EOL("FDE CIE offset"); + +    EmitReference("eh_func_begin", SubprogramCount, true); +    Asm->EOL("FDE initial location"); +    EmitDifference("eh_func_end", SubprogramCount, +                   "eh_func_begin", SubprogramCount); +    Asm->EOL("FDE address range"); +     +    Asm->EmitULEB128Bytes(0); +    Asm->EOL("Augmentation size"); +     +    std::vector<MachineMove> &Moves = MMI->getFrameMoves(); +     +    EmitFrameMoves("eh_func_begin", SubprogramCount, Moves); +     +    Asm->EmitAlignment(2); +    EmitLabel("eh_frame_end", SubprogramCount); +  } +  public:    //===--------------------------------------------------------------------===//    // Main entry points. @@ -2675,10 +2751,15 @@ public:    /// SetModuleInfo - Set machine module information when it's known that pass    /// manager has created it.  Set by the target AsmPrinter.    void SetModuleInfo(MachineModuleInfo *mmi) { +#if 1  // Not ready for prime time. +    return; +#endif      // Make sure initial declarations are made.      if (!MMI && ExceptionHandling && TAI->getSupportsExceptionHandling()) {        MMI = mmi;        shouldEmit = true; +       +      EmitInitial();      }    } @@ -2702,21 +2783,32 @@ public:      this->MF = MF;      if (!ShouldEmitDwarf()) return; +     +    // Assumes in correct section after the entry point. +    EmitLabel("eh_func_begin", ++SubprogramCount);    }    /// EndFunction - Gather and emit post-function exception information.    ///    void EndFunction() {      if (!ShouldEmitDwarf()) return; -#if 0 + +    EmitLabel("eh_func_end", SubprogramCount); + +    Asm->SwitchToTextSection(TAI->getDwarfEHFrameSection()); +      if (const char *GlobalDirective = TAI->getGlobalDirective())        O << GlobalDirective << getAsm()->CurrentFnName << ".eh\n"; -       -    O << getAsm()->CurrentFnName << ".eh = 0\n"; +      +    if (0) { +      O << getAsm()->CurrentFnName << ".eh = 0\n"; +    } else { +      O << getAsm()->CurrentFnName << ".eh:\n"; +      EmitEHFrame(); +    }      if (const char *UsedDirective = TAI->getUsedDirective()) -      O << UsedDirective << getAsm()->CurrentFnName << ".eh\n"; -#endif +      O << UsedDirective << getAsm()->CurrentFnName << ".eh\n\n";    }  }; @@ -3031,8 +3123,8 @@ DwarfWriter::~DwarfWriter() {  /// SetModuleInfo - Set machine module info when it's known that pass manager  /// has created it.  Set by the target AsmPrinter.  void DwarfWriter::SetModuleInfo(MachineModuleInfo *MMI) { -  DE->SetModuleInfo(MMI);    DD->SetModuleInfo(MMI); +  DE->SetModuleInfo(MMI);  }  /// BeginModule - Emit all Dwarf sections that should come prior to the @@ -3059,7 +3151,11 @@ void DwarfWriter::BeginFunction(MachineFunction *MF) {  /// EndFunction - Gather and emit post-function debug information.  ///  void DwarfWriter::EndFunction() { -  DD->PreExceptionEndFunction(); -  DE->EndFunction();    DD->EndFunction(); +  DE->EndFunction(); +   +  if (MachineModuleInfo *MMI = DD->getMMI()) { +    // Clear function debug information. +    MMI->EndFunction(); +  }  } diff --git a/llvm/lib/CodeGen/MachineModuleInfo.cpp b/llvm/lib/CodeGen/MachineModuleInfo.cpp index 15ea9b828de..4cc2a150ebc 100644 --- a/llvm/lib/CodeGen/MachineModuleInfo.cpp +++ b/llvm/lib/CodeGen/MachineModuleInfo.cpp @@ -1505,6 +1505,9 @@ void MachineModuleInfo::EndFunction() {      RootScope = NULL;    } +  // Clean up line info. +  Lines.clear(); +    // Clean up frame info.    FrameMoves.clear();  } diff --git a/llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp b/llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp index fb80350c557..3370c362f98 100644 --- a/llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp +++ b/llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp @@ -902,6 +902,10 @@ void PPCRegisterInfo::emitPrologue(MachineFunction &MF) const {        Moves.push_back(MachineMove(FrameLabelId, CSDst, CSSrc));      } +    MachineLocation LRDst(MachineLocation::VirtualFP, LROffset); +    MachineLocation LRSrc(IsPPC64 ? PPC::LR8 : PPC::LR); +    Moves.push_back(MachineMove(FrameLabelId, LRDst, LRSrc)); +          // Mark effective beginning of when frame pointer is ready.      unsigned ReadyLabelId = MMI->NextLabelID();      BuildMI(MBB, MBBI, TII.get(PPC::LABEL)).addImm(ReadyLabelId); diff --git a/llvm/lib/Target/PowerPC/PPCTargetAsmInfo.cpp b/llvm/lib/Target/PowerPC/PPCTargetAsmInfo.cpp index 2442a38366f..38e0d212bf6 100644 --- a/llvm/lib/Target/PowerPC/PPCTargetAsmInfo.cpp +++ b/llvm/lib/Target/PowerPC/PPCTargetAsmInfo.cpp @@ -41,11 +41,14 @@ PPCTargetAsmInfo::PPCTargetAsmInfo(const PPCTargetMachine &TM) {    DwarfARangesSection = ".section __DWARF,__debug_aranges,regular,debug";    DwarfRangesSection = ".section __DWARF,__debug_ranges,regular,debug";    DwarfMacInfoSection = ".section __DWARF,__debug_macinfo,regular,debug"; +  DwarfEHFrameSection = +  ".section __TEXT,__eh_frame,coalesced,no_toc+strip_static_syms+live_support";  }  DarwinTargetAsmInfo::DarwinTargetAsmInfo(const PPCTargetMachine &TM)  : PPCTargetAsmInfo(TM)  { +  PCSymbol = ".";    CommentString = ";";    GlobalPrefix = "_";    PrivateGlobalPrefix = "L"; diff --git a/llvm/lib/Target/TargetAsmInfo.cpp b/llvm/lib/Target/TargetAsmInfo.cpp index 7ac395002ed..e8e2de46bdd 100644 --- a/llvm/lib/Target/TargetAsmInfo.cpp +++ b/llvm/lib/Target/TargetAsmInfo.cpp @@ -24,6 +24,7 @@ TargetAsmInfo::TargetAsmInfo() :    AddressSize(4),    NeedsSet(false),    MaxInstLength(4), +  PCSymbol("$"),    SeparatorChar(';'),    CommentString("#"),    GlobalPrefix(""), @@ -84,6 +85,7 @@ TargetAsmInfo::TargetAsmInfo() :    DwarfARangesSection(".debug_aranges"),    DwarfRangesSection(".debug_ranges"),    DwarfMacInfoSection(".debug_macinfo"), +  DwarfEHFrameSection(".eh_frame"),    AsmTransCBE(0) {  } | 

