X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=docs%2FSourceLevelDebugging.html;h=2bbe18118e122bd8825b7b558beeedb58b6c70b2;hb=170f06ebe2e80ce8bda87425081541493056fb10;hp=b028ee6d34928150704531c9e8e940d539fa1f56;hpb=67a1a54195706f48170ddc42b1eaba799274718a;p=oota-llvm.git diff --git a/docs/SourceLevelDebugging.html b/docs/SourceLevelDebugging.html index b028ee6d349..2bbe18118e1 100644 --- a/docs/SourceLevelDebugging.html +++ b/docs/SourceLevelDebugging.html @@ -25,6 +25,7 @@
Currently, debug information is consumed by the DwarfWriter to produce dwarf +
Currently, debug information is consumed by DwarfDebug to produce dwarf information used by the gdb debugger. Other targets could use the same information to produce stabs or other debug forms.
@@ -236,7 +237,7 @@ height="369">LLVM debugging information has been carefully designed to make it possible for the optimizer to optimize the program and debugging information without necessarily having to know anything about debugging information. In - particular, te use of metadadta avoids duplicated dubgging information from + particular, the use of metadata avoids duplicated debugging information from the beginning, and the global dead code elimination pass automatically deletes debugging information for a function if it decides to delete the function.
@@ -255,7 +256,7 @@ height="369">To provide basic functionality, the LLVM debugger does have to make some assumptions about the source-level language being debugged, though it keeps these to a minimum. The only common features that the LLVM debugger assumes - exist are source files, + exist are source files, and program objects. These abstract objects are used by a debugger to form stack traces, show information about local variables, etc.
@@ -288,27 +289,26 @@ height="369"> 0x1000.)The fields of debug descriptors used internally by LLVM - are restricted to only the simple data types int, uint, - bool, float, double, mdstring and - mdnode.
+ are restricted to only the simple data types i32, i1, + float, double, mdstring and mdnode.!1 = metadata !{ - uint, ;; A tag + i32, ;; A tag ... }
The details of the various descriptors follow.
@@ -346,18 +346,36 @@ height="369"> that produced it.Compile unit descriptors provide the root context for objects declared in a - specific source file. Global variables and top level functions would be - defined using this context. Compile unit descriptors also provide context - for source line correspondence.
+ specific compilation unit. File descriptors are defined using this context. -Each input file is encoded as a separate compile unit in LLVM debugging - information output. However, many target specific tool chains prefer to - encode only one compile unit in an object file. In this situation, the LLVM - code generator will include debugging information entities in the compile - unit that is marked as main compile unit. The 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.
+ + + ++!0 = metadata !{ + i32, ;; Tag = 41 + LLVMDebugVersion + ;; (DW_TAG_file_type) + metadata, ;; Source file name + metadata, ;; Source file directory (includes trailing slash) + metadata ;; Reference to compile unit where defined +} ++
These descriptors contain information for a file. Global variables and top + level functions would be defined using this context.k File descriptors also + provide context for source line correspondence.
+ +Each input file is encoded as a separate file descriptor in LLVM debugging + information output. Each file descriptor would be defined using a + compile unit.
- void %llvm.dbg.declare( { } *, metadata ) + void %llvm.dbg.declare({}*, metadata)
This intrinsic provides information about a local element (ex. variable.) The - first argument is the alloca for the variable, cast to a { }*. The + first argument is the alloca for the variable, cast to a {}*. The second argument is the %llvm.dbg.variable containing the description of the variable.
@@ -782,7 +807,7 @@ DW_TAG_return_variable = 258- void %llvm.dbg.value( metadata, i64, metadata ) + void %llvm.dbg.value(metadata, i64, metadata)
This intrinsic provides information when a user source variable is set to a @@ -810,8 +835,8 @@ DW_TAG_return_variable = 258 rules.
In order to handle this, the LLVM debug format uses the metadata attached to - llvm instructions to encode line nuber and scoping information. Consider the - following C fragment, for example:
+ llvm instructions to encode line number and scoping information. Consider + the following C fragment, for example:@@ -836,14 +861,14 @@ entry: %X = alloca i32, align 4 ; <i32*> [#uses=4] %Y = alloca i32, align 4 ; <i32*> [#uses=4] %Z = alloca i32, align 4 ; <i32*> [#uses=3] - %0 = bitcast i32* %X to { }* ; <{ }*> [#uses=1] - call void @llvm.dbg.declare({ }* %0, metadata !0), !dbg !7 + %0 = bitcast i32* %X to {}* ; <{}*> [#uses=1] + call void @llvm.dbg.declare({}* %0, metadata !0), !dbg !7 store i32 21, i32* %X, !dbg !8 - %1 = bitcast i32* %Y to { }* ; <{ }*> [#uses=1] - call void @llvm.dbg.declare({ }* %1, metadata !9), !dbg !10 + %1 = bitcast i32* %Y to {}* ; <{}*> [#uses=1] + call void @llvm.dbg.declare({}* %1, metadata !9), !dbg !10 store i32 22, i32* %Y, !dbg !11 - %2 = bitcast i32* %Z to { }* ; <{ }*> [#uses=1] - call void @llvm.dbg.declare({ }* %2, metadata !12), !dbg !14 + %2 = bitcast i32* %Z to {}* ; <{}*> [#uses=1] + call void @llvm.dbg.declare({}* %2, metadata !12), !dbg !14 store i32 23, i32* %Z, !dbg !15 %tmp = load i32* %X, !dbg !16 ; <i32> [#uses=1] %tmp1 = load i32* %Y, !dbg !16 ; <i32> [#uses=1] @@ -854,7 +879,7 @@ entry: ret void, !dbg !18 } -declare void @llvm.dbg.declare({ }*, metadata) nounwind readnone +declare void @llvm.dbg.declare({}*, metadata) nounwind readnone !0 = metadata !{i32 459008, metadata !1, metadata !"X", metadata !3, i32 2, metadata !6}; [ DW_TAG_auto_variable ] @@ -896,7 +921,7 @@ declare void @llvm.dbg.declare({ }*, metadata) nounwind readnone@@ -931,7 +956,7 @@ call void @llvm.dbg.declare({ }* %0, metadata !0), !dbg !7-call void @llvm.dbg.declare({ }* %0, metadata !0), !dbg !7 +call void @llvm.dbg.declare({}* %0, metadata !0), !dbg !7@@ -948,7 +973,7 @@ call void @llvm.dbg.declare({ }* %2, metadata !12), !dbg !14-call void @llvm.dbg.declare({ }* %2, metadata !12), !dbg !14 +call void @llvm.dbg.declare({}* %2, metadata !12), !dbg !14
Here !14 indicates that Z is declaread at line number 5 and +
Here !14 indicates that Z is declared at line number 5 and column number 9 inside of lexical scope !13. The lexical scope itself resides inside of lexical scope !1 described above.
@@ -1012,10 +1037,10 @@ int main(int argc, char *argv[]) {... ;; -;; Define the compile unit for the source file "/Users/mine/sources/MySource.cpp". +;; Define the compile unit for the main source file "/Users/mine/sources/MySource.cpp". ;; -!3 = metadata !{ - i32 458769, ;; Tag +!2 = metadata !{ + i32 524305, ;; Tag i32 0, ;; Unused i32 4, ;; Language Id metadata !"MySource.cpp", @@ -1027,24 +1052,41 @@ int main(int argc, char *argv[]) { i32 0} ;; Runtime version ;; -;; Define the compile unit for the header file "/Users/mine/sources/MyHeader.h". +;; Define the file for the file "/Users/mine/sources/MySource.cpp". ;; !1 = metadata !{ - i32 458769, ;; Tag - i32 0, ;; Unused - i32 4, ;; Language Id - metadata !"MyHeader.h", + i32 524329, ;; Tag + metadata !"MySource.cpp", metadata !"/Users/mine/sources", - metadata !"4.2.1 (Based on Apple Inc. build 5649) (LLVM build 00)", - i1 false, ;; Main Compile Unit - i1 false, ;; Optimized compile unit - metadata !"", ;; Compiler flags - i32 0} ;; Runtime version + metadata !3 ;; Compile unit +} + +;; +;; Define the file for the file "/Users/mine/sources/Myheader.h" +;; +!3 = metadata !{ + i32 524329, ;; Tag + metadata !"Myheader.h" + metadata !"/Users/mine/sources", + metadata !3 ;; Compile unit +} ...
llvm::Instruction provides easy access to metadata attached with an +instruction. One can extract line number information encoded in LLVM IR +using Instruction::getMetadata() and +DILocation::getLineNumber(). +
+ if (MDNode *N = I->getMetadata("dbg")) { // Here I is an LLVM instruction + DILocation Loc(N); // DILocation is in DebugInfo.h + unsigned Line = Loc.getLineNumber(); + StringRef File = Loc.getFilename(); + StringRef Dir = Loc.getDirectory(); + } +
!2 = metadata !{ - i32 458788, ;; Tag + i32 524324, ;; Tag metadata !1, ;; Context metadata !"bool", ;; Name - metadata !1, ;; Compile Unit + metadata !1, ;; File i32 0, ;; Line number i64 8, ;; Size in Bits i64 8, ;; Align in Bits @@ -1214,10 +1256,10 @@ define i32 @main(i32 %argc, i8** %argv) {!2 = metadata !{ - i32 458788, ;; Tag + i32 524324, ;; Tag metadata !1, ;; Context metadata !"char", ;; Name - metadata !1, ;; Compile Unit + metadata !1, ;; File i32 0, ;; Line number i64 8, ;; Size in Bits i64 8, ;; Align in Bits @@ -1240,10 +1282,10 @@ define i32 @main(i32 %argc, i8** %argv) {!2 = metadata !{ - i32 458788, ;; Tag + i32 524324, ;; Tag metadata !1, ;; Context metadata !"unsigned char", - metadata !1, ;; Compile Unit + metadata !1, ;; File i32 0, ;; Line number i64 8, ;; Size in Bits i64 8, ;; Align in Bits @@ -1266,10 +1308,10 @@ define i32 @main(i32 %argc, i8** %argv) {!2 = metadata !{ - i32 458788, ;; Tag + i32 524324, ;; Tag metadata !1, ;; Context metadata !"short int", - metadata !1, ;; Compile Unit + metadata !1, ;; File i32 0, ;; Line number i64 16, ;; Size in Bits i64 16, ;; Align in Bits @@ -1292,10 +1334,10 @@ define i32 @main(i32 %argc, i8** %argv) {!2 = metadata !{ - i32 458788, ;; Tag + i32 524324, ;; Tag metadata !1, ;; Context metadata !"short unsigned int", - metadata !1, ;; Compile Unit + metadata !1, ;; File i32 0, ;; Line number i64 16, ;; Size in Bits i64 16, ;; Align in Bits @@ -1318,10 +1360,10 @@ define i32 @main(i32 %argc, i8** %argv) {!2 = metadata !{ - i32 458788, ;; Tag + i32 524324, ;; Tag metadata !1, ;; Context metadata !"int", ;; Name - metadata !1, ;; Compile Unit + metadata !1, ;; File i32 0, ;; Line number i64 32, ;; Size in Bits i64 32, ;; Align in Bits @@ -1343,10 +1385,10 @@ define i32 @main(i32 %argc, i8** %argv) {!2 = metadata !{ - i32 458788, ;; Tag + i32 524324, ;; Tag metadata !1, ;; Context metadata !"unsigned int", - metadata !1, ;; Compile Unit + metadata !1, ;; File i32 0, ;; Line number i64 32, ;; Size in Bits i64 32, ;; Align in Bits @@ -1369,10 +1411,10 @@ define i32 @main(i32 %argc, i8** %argv) {!2 = metadata !{ - i32 458788, ;; Tag + i32 524324, ;; Tag metadata !1, ;; Context metadata !"long long int", - metadata !1, ;; Compile Unit + metadata !1, ;; File i32 0, ;; Line number i64 64, ;; Size in Bits i64 64, ;; Align in Bits @@ -1395,10 +1437,10 @@ define i32 @main(i32 %argc, i8** %argv) {!2 = metadata !{ - i32 458788, ;; Tag + i32 524324, ;; Tag metadata !1, ;; Context metadata !"long long unsigned int", - metadata !1, ;; Compile Unit + metadata !1, ;; File i32 0, ;; Line number i64 64, ;; Size in Bits i64 64, ;; Align in Bits @@ -1421,10 +1463,10 @@ define i32 @main(i32 %argc, i8** %argv) {!2 = metadata !{ - i32 458788, ;; Tag + i32 524324, ;; Tag metadata !1, ;; Context metadata !"float", - metadata !1, ;; Compile Unit + metadata !1, ;; File i32 0, ;; Line number i64 32, ;; Size in Bits i64 32, ;; Align in Bits @@ -1447,10 +1489,10 @@ define i32 @main(i32 %argc, i8** %argv) {!2 = metadata !{ - i32 458788, ;; Tag + i32 524324, ;; Tag metadata !1, ;; Context metadata !"double",;; Name - metadata !1, ;; Compile Unit + metadata !1, ;; File i32 0, ;; Line number i64 64, ;; Size in Bits i64 64, ;; Align in Bits @@ -1486,10 +1528,10 @@ typedef const int *IntPtr; ;; Define the typedef "IntPtr". ;; !2 = metadata !{ - i32 458774, ;; Tag + i32 524310, ;; Tag metadata !1, ;; Context metadata !"IntPtr", ;; Name - metadata !3, ;; Compile unit + metadata !3, ;; File i32 0, ;; Line number i64 0, ;; Size in bits i64 0, ;; Align in bits @@ -1502,10 +1544,10 @@ typedef const int *IntPtr; ;; Define the pointer type. ;; !4 = metadata !{ - i32 458767, ;; Tag + i32 524303, ;; Tag metadata !1, ;; Context metadata !"", ;; Name - metadata !1, ;; Compile unit + metadata !1, ;; File i32 0, ;; Line number i64 64, ;; Size in bits i64 64, ;; Align in bits @@ -1517,10 +1559,10 @@ typedef const int *IntPtr; ;; Define the const type. ;; !5 = metadata !{ - i32 458790, ;; Tag + i32 524326, ;; Tag metadata !1, ;; Context metadata !"", ;; Name - metadata !1, ;; Compile unit + metadata !1, ;; File i32 0, ;; Line number i64 32, ;; Size in bits i64 32, ;; Align in bits @@ -1532,10 +1574,10 @@ typedef const int *IntPtr; ;; Define the int type. ;; !6 = metadata !{ - i32 458788, ;; Tag + i32 524324, ;; Tag metadata !1, ;; Context metadata !"int", ;; Name - metadata !1, ;; Compile unit + metadata !1, ;; File i32 0, ;; Line number i64 32, ;; Size in bits i64 32, ;; Align in bits @@ -1575,10 +1617,10 @@ struct Color { ;; Define basic type for unsigned int. ;; !5 = metadata !{ - i32 458788, ;; Tag + i32 524324, ;; Tag metadata !1, ;; Context metadata !"unsigned int", - metadata !1, ;; Compile Unit + metadata !1, ;; File i32 0, ;; Line number i64 32, ;; Size in Bits i64 32, ;; Align in Bits @@ -1590,7 +1632,7 @@ struct Color { ;; Define composite type for struct Color. ;; !2 = metadata !{ - i32 458771, ;; Tag + i32 524307, ;; Tag metadata !1, ;; Context metadata !"Color", ;; Name metadata !1, ;; Compile unit @@ -1608,10 +1650,10 @@ struct Color { ;; Define the Red field. ;; !4 = metadata !{ - i32 458765, ;; Tag + i32 524301, ;; Tag metadata !1, ;; Context metadata !"Red", ;; Name - metadata !1, ;; Compile Unit + metadata !1, ;; File i32 2, ;; Line number i64 32, ;; Size in bits i64 32, ;; Align in bits @@ -1624,10 +1666,10 @@ struct Color { ;; Define the Green field. ;; !6 = metadata !{ - i32 458765, ;; Tag + i32 524301, ;; Tag metadata !1, ;; Context metadata !"Green", ;; Name - metadata !1, ;; Compile Unit + metadata !1, ;; File i32 3, ;; Line number i64 32, ;; Size in bits i64 32, ;; Align in bits @@ -1640,10 +1682,10 @@ struct Color { ;; Define the Blue field. ;; !7 = metadata !{ - i32 458765, ;; Tag + i32 524301, ;; Tag metadata !1, ;; Context metadata !"Blue", ;; Name - metadata !1, ;; Compile Unit + metadata !1, ;; File i32 4, ;; Line number i64 32, ;; Size in bits i64 32, ;; Align in bits @@ -1688,10 +1730,10 @@ enum Trees { ;; Define composite type for enum Trees ;; !2 = metadata !{ - i32 458756, ;; Tag + i32 524292, ;; Tag metadata !1, ;; Context metadata !"Trees", ;; Name - metadata !1, ;; Compile unit + metadata !1, ;; File i32 1, ;; Line number i64 32, ;; Size in bits i64 32, ;; Align in bits @@ -1710,17 +1752,17 @@ enum Trees { ;; ;; Define Spruce enumerator. ;; -!4 = metadata !{i32 458792, metadata !"Spruce", i64 100} +!4 = metadata !{i32 524328, metadata !"Spruce", i64 100} ;; ;; Define Oak enumerator. ;; -!5 = metadata !{i32 458792, metadata !"Oak", i64 200} +!5 = metadata !{i32 524328, metadata !"Oak", i64 200} ;; ;; Define Maple enumerator. ;; -!6 = metadata !{i32 458792, metadata !"Maple", i64 300} +!6 = metadata !{i32 524328, metadata !"Maple", i64 300}