[llvm-commits] [llvm] r64839 - in /llvm/branches/Apple/Dib: include/llvm/Analysis/DebugInfo.h include/llvm/Support/Dwarf.h lib/Analysis/DebugInfo.cpp lib/CodeGen/AsmPrinter/DwarfWriter.cpp lib/Support/Dwarf.cpp tools/lto/LTOCodeGenerator.cpp
Bill Wendling
isanbard at gmail.com
Tue Feb 17 14:52:33 PST 2009
Author: void
Date: Tue Feb 17 16:52:33 2009
New Revision: 64839
URL: http://llvm.org/viewvc/llvm-project?rev=64839&view=rev
Log:
--- Merging (from foreign repository) r64834 into '.':
U include/llvm/Analysis/DebugInfo.h
U include/llvm/Support/Dwarf.h
U tools/lto/LTOCodeGenerator.cpp
U lib/Analysis/DebugInfo.cpp
U lib/CodeGen/AsmPrinter/DwarfWriter.cpp
U lib/Support/Dwarf.cpp
The debugger sometimes lookup dynamically in the runtime to find ivar info of
any Objective-C classes. It would be very helpful to debugger if the compiler
encodes runtime version number in DWARF.
Add support for two additional DWARF attributes to encode Objective-C runtime
version number.
Modified:
llvm/branches/Apple/Dib/include/llvm/Analysis/DebugInfo.h
llvm/branches/Apple/Dib/include/llvm/Support/Dwarf.h
llvm/branches/Apple/Dib/lib/Analysis/DebugInfo.cpp
llvm/branches/Apple/Dib/lib/CodeGen/AsmPrinter/DwarfWriter.cpp
llvm/branches/Apple/Dib/lib/Support/Dwarf.cpp
llvm/branches/Apple/Dib/tools/lto/LTOCodeGenerator.cpp
Modified: llvm/branches/Apple/Dib/include/llvm/Analysis/DebugInfo.h
URL: http://llvm.org/viewvc/llvm-project/llvm/branches/Apple/Dib/include/llvm/Analysis/DebugInfo.h?rev=64839&r1=64838&r2=64839&view=diff
==============================================================================
--- llvm/branches/Apple/Dib/include/llvm/Analysis/DebugInfo.h (original)
+++ llvm/branches/Apple/Dib/include/llvm/Analysis/DebugInfo.h Tue Feb 17 16:52:33 2009
@@ -118,9 +118,11 @@
/// code generator accepts maximum one main compile unit per module. If a
/// module does not contain any main compile unit then the code generator
/// will emit multiple compile units in the output object file.
+
bool isMain() const { return getUnsignedField(6); }
bool isOptimized() const { return getUnsignedField(7); }
std::string getFlags() const { return getStringField(8); }
+ unsigned getRunTimeVersion() const { return getUnsignedField(9); }
/// Verify - Verify that a compile unit is well formed.
bool Verify() const;
@@ -231,6 +233,7 @@
public:
explicit DICompositeType(GlobalVariable *GV);
DIArray getTypeArray() const { return getFieldAs<DIArray>(10); }
+ unsigned getRunTimeLang() const { return getUnsignedField(11); }
/// Verify - Verify that a composite type descriptor is well formed.
bool Verify() const;
@@ -381,7 +384,8 @@
const std::string &Producer,
bool isMain = false,
bool isOptimized = false,
- const char *Flags = "");
+ const char *Flags = "",
+ unsigned RunTimeVer = 0);
/// CreateEnumerator - Create a single enumerator value.
DIEnumerator CreateEnumerator(const std::string &Name, uint64_t Val);
@@ -412,7 +416,8 @@
uint64_t AlignInBits,
uint64_t OffsetInBits, unsigned Flags,
DIType DerivedFrom,
- DIArray Elements);
+ DIArray Elements,
+ unsigned RunTimeLang = 0);
/// CreateSubprogram - Create a new descriptor for the specified subprogram.
/// See comments in DISubprogram for descriptions of these fields.
Modified: llvm/branches/Apple/Dib/include/llvm/Support/Dwarf.h
URL: http://llvm.org/viewvc/llvm-project/llvm/branches/Apple/Dib/include/llvm/Support/Dwarf.h?rev=64839&r1=64838&r2=64839&view=diff
==============================================================================
--- llvm/branches/Apple/Dib/include/llvm/Support/Dwarf.h (original)
+++ llvm/branches/Apple/Dib/include/llvm/Support/Dwarf.h Tue Feb 17 16:52:33 2009
@@ -225,6 +225,8 @@
// Apple extensions.
DW_AT_APPLE_optimized = 0x3fe1,
DW_AT_APPLE_flags = 0x3fe2,
+ DW_AT_APPLE_major_runtime_vers = 0x3fe5,
+ DW_AT_APPLE_runtime_class = 0x3fe6,
// Attribute form encodings
DW_FORM_addr = 0x01,
Modified: llvm/branches/Apple/Dib/lib/Analysis/DebugInfo.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/branches/Apple/Dib/lib/Analysis/DebugInfo.cpp?rev=64839&r1=64838&r2=64839&view=diff
==============================================================================
--- llvm/branches/Apple/Dib/lib/Analysis/DebugInfo.cpp (original)
+++ llvm/branches/Apple/Dib/lib/Analysis/DebugInfo.cpp Tue Feb 17 16:52:33 2009
@@ -453,7 +453,8 @@
const std::string &Producer,
bool isMain,
bool isOptimized,
- const char *Flags) {
+ const char *Flags,
+ unsigned RunTimeVer) {
Constant *Elts[] = {
GetTagConstant(dwarf::DW_TAG_compile_unit),
getCastToEmpty(GetOrCreateCompileUnitAnchor()),
@@ -463,7 +464,8 @@
GetStringConstant(Producer),
ConstantInt::get(Type::Int1Ty, isMain),
ConstantInt::get(Type::Int1Ty, isOptimized),
- GetStringConstant(Flags)
+ GetStringConstant(Flags),
+ ConstantInt::get(Type::Int32Ty, RunTimeVer)
};
Constant *Init = ConstantStruct::get(Elts, sizeof(Elts)/sizeof(Elts[0]));
@@ -573,7 +575,8 @@
uint64_t OffsetInBits,
unsigned Flags,
DIType DerivedFrom,
- DIArray Elements) {
+ DIArray Elements,
+ unsigned RuntimeLang) {
Constant *Elts[] = {
GetTagConstant(Tag),
@@ -586,7 +589,8 @@
ConstantInt::get(Type::Int64Ty, OffsetInBits),
ConstantInt::get(Type::Int32Ty, Flags),
getCastToEmpty(DerivedFrom),
- getCastToEmpty(Elements)
+ getCastToEmpty(Elements),
+ ConstantInt::get(Type::Int32Ty, RuntimeLang)
};
Constant *Init = ConstantStruct::get(Elts, sizeof(Elts)/sizeof(Elts[0]));
Modified: llvm/branches/Apple/Dib/lib/CodeGen/AsmPrinter/DwarfWriter.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/branches/Apple/Dib/lib/CodeGen/AsmPrinter/DwarfWriter.cpp?rev=64839&r1=64838&r2=64839&view=diff
==============================================================================
--- llvm/branches/Apple/Dib/lib/CodeGen/AsmPrinter/DwarfWriter.cpp (original)
+++ llvm/branches/Apple/Dib/lib/CodeGen/AsmPrinter/DwarfWriter.cpp Tue Feb 17 16:52:33 2009
@@ -1767,6 +1767,9 @@
DIDerivedType(Element.getGV()));
Buffer.AddChild(ElemDie);
}
+ unsigned RLang = CTy.getRunTimeLang();
+ if (RLang)
+ AddUInt(&Buffer, DW_AT_APPLE_runtime_class, DW_FORM_data1, RLang);
}
break;
default:
@@ -2797,6 +2800,9 @@
const std::string &Flags = DIUnit.getFlags();
if (!Flags.empty())
AddString(Die, DW_AT_APPLE_flags, DW_FORM_string, Flags);
+ unsigned RVer = DIUnit.getRunTimeVersion();
+ if (RVer)
+ AddUInt(Die, DW_AT_APPLE_major_runtime_vers, DW_FORM_data1, RVer);
CompileUnit *Unit = new CompileUnit(ID, Die);
if (DIUnit.isMain()) {
Modified: llvm/branches/Apple/Dib/lib/Support/Dwarf.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/branches/Apple/Dib/lib/Support/Dwarf.cpp?rev=64839&r1=64838&r2=64839&view=diff
==============================================================================
--- llvm/branches/Apple/Dib/lib/Support/Dwarf.cpp (original)
+++ llvm/branches/Apple/Dib/lib/Support/Dwarf.cpp Tue Feb 17 16:52:33 2009
@@ -200,6 +200,8 @@
case DW_AT_hi_user: return "DW_AT_hi_user";
case DW_AT_APPLE_optimized: return "DW_AT_APPLE_optimized";
case DW_AT_APPLE_flags: return "DW_AT_APPLE_flags";
+ case DW_AT_APPLE_major_runtime_vers: return "DW_AT_APPLE_major_runtime_vers";
+ case DW_AT_APPLE_runtime_class: return "DW_AT_APPLE_runtime_class";
}
assert(0 && "Unknown Dwarf Attribute");
return "";
Modified: llvm/branches/Apple/Dib/tools/lto/LTOCodeGenerator.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/branches/Apple/Dib/tools/lto/LTOCodeGenerator.cpp?rev=64839&r1=64838&r2=64839&view=diff
==============================================================================
--- llvm/branches/Apple/Dib/tools/lto/LTOCodeGenerator.cpp (original)
+++ llvm/branches/Apple/Dib/tools/lto/LTOCodeGenerator.cpp Tue Feb 17 16:52:33 2009
@@ -356,6 +356,10 @@
// Add an appropriate TargetData instance for this module...
passes.add(new TargetData(*_target->getTargetData()));
+ std::string targetTriple = _linker.getModule()->getTargetTriple();
+// if ( targetTriple.find("darwin") != targetTriple.size() )
+ passes.add(createStripSymbolsPass(true /* strip debug info only */));
+
// Propagate constants at call sites into the functions they call. This
// opens opportunities for globalopt (and inlining) by substituting function
// pointers passed as arguments to direct uses of functions.
@@ -412,6 +416,8 @@
// Make sure everything is still good.
passes.add(createVerifierPass());
+ setCodeGenDebugOptions("-debug-pass=Structure");
+
FunctionPassManager* codeGenPasses =
new FunctionPassManager(new ExistingModuleProvider(mergedModule));
More information about the llvm-commits
mailing list