diff options
author | Jim Laskey <jlaskey@mac.com> | 2006-01-04 13:52:30 +0000 |
---|---|---|
committer | Jim Laskey <jlaskey@mac.com> | 2006-01-04 13:52:30 +0000 |
commit | a7cea6f599418a579ab5ce66413fba7efa8bf581 (patch) | |
tree | e9c08c564c24dff6a38c307e396c36c539b2f827 /lib/Target | |
parent | 780a61cf04563a198f32b2eebe752d8ba6b98953 (diff) | |
download | external_llvm-a7cea6f599418a579ab5ce66413fba7efa8bf581.zip external_llvm-a7cea6f599418a579ab5ce66413fba7efa8bf581.tar.gz external_llvm-a7cea6f599418a579ab5ce66413fba7efa8bf581.tar.bz2 |
Tie dwarf generation to darwin assembler.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25093 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target')
-rw-r--r-- | lib/Target/PowerPC/PPCAsmPrinter.cpp | 42 | ||||
-rw-r--r-- | lib/Target/PowerPC/PPCTargetMachine.cpp | 2 |
2 files changed, 35 insertions, 9 deletions
diff --git a/lib/Target/PowerPC/PPCAsmPrinter.cpp b/lib/Target/PowerPC/PPCAsmPrinter.cpp index f75e4aa..12b5f44 100644 --- a/lib/Target/PowerPC/PPCAsmPrinter.cpp +++ b/lib/Target/PowerPC/PPCAsmPrinter.cpp @@ -25,6 +25,7 @@ #include "llvm/Module.h" #include "llvm/Assembly/Writer.h" #include "llvm/CodeGen/AsmPrinter.h" +#include "llvm/CodeGen/DwarfWriter.h" #include "llvm/CodeGen/MachineDebugInfo.h" #include "llvm/CodeGen/MachineFunctionPass.h" #include "llvm/CodeGen/MachineInstr.h" @@ -205,13 +206,33 @@ namespace { virtual bool doFinalization(Module &M) = 0; }; + /// DarwinDwarfWriter - Dwarf debug info writer customized for Darwin/Mac OS X + /// + struct DarwinDwarfWriter : public DwarfWriter { + // Ctor. + DarwinDwarfWriter(std::ostream &o, AsmPrinter *ap, MachineDebugInfo &di) + : DwarfWriter(o, ap, di) + { + hasLEB128 = false; + needsSet = true; + DwarfAbbrevSection = ".section __DWARFA,__debug_abbrev,regular,debug"; + DwarfInfoSection = ".section __DWARFA,__debug_info,regular,debug"; + DwarfLineSection = ".section __DWARFA,__debug_line,regular,debug"; + } + }; + /// DarwinAsmPrinter - PowerPC assembly printer, customized for Darwin/Mac OS /// X /// struct DarwinAsmPrinter : public PPCAsmPrinter { + + DarwinDwarfWriter DW; DarwinAsmPrinter(std::ostream &O, TargetMachine &TM) - : PPCAsmPrinter(O, TM) { + : PPCAsmPrinter(O, TM), + // FIXME - MachineDebugInfo needs a proper location + DW(O, this, getMachineDebugInfo()) + { CommentString = ";"; GlobalPrefix = "_"; PrivateGlobalPrefix = "L"; // Marker for constant pool idxs @@ -397,12 +418,8 @@ bool DarwinAsmPrinter::runOnMachineFunction(MachineFunction &MF) { SetupMachineFunction(MF); O << "\n\n"; - // Print out dwarf file info - MachineDebugInfo &DebugInfo = MF.getDebugInfo(); - std::vector<std::string> Sources = DebugInfo.getSourceFiles(); - for (unsigned i = 0, N = Sources.size(); i < N; i++) { - O << "\t; .file\t" << (i + 1) << "," << "\"" << Sources[i] << "\"" << "\n"; - } + // Emit pre-function debug information. + DW.BeginFunction(); // Print out constants referenced by the function EmitConstantPool(MF.getConstantPool()); @@ -449,6 +466,9 @@ bool DarwinAsmPrinter::runOnMachineFunction(MachineFunction &MF) { } } + // Emit post-function debug information. + DW.EndFunction(); + // We didn't modify anything. return false; } @@ -461,6 +481,9 @@ bool DarwinAsmPrinter::doInitialization(Module &M) { // Darwin wants symbols to be quoted if they have complex names. Mang->setUseQuotes(true); + + // Emit initial debug information. + DW.BeginModule(); return false; } @@ -583,6 +606,9 @@ bool DarwinAsmPrinter::doFinalization(Module &M) { // code that does this, it is always safe to set. O << "\t.subsections_via_symbols\n"; + // Emit initial debug information. + DW.EndModule(); + AsmPrinter::doFinalization(M); return false; // success } @@ -592,7 +618,7 @@ bool DarwinAsmPrinter::doFinalization(Module &M) { /// bool AIXAsmPrinter::runOnMachineFunction(MachineFunction &MF) { SetupMachineFunction(MF); - + // Print out constants referenced by the function EmitConstantPool(MF.getConstantPool()); diff --git a/lib/Target/PowerPC/PPCTargetMachine.cpp b/lib/Target/PowerPC/PPCTargetMachine.cpp index c92122e..3115a57 100644 --- a/lib/Target/PowerPC/PPCTargetMachine.cpp +++ b/lib/Target/PowerPC/PPCTargetMachine.cpp @@ -80,7 +80,7 @@ bool PPCTargetMachine::addPassesToEmitFile(PassManager &PM, CodeGenFileType FileType, bool Fast) { if (FileType != TargetMachine::AssemblyFile) return true; - + // Run loop strength reduction before anything else. if (!Fast) PM.add(createLoopStrengthReducePass()); |