blob: 93c9aeea3ce1a0d613b9237f752b22ded53d8c5a [file] [log] [blame]
Daniel Dunbar3845f862008-10-31 03:54:29 +00001//===--- CGDebugInfo.h - DebugInfo for LLVM CodeGen -------------*- C++ -*-===//
Sanjiv Guptae8b9f5b2008-05-08 08:54:20 +00002//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
Mike Stump1eb44332009-09-09 15:08:12 +000010// This is the source level debug info generator for llvm translation.
Sanjiv Guptae8b9f5b2008-05-08 08:54:20 +000011//
12//===----------------------------------------------------------------------===//
13
14#ifndef CLANG_CODEGEN_CGDEBUGINFO_H
15#define CLANG_CODEGEN_CGDEBUGINFO_H
16
Sanjiv Gupta1c6a38b2008-05-25 05:15:42 +000017#include "clang/AST/Type.h"
Mike Stumpb1a6e682009-09-30 02:43:10 +000018#include "clang/AST/Expr.h"
Sanjiv Guptae8b9f5b2008-05-08 08:54:20 +000019#include "clang/Basic/SourceLocation.h"
Chris Lattner9c85ba32008-11-10 06:08:34 +000020#include "llvm/ADT/DenseMap.h"
21#include "llvm/Analysis/DebugInfo.h"
Daniel Dunbar23e81ba2009-09-19 19:27:24 +000022#include "llvm/Support/ValueHandle.h"
Devang Patel9c6c3a02010-01-14 00:36:21 +000023#include "llvm/Support/Allocator.h"
Sanjiv Guptae8b9f5b2008-05-08 08:54:20 +000024
Daniel Dunbar45d196b2008-11-01 01:53:16 +000025#include "CGBuilder.h"
Sanjiv Guptae8b9f5b2008-05-08 08:54:20 +000026
Daniel Dunbar23e81ba2009-09-19 19:27:24 +000027namespace llvm {
28 class MDNode;
29}
30
Sanjiv Guptae8b9f5b2008-05-08 08:54:20 +000031namespace clang {
Sanjiv Guptacc9b1632008-05-30 10:30:31 +000032 class VarDecl;
Devang Patel9ca36b62009-02-26 21:10:26 +000033 class ObjCInterfaceDecl;
Daniel Dunbar45d196b2008-11-01 01:53:16 +000034
Sanjiv Guptae8b9f5b2008-05-08 08:54:20 +000035namespace CodeGen {
36 class CodeGenModule;
Mike Stumpb1a6e682009-09-30 02:43:10 +000037 class CodeGenFunction;
Devang Patel9c6c3a02010-01-14 00:36:21 +000038 class GlobalDecl;
Sanjiv Guptae8b9f5b2008-05-08 08:54:20 +000039
Mike Stump1eb44332009-09-09 15:08:12 +000040/// CGDebugInfo - This class gathers all debug information during compilation
41/// and is responsible for emitting to llvm globals or pass directly to
Sanjiv Gupta1c6a38b2008-05-25 05:15:42 +000042/// the backend.
Sanjiv Guptae8b9f5b2008-05-08 08:54:20 +000043class CGDebugInfo {
Anders Carlsson20f12a22009-12-06 18:00:51 +000044 CodeGenModule &CGM;
Chris Lattner9c85ba32008-11-10 06:08:34 +000045 llvm::DIFactory DebugFactory;
Devang Patel17800552010-03-09 00:44:50 +000046 llvm::DICompileUnit TheCU;
Chris Lattner9c85ba32008-11-10 06:08:34 +000047 SourceLocation CurLoc, PrevLoc;
Devang Patel4ce3f202010-01-28 18:11:52 +000048 llvm::DIType VTablePtrType;
Devang Patel7573f8b2010-03-09 21:32:27 +000049 /// FwdDeclCount - This counter is used to ensure unique names for forward
50 /// record decls.
51 unsigned FwdDeclCount;
Devang Patel17800552010-03-09 00:44:50 +000052
Sanjiv Gupta1c6a38b2008-05-25 05:15:42 +000053 /// TypeCache - Cache of previously constructed Types.
Ted Kremenek590838b2010-03-29 18:29:57 +000054 llvm::DenseMap<void *, llvm::WeakVH> TypeCache;
Mike Stump1eb44332009-09-09 15:08:12 +000055
Mike Stump9bc093c2009-05-14 02:03:51 +000056 bool BlockLiteralGenericSet;
57 llvm::DIType BlockLiteralGeneric;
58
Devang Patel8fae0602009-11-13 19:10:24 +000059 std::vector<llvm::TrackingVH<llvm::MDNode> > RegionStack;
Devang Patel3dd96a12010-01-29 18:11:03 +000060 llvm::DenseMap<const Decl *, llvm::WeakVH> RegionMap;
Devang Patel5a6fbcf2010-07-22 22:29:16 +000061 // FnBeginRegionCount - Keep track of RegionStack counter at the beginning
62 // of a function. This is used to pop unbalanced regions at the end of a
63 // function.
64 std::vector<unsigned> FnBeginRegionCount;
65
66 /// LineDirectiveFiles - This stack is used to keep track of
67 /// scopes introduced by #line directives.
68 std::vector<const char *> LineDirectiveFiles;
Eli Friedman3f2af102008-05-22 01:40:10 +000069
Devang Patel89f05f82010-01-28 18:21:00 +000070 /// DebugInfoNames - This is a storage for names that are
Devang Patel9c6c3a02010-01-14 00:36:21 +000071 /// constructed on demand. For example, C++ destructors, C++ operators etc..
Devang Patel89f05f82010-01-28 18:21:00 +000072 llvm::BumpPtrAllocator DebugInfoNames;
Devang Patelac4d13c2010-07-27 15:17:16 +000073 llvm::StringRef CWDName;
Devang Patel9c6c3a02010-01-14 00:36:21 +000074
Ted Kremenek9c250392010-03-30 00:27:51 +000075 llvm::DenseMap<const char *, llvm::WeakVH> DIFileCache;
Devang Patel4125fd22010-01-19 01:54:44 +000076 llvm::DenseMap<const FunctionDecl *, llvm::WeakVH> SPCache;
Devang Patelabb485f2010-02-01 19:16:32 +000077 llvm::DenseMap<const NamespaceDecl *, llvm::WeakVH> NameSpaceCache;
Devang Patel4125fd22010-01-19 01:54:44 +000078
Sanjiv Gupta1c6a38b2008-05-25 05:15:42 +000079 /// Helper functions for getOrCreateType.
Devang Patel17800552010-03-09 00:44:50 +000080 llvm::DIType CreateType(const BuiltinType *Ty, llvm::DIFile F);
81 llvm::DIType CreateType(const ComplexType *Ty, llvm::DIFile F);
82 llvm::DIType CreateQualifiedType(QualType Ty, llvm::DIFile F);
83 llvm::DIType CreateType(const TypedefType *Ty, llvm::DIFile F);
Mike Stump1eb44332009-09-09 15:08:12 +000084 llvm::DIType CreateType(const ObjCObjectPointerType *Ty,
Devang Patel17800552010-03-09 00:44:50 +000085 llvm::DIFile F);
86 llvm::DIType CreateType(const PointerType *Ty, llvm::DIFile F);
87 llvm::DIType CreateType(const BlockPointerType *Ty, llvm::DIFile F);
88 llvm::DIType CreateType(const FunctionType *Ty, llvm::DIFile F);
89 llvm::DIType CreateType(const TagType *Ty, llvm::DIFile F);
90 llvm::DIType CreateType(const RecordType *Ty, llvm::DIFile F);
91 llvm::DIType CreateType(const ObjCInterfaceType *Ty, llvm::DIFile F);
John McCallc12c5bb2010-05-15 11:32:37 +000092 llvm::DIType CreateType(const ObjCObjectType *Ty, llvm::DIFile F);
Devang Patel17800552010-03-09 00:44:50 +000093 llvm::DIType CreateType(const EnumType *Ty, llvm::DIFile F);
94 llvm::DIType CreateType(const VectorType *Ty, llvm::DIFile F);
95 llvm::DIType CreateType(const ArrayType *Ty, llvm::DIFile F);
96 llvm::DIType CreateType(const LValueReferenceType *Ty, llvm::DIFile F);
97 llvm::DIType CreateType(const MemberPointerType *Ty, llvm::DIFile F);
Devang Patela6da1922010-01-28 00:28:01 +000098 llvm::DIType getOrCreateMethodType(const CXXMethodDecl *Method,
Devang Patel17800552010-03-09 00:44:50 +000099 llvm::DIFile F);
100 llvm::DIType getOrCreateVTablePtrType(llvm::DIFile F);
Devang Patelabb485f2010-02-01 19:16:32 +0000101 llvm::DINameSpace getOrCreateNameSpace(const NamespaceDecl *N,
102 llvm::DIDescriptor Unit);
103
Anders Carlssona031b352009-11-06 19:19:55 +0000104 llvm::DIType CreatePointerLikeType(unsigned Tag,
105 const Type *Ty, QualType PointeeTy,
Devang Patel17800552010-03-09 00:44:50 +0000106 llvm::DIFile F);
Anders Carlssond6f9a0d2010-01-26 04:49:33 +0000107
Anders Carlsson4433f1c2010-01-26 05:19:50 +0000108 llvm::DISubprogram CreateCXXMemberFunction(const CXXMethodDecl *Method,
Devang Patel17800552010-03-09 00:44:50 +0000109 llvm::DIFile F,
Anders Carlssond6f9a0d2010-01-26 04:49:33 +0000110 llvm::DICompositeType &RecordTy);
111
Devang Patel4125fd22010-01-19 01:54:44 +0000112 void CollectCXXMemberFunctions(const CXXRecordDecl *Decl,
Devang Patel17800552010-03-09 00:44:50 +0000113 llvm::DIFile F,
Devang Patel4125fd22010-01-19 01:54:44 +0000114 llvm::SmallVectorImpl<llvm::DIDescriptor> &E,
115 llvm::DICompositeType &T);
Devang Patela245c5b2010-01-25 23:32:18 +0000116 void CollectCXXBases(const CXXRecordDecl *Decl,
Devang Patel17800552010-03-09 00:44:50 +0000117 llvm::DIFile F,
Devang Patela245c5b2010-01-25 23:32:18 +0000118 llvm::SmallVectorImpl<llvm::DIDescriptor> &EltTys,
119 llvm::DICompositeType &RecordTy);
120
121
Devang Patel17800552010-03-09 00:44:50 +0000122 void CollectRecordFields(const RecordDecl *Decl, llvm::DIFile F,
Devang Patel428deb52010-01-19 00:00:59 +0000123 llvm::SmallVectorImpl<llvm::DIDescriptor> &E);
Devang Patel4ce3f202010-01-28 18:11:52 +0000124
Anders Carlsson046c2942010-04-17 20:15:18 +0000125 void CollectVTableInfo(const CXXRecordDecl *Decl,
Devang Patel17800552010-03-09 00:44:50 +0000126 llvm::DIFile F,
Devang Patel4ce3f202010-01-28 18:11:52 +0000127 llvm::SmallVectorImpl<llvm::DIDescriptor> &EltTys);
128
Sanjiv Guptae8b9f5b2008-05-08 08:54:20 +0000129public:
Anders Carlsson20f12a22009-12-06 18:00:51 +0000130 CGDebugInfo(CodeGenModule &CGM);
Sanjiv Guptae8b9f5b2008-05-08 08:54:20 +0000131 ~CGDebugInfo();
132
Daniel Dunbar66031a52008-10-17 16:15:48 +0000133 /// setLocation - Update the current source location. If \arg loc is
134 /// invalid it is ignored.
Chris Lattner9c85ba32008-11-10 06:08:34 +0000135 void setLocation(SourceLocation Loc);
Sanjiv Guptae8b9f5b2008-05-08 08:54:20 +0000136
137 /// EmitStopPoint - Emit a call to llvm.dbg.stoppoint to indicate a change of
138 /// source line.
Devang Patel4d939e62010-07-20 22:20:10 +0000139 void EmitStopPoint(CGBuilderTy &Builder);
Sanjiv Gupta1c6a38b2008-05-25 05:15:42 +0000140
141 /// EmitFunctionStart - Emit a call to llvm.dbg.function.start to indicate
Daniel Dunbar2284ac92008-10-18 18:22:23 +0000142 /// start of a new function.
Devang Patel9c6c3a02010-01-14 00:36:21 +0000143 void EmitFunctionStart(GlobalDecl GD, QualType FnType,
Daniel Dunbar45d196b2008-11-01 01:53:16 +0000144 llvm::Function *Fn, CGBuilderTy &Builder);
Mike Stump1eb44332009-09-09 15:08:12 +0000145
Devang Patel5a6fbcf2010-07-22 22:29:16 +0000146 /// EmitFunctionEnd - Constructs the debug code for exiting a function.
147 void EmitFunctionEnd(CGBuilderTy &Builder);
148
149 /// UpdateLineDirectiveRegion - Update region stack only if #line directive
150 /// has introduced scope change.
151 void UpdateLineDirectiveRegion(CGBuilderTy &Builder);
152
Sanjiv Gupta1c6a38b2008-05-25 05:15:42 +0000153 /// EmitRegionStart - Emit a call to llvm.dbg.region.start to indicate start
Mike Stump1eb44332009-09-09 15:08:12 +0000154 /// of a new block.
Devang Patel4d939e62010-07-20 22:20:10 +0000155 void EmitRegionStart(CGBuilderTy &Builder);
Mike Stump1eb44332009-09-09 15:08:12 +0000156
157 /// EmitRegionEnd - Emit call to llvm.dbg.region.end to indicate end of a
Sanjiv Guptae8b9f5b2008-05-08 08:54:20 +0000158 /// block.
Devang Patel4d939e62010-07-20 22:20:10 +0000159 void EmitRegionEnd(CGBuilderTy &Builder);
Sanjiv Guptacc9b1632008-05-30 10:30:31 +0000160
Chris Lattner9c85ba32008-11-10 06:08:34 +0000161 /// EmitDeclareOfAutoVariable - Emit call to llvm.dbg.declare for an automatic
162 /// variable declaration.
163 void EmitDeclareOfAutoVariable(const VarDecl *Decl, llvm::Value *AI,
164 CGBuilderTy &Builder);
Sanjiv Gupta686226b2008-06-05 08:59:10 +0000165
Mike Stumpb1a6e682009-09-30 02:43:10 +0000166 /// EmitDeclareOfBlockDeclRefVariable - Emit call to llvm.dbg.declare for an
167 /// imported variable declaration in a block.
168 void EmitDeclareOfBlockDeclRefVariable(const BlockDeclRefExpr *BDRE,
169 llvm::Value *AI,
170 CGBuilderTy &Builder,
171 CodeGenFunction *CGF);
172
Chris Lattner9c85ba32008-11-10 06:08:34 +0000173 /// EmitDeclareOfArgVariable - Emit call to llvm.dbg.declare for an argument
174 /// variable declaration.
175 void EmitDeclareOfArgVariable(const VarDecl *Decl, llvm::Value *AI,
176 CGBuilderTy &Builder);
Mike Stump1eb44332009-09-09 15:08:12 +0000177
Sanjiv Gupta686226b2008-06-05 08:59:10 +0000178 /// EmitGlobalVariable - Emit information about a global variable.
Chris Lattner9c85ba32008-11-10 06:08:34 +0000179 void EmitGlobalVariable(llvm::GlobalVariable *GV, const VarDecl *Decl);
Devang Patel9ca36b62009-02-26 21:10:26 +0000180
181 /// EmitGlobalVariable - Emit information about an objective-c interface.
182 void EmitGlobalVariable(llvm::GlobalVariable *GV, ObjCInterfaceDecl *Decl);
Mike Stump1eb44332009-09-09 15:08:12 +0000183
Devang Patel25c2c8f2010-08-10 17:53:33 +0000184 /// EmitGlobalVariable - Emit global variable's debug info.
185 void EmitGlobalVariable(const ValueDecl *VD, llvm::ConstantInt *Init,
Devang Patel8d308382010-08-10 07:24:25 +0000186 CGBuilderTy &Builder);
187
Chris Lattner86cd8af2008-11-03 09:11:11 +0000188private:
Chris Lattner9c85ba32008-11-10 06:08:34 +0000189 /// EmitDeclare - Emit call to llvm.dbg.declare for a variable declaration.
190 void EmitDeclare(const VarDecl *decl, unsigned Tag, llvm::Value *AI,
191 CGBuilderTy &Builder);
Mike Stump1eb44332009-09-09 15:08:12 +0000192
Mike Stumpb1a6e682009-09-30 02:43:10 +0000193 /// EmitDeclare - Emit call to llvm.dbg.declare for a variable declaration.
194 void EmitDeclare(const BlockDeclRefExpr *BDRE, unsigned Tag, llvm::Value *AI,
195 CGBuilderTy &Builder, CodeGenFunction *CGF);
Mike Stump1eb44332009-09-09 15:08:12 +0000196
Devang Patel809b9bb2010-02-10 18:49:08 +0000197 // EmitTypeForVarWithBlocksAttr - Build up structure info for the byref.
198 // See BuildByRefType.
199 llvm::DIType EmitTypeForVarWithBlocksAttr(const ValueDecl *VD,
200 uint64_t *OffSet);
201
Devang Patel33583052010-01-28 23:15:27 +0000202 /// getContextDescriptor - Get context info for the decl.
Devang Patel3dd96a12010-01-29 18:11:03 +0000203 llvm::DIDescriptor getContextDescriptor(const Decl *Decl,
Devang Patel33583052010-01-28 23:15:27 +0000204 llvm::DIDescriptor &CU);
Devang Patel979ec2e2009-10-06 00:35:31 +0000205
Devang Patelac4d13c2010-07-27 15:17:16 +0000206 /// getCurrentDirname - Return current directory name.
207 llvm::StringRef getCurrentDirname();
208
Devang Patel17800552010-03-09 00:44:50 +0000209 /// CreateCompileUnit - Create new compile unit.
210 void CreateCompileUnit();
211
212 /// getOrCreateFile - Get the file debug info descriptor for the input
213 /// location.
214 llvm::DIFile getOrCreateFile(SourceLocation Loc);
Sanjiv Gupta1c6a38b2008-05-25 05:15:42 +0000215
216 /// getOrCreateType - Get the type from the cache or create a new type if
217 /// necessary.
Devang Patel17800552010-03-09 00:44:50 +0000218 llvm::DIType getOrCreateType(QualType Ty, llvm::DIFile F);
Daniel Dunbar03faac32009-09-19 19:27:14 +0000219
220 /// CreateTypeNode - Create type metadata for a source language type.
Devang Patel17800552010-03-09 00:44:50 +0000221 llvm::DIType CreateTypeNode(QualType Ty, llvm::DIFile F);
Devang Patel9c6c3a02010-01-14 00:36:21 +0000222
Benjamin Kramerd3651cc2010-04-24 20:26:20 +0000223 /// CreateMemberType - Create new member and increase Offset by FType's size.
Benjamin Kramer48c70f62010-04-24 20:19:58 +0000224 llvm::DIType CreateMemberType(llvm::DIFile Unit, QualType FType,
225 llvm::StringRef Name, uint64_t *Offset);
226
Devang Patel9c6c3a02010-01-14 00:36:21 +0000227 /// getFunctionName - Get function name for the given FunctionDecl. If the
228 /// name is constructred on demand (e.g. C++ destructor) then the name
229 /// is stored on the side.
230 llvm::StringRef getFunctionName(const FunctionDecl *FD);
Devang Patel4ce3f202010-01-28 18:11:52 +0000231
Devang Patel700a1cb2010-07-20 20:24:18 +0000232 /// getClassName - Get class name including template argument list.
233 llvm::StringRef getClassName(RecordDecl *RD);
234
Anders Carlsson046c2942010-04-17 20:15:18 +0000235 /// getVTableName - Get vtable name for the given Class.
236 llvm::StringRef getVTableName(const CXXRecordDecl *Decl);
Devang Patel4ce3f202010-01-28 18:11:52 +0000237
Devang Patel8ab870d2010-05-12 23:46:38 +0000238 /// getLineNumber - Get line number for the location. If location is invalid
239 /// then use current location.
240 unsigned getLineNumber(SourceLocation Loc);
241
242 /// getColumnNumber - Get column number for the location. If location is
243 /// invalid then use current location.
244 unsigned getColumnNumber(SourceLocation Loc);
Sanjiv Guptae8b9f5b2008-05-08 08:54:20 +0000245};
246} // namespace CodeGen
247} // namespace clang
248
Devang Patelbbd9fa42009-10-06 18:36:08 +0000249
Sanjiv Guptae8b9f5b2008-05-08 08:54:20 +0000250#endif