blob: f92b21d5e63657c40b4dbcb03ae7465cb7c44ce2 [file] [log] [blame]
Guy Benyei11169dd2012-12-18 14:30:41 +00001//===--- CGDebugInfo.cpp - Emit Debug Information for a Module ------------===//
2//
Chandler Carruth2946cd72019-01-19 08:50:56 +00003// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
Guy Benyei11169dd2012-12-18 14:30:41 +00006//
7//===----------------------------------------------------------------------===//
8//
9// This coordinates the debug information generation while generating code.
10//
11//===----------------------------------------------------------------------===//
12
13#include "CGDebugInfo.h"
14#include "CGBlocks.h"
David Blaikie38079fd2013-05-10 21:53:14 +000015#include "CGCXXABI.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000016#include "CGObjCRuntime.h"
Bob Haarmandff36732016-10-25 22:19:32 +000017#include "CGRecordLayout.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000018#include "CodeGenFunction.h"
19#include "CodeGenModule.h"
John McCallde0fe072017-08-15 21:42:52 +000020#include "ConstantEmitter.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000021#include "clang/AST/ASTContext.h"
Reid Kleckner98031782019-12-09 16:11:56 -080022#include "clang/AST/Attr.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000023#include "clang/AST/DeclFriend.h"
24#include "clang/AST/DeclObjC.h"
25#include "clang/AST/DeclTemplate.h"
26#include "clang/AST/Expr.h"
27#include "clang/AST/RecordLayout.h"
Richard Trieu63688182018-12-11 03:18:39 +000028#include "clang/Basic/CodeGenOptions.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000029#include "clang/Basic/FileManager.h"
30#include "clang/Basic/SourceManager.h"
31#include "clang/Basic/Version.h"
Taewook Oh0fb5b782017-08-16 19:36:24 +000032#include "clang/Frontend/FrontendOptions.h"
Adrian Prantlc4bb47e2015-06-30 17:39:51 +000033#include "clang/Lex/HeaderSearchOptions.h"
Adrian Prantl9402cef2015-09-20 16:51:35 +000034#include "clang/Lex/ModuleMap.h"
Adrian Prantlc4bb47e2015-06-30 17:39:51 +000035#include "clang/Lex/PreprocessorOptions.h"
Bob Haarmandff36732016-10-25 22:19:32 +000036#include "llvm/ADT/DenseSet.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000037#include "llvm/ADT/SmallVector.h"
38#include "llvm/ADT/StringExtras.h"
Chandler Carruthffd55512013-01-02 11:45:17 +000039#include "llvm/IR/Constants.h"
40#include "llvm/IR/DataLayout.h"
41#include "llvm/IR/DerivedTypes.h"
42#include "llvm/IR/Instructions.h"
43#include "llvm/IR/Intrinsics.h"
Matthew Voss20165362018-10-03 18:45:04 +000044#include "llvm/IR/Metadata.h"
Chandler Carruthffd55512013-01-02 11:45:17 +000045#include "llvm/IR/Module.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000046#include "llvm/Support/FileSystem.h"
Amjad Aboude2aab8c2016-12-25 10:12:27 +000047#include "llvm/Support/MD5.h"
Adrian Prantl0630eb72013-12-18 21:48:18 +000048#include "llvm/Support/Path.h"
Luboš Luňák4f2104c2019-11-02 16:39:59 +010049#include "llvm/Support/TimeProfiler.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000050using namespace clang;
51using namespace clang::CodeGen;
52
Victor Leschuka7ece032016-10-20 00:13:19 +000053static uint32_t getTypeAlignIfRequired(const Type *Ty, const ASTContext &Ctx) {
54 auto TI = Ctx.getTypeInfo(Ty);
55 return TI.AlignIsRequired ? TI.Align : 0;
56}
57
58static uint32_t getTypeAlignIfRequired(QualType Ty, const ASTContext &Ctx) {
59 return getTypeAlignIfRequired(Ty.getTypePtr(), Ctx);
60}
61
62static uint32_t getDeclAlignIfRequired(const Decl *D, const ASTContext &Ctx) {
63 return D->hasAttr<AlignedAttr>() ? D->getMaxAlignment() : 0;
64}
65
Guy Benyei11169dd2012-12-18 14:30:41 +000066CGDebugInfo::CGDebugInfo(CodeGenModule &CGM)
Eric Christopher324bbbd2013-07-14 21:12:44 +000067 : CGM(CGM), DebugKind(CGM.getCodeGenOpts().getDebugInfo()),
Adrian Prantl6b21ab22015-08-27 19:46:20 +000068 DebugTypeExtRefs(CGM.getCodeGenOpts().DebugTypeExtRefs),
Eric Christopher324bbbd2013-07-14 21:12:44 +000069 DBuilder(CGM.getModule()) {
Saleem Abdulrasool436256a2015-10-12 20:21:08 +000070 for (const auto &KV : CGM.getCodeGenOpts().DebugPrefixMap)
71 DebugPrefixMap[KV.first] = KV.second;
Guy Benyei11169dd2012-12-18 14:30:41 +000072 CreateCompileUnit();
73}
74
75CGDebugInfo::~CGDebugInfo() {
76 assert(LexicalBlockStack.empty() &&
77 "Region stack mismatch, stack not empty!");
78}
79
David Blaikie66e41972015-01-14 07:38:27 +000080ApplyDebugLocation::ApplyDebugLocation(CodeGenFunction &CGF,
Calixte Denizetfcd661d2018-09-24 18:24:18 +000081 SourceLocation TemporaryLocation)
David Blaikied7057d92015-08-12 23:49:57 +000082 : CGF(&CGF) {
Calixte Denizetfcd661d2018-09-24 18:24:18 +000083 init(TemporaryLocation);
David Blaikie9b479662015-01-25 01:19:10 +000084}
85
Adrian Prantl39428e72015-02-03 18:40:42 +000086ApplyDebugLocation::ApplyDebugLocation(CodeGenFunction &CGF,
Adrian Prantl95b24e92015-02-03 20:00:54 +000087 bool DefaultToEmpty,
Calixte Denizetfcd661d2018-09-24 18:24:18 +000088 SourceLocation TemporaryLocation)
David Blaikied7057d92015-08-12 23:49:57 +000089 : CGF(&CGF) {
Calixte Denizetfcd661d2018-09-24 18:24:18 +000090 init(TemporaryLocation, DefaultToEmpty);
Adrian Prantl39428e72015-02-03 18:40:42 +000091}
92
93void ApplyDebugLocation::init(SourceLocation TemporaryLocation,
Calixte Denizetfcd661d2018-09-24 18:24:18 +000094 bool DefaultToEmpty) {
David Blaikied7057d92015-08-12 23:49:57 +000095 auto *DI = CGF->getDebugInfo();
96 if (!DI) {
97 CGF = nullptr;
98 return;
David Blaikie66e41972015-01-14 07:38:27 +000099 }
David Blaikied7057d92015-08-12 23:49:57 +0000100
101 OriginalLocation = CGF->Builder.getCurrentDebugLocation();
Bob Haarmanc6c9b8f2017-09-11 22:11:57 +0000102
103 if (OriginalLocation && !DI->CGM.getExpressionLocationsEnabled())
104 return;
105
David Blaikied7057d92015-08-12 23:49:57 +0000106 if (TemporaryLocation.isValid()) {
Calixte Denizetfcd661d2018-09-24 18:24:18 +0000107 DI->EmitLocation(CGF->Builder, TemporaryLocation);
David Blaikied7057d92015-08-12 23:49:57 +0000108 return;
109 }
110
111 if (DefaultToEmpty) {
112 CGF->Builder.SetCurrentDebugLocation(llvm::DebugLoc());
113 return;
114 }
115
116 // Construct a location that has a valid scope, but no line info.
117 assert(!DI->LexicalBlockStack.empty());
Adrian Prantlb7acfc02017-02-27 21:30:05 +0000118 CGF->Builder.SetCurrentDebugLocation(llvm::DebugLoc::get(
119 0, 0, DI->LexicalBlockStack.back(), DI->getInlinedAt()));
Adrian Prantl2e0637f2013-07-18 00:28:02 +0000120}
121
David Blaikie9b479662015-01-25 01:19:10 +0000122ApplyDebugLocation::ApplyDebugLocation(CodeGenFunction &CGF, const Expr *E)
David Blaikied7057d92015-08-12 23:49:57 +0000123 : CGF(&CGF) {
David Blaikie9b479662015-01-25 01:19:10 +0000124 init(E->getExprLoc());
125}
126
David Blaikie66e41972015-01-14 07:38:27 +0000127ApplyDebugLocation::ApplyDebugLocation(CodeGenFunction &CGF, llvm::DebugLoc Loc)
David Blaikied7057d92015-08-12 23:49:57 +0000128 : CGF(&CGF) {
129 if (!CGF.getDebugInfo()) {
130 this->CGF = nullptr;
131 return;
David Blaikie66e41972015-01-14 07:38:27 +0000132 }
David Blaikied7057d92015-08-12 23:49:57 +0000133 OriginalLocation = CGF.Builder.getCurrentDebugLocation();
134 if (Loc)
135 CGF.Builder.SetCurrentDebugLocation(std::move(Loc));
David Blaikie66e41972015-01-14 07:38:27 +0000136}
137
138ApplyDebugLocation::~ApplyDebugLocation() {
139 // Query CGF so the location isn't overwritten when location updates are
140 // temporarily disabled (for C++ default function arguments)
David Blaikied7057d92015-08-12 23:49:57 +0000141 if (CGF)
142 CGF->Builder.SetCurrentDebugLocation(std::move(OriginalLocation));
David Blaikie66e41972015-01-14 07:38:27 +0000143}
144
Adrian Prantlb7acfc02017-02-27 21:30:05 +0000145ApplyInlineDebugLocation::ApplyInlineDebugLocation(CodeGenFunction &CGF,
146 GlobalDecl InlinedFn)
147 : CGF(&CGF) {
148 if (!CGF.getDebugInfo()) {
149 this->CGF = nullptr;
150 return;
151 }
152 auto &DI = *CGF.getDebugInfo();
153 SavedLocation = DI.getLocation();
154 assert((DI.getInlinedAt() ==
155 CGF.Builder.getCurrentDebugLocation()->getInlinedAt()) &&
156 "CGDebugInfo and IRBuilder are out of sync");
157
158 DI.EmitInlineFunctionStart(CGF.Builder, InlinedFn);
159}
160
161ApplyInlineDebugLocation::~ApplyInlineDebugLocation() {
162 if (!CGF)
163 return;
164 auto &DI = *CGF->getDebugInfo();
165 DI.EmitInlineFunctionEnd(CGF->Builder);
166 DI.EmitLocation(CGF->Builder, SavedLocation);
167}
168
Guy Benyei11169dd2012-12-18 14:30:41 +0000169void CGDebugInfo::setLocation(SourceLocation Loc) {
170 // If the new location isn't valid return.
Eric Christophere7b87e52014-10-26 23:40:33 +0000171 if (Loc.isInvalid())
172 return;
Guy Benyei11169dd2012-12-18 14:30:41 +0000173
174 CurLoc = CGM.getContext().getSourceManager().getExpansionLoc(Loc);
175
176 // If we've changed files in the middle of a lexical scope go ahead
177 // and create a new lexical scope with file node if it's different
178 // from the one in the scope.
Eric Christophere7b87e52014-10-26 23:40:33 +0000179 if (LexicalBlockStack.empty())
180 return;
Guy Benyei11169dd2012-12-18 14:30:41 +0000181
182 SourceManager &SM = CGM.getContext().getSourceManager();
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +0000183 auto *Scope = cast<llvm::DIScope>(LexicalBlockStack.back());
Guy Benyei11169dd2012-12-18 14:30:41 +0000184 PresumedLoc PCLoc = SM.getPresumedLoc(CurLoc);
Adrian Prantl212c1042018-12-06 18:44:50 +0000185 if (PCLoc.isInvalid() || Scope->getFile() == getOrCreateFile(CurLoc))
Guy Benyei11169dd2012-12-18 14:30:41 +0000186 return;
187
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +0000188 if (auto *LBF = dyn_cast<llvm::DILexicalBlockFile>(Scope)) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000189 LexicalBlockStack.pop_back();
Duncan P. N. Exon Smithd899f6e2015-04-18 00:07:30 +0000190 LexicalBlockStack.emplace_back(DBuilder.createLexicalBlockFile(
191 LBF->getScope(), getOrCreateFile(CurLoc)));
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +0000192 } else if (isa<llvm::DILexicalBlock>(Scope) ||
193 isa<llvm::DISubprogram>(Scope)) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000194 LexicalBlockStack.pop_back();
Duncan P. N. Exon Smithd899f6e2015-04-18 00:07:30 +0000195 LexicalBlockStack.emplace_back(
196 DBuilder.createLexicalBlockFile(Scope, getOrCreateFile(CurLoc)));
Guy Benyei11169dd2012-12-18 14:30:41 +0000197 }
198}
199
Adrian Prantl6ec370a2015-09-10 18:39:45 +0000200llvm::DIScope *CGDebugInfo::getDeclContextDescriptor(const Decl *D) {
Adrian Prantl5c8bd882015-09-11 17:23:08 +0000201 llvm::DIScope *Mod = getParentModuleOrNull(D);
202 return getContextDescriptor(cast<Decl>(D->getDeclContext()),
203 Mod ? Mod : TheCU);
Adrian Prantl6ec370a2015-09-10 18:39:45 +0000204}
205
206llvm::DIScope *CGDebugInfo::getContextDescriptor(const Decl *Context,
207 llvm::DIScope *Default) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000208 if (!Context)
Adrian Prantl6ec370a2015-09-10 18:39:45 +0000209 return Default;
Guy Benyei11169dd2012-12-18 14:30:41 +0000210
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +0000211 auto I = RegionMap.find(Context);
Guy Benyei11169dd2012-12-18 14:30:41 +0000212 if (I != RegionMap.end()) {
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +0000213 llvm::Metadata *V = I->second;
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +0000214 return dyn_cast_or_null<llvm::DIScope>(V);
Guy Benyei11169dd2012-12-18 14:30:41 +0000215 }
216
217 // Check namespace.
Adrian Prantlddb8e062017-05-12 16:23:53 +0000218 if (const auto *NSDecl = dyn_cast<NamespaceDecl>(Context))
219 return getOrCreateNamespace(NSDecl);
Guy Benyei11169dd2012-12-18 14:30:41 +0000220
David Majnemer58ed0f32016-07-17 00:39:12 +0000221 if (const auto *RDecl = dyn_cast<RecordDecl>(Context))
David Blaikiebfa52742013-04-19 06:56:38 +0000222 if (!RDecl->isDependentType())
223 return getOrCreateType(CGM.getContext().getTypeDeclType(RDecl),
Adrian Prantlc2a44ec2018-12-11 16:58:46 +0000224 TheCU->getFile());
Adrian Prantl6ec370a2015-09-10 18:39:45 +0000225 return Default;
Guy Benyei11169dd2012-12-18 14:30:41 +0000226}
227
Reid Kleckner59d12202017-08-08 01:33:53 +0000228PrintingPolicy CGDebugInfo::getPrintingPolicy() const {
229 PrintingPolicy PP = CGM.getContext().getPrintingPolicy();
230
231 // If we're emitting codeview, it's important to try to match MSVC's naming so
232 // that visualizers written for MSVC will trigger for our class names. In
233 // particular, we can't have spaces between arguments of standard templates
234 // like basic_string and vector.
235 if (CGM.getCodeGenOpts().EmitCodeView)
236 PP.MSVCFormatting = true;
237
Adrian Prantl56acd5a2018-12-05 18:37:44 +0000238 // Apply -fdebug-prefix-map.
Richard Smithdbcb6902019-10-15 17:51:08 -0700239 PP.Callbacks = &PrintCB;
Reid Kleckner59d12202017-08-08 01:33:53 +0000240 return PP;
241}
242
Guy Benyei11169dd2012-12-18 14:30:41 +0000243StringRef CGDebugInfo::getFunctionName(const FunctionDecl *FD) {
Eric Christophere7b87e52014-10-26 23:40:33 +0000244 assert(FD && "Invalid FunctionDecl!");
Guy Benyei11169dd2012-12-18 14:30:41 +0000245 IdentifierInfo *FII = FD->getIdentifier();
Eric Christophere7b87e52014-10-26 23:40:33 +0000246 FunctionTemplateSpecializationInfo *Info =
247 FD->getTemplateSpecializationInfo();
Reid Kleckner60103382015-12-16 02:04:40 +0000248
Reid Kleckner31abd802016-06-30 17:41:31 +0000249 // Emit the unqualified name in normal operation. LLVM and the debugger can
250 // compute the fully qualified name from the scope chain. If we're only
251 // emitting line table info, there won't be any scope chains, so emit the
252 // fully qualified name here so that stack traces are more accurate.
253 // FIXME: Do this when emitting DWARF as well as when emitting CodeView after
254 // evaluating the size impact.
255 bool UseQualifiedName = DebugKind == codegenoptions::DebugLineTablesOnly &&
256 CGM.getCodeGenOpts().EmitCodeView;
257
258 if (!Info && FII && !UseQualifiedName)
Guy Benyei11169dd2012-12-18 14:30:41 +0000259 return FII->getName();
260
Benjamin Kramer9170e912013-02-22 15:46:01 +0000261 SmallString<128> NS;
262 llvm::raw_svector_ostream OS(NS);
Reid Kleckner31abd802016-06-30 17:41:31 +0000263 if (!UseQualifiedName)
264 FD->printName(OS);
265 else
Reid Kleckner59d12202017-08-08 01:33:53 +0000266 FD->printQualifiedName(OS, getPrintingPolicy());
Guy Benyei11169dd2012-12-18 14:30:41 +0000267
Reid Kleckner829398e2016-06-17 16:11:20 +0000268 // Add any template specialization args.
269 if (Info) {
270 const TemplateArgumentList *TArgs = Info->TemplateArguments;
Serge Pavlov03e672c2017-11-28 16:14:14 +0000271 printTemplateArgumentList(OS, TArgs->asArray(), getPrintingPolicy());
Guy Benyei11169dd2012-12-18 14:30:41 +0000272 }
273
274 // Copy this name on the side and use its reference.
Benjamin Kramer1b18a5e2013-09-09 16:39:06 +0000275 return internString(OS.str());
Guy Benyei11169dd2012-12-18 14:30:41 +0000276}
277
278StringRef CGDebugInfo::getObjCMethodName(const ObjCMethodDecl *OMD) {
279 SmallString<256> MethodName;
280 llvm::raw_svector_ostream OS(MethodName);
281 OS << (OMD->isInstanceMethod() ? '-' : '+') << '[';
282 const DeclContext *DC = OMD->getDeclContext();
David Majnemer58ed0f32016-07-17 00:39:12 +0000283 if (const auto *OID = dyn_cast<ObjCImplementationDecl>(DC)) {
Eric Christophere7b87e52014-10-26 23:40:33 +0000284 OS << OID->getName();
David Majnemer58ed0f32016-07-17 00:39:12 +0000285 } else if (const auto *OID = dyn_cast<ObjCInterfaceDecl>(DC)) {
Eric Christophere7b87e52014-10-26 23:40:33 +0000286 OS << OID->getName();
David Majnemer58ed0f32016-07-17 00:39:12 +0000287 } else if (const auto *OC = dyn_cast<ObjCCategoryDecl>(DC)) {
Douglas Gregoracf4fd32015-11-03 01:15:46 +0000288 if (OC->IsClassExtension()) {
289 OS << OC->getClassInterface()->getName();
290 } else {
David Majnemer58ed0f32016-07-17 00:39:12 +0000291 OS << OC->getIdentifier()->getNameStart() << '('
Douglas Gregoracf4fd32015-11-03 01:15:46 +0000292 << OC->getIdentifier()->getNameStart() << ')';
293 }
David Majnemer58ed0f32016-07-17 00:39:12 +0000294 } else if (const auto *OCD = dyn_cast<ObjCCategoryImplDecl>(DC)) {
Jonas Devlieghere9ef49652018-06-28 10:56:40 +0000295 OS << OCD->getClassInterface()->getName() << '(' << OCD->getName() << ')';
Guy Benyei11169dd2012-12-18 14:30:41 +0000296 }
297 OS << ' ' << OMD->getSelector().getAsString() << ']';
298
Benjamin Kramer1b18a5e2013-09-09 16:39:06 +0000299 return internString(OS.str());
Guy Benyei11169dd2012-12-18 14:30:41 +0000300}
301
Guy Benyei11169dd2012-12-18 14:30:41 +0000302StringRef CGDebugInfo::getSelectorName(Selector S) {
Benjamin Kramer1b18a5e2013-09-09 16:39:06 +0000303 return internString(S.getAsString());
Guy Benyei11169dd2012-12-18 14:30:41 +0000304}
305
Eric Christophere7b87e52014-10-26 23:40:33 +0000306StringRef CGDebugInfo::getClassName(const RecordDecl *RD) {
David Majnemerbc5976a2016-07-01 23:12:54 +0000307 if (isa<ClassTemplateSpecializationDecl>(RD)) {
308 SmallString<128> Name;
David Blaikie65813a32014-04-02 18:21:09 +0000309 llvm::raw_svector_ostream OS(Name);
David Blaikie9fdd09a2019-10-18 23:58:34 +0000310 PrintingPolicy PP = getPrintingPolicy();
311 PP.PrintCanonicalTypes = true;
312 RD->getNameForDiagnostic(OS, PP,
David Blaikie65813a32014-04-02 18:21:09 +0000313 /*Qualified*/ false);
David Majnemerbc5976a2016-07-01 23:12:54 +0000314
315 // Copy this name on the side and use its reference.
316 return internString(Name);
Benjamin Kramer9170e912013-02-22 15:46:01 +0000317 }
Guy Benyei11169dd2012-12-18 14:30:41 +0000318
David Majnemerbc5976a2016-07-01 23:12:54 +0000319 // quick optimization to avoid having to intern strings that are already
320 // stored reliably elsewhere
321 if (const IdentifierInfo *II = RD->getIdentifier())
322 return II->getName();
323
324 // The CodeView printer in LLVM wants to see the names of unnamed types: it is
325 // used to reconstruct the fully qualified type names.
326 if (CGM.getCodeGenOpts().EmitCodeView) {
327 if (const TypedefNameDecl *D = RD->getTypedefNameForAnonDecl()) {
328 assert(RD->getDeclContext() == D->getDeclContext() &&
329 "Typedef should not be in another decl context!");
330 assert(D->getDeclName().getAsIdentifierInfo() &&
331 "Typedef was not named!");
332 return D->getDeclName().getAsIdentifierInfo()->getName();
333 }
334
335 if (CGM.getLangOpts().CPlusPlus) {
336 StringRef Name;
337
338 ASTContext &Context = CGM.getContext();
339 if (const DeclaratorDecl *DD = Context.getDeclaratorForUnnamedTagDecl(RD))
340 // Anonymous types without a name for linkage purposes have their
341 // declarator mangled in if they have one.
342 Name = DD->getName();
343 else if (const TypedefNameDecl *TND =
344 Context.getTypedefNameForUnnamedTagDecl(RD))
345 // Anonymous types without a name for linkage purposes have their
346 // associate typedef mangled in if they have one.
347 Name = TND->getName();
348
349 if (!Name.empty()) {
350 SmallString<256> UnnamedType("<unnamed-type-");
351 UnnamedType += Name;
352 UnnamedType += '>';
353 return internString(UnnamedType);
354 }
355 }
356 }
357
358 return StringRef();
Guy Benyei11169dd2012-12-18 14:30:41 +0000359}
360
Scott Linder94834f12018-02-12 19:47:05 +0000361Optional<llvm::DIFile::ChecksumKind>
Amjad Aboude2aab8c2016-12-25 10:12:27 +0000362CGDebugInfo::computeChecksum(FileID FID, SmallString<32> &Checksum) const {
363 Checksum.clear();
364
Paul Robinson76178632018-05-25 22:35:59 +0000365 if (!CGM.getCodeGenOpts().EmitCodeView &&
366 CGM.getCodeGenOpts().DwarfVersion < 5)
Scott Linder94834f12018-02-12 19:47:05 +0000367 return None;
Amjad Aboude2aab8c2016-12-25 10:12:27 +0000368
369 SourceManager &SM = CGM.getContext().getSourceManager();
370 bool Invalid;
Nico Weber04347d82019-04-04 21:06:41 +0000371 const llvm::MemoryBuffer *MemBuffer = SM.getBuffer(FID, &Invalid);
Paul Robinson76178632018-05-25 22:35:59 +0000372 if (Invalid)
Scott Linder94834f12018-02-12 19:47:05 +0000373 return None;
Amjad Aboude2aab8c2016-12-25 10:12:27 +0000374
375 llvm::MD5 Hash;
376 llvm::MD5::MD5Result Result;
377
378 Hash.update(MemBuffer->getBuffer());
379 Hash.final(Result);
380
381 Hash.stringifyResult(Result, Checksum);
382 return llvm::DIFile::CSK_MD5;
383}
384
Jonas Devlieghere9ef49652018-06-28 10:56:40 +0000385Optional<StringRef> CGDebugInfo::getSource(const SourceManager &SM,
386 FileID FID) {
Scott Lindera2fbcef2018-02-26 17:32:31 +0000387 if (!CGM.getCodeGenOpts().EmbedSource)
388 return None;
389
390 bool SourceInvalid = false;
391 StringRef Source = SM.getBufferData(FID, &SourceInvalid);
392
393 if (SourceInvalid)
394 return None;
395
396 return Source;
397}
398
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +0000399llvm::DIFile *CGDebugInfo::getOrCreateFile(SourceLocation Loc) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000400 if (!Loc.isValid())
401 // If Location is not valid then use main input file.
Adrian Prantlc2a44ec2018-12-11 16:58:46 +0000402 return TheCU->getFile();
Guy Benyei11169dd2012-12-18 14:30:41 +0000403
404 SourceManager &SM = CGM.getContext().getSourceManager();
405 PresumedLoc PLoc = SM.getPresumedLoc(Loc);
406
Adrian Prantl212c1042018-12-06 18:44:50 +0000407 StringRef FileName = PLoc.getFilename();
408 if (PLoc.isInvalid() || FileName.empty())
Guy Benyei11169dd2012-12-18 14:30:41 +0000409 // If the location is not valid then use main input file.
Adrian Prantlc2a44ec2018-12-11 16:58:46 +0000410 return TheCU->getFile();
Guy Benyei11169dd2012-12-18 14:30:41 +0000411
412 // Cache the results.
Adrian Prantl212c1042018-12-06 18:44:50 +0000413 auto It = DIFileCache.find(FileName.data());
Jonas Devlieghere9ef49652018-06-28 10:56:40 +0000414 if (It != DIFileCache.end()) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000415 // Verify that the information still exists.
Jonas Devlieghere9ef49652018-06-28 10:56:40 +0000416 if (llvm::Metadata *V = It->second)
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +0000417 return cast<llvm::DIFile>(V);
Guy Benyei11169dd2012-12-18 14:30:41 +0000418 }
419
Amjad Aboude2aab8c2016-12-25 10:12:27 +0000420 SmallString<32> Checksum;
Alexandre Ganea047e65d2019-05-21 19:40:28 +0000421
422 // Compute the checksum if possible. If the location is affected by a #line
423 // directive that refers to a file, PLoc will have an invalid FileID, and we
424 // will correctly get no checksum.
Scott Linder94834f12018-02-12 19:47:05 +0000425 Optional<llvm::DIFile::ChecksumKind> CSKind =
Alexandre Ganea047e65d2019-05-21 19:40:28 +0000426 computeChecksum(PLoc.getFileID(), Checksum);
Scott Linder94834f12018-02-12 19:47:05 +0000427 Optional<llvm::DIFile::ChecksumInfo<StringRef>> CSInfo;
428 if (CSKind)
429 CSInfo.emplace(*CSKind, Checksum);
Adrian Prantlaa5bad42018-12-11 16:58:43 +0000430 return createFile(FileName, CSInfo, getSource(SM, SM.getFileID(Loc)));
431}
Amjad Aboude2aab8c2016-12-25 10:12:27 +0000432
Adrian Prantlaa5bad42018-12-11 16:58:43 +0000433llvm::DIFile *
434CGDebugInfo::createFile(StringRef FileName,
435 Optional<llvm::DIFile::ChecksumInfo<StringRef>> CSInfo,
436 Optional<StringRef> Source) {
Adrian Prantl212c1042018-12-06 18:44:50 +0000437 StringRef Dir;
438 StringRef File;
439 std::string RemappedFile = remapDIPath(FileName);
440 std::string CurDir = remapDIPath(getCurrentDirname());
441 SmallString<128> DirBuf;
442 SmallString<128> FileBuf;
443 if (llvm::sys::path::is_absolute(RemappedFile)) {
444 // Strip the common prefix (if it is more than just "/") from current
445 // directory and FileName for a more space-efficient encoding.
446 auto FileIt = llvm::sys::path::begin(RemappedFile);
447 auto FileE = llvm::sys::path::end(RemappedFile);
448 auto CurDirIt = llvm::sys::path::begin(CurDir);
449 auto CurDirE = llvm::sys::path::end(CurDir);
450 for (; CurDirIt != CurDirE && *CurDirIt == *FileIt; ++CurDirIt, ++FileIt)
451 llvm::sys::path::append(DirBuf, *CurDirIt);
452 if (std::distance(llvm::sys::path::begin(CurDir), CurDirIt) == 1) {
Adrian Prantl0feb7b72019-02-05 21:21:01 +0000453 // Don't strip the common prefix if it is only the root "/"
454 // since that would make LLVM diagnostic locations confusing.
Adrian Prantl212c1042018-12-06 18:44:50 +0000455 Dir = {};
456 File = RemappedFile;
457 } else {
458 for (; FileIt != FileE; ++FileIt)
459 llvm::sys::path::append(FileBuf, *FileIt);
460 Dir = DirBuf;
461 File = FileBuf;
462 }
463 } else {
464 Dir = CurDir;
465 File = RemappedFile;
466 }
Adrian Prantlaa5bad42018-12-11 16:58:43 +0000467 llvm::DIFile *F = DBuilder.createFile(File, Dir, CSInfo, Source);
Adrian Prantl212c1042018-12-06 18:44:50 +0000468 DIFileCache[FileName.data()].reset(F);
Guy Benyei11169dd2012-12-18 14:30:41 +0000469 return F;
470}
471
Saleem Abdulrasool436256a2015-10-12 20:21:08 +0000472std::string CGDebugInfo::remapDIPath(StringRef Path) const {
Sylvain Audi7a8edcb2020-04-29 12:50:37 -0400473 if (DebugPrefixMap.empty())
474 return Path.str();
475
476 SmallString<256> P = Path;
Saleem Abdulrasool436256a2015-10-12 20:21:08 +0000477 for (const auto &Entry : DebugPrefixMap)
Sylvain Audi7a8edcb2020-04-29 12:50:37 -0400478 if (llvm::sys::path::replace_path_prefix(P, Entry.first, Entry.second))
479 break;
480 return P.str().str();
Guy Benyei11169dd2012-12-18 14:30:41 +0000481}
482
Guy Benyei11169dd2012-12-18 14:30:41 +0000483unsigned CGDebugInfo::getLineNumber(SourceLocation Loc) {
484 if (Loc.isInvalid() && CurLoc.isInvalid())
485 return 0;
486 SourceManager &SM = CGM.getContext().getSourceManager();
487 PresumedLoc PLoc = SM.getPresumedLoc(Loc.isValid() ? Loc : CurLoc);
Eric Christophere7b87e52014-10-26 23:40:33 +0000488 return PLoc.isValid() ? PLoc.getLine() : 0;
Guy Benyei11169dd2012-12-18 14:30:41 +0000489}
490
Adrian Prantlc7822422013-03-12 20:43:25 +0000491unsigned CGDebugInfo::getColumnNumber(SourceLocation Loc, bool Force) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000492 // We may not want column information at all.
Adrian Prantlc7822422013-03-12 20:43:25 +0000493 if (!Force && !CGM.getCodeGenOpts().DebugColumnInfo)
Guy Benyei11169dd2012-12-18 14:30:41 +0000494 return 0;
495
496 // If the location is invalid then use the current column.
497 if (Loc.isInvalid() && CurLoc.isInvalid())
498 return 0;
499 SourceManager &SM = CGM.getContext().getSourceManager();
500 PresumedLoc PLoc = SM.getPresumedLoc(Loc.isValid() ? Loc : CurLoc);
Eric Christophere7b87e52014-10-26 23:40:33 +0000501 return PLoc.isValid() ? PLoc.getColumn() : 0;
Guy Benyei11169dd2012-12-18 14:30:41 +0000502}
503
504StringRef CGDebugInfo::getCurrentDirname() {
505 if (!CGM.getCodeGenOpts().DebugCompilationDir.empty())
506 return CGM.getCodeGenOpts().DebugCompilationDir;
507
508 if (!CWDName.empty())
509 return CWDName;
510 SmallString<256> CWD;
511 llvm::sys::fs::current_path(CWD);
Benjamin Kramer1b18a5e2013-09-09 16:39:06 +0000512 return CWDName = internString(CWD);
Guy Benyei11169dd2012-12-18 14:30:41 +0000513}
514
Guy Benyei11169dd2012-12-18 14:30:41 +0000515void CGDebugInfo::CreateCompileUnit() {
Amjad Aboude2aab8c2016-12-25 10:12:27 +0000516 SmallString<32> Checksum;
Scott Linder94834f12018-02-12 19:47:05 +0000517 Optional<llvm::DIFile::ChecksumKind> CSKind;
518 Optional<llvm::DIFile::ChecksumInfo<StringRef>> CSInfo;
Guy Benyei11169dd2012-12-18 14:30:41 +0000519
David Blaikieaabde052014-05-14 00:29:00 +0000520 // Should we be asking the SourceManager for the main file name, instead of
521 // accepting it as an argument? This just causes the main file name to
522 // mismatch with source locations and create extra lexical scopes or
523 // mismatched debug info (a CU with a DW_AT_file of "-", because that's what
524 // the driver passed, but functions/other things have DW_AT_file of "<stdin>"
525 // because that's what the SourceManager says)
526
Guy Benyei11169dd2012-12-18 14:30:41 +0000527 // Get absolute path name.
528 SourceManager &SM = CGM.getContext().getSourceManager();
529 std::string MainFileName = CGM.getCodeGenOpts().MainFileName;
530 if (MainFileName.empty())
David Blaikieaabde052014-05-14 00:29:00 +0000531 MainFileName = "<stdin>";
Guy Benyei11169dd2012-12-18 14:30:41 +0000532
533 // The main file name provided via the "-main-file-name" option contains just
534 // the file name itself with no path information. This file name may have had
535 // a relative path, so we look into the actual file entry for the main
536 // file to determine the real absolute path for the file.
537 std::string MainFileDir;
538 if (const FileEntry *MainFile = SM.getFileEntryForID(SM.getMainFileID())) {
Benjamin Krameradcd0262020-01-28 20:23:46 +0100539 MainFileDir = std::string(MainFile->getDir()->getName());
Adrian Prantl122e7af2019-10-21 16:44:37 +0000540 if (!llvm::sys::path::is_absolute(MainFileName)) {
Eric Christopher0a1301f2014-02-26 02:49:36 +0000541 llvm::SmallString<1024> MainFileDirSS(MainFileDir);
542 llvm::sys::path::append(MainFileDirSS, MainFileName);
Benjamin Krameradcd0262020-01-28 20:23:46 +0100543 MainFileName =
544 std::string(llvm::sys::path::remove_leading_dotslash(MainFileDirSS));
Yaron Keren9fb7e902013-10-21 20:07:37 +0000545 }
Taewook Oh0fb5b782017-08-16 19:36:24 +0000546 // If the main file name provided is identical to the input file name, and
547 // if the input file is a preprocessed source, use the module name for
548 // debug info. The module name comes from the name specified in the first
549 // linemarker if the input is a preprocessed source.
550 if (MainFile->getName() == MainFileName &&
551 FrontendOptions::getInputKindForExtension(
552 MainFile->getName().rsplit('.').second)
553 .isPreprocessed())
554 MainFileName = CGM.getModule().getName().str();
555
Amjad Aboude2aab8c2016-12-25 10:12:27 +0000556 CSKind = computeChecksum(SM.getMainFileID(), Checksum);
Guy Benyei11169dd2012-12-18 14:30:41 +0000557 }
558
Ed Masteda706022014-05-07 12:49:30 +0000559 llvm::dwarf::SourceLanguage LangTag;
Guy Benyei11169dd2012-12-18 14:30:41 +0000560 const LangOptions &LO = CGM.getLangOpts();
561 if (LO.CPlusPlus) {
Erik Pilkingtonfa983902018-10-30 20:31:30 +0000562 if (LO.ObjC)
Guy Benyei11169dd2012-12-18 14:30:41 +0000563 LangTag = llvm::dwarf::DW_LANG_ObjC_plus_plus;
Adrian Prantl350de4f2019-09-24 00:38:49 +0000564 else if (LO.CPlusPlus14)
565 LangTag = llvm::dwarf::DW_LANG_C_plus_plus_14;
566 else if (LO.CPlusPlus11)
567 LangTag = llvm::dwarf::DW_LANG_C_plus_plus_11;
Guy Benyei11169dd2012-12-18 14:30:41 +0000568 else
569 LangTag = llvm::dwarf::DW_LANG_C_plus_plus;
Erik Pilkingtonfa983902018-10-30 20:31:30 +0000570 } else if (LO.ObjC) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000571 LangTag = llvm::dwarf::DW_LANG_ObjC;
Pirama Arumuga Nainara7484c92016-06-21 21:35:11 +0000572 } else if (LO.RenderScript) {
573 LangTag = llvm::dwarf::DW_LANG_GOOGLE_RenderScript;
Guy Benyei11169dd2012-12-18 14:30:41 +0000574 } else if (LO.C99) {
575 LangTag = llvm::dwarf::DW_LANG_C99;
576 } else {
577 LangTag = llvm::dwarf::DW_LANG_C89;
578 }
579
580 std::string Producer = getClangFullVersion();
581
582 // Figure out which version of the ObjC runtime we have.
583 unsigned RuntimeVers = 0;
Erik Pilkingtonfa983902018-10-30 20:31:30 +0000584 if (LO.ObjC)
Guy Benyei11169dd2012-12-18 14:30:41 +0000585 RuntimeVers = LO.ObjCRuntime.isNonFragile() ? 2 : 1;
586
Adrian Prantl826824e2016-04-08 22:43:06 +0000587 llvm::DICompileUnit::DebugEmissionKind EmissionKind;
588 switch (DebugKind) {
589 case codegenoptions::NoDebugInfo:
590 case codegenoptions::LocTrackingOnly:
591 EmissionKind = llvm::DICompileUnit::NoDebug;
592 break;
593 case codegenoptions::DebugLineTablesOnly:
594 EmissionKind = llvm::DICompileUnit::LineTablesOnly;
595 break;
Alexey Bataev80e1b5e2018-08-31 13:56:14 +0000596 case codegenoptions::DebugDirectivesOnly:
597 EmissionKind = llvm::DICompileUnit::DebugDirectivesOnly;
598 break;
Amy Huang53539bb2020-01-13 15:54:54 -0800599 case codegenoptions::DebugInfoConstructor:
Adrian Prantl826824e2016-04-08 22:43:06 +0000600 case codegenoptions::LimitedDebugInfo:
601 case codegenoptions::FullDebugInfo:
602 EmissionKind = llvm::DICompileUnit::FullDebug;
603 break;
604 }
605
Adrian Prantl046d1002018-12-13 17:53:29 +0000606 uint64_t DwoId = 0;
607 auto &CGOpts = CGM.getCodeGenOpts();
608 // The DIFile used by the CU is distinct from the main source
609 // file. Its directory part specifies what becomes the
610 // DW_AT_comp_dir (the compilation directory), even if the source
611 // file was specified with an absolute path.
Scott Linder94834f12018-02-12 19:47:05 +0000612 if (CSKind)
613 CSInfo.emplace(*CSKind, Checksum);
Adrian Prantl046d1002018-12-13 17:53:29 +0000614 llvm::DIFile *CUFile = DBuilder.createFile(
615 remapDIPath(MainFileName), remapDIPath(getCurrentDirname()), CSInfo,
616 getSource(SM, SM.getMainFileID()));
Scott Linder94834f12018-02-12 19:47:05 +0000617
Adrian Prantl842ea702020-03-12 14:19:04 -0700618 StringRef Sysroot, SDK;
619 if (CGM.getCodeGenOpts().getDebuggerTuning() == llvm::DebuggerKind::LLDB) {
Adrian Prantl7b303702020-01-14 13:37:04 -0800620 Sysroot = CGM.getHeaderSearchOpts().Sysroot;
Adrian Prantl842ea702020-03-12 14:19:04 -0700621 auto B = llvm::sys::path::rbegin(Sysroot);
622 auto E = llvm::sys::path::rend(Sysroot);
623 auto It = std::find_if(B, E, [](auto SDK) { return SDK.endswith(".sdk"); });
624 if (It != E)
625 SDK = *It;
626 }
Adrian Prantl7b303702020-01-14 13:37:04 -0800627
Guy Benyei11169dd2012-12-18 14:30:41 +0000628 // Create new compile unit.
Eric Christophere4200a22014-02-27 01:25:08 +0000629 TheCU = DBuilder.createCompileUnit(
Adrian Prantl046d1002018-12-13 17:53:29 +0000630 LangTag, CUFile, CGOpts.EmitVersionIdentMetadata ? Producer : "",
Tobias Edler von Koch7609cb82018-06-22 20:23:21 +0000631 LO.Optimize || CGOpts.PrepareForLTO || CGOpts.PrepareForThinLTO,
Aaron Puchert45611612019-06-26 21:39:19 +0000632 CGOpts.DwarfDebugFlags, RuntimeVers, CGOpts.SplitDwarfFile, EmissionKind,
633 DwoId, CGOpts.SplitDwarfInlining, CGOpts.DebugInfoForProfiling,
David Blaikie9982bb82018-08-16 23:56:32 +0000634 CGM.getTarget().getTriple().isNVPTX()
635 ? llvm::DICompileUnit::DebugNameTableKind::None
David Blaikie65864522018-08-20 20:14:08 +0000636 : static_cast<llvm::DICompileUnit::DebugNameTableKind>(
David Blaikie27692de2018-11-13 20:08:13 +0000637 CGOpts.DebugNameTable),
Adrian Prantlceae4712020-03-18 15:48:23 -0700638 CGOpts.DebugRangesBaseAddress, remapDIPath(Sysroot), SDK);
Guy Benyei11169dd2012-12-18 14:30:41 +0000639}
640
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +0000641llvm::DIType *CGDebugInfo::CreateType(const BuiltinType *BT) {
Ed Masteda706022014-05-07 12:49:30 +0000642 llvm::dwarf::TypeKind Encoding;
Guy Benyei11169dd2012-12-18 14:30:41 +0000643 StringRef BTName;
644 switch (BT->getKind()) {
645#define BUILTIN_TYPE(Id, SingletonId)
Eric Christophere7b87e52014-10-26 23:40:33 +0000646#define PLACEHOLDER_TYPE(Id, SingletonId) case BuiltinType::Id:
Guy Benyei11169dd2012-12-18 14:30:41 +0000647#include "clang/AST/BuiltinTypes.def"
648 case BuiltinType::Dependent:
649 llvm_unreachable("Unexpected builtin type");
650 case BuiltinType::NullPtr:
Peter Collingbourne5c5e6172013-06-27 22:51:01 +0000651 return DBuilder.createNullPtrType();
Guy Benyei11169dd2012-12-18 14:30:41 +0000652 case BuiltinType::Void:
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +0000653 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +0000654 case BuiltinType::ObjCClass:
David Blaikief427b002014-05-06 03:42:01 +0000655 if (!ClassTy)
Adrian Prantlc2a44ec2018-12-11 16:58:46 +0000656 ClassTy =
657 DBuilder.createForwardDecl(llvm::dwarf::DW_TAG_structure_type,
658 "objc_class", TheCU, TheCU->getFile(), 0);
Guy Benyei11169dd2012-12-18 14:30:41 +0000659 return ClassTy;
660 case BuiltinType::ObjCId: {
661 // typedef struct objc_class *Class;
662 // typedef struct objc_object {
663 // Class isa;
664 // } *id;
665
Eric Christopherf8bc4d82013-07-18 00:52:50 +0000666 if (ObjTy)
Guy Benyei11169dd2012-12-18 14:30:41 +0000667 return ObjTy;
668
Eric Christopherf8bc4d82013-07-18 00:52:50 +0000669 if (!ClassTy)
Adrian Prantlc2a44ec2018-12-11 16:58:46 +0000670 ClassTy =
671 DBuilder.createForwardDecl(llvm::dwarf::DW_TAG_structure_type,
672 "objc_class", TheCU, TheCU->getFile(), 0);
Guy Benyei11169dd2012-12-18 14:30:41 +0000673
674 unsigned Size = CGM.getContext().getTypeSize(CGM.getContext().VoidPtrTy);
Eric Christopherb2a008c2013-05-16 00:45:12 +0000675
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +0000676 auto *ISATy = DBuilder.createPointerType(ClassTy, Size);
Guy Benyei11169dd2012-12-18 14:30:41 +0000677
Adrian Prantlc2a44ec2018-12-11 16:58:46 +0000678 ObjTy = DBuilder.createStructType(TheCU, "objc_object", TheCU->getFile(), 0,
679 0, 0, llvm::DINode::FlagZero, nullptr,
680 llvm::DINodeArray());
Guy Benyei11169dd2012-12-18 14:30:41 +0000681
Duncan P. N. Exon Smithc8ee63e2014-12-18 00:48:56 +0000682 DBuilder.replaceArrays(
Leny Kholodovdf050fd2016-09-06 17:06:14 +0000683 ObjTy, DBuilder.getOrCreateArray(&*DBuilder.createMemberType(
Adrian Prantlc2a44ec2018-12-11 16:58:46 +0000684 ObjTy, "isa", TheCU->getFile(), 0, Size, 0, 0,
Leny Kholodovdf050fd2016-09-06 17:06:14 +0000685 llvm::DINode::FlagZero, ISATy)));
Guy Benyei11169dd2012-12-18 14:30:41 +0000686 return ObjTy;
687 }
688 case BuiltinType::ObjCSel: {
David Blaikief427b002014-05-06 03:42:01 +0000689 if (!SelTy)
690 SelTy = DBuilder.createForwardDecl(llvm::dwarf::DW_TAG_structure_type,
691 "objc_selector", TheCU,
Adrian Prantlc2a44ec2018-12-11 16:58:46 +0000692 TheCU->getFile(), 0);
Guy Benyei11169dd2012-12-18 14:30:41 +0000693 return SelTy;
694 }
Guy Benyeid8a08ea2012-12-18 14:38:23 +0000695
Jonas Devlieghere9ef49652018-06-28 10:56:40 +0000696#define IMAGE_TYPE(ImgType, Id, SingletonId, Access, Suffix) \
697 case BuiltinType::Id: \
698 return getOrCreateStructPtrType("opencl_" #ImgType "_" #Suffix "_t", \
Alexey Bader954ba212016-04-08 13:40:33 +0000699 SingletonId);
Alexey Baderb62f1442016-04-13 08:33:41 +0000700#include "clang/Basic/OpenCLImageTypes.def"
Guy Benyei61054192013-02-07 10:55:47 +0000701 case BuiltinType::OCLSampler:
Jonas Devlieghere9ef49652018-06-28 10:56:40 +0000702 return getOrCreateStructPtrType("opencl_sampler_t", OCLSamplerDITy);
Guy Benyei1b4fb3e2013-01-20 12:31:11 +0000703 case BuiltinType::OCLEvent:
Eric Christophere7b87e52014-10-26 23:40:33 +0000704 return getOrCreateStructPtrType("opencl_event_t", OCLEventDITy);
Alexey Bader9c8453f2015-09-15 11:18:52 +0000705 case BuiltinType::OCLClkEvent:
706 return getOrCreateStructPtrType("opencl_clk_event_t", OCLClkEventDITy);
707 case BuiltinType::OCLQueue:
708 return getOrCreateStructPtrType("opencl_queue_t", OCLQueueDITy);
Alexey Bader9c8453f2015-09-15 11:18:52 +0000709 case BuiltinType::OCLReserveID:
710 return getOrCreateStructPtrType("opencl_reserve_id_t", OCLReserveIDDITy);
Andrew Savonichev3fee3512018-11-08 11:25:41 +0000711#define EXT_OPAQUE_TYPE(ExtType, Id, Ext) \
712 case BuiltinType::Id: \
713 return getOrCreateStructPtrType("opencl_" #ExtType, Id##Ty);
714#include "clang/Basic/OpenCLExtensionTypes.def"
Richard Sandifordeb485fb2019-08-09 08:52:54 +0000715 // TODO: real support for SVE types requires more infrastructure
716 // to be added first. The types have a variable length and are
717 // represented in debug info as types whose length depends on a
718 // target-specific pseudo register.
719#define SVE_TYPE(Name, Id, SingletonId) \
720 case BuiltinType::Id:
721#include "clang/Basic/AArch64SVEACLETypes.def"
722 {
723 unsigned DiagID = CGM.getDiags().getCustomDiagID(
724 DiagnosticsEngine::Error,
725 "cannot yet generate debug info for SVE type '%0'");
726 auto Name = BT->getName(CGM.getContext().getPrintingPolicy());
727 CGM.getDiags().Report(DiagID) << Name;
728 // Return something safe.
729 return CreateType(cast<const BuiltinType>(CGM.getContext().IntTy));
730 }
Guy Benyeid8a08ea2012-12-18 14:38:23 +0000731
Guy Benyei11169dd2012-12-18 14:30:41 +0000732 case BuiltinType::UChar:
Eric Christophere7b87e52014-10-26 23:40:33 +0000733 case BuiltinType::Char_U:
734 Encoding = llvm::dwarf::DW_ATE_unsigned_char;
735 break;
Guy Benyei11169dd2012-12-18 14:30:41 +0000736 case BuiltinType::Char_S:
Eric Christophere7b87e52014-10-26 23:40:33 +0000737 case BuiltinType::SChar:
738 Encoding = llvm::dwarf::DW_ATE_signed_char;
739 break;
Richard Smith3a8244d2018-05-01 05:02:45 +0000740 case BuiltinType::Char8:
Guy Benyei11169dd2012-12-18 14:30:41 +0000741 case BuiltinType::Char16:
Eric Christophere7b87e52014-10-26 23:40:33 +0000742 case BuiltinType::Char32:
743 Encoding = llvm::dwarf::DW_ATE_UTF;
744 break;
Guy Benyei11169dd2012-12-18 14:30:41 +0000745 case BuiltinType::UShort:
746 case BuiltinType::UInt:
747 case BuiltinType::UInt128:
748 case BuiltinType::ULong:
749 case BuiltinType::WChar_U:
Eric Christophere7b87e52014-10-26 23:40:33 +0000750 case BuiltinType::ULongLong:
751 Encoding = llvm::dwarf::DW_ATE_unsigned;
752 break;
Guy Benyei11169dd2012-12-18 14:30:41 +0000753 case BuiltinType::Short:
754 case BuiltinType::Int:
755 case BuiltinType::Int128:
756 case BuiltinType::Long:
757 case BuiltinType::WChar_S:
Eric Christophere7b87e52014-10-26 23:40:33 +0000758 case BuiltinType::LongLong:
759 Encoding = llvm::dwarf::DW_ATE_signed;
760 break;
761 case BuiltinType::Bool:
762 Encoding = llvm::dwarf::DW_ATE_boolean;
763 break;
Guy Benyei11169dd2012-12-18 14:30:41 +0000764 case BuiltinType::Half:
765 case BuiltinType::Float:
766 case BuiltinType::LongDouble:
Sjoerd Meijercc623ad2017-09-08 15:15:00 +0000767 case BuiltinType::Float16:
Nemanja Ivanovicbb1ea2d2016-05-09 08:52:33 +0000768 case BuiltinType::Float128:
Eric Christophere7b87e52014-10-26 23:40:33 +0000769 case BuiltinType::Double:
Nemanja Ivanovicbb1ea2d2016-05-09 08:52:33 +0000770 // FIXME: For targets where long double and __float128 have the same size,
771 // they are currently indistinguishable in the debugger without some
772 // special treatment. However, there is currently no consensus on encoding
773 // and this should be updated once a DWARF encoding exists for distinct
774 // floating point types of the same size.
Eric Christophere7b87e52014-10-26 23:40:33 +0000775 Encoding = llvm::dwarf::DW_ATE_float;
776 break;
Leonard Chanf921d852018-06-04 16:07:52 +0000777 case BuiltinType::ShortAccum:
778 case BuiltinType::Accum:
779 case BuiltinType::LongAccum:
Leonard Chanab80f3c2018-06-14 14:53:51 +0000780 case BuiltinType::ShortFract:
781 case BuiltinType::Fract:
782 case BuiltinType::LongFract:
783 case BuiltinType::SatShortFract:
784 case BuiltinType::SatFract:
785 case BuiltinType::SatLongFract:
786 case BuiltinType::SatShortAccum:
787 case BuiltinType::SatAccum:
788 case BuiltinType::SatLongAccum:
Leonard Chanf921d852018-06-04 16:07:52 +0000789 Encoding = llvm::dwarf::DW_ATE_signed_fixed;
790 break;
791 case BuiltinType::UShortAccum:
792 case BuiltinType::UAccum:
793 case BuiltinType::ULongAccum:
Leonard Chanab80f3c2018-06-14 14:53:51 +0000794 case BuiltinType::UShortFract:
795 case BuiltinType::UFract:
796 case BuiltinType::ULongFract:
797 case BuiltinType::SatUShortAccum:
798 case BuiltinType::SatUAccum:
799 case BuiltinType::SatULongAccum:
800 case BuiltinType::SatUShortFract:
801 case BuiltinType::SatUFract:
802 case BuiltinType::SatULongFract:
Leonard Chanf921d852018-06-04 16:07:52 +0000803 Encoding = llvm::dwarf::DW_ATE_unsigned_fixed;
804 break;
Guy Benyei11169dd2012-12-18 14:30:41 +0000805 }
806
807 switch (BT->getKind()) {
Eric Christophere7b87e52014-10-26 23:40:33 +0000808 case BuiltinType::Long:
809 BTName = "long int";
810 break;
811 case BuiltinType::LongLong:
812 BTName = "long long int";
813 break;
814 case BuiltinType::ULong:
815 BTName = "long unsigned int";
816 break;
817 case BuiltinType::ULongLong:
818 BTName = "long long unsigned int";
819 break;
Guy Benyei11169dd2012-12-18 14:30:41 +0000820 default:
821 BTName = BT->getName(CGM.getLangOpts());
822 break;
823 }
Victor Leschuka7ece032016-10-20 00:13:19 +0000824 // Bit size and offset of the type.
Guy Benyei11169dd2012-12-18 14:30:41 +0000825 uint64_t Size = CGM.getContext().getTypeSize(BT);
Victor Leschuka7ece032016-10-20 00:13:19 +0000826 return DBuilder.createBasicType(BTName, Size, Encoding);
Guy Benyei11169dd2012-12-18 14:30:41 +0000827}
828
Awanish Pandeyc83602f2020-01-23 16:06:52 +0530829llvm::DIType *CGDebugInfo::CreateType(const AutoType *Ty) {
830 return DBuilder.createUnspecifiedType("auto");
831}
832
Erich Keane5f0903e2020-04-17 10:44:19 -0700833llvm::DIType *CGDebugInfo::CreateType(const ExtIntType *Ty) {
834
835 StringRef Name = Ty->isUnsigned() ? "unsigned _ExtInt" : "_ExtInt";
836 llvm::dwarf::TypeKind Encoding = Ty->isUnsigned()
837 ? llvm::dwarf::DW_ATE_unsigned
838 : llvm::dwarf::DW_ATE_signed;
839
840 return DBuilder.createBasicType(Name, CGM.getContext().getTypeSize(Ty),
841 Encoding);
842}
843
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +0000844llvm::DIType *CGDebugInfo::CreateType(const ComplexType *Ty) {
Victor Leschuka7ece032016-10-20 00:13:19 +0000845 // Bit size and offset of the type.
Ed Masteda706022014-05-07 12:49:30 +0000846 llvm::dwarf::TypeKind Encoding = llvm::dwarf::DW_ATE_complex_float;
Guy Benyei11169dd2012-12-18 14:30:41 +0000847 if (Ty->isComplexIntegerType())
848 Encoding = llvm::dwarf::DW_ATE_lo_user;
849
850 uint64_t Size = CGM.getContext().getTypeSize(Ty);
Victor Leschuka7ece032016-10-20 00:13:19 +0000851 return DBuilder.createBasicType("complex", Size, Encoding);
Guy Benyei11169dd2012-12-18 14:30:41 +0000852}
853
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +0000854llvm::DIType *CGDebugInfo::CreateQualifiedType(QualType Ty,
855 llvm::DIFile *Unit) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000856 QualifierCollector Qc;
857 const Type *T = Qc.strip(Ty);
858
859 // Ignore these qualifiers for now.
860 Qc.removeObjCGCAttr();
861 Qc.removeAddressSpace();
862 Qc.removeObjCLifetime();
863
864 // We will create one Derived type for one qualifier and recurse to handle any
865 // additional ones.
Ed Masteda706022014-05-07 12:49:30 +0000866 llvm::dwarf::Tag Tag;
Guy Benyei11169dd2012-12-18 14:30:41 +0000867 if (Qc.hasConst()) {
868 Tag = llvm::dwarf::DW_TAG_const_type;
869 Qc.removeConst();
870 } else if (Qc.hasVolatile()) {
871 Tag = llvm::dwarf::DW_TAG_volatile_type;
872 Qc.removeVolatile();
873 } else if (Qc.hasRestrict()) {
874 Tag = llvm::dwarf::DW_TAG_restrict_type;
875 Qc.removeRestrict();
876 } else {
877 assert(Qc.empty() && "Unknown type qualifier for debug info");
878 return getOrCreateType(QualType(T, 0), Unit);
879 }
880
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +0000881 auto *FromTy = getOrCreateType(Qc.apply(CGM.getContext(), T), Unit);
Guy Benyei11169dd2012-12-18 14:30:41 +0000882
883 // No need to fill in the Name, Line, Size, Alignment, Offset in case of
884 // CVR derived types.
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +0000885 return DBuilder.createQualifiedType(Tag, FromTy);
Guy Benyei11169dd2012-12-18 14:30:41 +0000886}
887
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +0000888llvm::DIType *CGDebugInfo::CreateType(const ObjCObjectPointerType *Ty,
889 llvm::DIFile *Unit) {
Fariborz Jahanian65f1fa12013-02-21 20:42:11 +0000890
891 // The frontend treats 'id' as a typedef to an ObjCObjectType,
892 // whereas 'id<protocol>' is treated as an ObjCPointerType. For the
893 // debug info, we want to emit 'id' in both cases.
894 if (Ty->isObjCQualifiedIdType())
Eric Christophere7b87e52014-10-26 23:40:33 +0000895 return getOrCreateType(CGM.getContext().getObjCIdType(), Unit);
Fariborz Jahanian65f1fa12013-02-21 20:42:11 +0000896
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +0000897 return CreatePointerLikeType(llvm::dwarf::DW_TAG_pointer_type, Ty,
898 Ty->getPointeeType(), Unit);
Guy Benyei11169dd2012-12-18 14:30:41 +0000899}
900
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +0000901llvm::DIType *CGDebugInfo::CreateType(const PointerType *Ty,
902 llvm::DIFile *Unit) {
Eric Christopherb2a008c2013-05-16 00:45:12 +0000903 return CreatePointerLikeType(llvm::dwarf::DW_TAG_pointer_type, Ty,
Guy Benyei11169dd2012-12-18 14:30:41 +0000904 Ty->getPointeeType(), Unit);
905}
906
Adrian Prantlc6f91a22015-06-15 23:18:16 +0000907/// \return whether a C++ mangling exists for the type defined by TD.
908static bool hasCXXMangling(const TagDecl *TD, llvm::DICompileUnit *TheCU) {
909 switch (TheCU->getSourceLanguage()) {
910 case llvm::dwarf::DW_LANG_C_plus_plus:
Adrian Prantl350de4f2019-09-24 00:38:49 +0000911 case llvm::dwarf::DW_LANG_C_plus_plus_11:
912 case llvm::dwarf::DW_LANG_C_plus_plus_14:
Adrian Prantlc6f91a22015-06-15 23:18:16 +0000913 return true;
914 case llvm::dwarf::DW_LANG_ObjC_plus_plus:
915 return isa<CXXRecordDecl>(TD) || isa<EnumDecl>(TD);
916 default:
917 return false;
918 }
919}
920
Reid Kleckner59320fc2018-08-17 20:59:52 +0000921// Determines if the debug info for this tag declaration needs a type
922// identifier. The purpose of the unique identifier is to deduplicate type
923// information for identical types across TUs. Because of the C++ one definition
924// rule (ODR), it is valid to assume that the type is defined the same way in
925// every TU and its debug info is equivalent.
926//
927// C does not have the ODR, and it is common for codebases to contain multiple
928// different definitions of a struct with the same name in different TUs.
929// Therefore, if the type doesn't have a C++ mangling, don't give it an
930// identifer. Type information in C is smaller and simpler than C++ type
931// information, so the increase in debug info size is negligible.
932//
933// If the type is not externally visible, it should be unique to the current TU,
934// and should not need an identifier to participate in type deduplication.
935// However, when emitting CodeView, the format internally uses these
936// unique type name identifers for references between debug info. For example,
937// the method of a class in an anonymous namespace uses the identifer to refer
938// to its parent class. The Microsoft C++ ABI attempts to provide unique names
939// for such types, so when emitting CodeView, always use identifiers for C++
940// types. This may create problems when attempting to emit CodeView when the MS
941// C++ ABI is not in use.
Jonas Devlieghere9ef49652018-06-28 10:56:40 +0000942static bool needsTypeIdentifier(const TagDecl *TD, CodeGenModule &CGM,
Brock Wyma8557ec52018-05-22 12:41:19 +0000943 llvm::DICompileUnit *TheCU) {
944 // We only add a type identifier for types with C++ name mangling.
945 if (!hasCXXMangling(TD, TheCU))
946 return false;
947
Brock Wyma8557ec52018-05-22 12:41:19 +0000948 // Externally visible types with C++ mangling need a type identifier.
949 if (TD->isExternallyVisible())
950 return true;
951
Reid Kleckner59320fc2018-08-17 20:59:52 +0000952 // CodeView types with C++ mangling need a type identifier.
953 if (CGM.getCodeGenOpts().EmitCodeView)
954 return true;
955
Brock Wyma8557ec52018-05-22 12:41:19 +0000956 return false;
957}
958
Reid Kleckner59320fc2018-08-17 20:59:52 +0000959// Returns a unique type identifier string if one exists, or an empty string.
Jonas Devlieghere9ef49652018-06-28 10:56:40 +0000960static SmallString<256> getTypeIdentifier(const TagType *Ty, CodeGenModule &CGM,
Brock Wyma8557ec52018-05-22 12:41:19 +0000961 llvm::DICompileUnit *TheCU) {
962 SmallString<256> Identifier;
Manman Rene0064d82013-08-29 23:19:58 +0000963 const TagDecl *TD = Ty->getDecl();
Adrian Prantlc6f91a22015-06-15 23:18:16 +0000964
Brock Wyma8557ec52018-05-22 12:41:19 +0000965 if (!needsTypeIdentifier(TD, CGM, TheCU))
966 return Identifier;
David Blaikief0d66552019-04-25 20:05:47 +0000967 if (const auto *RD = dyn_cast<CXXRecordDecl>(TD))
968 if (RD->getDefinition())
969 if (RD->isDynamicClass() &&
970 CGM.getVTableLinkage(RD) == llvm::GlobalValue::ExternalLinkage)
971 return Identifier;
Adrian Prantlc6f91a22015-06-15 23:18:16 +0000972
Manman Rene0064d82013-08-29 23:19:58 +0000973 // TODO: This is using the RTTI name. Is there a better way to get
974 // a unique string for a type?
Brock Wyma8557ec52018-05-22 12:41:19 +0000975 llvm::raw_svector_ostream Out(Identifier);
Manman Rene0064d82013-08-29 23:19:58 +0000976 CGM.getCXXABI().getMangleContext().mangleCXXRTTIName(QualType(Ty, 0), Out);
Brock Wyma8557ec52018-05-22 12:41:19 +0000977 return Identifier;
Manman Rene0064d82013-08-29 23:19:58 +0000978}
979
Alexander Kornienko2a8c18d2018-04-06 15:14:32 +0000980/// \return the appropriate DWARF tag for a composite type.
Adrian Prantl5f66bae2015-02-11 17:45:15 +0000981static llvm::dwarf::Tag getTagForRecord(const RecordDecl *RD) {
Jonas Devlieghere9ef49652018-06-28 10:56:40 +0000982 llvm::dwarf::Tag Tag;
Adrian Prantl5f66bae2015-02-11 17:45:15 +0000983 if (RD->isStruct() || RD->isInterface())
984 Tag = llvm::dwarf::DW_TAG_structure_type;
985 else if (RD->isUnion())
986 Tag = llvm::dwarf::DW_TAG_union_type;
987 else {
988 // FIXME: This could be a struct type giving a default visibility different
989 // than C++ class type, but needs llvm metadata changes first.
990 assert(RD->isClass());
991 Tag = llvm::dwarf::DW_TAG_class_type;
992 }
993 return Tag;
994}
995
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +0000996llvm::DICompositeType *
Manman Ren1b457022013-08-28 21:20:28 +0000997CGDebugInfo::getOrCreateRecordFwdDecl(const RecordType *Ty,
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +0000998 llvm::DIScope *Ctx) {
Manman Ren1b457022013-08-28 21:20:28 +0000999 const RecordDecl *RD = Ty->getDecl();
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001000 if (llvm::DIType *T = getTypeOrNull(CGM.getContext().getRecordType(RD)))
1001 return cast<llvm::DICompositeType>(T);
1002 llvm::DIFile *DefUnit = getOrCreateFile(RD->getLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00001003 unsigned Line = getLineNumber(RD->getLocation());
1004 StringRef RDName = getClassName(RD);
1005
Peter Collingbourned251b0a2015-03-01 22:07:04 +00001006 uint64_t Size = 0;
Victor Leschuk802e4a52016-10-19 22:11:07 +00001007 uint32_t Align = 0;
Peter Collingbourned251b0a2015-03-01 22:07:04 +00001008
Amy Huangbcf66082020-02-04 13:20:13 -08001009 llvm::DINode::DIFlags Flags = llvm::DINode::FlagFwdDecl;
1010
1011 // Add flag to nontrivial forward declarations. To be consistent with MSVC,
1012 // add the flag if a record has no definition because we don't know whether
1013 // it will be trivial or not.
1014 if (const CXXRecordDecl *CXXRD = dyn_cast<CXXRecordDecl>(RD))
1015 if (!CXXRD->hasDefinition() ||
1016 (CXXRD->hasDefinition() && !CXXRD->isTrivial()))
1017 Flags |= llvm::DINode::FlagNonTrivial;
1018
Guy Benyei11169dd2012-12-18 14:30:41 +00001019 // Create the type.
Brock Wyma8557ec52018-05-22 12:41:19 +00001020 SmallString<256> Identifier = getTypeIdentifier(Ty, CGM, TheCU);
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001021 llvm::DICompositeType *RetTy = DBuilder.createReplaceableCompositeType(
Amy Huangbcf66082020-02-04 13:20:13 -08001022 getTagForRecord(RD), RDName, Ctx, DefUnit, Line, 0, Size, Align, Flags,
1023 Identifier);
Paul Robinson1787f812017-09-28 18:37:02 +00001024 if (CGM.getCodeGenOpts().DebugFwdTemplateParams)
1025 if (auto *TSpecial = dyn_cast<ClassTemplateSpecializationDecl>(RD))
1026 DBuilder.replaceArrays(RetTy, llvm::DINodeArray(),
1027 CollectCXXTemplateParams(TSpecial, DefUnit));
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001028 ReplaceMap.emplace_back(
1029 std::piecewise_construct, std::make_tuple(Ty),
1030 std::make_tuple(static_cast<llvm::Metadata *>(RetTy)));
David Blaikief427b002014-05-06 03:42:01 +00001031 return RetTy;
Guy Benyei11169dd2012-12-18 14:30:41 +00001032}
1033
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001034llvm::DIType *CGDebugInfo::CreatePointerLikeType(llvm::dwarf::Tag Tag,
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +00001035 const Type *Ty,
1036 QualType PointeeTy,
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001037 llvm::DIFile *Unit) {
Guy Benyei11169dd2012-12-18 14:30:41 +00001038 // Bit size, align and offset of the type.
1039 // Size is always the size of a pointer. We can't use getTypeSize here
1040 // because that does not return the correct value for references.
Konstantin Zhuravlyovd1ba16e2017-03-08 23:56:48 +00001041 unsigned AddressSpace = CGM.getContext().getTargetAddressSpace(PointeeTy);
1042 uint64_t Size = CGM.getTarget().getPointerWidth(AddressSpace);
Victor Leschuka7ece032016-10-20 00:13:19 +00001043 auto Align = getTypeAlignIfRequired(Ty, CGM.getContext());
Konstantin Zhuravlyovd1ba16e2017-03-08 23:56:48 +00001044 Optional<unsigned> DWARFAddressSpace =
1045 CGM.getTarget().getDWARFAddressSpace(AddressSpace);
Guy Benyei11169dd2012-12-18 14:30:41 +00001046
Keno Fischer87842f32015-11-16 09:04:13 +00001047 if (Tag == llvm::dwarf::DW_TAG_reference_type ||
1048 Tag == llvm::dwarf::DW_TAG_rvalue_reference_type)
1049 return DBuilder.createReferenceType(Tag, getOrCreateType(PointeeTy, Unit),
Konstantin Zhuravlyovd1ba16e2017-03-08 23:56:48 +00001050 Size, Align, DWARFAddressSpace);
Keno Fischer87842f32015-11-16 09:04:13 +00001051 else
1052 return DBuilder.createPointerType(getOrCreateType(PointeeTy, Unit), Size,
Konstantin Zhuravlyovd1ba16e2017-03-08 23:56:48 +00001053 Align, DWARFAddressSpace);
Guy Benyei11169dd2012-12-18 14:30:41 +00001054}
1055
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001056llvm::DIType *CGDebugInfo::getOrCreateStructPtrType(StringRef Name,
1057 llvm::DIType *&Cache) {
Eric Christopherf8bc4d82013-07-18 00:52:50 +00001058 if (Cache)
Guy Benyeid8a08ea2012-12-18 14:38:23 +00001059 return Cache;
David Blaikiefefc7f72013-05-21 17:58:54 +00001060 Cache = DBuilder.createForwardDecl(llvm::dwarf::DW_TAG_structure_type, Name,
Adrian Prantlc2a44ec2018-12-11 16:58:46 +00001061 TheCU, TheCU->getFile(), 0);
David Blaikiefefc7f72013-05-21 17:58:54 +00001062 unsigned Size = CGM.getContext().getTypeSize(CGM.getContext().VoidPtrTy);
1063 Cache = DBuilder.createPointerType(Cache, Size);
1064 return Cache;
Guy Benyeid8a08ea2012-12-18 14:38:23 +00001065}
1066
Scott Linder58df0e42018-08-08 15:56:12 +00001067uint64_t CGDebugInfo::collectDefaultElementTypesForBlockPointer(
1068 const BlockPointerType *Ty, llvm::DIFile *Unit, llvm::DIDerivedType *DescTy,
1069 unsigned LineNo, SmallVectorImpl<llvm::Metadata *> &EltTys) {
Guy Benyei11169dd2012-12-18 14:30:41 +00001070 QualType FType;
Guy Benyei11169dd2012-12-18 14:30:41 +00001071
Scott Linder58df0e42018-08-08 15:56:12 +00001072 // Advanced by calls to CreateMemberType in increments of FType, then
1073 // returned as the overall size of the default elements.
1074 uint64_t FieldOffset = 0;
Guy Benyei11169dd2012-12-18 14:30:41 +00001075
Scott Linder58df0e42018-08-08 15:56:12 +00001076 // Blocks in OpenCL have unique constraints which make the standard fields
1077 // redundant while requiring size and align fields for enqueue_kernel. See
1078 // initializeForBlockHeader in CGBlocks.cpp
Scott Linder2b5cf042018-07-30 20:31:11 +00001079 if (CGM.getLangOpts().OpenCL) {
1080 FType = CGM.getContext().IntTy;
1081 EltTys.push_back(CreateMemberType(Unit, FType, "__size", &FieldOffset));
1082 EltTys.push_back(CreateMemberType(Unit, FType, "__align", &FieldOffset));
1083 } else {
1084 FType = CGM.getContext().getPointerType(CGM.getContext().VoidTy);
1085 EltTys.push_back(CreateMemberType(Unit, FType, "__isa", &FieldOffset));
1086 FType = CGM.getContext().IntTy;
1087 EltTys.push_back(CreateMemberType(Unit, FType, "__flags", &FieldOffset));
1088 EltTys.push_back(CreateMemberType(Unit, FType, "__reserved", &FieldOffset));
1089 FType = CGM.getContext().getPointerType(Ty->getPointeeType());
1090 EltTys.push_back(CreateMemberType(Unit, FType, "__FuncPtr", &FieldOffset));
1091 FType = CGM.getContext().getPointerType(CGM.getContext().VoidTy);
Scott Linder58df0e42018-08-08 15:56:12 +00001092 uint64_t FieldSize = CGM.getContext().getTypeSize(Ty);
1093 uint32_t FieldAlign = CGM.getContext().getTypeAlign(Ty);
Scott Linder2b5cf042018-07-30 20:31:11 +00001094 EltTys.push_back(DBuilder.createMemberType(
Scott Linder58df0e42018-08-08 15:56:12 +00001095 Unit, "__descriptor", nullptr, LineNo, FieldSize, FieldAlign,
1096 FieldOffset, llvm::DINode::FlagZero, DescTy));
Scott Lindera7c45682018-07-30 22:52:07 +00001097 FieldOffset += FieldSize;
Scott Linder2b5cf042018-07-30 20:31:11 +00001098 }
Guy Benyei11169dd2012-12-18 14:30:41 +00001099
Scott Linder58df0e42018-08-08 15:56:12 +00001100 return FieldOffset;
1101}
1102
1103llvm::DIType *CGDebugInfo::CreateType(const BlockPointerType *Ty,
1104 llvm::DIFile *Unit) {
1105 SmallVector<llvm::Metadata *, 8> EltTys;
1106 QualType FType;
1107 uint64_t FieldOffset;
1108 llvm::DINodeArray Elements;
1109
1110 FieldOffset = 0;
1111 FType = CGM.getContext().UnsignedLongTy;
1112 EltTys.push_back(CreateMemberType(Unit, FType, "reserved", &FieldOffset));
1113 EltTys.push_back(CreateMemberType(Unit, FType, "Size", &FieldOffset));
1114
1115 Elements = DBuilder.getOrCreateArray(EltTys);
1116 EltTys.clear();
1117
1118 llvm::DINode::DIFlags Flags = llvm::DINode::FlagAppleBlock;
1119
1120 auto *EltTy =
1121 DBuilder.createStructType(Unit, "__block_descriptor", nullptr, 0,
1122 FieldOffset, 0, Flags, nullptr, Elements);
1123
1124 // Bit size, align and offset of the type.
1125 uint64_t Size = CGM.getContext().getTypeSize(Ty);
1126
1127 auto *DescTy = DBuilder.createPointerType(EltTy, Size);
1128
1129 FieldOffset = collectDefaultElementTypesForBlockPointer(Ty, Unit, DescTy,
1130 0, EltTys);
1131
Guy Benyei11169dd2012-12-18 14:30:41 +00001132 Elements = DBuilder.getOrCreateArray(EltTys);
1133
Adrian Prantl3d2c0512015-07-07 00:49:35 +00001134 // The __block_literal_generic structs are marked with a special
1135 // DW_AT_APPLE_BLOCK attribute and are an implementation detail only
1136 // the debugger needs to know about. To allow type uniquing, emit
1137 // them without a name or a location.
Scott Linder58df0e42018-08-08 15:56:12 +00001138 EltTy = DBuilder.createStructType(Unit, "", nullptr, 0, FieldOffset, 0,
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00001139 Flags, nullptr, Elements);
Guy Benyei11169dd2012-12-18 14:30:41 +00001140
Adrian Prantl3d2c0512015-07-07 00:49:35 +00001141 return DBuilder.createPointerType(EltTy, Size);
Guy Benyei11169dd2012-12-18 14:30:41 +00001142}
1143
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001144llvm::DIType *CGDebugInfo::CreateType(const TemplateSpecializationType *Ty,
1145 llvm::DIFile *Unit) {
David Blaikief1b382e2014-04-06 17:14:06 +00001146 assert(Ty->isTypeAlias());
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001147 llvm::DIType *Src = getOrCreateType(Ty->getAliasedType(), Unit);
David Blaikief1b382e2014-04-06 17:14:06 +00001148
David Blaikie8472fa62019-06-08 00:01:21 +00001149 auto *AliasDecl =
1150 cast<TypeAliasTemplateDecl>(Ty->getTemplateName().getAsTemplateDecl())
1151 ->getTemplatedDecl();
1152
1153 if (AliasDecl->hasAttr<NoDebugAttr>())
1154 return Src;
1155
David Blaikief1b382e2014-04-06 17:14:06 +00001156 SmallString<128> NS;
1157 llvm::raw_svector_ostream OS(NS);
Serge Pavlov03e672c2017-11-28 16:14:14 +00001158 Ty->getTemplateName().print(OS, getPrintingPolicy(), /*qualified*/ false);
1159 printTemplateArgumentList(OS, Ty->template_arguments(), getPrintingPolicy());
David Blaikief1b382e2014-04-06 17:14:06 +00001160
David Blaikief1b382e2014-04-06 17:14:06 +00001161 SourceLocation Loc = AliasDecl->getLocation();
Adrian Prantlb67dbce2015-09-11 18:45:02 +00001162 return DBuilder.createTypedef(Src, OS.str(), getOrCreateFile(Loc),
1163 getLineNumber(Loc),
Sam McCalld27a16e2019-11-18 15:53:22 +01001164 getDeclContextDescriptor(AliasDecl));
David Blaikief1b382e2014-04-06 17:14:06 +00001165}
1166
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001167llvm::DIType *CGDebugInfo::CreateType(const TypedefType *Ty,
1168 llvm::DIFile *Unit) {
David Blaikie8472fa62019-06-08 00:01:21 +00001169 llvm::DIType *Underlying =
1170 getOrCreateType(Ty->getDecl()->getUnderlyingType(), Unit);
1171
1172 if (Ty->getDecl()->hasAttr<NoDebugAttr>())
1173 return Underlying;
1174
Guy Benyei11169dd2012-12-18 14:30:41 +00001175 // We don't set size information, but do specify where the typedef was
1176 // declared.
Amjad Abouddc4531e2016-04-30 01:44:38 +00001177 SourceLocation Loc = Ty->getDecl()->getLocation();
Eric Christopherb2a008c2013-05-16 00:45:12 +00001178
Sourabh Singh Tomarf1e39882019-12-03 09:29:54 +05301179 uint32_t Align = getDeclAlignIfRequired(Ty->getDecl(), CGM.getContext());
Duncan P. N. Exon Smith4078ad42015-04-16 16:36:45 +00001180 // Typedefs are derived from some other type.
Sam McCalld27a16e2019-11-18 15:53:22 +01001181 return DBuilder.createTypedef(Underlying, Ty->getDecl()->getName(),
1182 getOrCreateFile(Loc), getLineNumber(Loc),
Sourabh Singh Tomarf1e39882019-12-03 09:29:54 +05301183 getDeclContextDescriptor(Ty->getDecl()), Align);
Guy Benyei11169dd2012-12-18 14:30:41 +00001184}
1185
Reid Klecknerf00f8032016-06-08 20:41:54 +00001186static unsigned getDwarfCC(CallingConv CC) {
1187 switch (CC) {
1188 case CC_C:
1189 // Avoid emitting DW_AT_calling_convention if the C convention was used.
1190 return 0;
1191
1192 case CC_X86StdCall:
1193 return llvm::dwarf::DW_CC_BORLAND_stdcall;
1194 case CC_X86FastCall:
1195 return llvm::dwarf::DW_CC_BORLAND_msfastcall;
1196 case CC_X86ThisCall:
1197 return llvm::dwarf::DW_CC_BORLAND_thiscall;
1198 case CC_X86VectorCall:
1199 return llvm::dwarf::DW_CC_LLVM_vectorcall;
1200 case CC_X86Pascal:
1201 return llvm::dwarf::DW_CC_BORLAND_pascal;
Martin Storsjo022e7822017-07-17 20:49:45 +00001202 case CC_Win64:
Jonas Devliegheref0702682018-03-22 13:53:30 +00001203 return llvm::dwarf::DW_CC_LLVM_Win64;
Reid Klecknerf00f8032016-06-08 20:41:54 +00001204 case CC_X86_64SysV:
Jonas Devliegheref0702682018-03-22 13:53:30 +00001205 return llvm::dwarf::DW_CC_LLVM_X86_64SysV;
Reid Klecknerf00f8032016-06-08 20:41:54 +00001206 case CC_AAPCS:
Sander de Smalen44a22532018-11-26 16:38:37 +00001207 case CC_AArch64VectorCall:
Jonas Devliegheref0702682018-03-22 13:53:30 +00001208 return llvm::dwarf::DW_CC_LLVM_AAPCS;
Reid Klecknerf00f8032016-06-08 20:41:54 +00001209 case CC_AAPCS_VFP:
Jonas Devliegheref0702682018-03-22 13:53:30 +00001210 return llvm::dwarf::DW_CC_LLVM_AAPCS_VFP;
Reid Klecknerf00f8032016-06-08 20:41:54 +00001211 case CC_IntelOclBicc:
Jonas Devliegheref0702682018-03-22 13:53:30 +00001212 return llvm::dwarf::DW_CC_LLVM_IntelOclBicc;
Reid Klecknerf00f8032016-06-08 20:41:54 +00001213 case CC_SpirFunction:
Jonas Devliegheref0702682018-03-22 13:53:30 +00001214 return llvm::dwarf::DW_CC_LLVM_SpirFunction;
Nikolay Haustov8c6538b2016-06-30 09:06:33 +00001215 case CC_OpenCLKernel:
Jonas Devliegheref0702682018-03-22 13:53:30 +00001216 return llvm::dwarf::DW_CC_LLVM_OpenCLKernel;
Reid Klecknerf00f8032016-06-08 20:41:54 +00001217 case CC_Swift:
Jonas Devliegheref0702682018-03-22 13:53:30 +00001218 return llvm::dwarf::DW_CC_LLVM_Swift;
Reid Klecknerf00f8032016-06-08 20:41:54 +00001219 case CC_PreserveMost:
Jonas Devliegheref0702682018-03-22 13:53:30 +00001220 return llvm::dwarf::DW_CC_LLVM_PreserveMost;
Reid Klecknerf00f8032016-06-08 20:41:54 +00001221 case CC_PreserveAll:
Jonas Devliegheref0702682018-03-22 13:53:30 +00001222 return llvm::dwarf::DW_CC_LLVM_PreserveAll;
Erich Keane757d3172016-11-02 18:29:35 +00001223 case CC_X86RegCall:
Jonas Devliegheref0702682018-03-22 13:53:30 +00001224 return llvm::dwarf::DW_CC_LLVM_X86RegCall;
Reid Klecknerf00f8032016-06-08 20:41:54 +00001225 }
1226 return 0;
1227}
1228
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001229llvm::DIType *CGDebugInfo::CreateType(const FunctionType *Ty,
1230 llvm::DIFile *Unit) {
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001231 SmallVector<llvm::Metadata *, 16> EltTys;
Guy Benyei11169dd2012-12-18 14:30:41 +00001232
1233 // Add the result type at least.
Alp Toker314cc812014-01-25 16:55:45 +00001234 EltTys.push_back(getOrCreateType(Ty->getReturnType(), Unit));
Guy Benyei11169dd2012-12-18 14:30:41 +00001235
1236 // Set up remainder of arguments if there is a prototype.
Adrian Prantl800faef2014-02-25 23:42:18 +00001237 // otherwise emit it as a variadic function.
Guy Benyei11169dd2012-12-18 14:30:41 +00001238 if (isa<FunctionNoProtoType>(Ty))
1239 EltTys.push_back(DBuilder.createUnspecifiedParameter());
David Majnemer58ed0f32016-07-17 00:39:12 +00001240 else if (const auto *FPT = dyn_cast<FunctionProtoType>(Ty)) {
1241 for (const QualType &ParamType : FPT->param_types())
1242 EltTys.push_back(getOrCreateType(ParamType, Unit));
Adrian Prantld45ba252014-02-25 19:38:11 +00001243 if (FPT->isVariadic())
1244 EltTys.push_back(DBuilder.createUnspecifiedParameter());
Guy Benyei11169dd2012-12-18 14:30:41 +00001245 }
1246
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001247 llvm::DITypeRefArray EltTypeArray = DBuilder.getOrCreateTypeArray(EltTys);
Leny Kholodov80c047d2016-09-06 10:48:04 +00001248 return DBuilder.createSubroutineType(EltTypeArray, llvm::DINode::FlagZero,
Reid Klecknerf00f8032016-06-08 20:41:54 +00001249 getDwarfCC(Ty->getCallConv()));
Guy Benyei11169dd2012-12-18 14:30:41 +00001250}
1251
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001252/// Convert an AccessSpecifier into the corresponding DINode flag.
Adrian Prantl21361fb2014-08-29 22:44:27 +00001253/// As an optimization, return 0 if the access specifier equals the
1254/// default for the containing type.
Leny Kholodovdf050fd2016-09-06 17:06:14 +00001255static llvm::DINode::DIFlags getAccessFlag(AccessSpecifier Access,
1256 const RecordDecl *RD) {
Adrian Prantl21361fb2014-08-29 22:44:27 +00001257 AccessSpecifier Default = clang::AS_none;
1258 if (RD && RD->isClass())
1259 Default = clang::AS_private;
1260 else if (RD && (RD->isStruct() || RD->isUnion()))
1261 Default = clang::AS_public;
1262
1263 if (Access == Default)
Leny Kholodov80c047d2016-09-06 10:48:04 +00001264 return llvm::DINode::FlagZero;
Adrian Prantl21361fb2014-08-29 22:44:27 +00001265
Eric Christophere7b87e52014-10-26 23:40:33 +00001266 switch (Access) {
1267 case clang::AS_private:
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001268 return llvm::DINode::FlagPrivate;
Eric Christophere7b87e52014-10-26 23:40:33 +00001269 case clang::AS_protected:
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001270 return llvm::DINode::FlagProtected;
Eric Christophere7b87e52014-10-26 23:40:33 +00001271 case clang::AS_public:
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001272 return llvm::DINode::FlagPublic;
Eric Christophere7b87e52014-10-26 23:40:33 +00001273 case clang::AS_none:
Leny Kholodov80c047d2016-09-06 10:48:04 +00001274 return llvm::DINode::FlagZero;
Adrian Prantl21361fb2014-08-29 22:44:27 +00001275 }
1276 llvm_unreachable("unexpected access enumerator");
1277}
Guy Benyei11169dd2012-12-18 14:30:41 +00001278
David Majnemerb4b671e2016-06-30 03:01:59 +00001279llvm::DIType *CGDebugInfo::createBitFieldType(const FieldDecl *BitFieldDecl,
1280 llvm::DIScope *RecordTy,
1281 const RecordDecl *RD) {
1282 StringRef Name = BitFieldDecl->getName();
1283 QualType Ty = BitFieldDecl->getType();
1284 SourceLocation Loc = BitFieldDecl->getLocation();
1285 llvm::DIFile *VUnit = getOrCreateFile(Loc);
1286 llvm::DIType *DebugType = getOrCreateType(Ty, VUnit);
1287
1288 // Get the location for the field.
1289 llvm::DIFile *File = getOrCreateFile(Loc);
1290 unsigned Line = getLineNumber(Loc);
1291
1292 const CGBitFieldInfo &BitFieldInfo =
1293 CGM.getTypes().getCGRecordLayout(RD).getBitFieldInfo(BitFieldDecl);
1294 uint64_t SizeInBits = BitFieldInfo.Size;
1295 assert(SizeInBits > 0 && "found named 0-width bitfield");
David Majnemerb4b671e2016-06-30 03:01:59 +00001296 uint64_t StorageOffsetInBits =
1297 CGM.getContext().toBits(BitFieldInfo.StorageOffset);
Reid Kleckner06a4b2a2017-06-12 19:57:56 +00001298 uint64_t Offset = BitFieldInfo.Offset;
1299 // The bit offsets for big endian machines are reversed for big
1300 // endian target, compensate for that as the DIDerivedType requires
1301 // un-reversed offsets.
1302 if (CGM.getDataLayout().isBigEndian())
1303 Offset = BitFieldInfo.StorageSize - BitFieldInfo.Size - Offset;
1304 uint64_t OffsetInBits = StorageOffsetInBits + Offset;
Leny Kholodov80c047d2016-09-06 10:48:04 +00001305 llvm::DINode::DIFlags Flags = getAccessFlag(BitFieldDecl->getAccess(), RD);
David Majnemerb4b671e2016-06-30 03:01:59 +00001306 return DBuilder.createBitFieldMemberType(
Victor Leschuka7ece032016-10-20 00:13:19 +00001307 RecordTy, Name, File, Line, SizeInBits, OffsetInBits, StorageOffsetInBits,
1308 Flags, DebugType);
David Majnemerb4b671e2016-06-30 03:01:59 +00001309}
1310
1311llvm::DIType *
1312CGDebugInfo::createFieldType(StringRef name, QualType type, SourceLocation loc,
1313 AccessSpecifier AS, uint64_t offsetInBits,
Victor Leschuka7ece032016-10-20 00:13:19 +00001314 uint32_t AlignInBits, llvm::DIFile *tunit,
1315 llvm::DIScope *scope, const RecordDecl *RD) {
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001316 llvm::DIType *debugType = getOrCreateType(type, tunit);
Guy Benyei11169dd2012-12-18 14:30:41 +00001317
1318 // Get the location for the field.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001319 llvm::DIFile *file = getOrCreateFile(loc);
Guy Benyei11169dd2012-12-18 14:30:41 +00001320 unsigned line = getLineNumber(loc);
1321
David Majnemer34b57492014-07-30 01:30:47 +00001322 uint64_t SizeInBits = 0;
Victor Leschuka7ece032016-10-20 00:13:19 +00001323 auto Align = AlignInBits;
Guy Benyei11169dd2012-12-18 14:30:41 +00001324 if (!type->isIncompleteArrayType()) {
David Majnemer34b57492014-07-30 01:30:47 +00001325 TypeInfo TI = CGM.getContext().getTypeInfo(type);
1326 SizeInBits = TI.Width;
Victor Leschuka7ece032016-10-20 00:13:19 +00001327 if (!Align)
1328 Align = getTypeAlignIfRequired(type, CGM.getContext());
Guy Benyei11169dd2012-12-18 14:30:41 +00001329 }
1330
Leny Kholodov80c047d2016-09-06 10:48:04 +00001331 llvm::DINode::DIFlags flags = getAccessFlag(AS, RD);
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00001332 return DBuilder.createMemberType(scope, name, file, line, SizeInBits, Align,
1333 offsetInBits, flags, debugType);
Guy Benyei11169dd2012-12-18 14:30:41 +00001334}
1335
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001336void CGDebugInfo::CollectRecordLambdaFields(
1337 const CXXRecordDecl *CXXDecl, SmallVectorImpl<llvm::Metadata *> &elements,
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001338 llvm::DIType *RecordTy) {
Eric Christopher91a31902013-01-16 01:22:32 +00001339 // For C++11 Lambdas a Field will be the same as a Capture, but the Capture
1340 // has the name and the location of the variable so we should iterate over
1341 // both concurrently.
1342 const ASTRecordLayout &layout = CGM.getContext().getASTRecordLayout(CXXDecl);
1343 RecordDecl::field_iterator Field = CXXDecl->field_begin();
1344 unsigned fieldno = 0;
1345 for (CXXRecordDecl::capture_const_iterator I = CXXDecl->captures_begin(),
Eric Christophere7b87e52014-10-26 23:40:33 +00001346 E = CXXDecl->captures_end();
1347 I != E; ++I, ++Field, ++fieldno) {
Benjamin Kramerf3ca26982014-05-10 16:31:55 +00001348 const LambdaCapture &C = *I;
Eric Christopher91a31902013-01-16 01:22:32 +00001349 if (C.capturesVariable()) {
David Majnemerb4b671e2016-06-30 03:01:59 +00001350 SourceLocation Loc = C.getLocation();
1351 assert(!Field->isBitField() && "lambdas don't have bitfield members!");
Eric Christopher91a31902013-01-16 01:22:32 +00001352 VarDecl *V = C.getCapturedVar();
Eric Christopher91a31902013-01-16 01:22:32 +00001353 StringRef VName = V->getName();
David Majnemerb4b671e2016-06-30 03:01:59 +00001354 llvm::DIFile *VUnit = getOrCreateFile(Loc);
Victor Leschuka7ece032016-10-20 00:13:19 +00001355 auto Align = getDeclAlignIfRequired(V, CGM.getContext());
David Majnemerb4b671e2016-06-30 03:01:59 +00001356 llvm::DIType *FieldType = createFieldType(
1357 VName, Field->getType(), Loc, Field->getAccess(),
Victor Leschuka7ece032016-10-20 00:13:19 +00001358 layout.getFieldOffset(fieldno), Align, VUnit, RecordTy, CXXDecl);
David Majnemerb4b671e2016-06-30 03:01:59 +00001359 elements.push_back(FieldType);
Alexey Bataev39c81e22014-08-28 04:28:19 +00001360 } else if (C.capturesThis()) {
Eric Christopher91a31902013-01-16 01:22:32 +00001361 // TODO: Need to handle 'this' in some way by probably renaming the
1362 // this of the lambda class and having a field member of 'this' or
1363 // by using AT_object_pointer for the function and having that be
1364 // used as 'this' for semantic references.
Eric Christopher91a31902013-01-16 01:22:32 +00001365 FieldDecl *f = *Field;
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001366 llvm::DIFile *VUnit = getOrCreateFile(f->getLocation());
Eric Christopher91a31902013-01-16 01:22:32 +00001367 QualType type = f->getType();
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001368 llvm::DIType *fieldType = createFieldType(
David Majnemerb4b671e2016-06-30 03:01:59 +00001369 "this", type, f->getLocation(), f->getAccess(),
Eric Christophere7b87e52014-10-26 23:40:33 +00001370 layout.getFieldOffset(fieldno), VUnit, RecordTy, CXXDecl);
Eric Christopher91a31902013-01-16 01:22:32 +00001371
1372 elements.push_back(fieldType);
1373 }
1374 }
1375}
1376
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001377llvm::DIDerivedType *
1378CGDebugInfo::CreateRecordStaticField(const VarDecl *Var, llvm::DIType *RecordTy,
Duncan P. N. Exon Smithc09c5482015-04-20 21:17:26 +00001379 const RecordDecl *RD) {
Eric Christopher91a31902013-01-16 01:22:32 +00001380 // Create the descriptor for the static variable, with or without
1381 // constant initializers.
David Blaikie8e707bb2014-10-14 22:22:17 +00001382 Var = Var->getCanonicalDecl();
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001383 llvm::DIFile *VUnit = getOrCreateFile(Var->getLocation());
1384 llvm::DIType *VTy = getOrCreateType(Var->getType(), VUnit);
Eric Christopher91a31902013-01-16 01:22:32 +00001385
Eric Christopher91a31902013-01-16 01:22:32 +00001386 unsigned LineNumber = getLineNumber(Var->getLocation());
1387 StringRef VName = Var->getName();
Craig Topper8a13c412014-05-21 05:09:00 +00001388 llvm::Constant *C = nullptr;
Eric Christopher91a31902013-01-16 01:22:32 +00001389 if (Var->getInit()) {
1390 const APValue *Value = Var->evaluateValue();
David Blaikied42917f2013-01-20 01:19:17 +00001391 if (Value) {
1392 if (Value->isInt())
1393 C = llvm::ConstantInt::get(CGM.getLLVMContext(), Value->getInt());
1394 if (Value->isFloat())
1395 C = llvm::ConstantFP::get(CGM.getLLVMContext(), Value->getFloat());
1396 }
Eric Christopher91a31902013-01-16 01:22:32 +00001397 }
1398
Leny Kholodov80c047d2016-09-06 10:48:04 +00001399 llvm::DINode::DIFlags Flags = getAccessFlag(Var->getAccess(), RD);
Victor Leschuka7ece032016-10-20 00:13:19 +00001400 auto Align = getDeclAlignIfRequired(Var, CGM.getContext());
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001401 llvm::DIDerivedType *GV = DBuilder.createStaticMemberType(
Victor Leschuka7ece032016-10-20 00:13:19 +00001402 RecordTy, VName, VUnit, LineNumber, VTy, Flags, C, Align);
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001403 StaticDataMemberCache[Var->getCanonicalDecl()].reset(GV);
David Blaikieae019462013-08-15 22:50:29 +00001404 return GV;
Eric Christopher91a31902013-01-16 01:22:32 +00001405}
1406
Eric Christophere7b87e52014-10-26 23:40:33 +00001407void CGDebugInfo::CollectRecordNormalField(
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001408 const FieldDecl *field, uint64_t OffsetInBits, llvm::DIFile *tunit,
1409 SmallVectorImpl<llvm::Metadata *> &elements, llvm::DIType *RecordTy,
Eric Christophere7b87e52014-10-26 23:40:33 +00001410 const RecordDecl *RD) {
Eric Christopher91a31902013-01-16 01:22:32 +00001411 StringRef name = field->getName();
1412 QualType type = field->getType();
1413
1414 // Ignore unnamed fields unless they're anonymous structs/unions.
1415 if (name.empty() && !type->isRecordType())
1416 return;
1417
David Majnemerb4b671e2016-06-30 03:01:59 +00001418 llvm::DIType *FieldType;
Eric Christopher91a31902013-01-16 01:22:32 +00001419 if (field->isBitField()) {
David Majnemerb4b671e2016-06-30 03:01:59 +00001420 FieldType = createBitFieldType(field, RecordTy, RD);
1421 } else {
Victor Leschuka7ece032016-10-20 00:13:19 +00001422 auto Align = getDeclAlignIfRequired(field, CGM.getContext());
David Majnemerb4b671e2016-06-30 03:01:59 +00001423 FieldType =
1424 createFieldType(name, type, field->getLocation(), field->getAccess(),
Victor Leschuka7ece032016-10-20 00:13:19 +00001425 OffsetInBits, Align, tunit, RecordTy, RD);
Eric Christopher91a31902013-01-16 01:22:32 +00001426 }
1427
David Majnemerb4b671e2016-06-30 03:01:59 +00001428 elements.push_back(FieldType);
Eric Christopher91a31902013-01-16 01:22:32 +00001429}
1430
Reid Klecknere2e82062017-08-08 20:30:14 +00001431void CGDebugInfo::CollectRecordNestedType(
1432 const TypeDecl *TD, SmallVectorImpl<llvm::Metadata *> &elements) {
1433 QualType Ty = CGM.getContext().getTypeDeclType(TD);
Reid Kleckner755220b2016-08-01 18:56:13 +00001434 // Injected class names are not considered nested records.
1435 if (isa<InjectedClassNameType>(Ty))
1436 return;
Reid Klecknere2e82062017-08-08 20:30:14 +00001437 SourceLocation Loc = TD->getLocation();
Adrian McCarthyab1e7862016-07-21 18:43:20 +00001438 llvm::DIType *nestedType = getOrCreateType(Ty, getOrCreateFile(Loc));
1439 elements.push_back(nestedType);
1440}
1441
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001442void CGDebugInfo::CollectRecordFields(
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001443 const RecordDecl *record, llvm::DIFile *tunit,
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001444 SmallVectorImpl<llvm::Metadata *> &elements,
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001445 llvm::DICompositeType *RecordTy) {
David Majnemer58ed0f32016-07-17 00:39:12 +00001446 const auto *CXXDecl = dyn_cast<CXXRecordDecl>(record);
Guy Benyei11169dd2012-12-18 14:30:41 +00001447
Eric Christopher91a31902013-01-16 01:22:32 +00001448 if (CXXDecl && CXXDecl->isLambda())
1449 CollectRecordLambdaFields(CXXDecl, elements, RecordTy);
1450 else {
1451 const ASTRecordLayout &layout = CGM.getContext().getASTRecordLayout(record);
Guy Benyei11169dd2012-12-18 14:30:41 +00001452
Eric Christopher91a31902013-01-16 01:22:32 +00001453 // Field number for non-static fields.
Eric Christopher0f7594372013-01-04 17:59:07 +00001454 unsigned fieldNo = 0;
Eric Christopher91a31902013-01-16 01:22:32 +00001455
Eric Christopher91a31902013-01-16 01:22:32 +00001456 // Static and non-static members should appear in the same order as
1457 // the corresponding declarations in the source program.
Aaron Ballman629afae2014-03-07 19:56:05 +00001458 for (const auto *I : record->decls())
1459 if (const auto *V = dyn_cast<VarDecl>(I)) {
Paul Robinsonb17327d2016-04-27 17:37:12 +00001460 if (V->hasAttr<NoDebugAttr>())
1461 continue;
Reid Kleckner891b2712018-07-20 20:55:00 +00001462
1463 // Skip variable template specializations when emitting CodeView. MSVC
1464 // doesn't emit them.
1465 if (CGM.getCodeGenOpts().EmitCodeView &&
1466 isa<VarTemplateSpecializationDecl>(V))
1467 continue;
1468
David Blaikie4f3b7362019-06-17 19:40:52 +00001469 if (isa<VarTemplatePartialSpecializationDecl>(V))
1470 continue;
1471
David Blaikiece763042013-08-20 21:49:21 +00001472 // Reuse the existing static member declaration if one exists
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001473 auto MI = StaticDataMemberCache.find(V->getCanonicalDecl());
David Blaikiece763042013-08-20 21:49:21 +00001474 if (MI != StaticDataMemberCache.end()) {
1475 assert(MI->second &&
1476 "Static data member declaration should still exist");
Duncan P. N. Exon Smithac346ba2015-07-24 18:05:58 +00001477 elements.push_back(MI->second);
Adrian Prantl21361fb2014-08-29 22:44:27 +00001478 } else {
1479 auto Field = CreateRecordStaticField(V, RecordTy, record);
1480 elements.push_back(Field);
1481 }
Aaron Ballman629afae2014-03-07 19:56:05 +00001482 } else if (const auto *field = dyn_cast<FieldDecl>(I)) {
Eric Christophere7b87e52014-10-26 23:40:33 +00001483 CollectRecordNormalField(field, layout.getFieldOffset(fieldNo), tunit,
1484 elements, RecordTy, record);
Eric Christopher91a31902013-01-16 01:22:32 +00001485
1486 // Bump field number for next field.
1487 ++fieldNo;
Reid Kleckner891b2712018-07-20 20:55:00 +00001488 } else if (CGM.getCodeGenOpts().EmitCodeView) {
1489 // Debug info for nested types is included in the member list only for
1490 // CodeView.
Reid Klecknere2e82062017-08-08 20:30:14 +00001491 if (const auto *nestedType = dyn_cast<TypeDecl>(I))
1492 if (!nestedType->isImplicit() &&
1493 nestedType->getDeclContext() == record)
1494 CollectRecordNestedType(nestedType, elements);
1495 }
Guy Benyei11169dd2012-12-18 14:30:41 +00001496 }
1497}
1498
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001499llvm::DISubroutineType *
Guy Benyei11169dd2012-12-18 14:30:41 +00001500CGDebugInfo::getOrCreateMethodType(const CXXMethodDecl *Method,
Awanish Pandeyc83602f2020-01-23 16:06:52 +05301501 llvm::DIFile *Unit, bool decl) {
David Blaikie7eb06852013-01-07 23:06:35 +00001502 const FunctionProtoType *Func = Method->getType()->getAs<FunctionProtoType>();
David Blaikie2aaf0652013-01-07 22:24:59 +00001503 if (Method->isStatic())
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001504 return cast_or_null<llvm::DISubroutineType>(
Duncan P. N. Exon Smithc7551282015-04-06 23:21:33 +00001505 getOrCreateType(QualType(Func, 0), Unit));
Awanish Pandeyc83602f2020-01-23 16:06:52 +05301506 return getOrCreateInstanceMethodType(Method->getThisType(), Func, Unit, decl);
David Blaikie7eb06852013-01-07 23:06:35 +00001507}
David Blaikie2aaf0652013-01-07 22:24:59 +00001508
Awanish Pandeyc83602f2020-01-23 16:06:52 +05301509llvm::DISubroutineType *
1510CGDebugInfo::getOrCreateInstanceMethodType(QualType ThisPtr,
1511 const FunctionProtoType *Func,
1512 llvm::DIFile *Unit, bool decl) {
Guy Benyei11169dd2012-12-18 14:30:41 +00001513 // Add "this" pointer.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001514 llvm::DITypeRefArray Args(
1515 cast<llvm::DISubroutineType>(getOrCreateType(QualType(Func, 0), Unit))
Duncan P. N. Exon Smithc7551282015-04-06 23:21:33 +00001516 ->getTypeArray());
Duncan P. N. Exon Smitha98fac62015-04-07 04:14:45 +00001517 assert(Args.size() && "Invalid number of arguments!");
Guy Benyei11169dd2012-12-18 14:30:41 +00001518
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001519 SmallVector<llvm::Metadata *, 16> Elts;
Guy Benyei11169dd2012-12-18 14:30:41 +00001520 // First element is always return type. For 'void' functions it is NULL.
Awanish Pandeyc83602f2020-01-23 16:06:52 +05301521 QualType temp = Func->getReturnType();
1522 if (temp->getTypeClass() == Type::Auto && decl)
1523 Elts.push_back(CreateType(cast<AutoType>(temp)));
1524 else
1525 Elts.push_back(Args[0]);
Guy Benyei11169dd2012-12-18 14:30:41 +00001526
David Blaikie2aaf0652013-01-07 22:24:59 +00001527 // "this" pointer is always first argument.
David Blaikie7eb06852013-01-07 23:06:35 +00001528 const CXXRecordDecl *RD = ThisPtr->getPointeeCXXRecordDecl();
David Blaikie2aaf0652013-01-07 22:24:59 +00001529 if (isa<ClassTemplateSpecializationDecl>(RD)) {
1530 // Create pointer type directly in this case.
1531 const PointerType *ThisPtrTy = cast<PointerType>(ThisPtr);
1532 QualType PointeeTy = ThisPtrTy->getPointeeType();
1533 unsigned AS = CGM.getContext().getTargetAddressSpace(PointeeTy);
John McCallc8e01702013-04-16 22:48:15 +00001534 uint64_t Size = CGM.getTarget().getPointerWidth(AS);
Victor Leschuka7ece032016-10-20 00:13:19 +00001535 auto Align = getTypeAlignIfRequired(ThisPtrTy, CGM.getContext());
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001536 llvm::DIType *PointeeType = getOrCreateType(PointeeTy, Unit);
1537 llvm::DIType *ThisPtrType =
Eric Christophere7b87e52014-10-26 23:40:33 +00001538 DBuilder.createPointerType(PointeeType, Size, Align);
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001539 TypeCache[ThisPtr.getAsOpaquePtr()].reset(ThisPtrType);
David Blaikie2aaf0652013-01-07 22:24:59 +00001540 // TODO: This and the artificial type below are misleading, the
1541 // types aren't artificial the argument is, but the current
1542 // metadata doesn't represent that.
1543 ThisPtrType = DBuilder.createObjectPointerType(ThisPtrType);
1544 Elts.push_back(ThisPtrType);
1545 } else {
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001546 llvm::DIType *ThisPtrType = getOrCreateType(ThisPtr, Unit);
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001547 TypeCache[ThisPtr.getAsOpaquePtr()].reset(ThisPtrType);
David Blaikie2aaf0652013-01-07 22:24:59 +00001548 ThisPtrType = DBuilder.createObjectPointerType(ThisPtrType);
1549 Elts.push_back(ThisPtrType);
Guy Benyei11169dd2012-12-18 14:30:41 +00001550 }
1551
1552 // Copy rest of the arguments.
Duncan P. N. Exon Smitha98fac62015-04-07 04:14:45 +00001553 for (unsigned i = 1, e = Args.size(); i != e; ++i)
1554 Elts.push_back(Args[i]);
Guy Benyei11169dd2012-12-18 14:30:41 +00001555
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001556 llvm::DITypeRefArray EltTypeArray = DBuilder.getOrCreateTypeArray(Elts);
Guy Benyei11169dd2012-12-18 14:30:41 +00001557
Leny Kholodov80c047d2016-09-06 10:48:04 +00001558 llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
Adrian Prantl0630eb72013-12-18 21:48:18 +00001559 if (Func->getExtProtoInfo().RefQualifier == RQ_LValue)
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001560 Flags |= llvm::DINode::FlagLValueReference;
Adrian Prantl0630eb72013-12-18 21:48:18 +00001561 if (Func->getExtProtoInfo().RefQualifier == RQ_RValue)
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001562 Flags |= llvm::DINode::FlagRValueReference;
Adrian Prantl0630eb72013-12-18 21:48:18 +00001563
Reid Klecknerf00f8032016-06-08 20:41:54 +00001564 return DBuilder.createSubroutineType(EltTypeArray, Flags,
1565 getDwarfCC(Func->getCallConv()));
Guy Benyei11169dd2012-12-18 14:30:41 +00001566}
1567
Eric Christopherb2a008c2013-05-16 00:45:12 +00001568/// isFunctionLocalClass - Return true if CXXRecordDecl is defined
Guy Benyei11169dd2012-12-18 14:30:41 +00001569/// inside a function.
1570static bool isFunctionLocalClass(const CXXRecordDecl *RD) {
David Majnemer58ed0f32016-07-17 00:39:12 +00001571 if (const auto *NRD = dyn_cast<CXXRecordDecl>(RD->getDeclContext()))
Guy Benyei11169dd2012-12-18 14:30:41 +00001572 return isFunctionLocalClass(NRD);
1573 if (isa<FunctionDecl>(RD->getDeclContext()))
1574 return true;
1575 return false;
1576}
1577
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001578llvm::DISubprogram *CGDebugInfo::CreateCXXMemberFunction(
1579 const CXXMethodDecl *Method, llvm::DIFile *Unit, llvm::DIType *RecordTy) {
Eric Christopherb2a008c2013-05-16 00:45:12 +00001580 bool IsCtorOrDtor =
Eric Christophere7b87e52014-10-26 23:40:33 +00001581 isa<CXXConstructorDecl>(Method) || isa<CXXDestructorDecl>(Method);
Eric Christopherb2a008c2013-05-16 00:45:12 +00001582
Guy Benyei11169dd2012-12-18 14:30:41 +00001583 StringRef MethodName = getFunctionName(Method);
Awanish Pandeyc83602f2020-01-23 16:06:52 +05301584 llvm::DISubroutineType *MethodTy = getOrCreateMethodType(Method, Unit, true);
Guy Benyei11169dd2012-12-18 14:30:41 +00001585
1586 // Since a single ctor/dtor corresponds to multiple functions, it doesn't
1587 // make sense to give a single ctor/dtor a linkage name.
1588 StringRef MethodLinkageName;
David Blaikie71647672016-04-12 21:22:48 +00001589 // FIXME: 'isFunctionLocalClass' seems like an arbitrary/unintentional
1590 // property to use here. It may've been intended to model "is non-external
1591 // type" but misses cases of non-function-local but non-external classes such
1592 // as those in anonymous namespaces as well as the reverse - external types
1593 // that are function local, such as those in (non-local) inline functions.
Guy Benyei11169dd2012-12-18 14:30:41 +00001594 if (!IsCtorOrDtor && !isFunctionLocalClass(Method->getParent()))
1595 MethodLinkageName = CGM.getMangledName(Method);
1596
1597 // Get the location for the method.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001598 llvm::DIFile *MethodDefUnit = nullptr;
David Blaikie7fceebf2013-08-19 03:37:48 +00001599 unsigned MethodLine = 0;
1600 if (!Method->isImplicit()) {
1601 MethodDefUnit = getOrCreateFile(Method->getLocation());
1602 MethodLine = getLineNumber(Method->getLocation());
1603 }
Guy Benyei11169dd2012-12-18 14:30:41 +00001604
1605 // Collect virtual method info.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001606 llvm::DIType *ContainingType = nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00001607 unsigned VIndex = 0;
Leny Kholodov80c047d2016-09-06 10:48:04 +00001608 llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
Paul Robinsoncda54212018-11-19 18:29:28 +00001609 llvm::DISubprogram::DISPFlags SPFlags = llvm::DISubprogram::SPFlagZero;
Reid Kleckner0358cbf2016-07-01 02:41:25 +00001610 int ThisAdjustment = 0;
Eric Christopherb2a008c2013-05-16 00:45:12 +00001611
Guy Benyei11169dd2012-12-18 14:30:41 +00001612 if (Method->isVirtual()) {
1613 if (Method->isPure())
Paul Robinsoncda54212018-11-19 18:29:28 +00001614 SPFlags |= llvm::DISubprogram::SPFlagPureVirtual;
Guy Benyei11169dd2012-12-18 14:30:41 +00001615 else
Paul Robinsoncda54212018-11-19 18:29:28 +00001616 SPFlags |= llvm::DISubprogram::SPFlagVirtual;
Eric Christopherb2a008c2013-05-16 00:45:12 +00001617
Reid Kleckner216d0a12016-06-16 20:08:51 +00001618 if (CGM.getTarget().getCXXABI().isItaniumFamily()) {
1619 // It doesn't make sense to give a virtual destructor a vtable index,
1620 // since a single destructor has two entries in the vtable.
1621 if (!isa<CXXDestructorDecl>(Method))
1622 VIndex = CGM.getItaniumVTableContext().getMethodVTableIndex(Method);
1623 } else {
1624 // Emit MS ABI vftable information. There is only one entry for the
1625 // deleting dtor.
1626 const auto *DD = dyn_cast<CXXDestructorDecl>(Method);
1627 GlobalDecl GD = DD ? GlobalDecl(DD, Dtor_Deleting) : GlobalDecl(Method);
Reid Klecknercbec0262018-04-02 20:00:39 +00001628 MethodVFTableLocation ML =
Reid Kleckner216d0a12016-06-16 20:08:51 +00001629 CGM.getMicrosoftVTableContext().getMethodVFTableLocation(GD);
1630 VIndex = ML.Index;
Reid Klecknerc4871ed2016-06-22 18:34:45 +00001631
1632 // CodeView only records the vftable offset in the class that introduces
1633 // the virtual method. This is possible because, unlike Itanium, the MS
1634 // C++ ABI does not include all virtual methods from non-primary bases in
1635 // the vtable for the most derived class. For example, if C inherits from
1636 // A and B, C's primary vftable will not include B's virtual methods.
Benjamin Krameracfa3392017-12-17 23:52:45 +00001637 if (Method->size_overridden_methods() == 0)
Reid Klecknerc4871ed2016-06-22 18:34:45 +00001638 Flags |= llvm::DINode::FlagIntroducedVirtual;
1639
Reid Kleckner0358cbf2016-07-01 02:41:25 +00001640 // The 'this' adjustment accounts for both the virtual and non-virtual
1641 // portions of the adjustment. Presumably the debugger only uses it when
1642 // it knows the dynamic type of an object.
1643 ThisAdjustment = CGM.getCXXABI()
1644 .getVirtualFunctionPrologueThisAdjustment(GD)
1645 .getQuantity();
Reid Kleckner216d0a12016-06-16 20:08:51 +00001646 }
Guy Benyei11169dd2012-12-18 14:30:41 +00001647 ContainingType = RecordTy;
1648 }
1649
Adrian Prantlf919be32019-10-29 09:20:14 -07001650 // We're checking for deleted C++ special member functions
1651 // [Ctors,Dtors, Copy/Move]
Sourabh Singh Tomar52ea3082019-11-02 01:28:40 +05301652 auto checkAttrDeleted = [&](const auto *Method) {
Adrian Prantlf919be32019-10-29 09:20:14 -07001653 if (Method->getCanonicalDecl()->isDeleted())
1654 SPFlags |= llvm::DISubprogram::SPFlagDeleted;
1655 };
1656
1657 switch (Method->getKind()) {
1658
1659 case Decl::CXXConstructor:
1660 case Decl::CXXDestructor:
1661 checkAttrDeleted(Method);
1662 break;
1663 case Decl::CXXMethod:
1664 if (Method->isCopyAssignmentOperator() ||
1665 Method->isMoveAssignmentOperator())
1666 checkAttrDeleted(Method);
1667 break;
1668 default:
1669 break;
1670 }
1671
Adrian Prantla9cfde12019-10-16 16:30:38 +00001672 if (Method->isNoReturn())
1673 Flags |= llvm::DINode::FlagNoReturn;
Adrian Prantlf919be32019-10-29 09:20:14 -07001674
Adrian McCarthyd91bf392017-09-13 20:53:55 +00001675 if (Method->isStatic())
1676 Flags |= llvm::DINode::FlagStaticMember;
Guy Benyei11169dd2012-12-18 14:30:41 +00001677 if (Method->isImplicit())
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001678 Flags |= llvm::DINode::FlagArtificial;
Adrian Prantl21361fb2014-08-29 22:44:27 +00001679 Flags |= getAccessFlag(Method->getAccess(), Method->getParent());
David Majnemer58ed0f32016-07-17 00:39:12 +00001680 if (const auto *CXXC = dyn_cast<CXXConstructorDecl>(Method)) {
Guy Benyei11169dd2012-12-18 14:30:41 +00001681 if (CXXC->isExplicit())
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001682 Flags |= llvm::DINode::FlagExplicit;
David Majnemer58ed0f32016-07-17 00:39:12 +00001683 } else if (const auto *CXXC = dyn_cast<CXXConversionDecl>(Method)) {
Guy Benyei11169dd2012-12-18 14:30:41 +00001684 if (CXXC->isExplicit())
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001685 Flags |= llvm::DINode::FlagExplicit;
Guy Benyei11169dd2012-12-18 14:30:41 +00001686 }
1687 if (Method->hasPrototype())
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001688 Flags |= llvm::DINode::FlagPrototyped;
Adrian Prantl0630eb72013-12-18 21:48:18 +00001689 if (Method->getRefQualifier() == RQ_LValue)
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001690 Flags |= llvm::DINode::FlagLValueReference;
Adrian Prantl0630eb72013-12-18 21:48:18 +00001691 if (Method->getRefQualifier() == RQ_RValue)
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001692 Flags |= llvm::DINode::FlagRValueReference;
Paul Robinsoncda54212018-11-19 18:29:28 +00001693 if (CGM.getLangOpts().Optimize)
1694 SPFlags |= llvm::DISubprogram::SPFlagOptimized;
Guy Benyei11169dd2012-12-18 14:30:41 +00001695
Amy Huang651128f2020-01-03 16:28:48 -08001696 // In this debug mode, emit type info for a class when its constructor type
1697 // info is emitted.
1698 if (DebugKind == codegenoptions::DebugInfoConstructor)
1699 if (const CXXConstructorDecl *CD = dyn_cast<CXXConstructorDecl>(Method))
1700 completeClass(CD->getParent());
1701
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001702 llvm::DINodeArray TParamsArray = CollectFunctionTemplateParams(Method, Unit);
1703 llvm::DISubprogram *SP = DBuilder.createMethod(
Eric Christophere7b87e52014-10-26 23:40:33 +00001704 RecordTy, MethodName, MethodLinkageName, MethodDefUnit, MethodLine,
Paul Robinsoncda54212018-11-19 18:29:28 +00001705 MethodTy, VIndex, ThisAdjustment, ContainingType, Flags, SPFlags,
Reid Kleckner0358cbf2016-07-01 02:41:25 +00001706 TParamsArray.get());
Eric Christopherb2a008c2013-05-16 00:45:12 +00001707
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001708 SPCache[Method->getCanonicalDecl()].reset(SP);
Guy Benyei11169dd2012-12-18 14:30:41 +00001709
1710 return SP;
1711}
1712
Eric Christophere7b87e52014-10-26 23:40:33 +00001713void CGDebugInfo::CollectCXXMemberFunctions(
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001714 const CXXRecordDecl *RD, llvm::DIFile *Unit,
1715 SmallVectorImpl<llvm::Metadata *> &EltTys, llvm::DIType *RecordTy) {
Guy Benyei11169dd2012-12-18 14:30:41 +00001716
1717 // Since we want more than just the individual member decls if we
1718 // have templated functions iterate over every declaration to gather
1719 // the functions.
Eric Christophere7b87e52014-10-26 23:40:33 +00001720 for (const auto *I : RD->decls()) {
David Blaikiefd580722014-10-06 05:18:55 +00001721 const auto *Method = dyn_cast<CXXMethodDecl>(I);
1722 // If the member is implicit, don't add it to the member list. This avoids
1723 // the member being added to type units by LLVM, while still allowing it
1724 // to be emitted into the type declaration/reference inside the compile
1725 // unit.
Paul Robinson6a7511b2015-06-25 17:50:43 +00001726 // Ditto 'nodebug' methods, for consistency with CodeGenFunction.cpp.
David Blaikie6dddfe32014-10-06 05:52:27 +00001727 // FIXME: Handle Using(Shadow?)Decls here to create
1728 // DW_TAG_imported_declarations inside the class for base decls brought into
1729 // derived classes. GDB doesn't seem to notice/leverage these when I tried
1730 // it, so I'm not rushing to fix this. (GCC seems to produce them, if
1731 // referenced)
Paul Robinson6a7511b2015-06-25 17:50:43 +00001732 if (!Method || Method->isImplicit() || Method->hasAttr<NoDebugAttr>())
David Blaikiefd580722014-10-06 05:18:55 +00001733 continue;
David Blaikie42edade2014-11-11 20:44:45 +00001734
Simon Pilgrim7e38f0c2019-10-07 16:42:25 +00001735 if (Method->getType()->castAs<FunctionProtoType>()->getContainedAutoType())
David Blaikie42edade2014-11-11 20:44:45 +00001736 continue;
1737
David Blaikiefd580722014-10-06 05:18:55 +00001738 // Reuse the existing member function declaration if it exists.
1739 // It may be associated with the declaration of the type & should be
1740 // reused as we're building the definition.
1741 //
1742 // This situation can arise in the vtable-based debug info reduction where
1743 // implicit members are emitted in a non-vtable TU.
1744 auto MI = SPCache.find(Method->getCanonicalDecl());
1745 EltTys.push_back(MI == SPCache.end()
1746 ? CreateCXXMemberFunction(Method, Unit, RecordTy)
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001747 : static_cast<llvm::Metadata *>(MI->second));
Guy Benyei11169dd2012-12-18 14:30:41 +00001748 }
Eric Christopherb2a008c2013-05-16 00:45:12 +00001749}
Guy Benyei11169dd2012-12-18 14:30:41 +00001750
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001751void CGDebugInfo::CollectCXXBases(const CXXRecordDecl *RD, llvm::DIFile *Unit,
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001752 SmallVectorImpl<llvm::Metadata *> &EltTys,
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001753 llvm::DIType *RecordTy) {
Bob Haarmandff36732016-10-25 22:19:32 +00001754 llvm::DenseSet<CanonicalDeclPtr<const CXXRecordDecl>> SeenTypes;
1755 CollectCXXBasesAux(RD, Unit, EltTys, RecordTy, RD->bases(), SeenTypes,
1756 llvm::DINode::FlagZero);
Eric Christopherb2a008c2013-05-16 00:45:12 +00001757
Bob Haarmandff36732016-10-25 22:19:32 +00001758 // If we are generating CodeView debug info, we also need to emit records for
1759 // indirect virtual base classes.
1760 if (CGM.getCodeGenOpts().EmitCodeView) {
1761 CollectCXXBasesAux(RD, Unit, EltTys, RecordTy, RD->vbases(), SeenTypes,
1762 llvm::DINode::FlagIndirectVirtualBase);
1763 }
1764}
1765
1766void CGDebugInfo::CollectCXXBasesAux(
1767 const CXXRecordDecl *RD, llvm::DIFile *Unit,
1768 SmallVectorImpl<llvm::Metadata *> &EltTys, llvm::DIType *RecordTy,
1769 const CXXRecordDecl::base_class_const_range &Bases,
1770 llvm::DenseSet<CanonicalDeclPtr<const CXXRecordDecl>> &SeenTypes,
1771 llvm::DINode::DIFlags StartingFlags) {
1772 const ASTRecordLayout &RL = CGM.getContext().getASTRecordLayout(RD);
1773 for (const auto &BI : Bases) {
David Majnemer58ed0f32016-07-17 00:39:12 +00001774 const auto *Base =
Simon Pilgrim1cd399c2019-10-03 11:22:48 +00001775 cast<CXXRecordDecl>(BI.getType()->castAs<RecordType>()->getDecl());
Bob Haarmandff36732016-10-25 22:19:32 +00001776 if (!SeenTypes.insert(Base).second)
1777 continue;
1778 auto *BaseTy = getOrCreateType(BI.getType(), Unit);
1779 llvm::DINode::DIFlags BFlags = StartingFlags;
1780 uint64_t BaseOffset;
Brock Wyma3db2b102018-05-14 21:21:22 +00001781 uint32_t VBPtrOffset = 0;
Eric Christopherb2a008c2013-05-16 00:45:12 +00001782
Aaron Ballman574705e2014-03-13 15:41:46 +00001783 if (BI.isVirtual()) {
Reid Klecknerd3b23d62014-08-07 21:29:25 +00001784 if (CGM.getTarget().getCXXABI().isItaniumFamily()) {
1785 // virtual base offset offset is -ve. The code generator emits dwarf
1786 // expression where it expects +ve number.
Eric Christophere7b87e52014-10-26 23:40:33 +00001787 BaseOffset = 0 - CGM.getItaniumVTableContext()
1788 .getVirtualBaseOffsetOffset(RD, Base)
1789 .getQuantity();
Reid Klecknerd3b23d62014-08-07 21:29:25 +00001790 } else {
1791 // In the MS ABI, store the vbtable offset, which is analogous to the
1792 // vbase offset offset in Itanium.
1793 BaseOffset =
1794 4 * CGM.getMicrosoftVTableContext().getVBTableIndex(RD, Base);
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00001795 VBPtrOffset = CGM.getContext()
1796 .getASTRecordLayout(RD)
1797 .getVBPtrOffset()
1798 .getQuantity();
Reid Klecknerd3b23d62014-08-07 21:29:25 +00001799 }
Bob Haarmandff36732016-10-25 22:19:32 +00001800 BFlags |= llvm::DINode::FlagVirtual;
Guy Benyei11169dd2012-12-18 14:30:41 +00001801 } else
1802 BaseOffset = CGM.getContext().toBits(RL.getBaseClassOffset(Base));
1803 // FIXME: Inconsistent units for BaseOffset. It is in bytes when
1804 // BI->isVirtual() and bits when not.
Eric Christopherb2a008c2013-05-16 00:45:12 +00001805
Adrian Prantl21361fb2014-08-29 22:44:27 +00001806 BFlags |= getAccessFlag(BI.getAccessSpecifier(), RD);
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00001807 llvm::DIType *DTy = DBuilder.createInheritance(RecordTy, BaseTy, BaseOffset,
1808 VBPtrOffset, BFlags);
Guy Benyei11169dd2012-12-18 14:30:41 +00001809 EltTys.push_back(DTy);
1810 }
1811}
1812
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001813llvm::DINodeArray
Eric Christophere7b87e52014-10-26 23:40:33 +00001814CGDebugInfo::CollectTemplateParams(const TemplateParameterList *TPList,
1815 ArrayRef<TemplateArgument> TAList,
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001816 llvm::DIFile *Unit) {
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001817 SmallVector<llvm::Metadata *, 16> TemplateParams;
Guy Benyei11169dd2012-12-18 14:30:41 +00001818 for (unsigned i = 0, e = TAList.size(); i != e; ++i) {
1819 const TemplateArgument &TA = TAList[i];
David Blaikie47c11502013-06-22 18:59:18 +00001820 StringRef Name;
Awanish Pandey7a42bab2020-03-02 10:52:12 +05301821 bool defaultParameter = false;
David Blaikie47c11502013-06-22 18:59:18 +00001822 if (TPList)
1823 Name = TPList->getParam(i)->getName();
David Blaikie38079fd2013-05-10 21:53:14 +00001824 switch (TA.getKind()) {
1825 case TemplateArgument::Type: {
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001826 llvm::DIType *TTy = getOrCreateType(TA.getAsType(), Unit);
Awanish Pandey7a42bab2020-03-02 10:52:12 +05301827
1828 if (TPList)
1829 if (auto *templateType =
1830 dyn_cast_or_null<TemplateTypeParmDecl>(TPList->getParam(i)))
1831 if (templateType->hasDefaultArgument())
1832 defaultParameter =
1833 templateType->getDefaultArgument() == TA.getAsType();
1834
1835 TemplateParams.push_back(DBuilder.createTemplateTypeParameter(
1836 TheCU, Name, TTy, defaultParameter));
1837
David Blaikie38079fd2013-05-10 21:53:14 +00001838 } break;
1839 case TemplateArgument::Integral: {
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001840 llvm::DIType *TTy = getOrCreateType(TA.getIntegralType(), Unit);
Awanish Pandey7a42bab2020-03-02 10:52:12 +05301841 if (TPList && CGM.getCodeGenOpts().DwarfVersion >= 5)
1842 if (auto *templateType =
1843 dyn_cast_or_null<NonTypeTemplateParmDecl>(TPList->getParam(i)))
David Blaikiee9644e62020-04-05 12:49:02 -07001844 if (templateType->hasDefaultArgument() &&
1845 !templateType->getDefaultArgument()->isValueDependent())
David Blaikiedb927192020-04-01 13:00:12 -07001846 defaultParameter = llvm::APSInt::isSameValue(
Awanish Pandey7a42bab2020-03-02 10:52:12 +05301847 templateType->getDefaultArgument()->EvaluateKnownConstInt(
David Blaikiedb927192020-04-01 13:00:12 -07001848 CGM.getContext()),
1849 TA.getAsIntegral());
Awanish Pandey7a42bab2020-03-02 10:52:12 +05301850
Duncan P. N. Exon Smithdadc2b62015-04-21 18:43:54 +00001851 TemplateParams.push_back(DBuilder.createTemplateValueParameter(
Awanish Pandey7a42bab2020-03-02 10:52:12 +05301852 TheCU, Name, TTy, defaultParameter,
Duncan P. N. Exon Smithdadc2b62015-04-21 18:43:54 +00001853 llvm::ConstantInt::get(CGM.getLLVMContext(), TA.getAsIntegral())));
David Blaikie38079fd2013-05-10 21:53:14 +00001854 } break;
1855 case TemplateArgument::Declaration: {
1856 const ValueDecl *D = TA.getAsDecl();
David Blaikieb5c7e6a2014-10-18 02:21:26 +00001857 QualType T = TA.getParamTypeForDecl().getDesugaredType(CGM.getContext());
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001858 llvm::DIType *TTy = getOrCreateType(T, Unit);
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001859 llvm::Constant *V = nullptr;
Michael Liao982cbb62019-03-06 21:16:27 +00001860 // Skip retrieve the value if that template parameter has cuda device
1861 // attribute, i.e. that value is not available at the host side.
1862 if (!CGM.getLangOpts().CUDA || CGM.getLangOpts().CUDAIsDevice ||
1863 !D->hasAttr<CUDADeviceAttr>()) {
1864 const CXXMethodDecl *MD;
1865 // Variable pointer template parameters have a value that is the address
1866 // of the variable.
1867 if (const auto *VD = dyn_cast<VarDecl>(D))
1868 V = CGM.GetAddrOfGlobalVar(VD);
1869 // Member function pointers have special support for building them,
1870 // though this is currently unsupported in LLVM CodeGen.
1871 else if ((MD = dyn_cast<CXXMethodDecl>(D)) && MD->isInstance())
1872 V = CGM.getCXXABI().EmitMemberFunctionPointer(MD);
1873 else if (const auto *FD = dyn_cast<FunctionDecl>(D))
1874 V = CGM.GetAddrOfFunction(FD);
1875 // Member data pointers have special handling too to compute the fixed
1876 // offset within the object.
1877 else if (const auto *MPT =
1878 dyn_cast<MemberPointerType>(T.getTypePtr())) {
1879 // These five lines (& possibly the above member function pointer
1880 // handling) might be able to be refactored to use similar code in
1881 // CodeGenModule::getMemberPointerConstant
1882 uint64_t fieldOffset = CGM.getContext().getFieldOffset(D);
1883 CharUnits chars =
1884 CGM.getContext().toCharUnitsFromBits((int64_t)fieldOffset);
1885 V = CGM.getCXXABI().EmitMemberDataPointer(MPT, chars);
Richard Smithbab6df82020-04-11 22:15:29 -07001886 } else if (const auto *GD = dyn_cast<MSGuidDecl>(D)) {
1887 V = CGM.GetAddrOfMSGuidDecl(GD).getPointer();
Michael Liao982cbb62019-03-06 21:16:27 +00001888 }
Simon Pilgrimcfee2ef2019-10-16 10:38:49 +00001889 assert(V && "Failed to find template parameter pointer");
Michael Liao982cbb62019-03-06 21:16:27 +00001890 V = V->stripPointerCasts();
David Blaikie38079fd2013-05-10 21:53:14 +00001891 }
Duncan P. N. Exon Smithdadc2b62015-04-21 18:43:54 +00001892 TemplateParams.push_back(DBuilder.createTemplateValueParameter(
Awanish Pandey7a42bab2020-03-02 10:52:12 +05301893 TheCU, Name, TTy, defaultParameter, cast_or_null<llvm::Constant>(V)));
David Blaikie38079fd2013-05-10 21:53:14 +00001894 } break;
1895 case TemplateArgument::NullPtr: {
1896 QualType T = TA.getNullPtrType();
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001897 llvm::DIType *TTy = getOrCreateType(T, Unit);
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001898 llvm::Constant *V = nullptr;
David Blaikie38079fd2013-05-10 21:53:14 +00001899 // Special case member data pointer null values since they're actually -1
1900 // instead of zero.
David Majnemer58ed0f32016-07-17 00:39:12 +00001901 if (const auto *MPT = dyn_cast<MemberPointerType>(T.getTypePtr()))
David Blaikie38079fd2013-05-10 21:53:14 +00001902 // But treat member function pointers as simple zero integers because
1903 // it's easier than having a special case in LLVM's CodeGen. If LLVM
1904 // CodeGen grows handling for values of non-null member function
1905 // pointers then perhaps we could remove this special case and rely on
1906 // EmitNullMemberPointer for member function pointers.
1907 if (MPT->isMemberDataPointer())
1908 V = CGM.getCXXABI().EmitNullMemberPointer(MPT);
1909 if (!V)
1910 V = llvm::ConstantInt::get(CGM.Int8Ty, 0);
Awanish Pandey7a42bab2020-03-02 10:52:12 +05301911 TemplateParams.push_back(DBuilder.createTemplateValueParameter(
1912 TheCU, Name, TTy, defaultParameter, V));
David Blaikie38079fd2013-05-10 21:53:14 +00001913 } break;
Duncan P. N. Exon Smithdadc2b62015-04-21 18:43:54 +00001914 case TemplateArgument::Template:
1915 TemplateParams.push_back(DBuilder.createTemplateTemplateParameter(
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +00001916 TheCU, Name, nullptr,
Duncan P. N. Exon Smithdadc2b62015-04-21 18:43:54 +00001917 TA.getAsTemplate().getAsTemplateDecl()->getQualifiedNameAsString()));
1918 break;
1919 case TemplateArgument::Pack:
1920 TemplateParams.push_back(DBuilder.createTemplateParameterPack(
1921 TheCU, Name, nullptr,
1922 CollectTemplateParams(nullptr, TA.getPackAsArray(), Unit)));
1923 break;
David Majnemer5559d472013-08-24 08:21:10 +00001924 case TemplateArgument::Expression: {
1925 const Expr *E = TA.getAsExpr();
1926 QualType T = E->getType();
David Majnemer922ad9f2014-10-24 19:49:04 +00001927 if (E->isGLValue())
1928 T = CGM.getContext().getLValueReferenceType(T);
John McCallde0fe072017-08-15 21:42:52 +00001929 llvm::Constant *V = ConstantEmitter(CGM).emitAbstract(E, T);
David Majnemer5559d472013-08-24 08:21:10 +00001930 assert(V && "Expression in template argument isn't constant");
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001931 llvm::DIType *TTy = getOrCreateType(T, Unit);
Duncan P. N. Exon Smithdadc2b62015-04-21 18:43:54 +00001932 TemplateParams.push_back(DBuilder.createTemplateValueParameter(
Awanish Pandey7a42bab2020-03-02 10:52:12 +05301933 TheCU, Name, TTy, defaultParameter, V->stripPointerCasts()));
David Majnemer5559d472013-08-24 08:21:10 +00001934 } break;
David Blaikie2b93c542013-05-10 23:36:06 +00001935 // And the following should never occur:
David Blaikie38079fd2013-05-10 21:53:14 +00001936 case TemplateArgument::TemplateExpansion:
David Blaikie38079fd2013-05-10 21:53:14 +00001937 case TemplateArgument::Null:
1938 llvm_unreachable(
1939 "These argument types shouldn't exist in concrete types");
Guy Benyei11169dd2012-12-18 14:30:41 +00001940 }
1941 }
1942 return DBuilder.getOrCreateArray(TemplateParams);
1943}
1944
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001945llvm::DINodeArray
Duncan P. N. Exon Smith8e47da42015-04-21 20:07:29 +00001946CGDebugInfo::CollectFunctionTemplateParams(const FunctionDecl *FD,
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001947 llvm::DIFile *Unit) {
Guy Benyei11169dd2012-12-18 14:30:41 +00001948 if (FD->getTemplatedKind() ==
1949 FunctionDecl::TK_FunctionTemplateSpecialization) {
Eric Christophere7b87e52014-10-26 23:40:33 +00001950 const TemplateParameterList *TList = FD->getTemplateSpecializationInfo()
1951 ->getTemplate()
1952 ->getTemplateParameters();
David Blaikie47c11502013-06-22 18:59:18 +00001953 return CollectTemplateParams(
1954 TList, FD->getTemplateSpecializationArgs()->asArray(), Unit);
Guy Benyei11169dd2012-12-18 14:30:41 +00001955 }
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001956 return llvm::DINodeArray();
Guy Benyei11169dd2012-12-18 14:30:41 +00001957}
1958
Matthew Voss20165362018-10-03 18:45:04 +00001959llvm::DINodeArray CGDebugInfo::CollectVarTemplateParams(const VarDecl *VL,
Reid Kleckner2dbd5d82019-05-02 17:45:54 +00001960 llvm::DIFile *Unit) {
1961 // Always get the full list of parameters, not just the ones from the
1962 // specialization. A partial specialization may have fewer parameters than
1963 // there are arguments.
1964 auto *TS = dyn_cast<VarTemplateSpecializationDecl>(VL);
1965 if (!TS)
1966 return llvm::DINodeArray();
1967 VarTemplateDecl *T = TS->getSpecializedTemplate();
1968 const TemplateParameterList *TList = T->getTemplateParameters();
1969 auto TA = TS->getTemplateArgs().asArray();
1970 return CollectTemplateParams(TList, TA, Unit);
Matthew Voss20165362018-10-03 18:45:04 +00001971}
1972
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001973llvm::DINodeArray CGDebugInfo::CollectCXXTemplateParams(
1974 const ClassTemplateSpecializationDecl *TSpecial, llvm::DIFile *Unit) {
Reid Kleckner2dbd5d82019-05-02 17:45:54 +00001975 // Always get the full list of parameters, not just the ones from the
1976 // specialization. A partial specialization may have fewer parameters than
1977 // there are arguments.
Adrian Prantl649f0302014-04-17 01:04:01 +00001978 TemplateParameterList *TPList =
Eric Christophere7b87e52014-10-26 23:40:33 +00001979 TSpecial->getSpecializedTemplate()->getTemplateParameters();
Adrian Prantl2c92e9c2014-04-17 00:30:48 +00001980 const TemplateArgumentList &TAList = TSpecial->getTemplateArgs();
David Blaikie47c11502013-06-22 18:59:18 +00001981 return CollectTemplateParams(TPList, TAList.asArray(), Unit);
Guy Benyei11169dd2012-12-18 14:30:41 +00001982}
1983
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001984llvm::DIType *CGDebugInfo::getOrCreateVTablePtrType(llvm::DIFile *Unit) {
Duncan P. N. Exon Smithb7470232015-04-15 23:48:50 +00001985 if (VTablePtrType)
Guy Benyei11169dd2012-12-18 14:30:41 +00001986 return VTablePtrType;
1987
1988 ASTContext &Context = CGM.getContext();
1989
1990 /* Function type */
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00001991 llvm::Metadata *STy = getOrCreateType(Context.IntTy, Unit);
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00001992 llvm::DITypeRefArray SElements = DBuilder.getOrCreateTypeArray(STy);
Eric Christopher28a6db52015-10-15 06:56:08 +00001993 llvm::DIType *SubTy = DBuilder.createSubroutineType(SElements);
Guy Benyei11169dd2012-12-18 14:30:41 +00001994 unsigned Size = Context.getTypeSize(Context.VoidPtrTy);
Konstantin Zhuravlyovd1ba16e2017-03-08 23:56:48 +00001995 unsigned VtblPtrAddressSpace = CGM.getTarget().getVtblPtrAddressSpace();
1996 Optional<unsigned> DWARFAddressSpace =
1997 CGM.getTarget().getDWARFAddressSpace(VtblPtrAddressSpace);
1998
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00001999 llvm::DIType *vtbl_ptr_type = DBuilder.createPointerType(
2000 SubTy, Size, 0, DWARFAddressSpace, "__vtbl_ptr_type");
Guy Benyei11169dd2012-12-18 14:30:41 +00002001 VTablePtrType = DBuilder.createPointerType(vtbl_ptr_type, Size);
2002 return VTablePtrType;
2003}
2004
Guy Benyei11169dd2012-12-18 14:30:41 +00002005StringRef CGDebugInfo::getVTableName(const CXXRecordDecl *RD) {
Benjamin Kramer1b18a5e2013-09-09 16:39:06 +00002006 // Copy the gdb compatible name on the side and use its reference.
2007 return internString("_vptr$", RD->getNameAsString());
Guy Benyei11169dd2012-12-18 14:30:41 +00002008}
2009
Reid Kleckner105c5652019-04-24 22:45:44 +00002010StringRef CGDebugInfo::getDynamicInitializerName(const VarDecl *VD,
2011 DynamicInitKind StubKind,
2012 llvm::Function *InitFn) {
2013 // If we're not emitting codeview, use the mangled name. For Itanium, this is
2014 // arbitrary.
Alexandre Ganeacaf31662019-11-15 16:21:17 -05002015 if (!CGM.getCodeGenOpts().EmitCodeView)
Reid Kleckner105c5652019-04-24 22:45:44 +00002016 return InitFn->getName();
2017
2018 // Print the normal qualified name for the variable, then break off the last
2019 // NNS, and add the appropriate other text. Clang always prints the global
2020 // variable name without template arguments, so we can use rsplit("::") and
2021 // then recombine the pieces.
2022 SmallString<128> QualifiedGV;
2023 StringRef Quals;
2024 StringRef GVName;
2025 {
2026 llvm::raw_svector_ostream OS(QualifiedGV);
2027 VD->printQualifiedName(OS, getPrintingPolicy());
2028 std::tie(Quals, GVName) = OS.str().rsplit("::");
2029 if (GVName.empty())
2030 std::swap(Quals, GVName);
2031 }
2032
2033 SmallString<128> InitName;
2034 llvm::raw_svector_ostream OS(InitName);
2035 if (!Quals.empty())
2036 OS << Quals << "::";
2037
2038 switch (StubKind) {
2039 case DynamicInitKind::NoStub:
2040 llvm_unreachable("not an initializer");
2041 case DynamicInitKind::Initializer:
2042 OS << "`dynamic initializer for '";
2043 break;
2044 case DynamicInitKind::AtExit:
2045 OS << "`dynamic atexit destructor for '";
2046 break;
2047 }
2048
2049 OS << GVName;
2050
2051 // Add any template specialization args.
2052 if (const auto *VTpl = dyn_cast<VarTemplateSpecializationDecl>(VD)) {
2053 printTemplateArgumentList(OS, VTpl->getTemplateArgs().asArray(),
2054 getPrintingPolicy());
2055 }
2056
2057 OS << '\'';
2058
2059 return internString(OS.str());
2060}
2061
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002062void CGDebugInfo::CollectVTableInfo(const CXXRecordDecl *RD, llvm::DIFile *Unit,
Reid Klecknerdc124992016-08-31 16:11:43 +00002063 SmallVectorImpl<llvm::Metadata *> &EltTys,
2064 llvm::DICompositeType *RecordTy) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002065 // If this class is not dynamic then there is not any vtable info to collect.
2066 if (!RD->isDynamicClass())
2067 return;
2068
Reid Kleckner59812422016-08-31 20:35:01 +00002069 // Don't emit any vtable shape or vptr info if this class doesn't have an
2070 // extendable vfptr. This can happen if the class doesn't have virtual
2071 // methods, or in the MS ABI if those virtual methods only come from virtually
2072 // inherited bases.
2073 const ASTRecordLayout &RL = CGM.getContext().getASTRecordLayout(RD);
2074 if (!RL.hasExtendableVFPtr())
2075 return;
2076
Reid Klecknerdc124992016-08-31 16:11:43 +00002077 // CodeView needs to know how large the vtable of every dynamic class is, so
2078 // emit a special named pointer type into the element list. The vptr type
2079 // points to this type as well.
2080 llvm::DIType *VPtrTy = nullptr;
2081 bool NeedVTableShape = CGM.getCodeGenOpts().EmitCodeView &&
2082 CGM.getTarget().getCXXABI().isMicrosoft();
2083 if (NeedVTableShape) {
2084 uint64_t PtrWidth =
2085 CGM.getContext().getTypeSize(CGM.getContext().VoidPtrTy);
2086 const VTableLayout &VFTLayout =
2087 CGM.getMicrosoftVTableContext().getVFTableLayout(RD, CharUnits::Zero());
2088 unsigned VSlotCount =
Peter Collingbournee53683f2016-09-08 01:14:39 +00002089 VFTLayout.vtable_components().size() - CGM.getLangOpts().RTTIData;
Reid Klecknerdc124992016-08-31 16:11:43 +00002090 unsigned VTableWidth = PtrWidth * VSlotCount;
Konstantin Zhuravlyovd1ba16e2017-03-08 23:56:48 +00002091 unsigned VtblPtrAddressSpace = CGM.getTarget().getVtblPtrAddressSpace();
2092 Optional<unsigned> DWARFAddressSpace =
2093 CGM.getTarget().getDWARFAddressSpace(VtblPtrAddressSpace);
Reid Klecknerdc124992016-08-31 16:11:43 +00002094
2095 // Create a very wide void* type and insert it directly in the element list.
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00002096 llvm::DIType *VTableType = DBuilder.createPointerType(
2097 nullptr, VTableWidth, 0, DWARFAddressSpace, "__vtbl_ptr_type");
Reid Klecknerdc124992016-08-31 16:11:43 +00002098 EltTys.push_back(VTableType);
2099
2100 // The vptr is a pointer to this special vtable type.
2101 VPtrTy = DBuilder.createPointerType(VTableType, PtrWidth);
2102 }
2103
2104 // If there is a primary base then the artificial vptr member lives there.
Reid Klecknerdc124992016-08-31 16:11:43 +00002105 if (RL.getPrimaryBase())
2106 return;
2107
2108 if (!VPtrTy)
2109 VPtrTy = getOrCreateVTablePtrType(Unit);
2110
Guy Benyei11169dd2012-12-18 14:30:41 +00002111 unsigned Size = CGM.getContext().getTypeSize(CGM.getContext().VoidPtrTy);
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00002112 llvm::DIType *VPtrMember =
2113 DBuilder.createMemberType(Unit, getVTableName(RD), Unit, 0, Size, 0, 0,
2114 llvm::DINode::FlagArtificial, VPtrTy);
Reid Klecknerdc124992016-08-31 16:11:43 +00002115 EltTys.push_back(VPtrMember);
Guy Benyei11169dd2012-12-18 14:30:41 +00002116}
2117
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002118llvm::DIType *CGDebugInfo::getOrCreateRecordType(QualType RTy,
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +00002119 SourceLocation Loc) {
Amy Huang53539bb2020-01-13 15:54:54 -08002120 assert(CGM.getCodeGenOpts().hasReducedDebugInfo());
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002121 llvm::DIType *T = getOrCreateType(RTy, getOrCreateFile(Loc));
Guy Benyei11169dd2012-12-18 14:30:41 +00002122 return T;
2123}
2124
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002125llvm::DIType *CGDebugInfo::getOrCreateInterfaceType(QualType D,
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +00002126 SourceLocation Loc) {
Adrian Prantlad9a195e2015-08-27 21:21:19 +00002127 return getOrCreateStandaloneType(D, Loc);
2128}
2129
2130llvm::DIType *CGDebugInfo::getOrCreateStandaloneType(QualType D,
2131 SourceLocation Loc) {
Amy Huang53539bb2020-01-13 15:54:54 -08002132 assert(CGM.getCodeGenOpts().hasReducedDebugInfo());
Adrian Prantlad9a195e2015-08-27 21:21:19 +00002133 assert(!D.isNull() && "null type");
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002134 llvm::DIType *T = getOrCreateType(D, getOrCreateFile(Loc));
Adrian Prantlad9a195e2015-08-27 21:21:19 +00002135 assert(T && "could not create debug info for type");
Adrian Prantl3a884fa2015-08-27 22:56:46 +00002136
Adrian Prantl73409ce2013-03-11 18:33:46 +00002137 RetainedTypes.push_back(D.getAsOpaquePtr());
Guy Benyei11169dd2012-12-18 14:30:41 +00002138 return T;
2139}
2140
Amy Huang0d0334f2019-04-12 20:25:30 +00002141void CGDebugInfo::addHeapAllocSiteMetadata(llvm::Instruction *CI,
2142 QualType D,
2143 SourceLocation Loc) {
2144 llvm::MDNode *node;
2145 if (D.getTypePtr()->isVoidPointerType()) {
2146 node = llvm::MDNode::get(CGM.getLLVMContext(), None);
2147 } else {
2148 QualType PointeeTy = D.getTypePtr()->getPointeeType();
2149 node = getOrCreateType(PointeeTy, getOrCreateFile(Loc));
2150 }
Amy Huangfc79ab92019-04-23 21:12:58 +00002151
Amy Huang0d0334f2019-04-12 20:25:30 +00002152 CI->setMetadata("heapallocsite", node);
2153}
2154
David Blaikie483a9da2014-05-06 18:35:21 +00002155void CGDebugInfo::completeType(const EnumDecl *ED) {
Benjamin Kramer8c305922016-02-02 11:06:51 +00002156 if (DebugKind <= codegenoptions::DebugLineTablesOnly)
David Blaikie483a9da2014-05-06 18:35:21 +00002157 return;
2158 QualType Ty = CGM.getContext().getEnumType(ED);
Eric Christophere7b87e52014-10-26 23:40:33 +00002159 void *TyPtr = Ty.getAsOpaquePtr();
David Blaikie483a9da2014-05-06 18:35:21 +00002160 auto I = TypeCache.find(TyPtr);
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002161 if (I == TypeCache.end() || !cast<llvm::DIType>(I->second)->isForwardDecl())
David Blaikie483a9da2014-05-06 18:35:21 +00002162 return;
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002163 llvm::DIType *Res = CreateTypeDefinition(Ty->castAs<EnumType>());
Duncan P. N. Exon Smith4caa7f22015-04-16 01:00:56 +00002164 assert(!Res->isForwardDecl());
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00002165 TypeCache[TyPtr].reset(Res);
David Blaikie483a9da2014-05-06 18:35:21 +00002166}
2167
David Blaikieb2e86eb2013-08-15 20:49:17 +00002168void CGDebugInfo::completeType(const RecordDecl *RD) {
Benjamin Kramer8c305922016-02-02 11:06:51 +00002169 if (DebugKind > codegenoptions::LimitedDebugInfo ||
David Blaikieb2e86eb2013-08-15 20:49:17 +00002170 !CGM.getLangOpts().CPlusPlus)
2171 completeRequiredType(RD);
2172}
2173
David Blaikieb11c8732017-01-30 06:36:08 +00002174/// Return true if the class or any of its methods are marked dllimport.
2175static bool isClassOrMethodDLLImport(const CXXRecordDecl *RD) {
2176 if (RD->hasAttr<DLLImportAttr>())
2177 return true;
2178 for (const CXXMethodDecl *MD : RD->methods())
2179 if (MD->hasAttr<DLLImportAttr>())
2180 return true;
2181 return false;
2182}
2183
Adrian Prantla43acdc2017-07-24 23:48:51 +00002184/// Does a type definition exist in an imported clang module?
2185static bool isDefinedInClangModule(const RecordDecl *RD) {
2186 // Only definitions that where imported from an AST file come from a module.
2187 if (!RD || !RD->isFromASTFile())
2188 return false;
2189 // Anonymous entities cannot be addressed. Treat them as not from module.
2190 if (!RD->isExternallyVisible() && RD->getName().empty())
2191 return false;
2192 if (auto *CXXDecl = dyn_cast<CXXRecordDecl>(RD)) {
2193 if (!CXXDecl->isCompleteDefinition())
2194 return false;
Adrian Prantlba6fdc52018-10-24 00:06:02 +00002195 // Check wether RD is a template.
Adrian Prantla43acdc2017-07-24 23:48:51 +00002196 auto TemplateKind = CXXDecl->getTemplateSpecializationKind();
2197 if (TemplateKind != TSK_Undeclared) {
Adrian Prantlba6fdc52018-10-24 00:06:02 +00002198 // Unfortunately getOwningModule() isn't accurate enough to find the
2199 // owning module of a ClassTemplateSpecializationDecl that is inside a
2200 // namespace spanning multiple modules.
2201 bool Explicit = false;
2202 if (auto *TD = dyn_cast<ClassTemplateSpecializationDecl>(CXXDecl))
2203 Explicit = TD->isExplicitInstantiationOrSpecialization();
2204 if (!Explicit && CXXDecl->getEnclosingNamespaceContext())
2205 return false;
Adrian Prantla43acdc2017-07-24 23:48:51 +00002206 // This is a template, check the origin of the first member.
2207 if (CXXDecl->field_begin() == CXXDecl->field_end())
2208 return TemplateKind == TSK_ExplicitInstantiationDeclaration;
2209 if (!CXXDecl->field_begin()->isFromASTFile())
2210 return false;
2211 }
2212 }
2213 return true;
2214}
2215
David Blaikie6943dea2013-08-20 01:28:15 +00002216void CGDebugInfo::completeClassData(const RecordDecl *RD) {
David Blaikieb11c8732017-01-30 06:36:08 +00002217 if (auto *CXXRD = dyn_cast<CXXRecordDecl>(RD))
2218 if (CXXRD->isDynamicClass() &&
2219 CGM.getVTableLinkage(CXXRD) ==
2220 llvm::GlobalValue::AvailableExternallyLinkage &&
2221 !isClassOrMethodDLLImport(CXXRD))
2222 return;
Adrian Prantla43acdc2017-07-24 23:48:51 +00002223
2224 if (DebugTypeExtRefs && isDefinedInClangModule(RD->getDefinition()))
2225 return;
2226
David Blaikieb11c8732017-01-30 06:36:08 +00002227 completeClass(RD);
2228}
2229
2230void CGDebugInfo::completeClass(const RecordDecl *RD) {
Benjamin Kramer8c305922016-02-02 11:06:51 +00002231 if (DebugKind <= codegenoptions::DebugLineTablesOnly)
Michael Gottesman349542b2013-08-19 18:46:16 +00002232 return;
David Blaikie6943dea2013-08-20 01:28:15 +00002233 QualType Ty = CGM.getContext().getRecordType(RD);
Eric Christophere7b87e52014-10-26 23:40:33 +00002234 void *TyPtr = Ty.getAsOpaquePtr();
David Blaikieef8a9512014-05-05 23:23:53 +00002235 auto I = TypeCache.find(TyPtr);
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002236 if (I != TypeCache.end() && !cast<llvm::DIType>(I->second)->isForwardDecl())
David Blaikieb2e86eb2013-08-15 20:49:17 +00002237 return;
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002238 llvm::DIType *Res = CreateTypeDefinition(Ty->castAs<RecordType>());
Duncan P. N. Exon Smith4caa7f22015-04-16 01:00:56 +00002239 assert(!Res->isForwardDecl());
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00002240 TypeCache[TyPtr].reset(Res);
David Blaikieb2e86eb2013-08-15 20:49:17 +00002241}
2242
David Blaikie0e716b42014-03-03 23:48:23 +00002243static bool hasExplicitMemberDefinition(CXXRecordDecl::method_iterator I,
2244 CXXRecordDecl::method_iterator End) {
David Majnemer58ed0f32016-07-17 00:39:12 +00002245 for (CXXMethodDecl *MD : llvm::make_range(I, End))
2246 if (FunctionDecl *Tmpl = MD->getInstantiatedFromMemberFunction())
David Blaikief7f21852014-03-04 03:08:14 +00002247 if (!Tmpl->isImplicit() && Tmpl->isThisDeclarationADefinition() &&
David Majnemer58ed0f32016-07-17 00:39:12 +00002248 !MD->getMemberSpecializationInfo()->isExplicitSpecialization())
David Blaikie0e716b42014-03-03 23:48:23 +00002249 return true;
2250 return false;
2251}
2252
Benjamin Kramer8c305922016-02-02 11:06:51 +00002253static bool shouldOmitDefinition(codegenoptions::DebugInfoKind DebugKind,
2254 bool DebugTypeExtRefs, const RecordDecl *RD,
David Blaikie0e716b42014-03-03 23:48:23 +00002255 const LangOptions &LangOpts) {
Adrian Prantl88d79172016-04-26 21:58:18 +00002256 if (DebugTypeExtRefs && isDefinedInClangModule(RD->getDefinition()))
Adrian Prantl43e00812016-01-19 23:42:53 +00002257 return true;
Adrian Prantl5c8bd882015-09-11 17:23:08 +00002258
David Blaikie1ac9c982017-04-11 21:13:37 +00002259 if (auto *ES = RD->getASTContext().getExternalSource())
2260 if (ES->hasExternalDefinitions(RD) == ExternalASTSource::EK_Always)
2261 return true;
2262
Benjamin Kramer8c305922016-02-02 11:06:51 +00002263 if (DebugKind > codegenoptions::LimitedDebugInfo)
David Blaikie0e716b42014-03-03 23:48:23 +00002264 return false;
2265
2266 if (!LangOpts.CPlusPlus)
2267 return false;
2268
2269 if (!RD->isCompleteDefinitionRequired())
2270 return true;
2271
David Majnemer58ed0f32016-07-17 00:39:12 +00002272 const auto *CXXDecl = dyn_cast<CXXRecordDecl>(RD);
David Blaikie0e716b42014-03-03 23:48:23 +00002273
2274 if (!CXXDecl)
2275 return false;
2276
Adrian McCarthy99242982016-08-16 22:11:18 +00002277 // Only emit complete debug info for a dynamic class when its vtable is
2278 // emitted. However, Microsoft debuggers don't resolve type information
Reid Klecknerc9404e12016-09-09 16:27:04 +00002279 // across DLL boundaries, so skip this optimization if the class or any of its
2280 // methods are marked dllimport. This isn't a complete solution, since objects
2281 // without any dllimport methods can be used in one DLL and constructed in
2282 // another, but it is the current behavior of LimitedDebugInfo.
Adrian McCarthy99242982016-08-16 22:11:18 +00002283 if (CXXDecl->hasDefinition() && CXXDecl->isDynamicClass() &&
Reid Klecknerc9404e12016-09-09 16:27:04 +00002284 !isClassOrMethodDLLImport(CXXDecl))
David Blaikie0e716b42014-03-03 23:48:23 +00002285 return true;
2286
Amy Huang651128f2020-01-03 16:28:48 -08002287 // In constructor debug mode, only emit debug info for a class when its
2288 // constructor is emitted. Skip this optimization if the class or any of
2289 // its methods are marked dllimport.
2290 if (DebugKind == codegenoptions::DebugInfoConstructor &&
Amy Huang11a04a62020-03-31 13:31:42 -07002291 !CXXDecl->isLambda() && !CXXDecl->hasConstexprNonCopyMoveConstructor() &&
2292 !isClassOrMethodDLLImport(CXXDecl))
2293 for (const auto *Ctor : CXXDecl->ctors())
Amy Huang651128f2020-01-03 16:28:48 -08002294 if (Ctor->isUserProvided())
2295 return true;
Amy Huang651128f2020-01-03 16:28:48 -08002296
David Blaikie0e716b42014-03-03 23:48:23 +00002297 TemplateSpecializationKind Spec = TSK_Undeclared;
David Majnemer58ed0f32016-07-17 00:39:12 +00002298 if (const auto *SD = dyn_cast<ClassTemplateSpecializationDecl>(RD))
David Blaikie0e716b42014-03-03 23:48:23 +00002299 Spec = SD->getSpecializationKind();
2300
2301 if (Spec == TSK_ExplicitInstantiationDeclaration &&
2302 hasExplicitMemberDefinition(CXXDecl->method_begin(),
2303 CXXDecl->method_end()))
2304 return true;
2305
2306 return false;
2307}
2308
Reid Kleckner6c7b1c62016-09-13 00:01:23 +00002309void CGDebugInfo::completeRequiredType(const RecordDecl *RD) {
2310 if (shouldOmitDefinition(DebugKind, DebugTypeExtRefs, RD, CGM.getLangOpts()))
2311 return;
2312
2313 QualType Ty = CGM.getContext().getRecordType(RD);
2314 llvm::DIType *T = getTypeOrNull(Ty);
2315 if (T && T->isForwardDecl())
2316 completeClassData(RD);
2317}
2318
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002319llvm::DIType *CGDebugInfo::CreateType(const RecordType *Ty) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002320 RecordDecl *RD = Ty->getDecl();
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002321 llvm::DIType *T = cast_or_null<llvm::DIType>(getTypeOrNull(QualType(Ty, 0)));
Adrian Prantl5c8bd882015-09-11 17:23:08 +00002322 if (T || shouldOmitDefinition(DebugKind, DebugTypeExtRefs, RD,
2323 CGM.getLangOpts())) {
David Blaikie3b1cc9b2013-09-06 06:45:04 +00002324 if (!T)
Adrian Prantl6ec370a2015-09-10 18:39:45 +00002325 T = getOrCreateRecordFwdDecl(Ty, getDeclContextDescriptor(RD));
David Blaikie3b1cc9b2013-09-06 06:45:04 +00002326 return T;
David Blaikiee36464c2013-06-05 05:32:23 +00002327 }
Guy Benyei11169dd2012-12-18 14:30:41 +00002328
David Blaikieb2e86eb2013-08-15 20:49:17 +00002329 return CreateTypeDefinition(Ty);
2330}
2331
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002332llvm::DIType *CGDebugInfo::CreateTypeDefinition(const RecordType *Ty) {
David Blaikieb2e86eb2013-08-15 20:49:17 +00002333 RecordDecl *RD = Ty->getDecl();
2334
Guy Benyei11169dd2012-12-18 14:30:41 +00002335 // Get overall information about the record type for the debug info.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002336 llvm::DIFile *DefUnit = getOrCreateFile(RD->getLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00002337
2338 // Records and classes and unions can all be recursive. To handle them, we
2339 // first generate a debug descriptor for the struct as a forward declaration.
2340 // Then (if it is a definition) we go through and get debug info for all of
2341 // its members. Finally, we create a descriptor for the complete type (which
2342 // may refer to the forward decl if the struct is recursive) and replace all
2343 // uses of the forward declaration with the final definition.
Duncan P. N. Exon Smithbd210e62015-07-24 20:34:41 +00002344 llvm::DICompositeType *FwdDecl = getOrCreateLimitedType(Ty, DefUnit);
Guy Benyei11169dd2012-12-18 14:30:41 +00002345
Adrian Prantl5f66bae2015-02-11 17:45:15 +00002346 const RecordDecl *D = RD->getDefinition();
2347 if (!D || !D->isCompleteDefinition())
Guy Benyei11169dd2012-12-18 14:30:41 +00002348 return FwdDecl;
2349
David Majnemer58ed0f32016-07-17 00:39:12 +00002350 if (const auto *CXXDecl = dyn_cast<CXXRecordDecl>(RD))
David Blaikieadfbf992013-08-18 16:55:33 +00002351 CollectContainingType(CXXDecl, FwdDecl);
2352
Guy Benyei11169dd2012-12-18 14:30:41 +00002353 // Push the struct on region stack.
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00002354 LexicalBlockStack.emplace_back(&*FwdDecl);
2355 RegionMap[Ty->getDecl()].reset(FwdDecl);
Guy Benyei11169dd2012-12-18 14:30:41 +00002356
Guy Benyei11169dd2012-12-18 14:30:41 +00002357 // Convert all the elements.
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00002358 SmallVector<llvm::Metadata *, 16> EltTys;
David Blaikie6943dea2013-08-20 01:28:15 +00002359 // what about nested types?
Guy Benyei11169dd2012-12-18 14:30:41 +00002360
2361 // Note: The split of CXXDecl information here is intentional, the
2362 // gdb tests will depend on a certain ordering at printout. The debug
2363 // information offsets are still correct if we merge them all together
2364 // though.
David Majnemer58ed0f32016-07-17 00:39:12 +00002365 const auto *CXXDecl = dyn_cast<CXXRecordDecl>(RD);
Guy Benyei11169dd2012-12-18 14:30:41 +00002366 if (CXXDecl) {
2367 CollectCXXBases(CXXDecl, DefUnit, EltTys, FwdDecl);
Reid Klecknerdc124992016-08-31 16:11:43 +00002368 CollectVTableInfo(CXXDecl, DefUnit, EltTys, FwdDecl);
Guy Benyei11169dd2012-12-18 14:30:41 +00002369 }
2370
Eric Christopher91a31902013-01-16 01:22:32 +00002371 // Collect data fields (including static variables and any initializers).
Guy Benyei11169dd2012-12-18 14:30:41 +00002372 CollectRecordFields(RD, DefUnit, EltTys, FwdDecl);
Eric Christopher2df080e2013-10-11 18:16:51 +00002373 if (CXXDecl)
Guy Benyei11169dd2012-12-18 14:30:41 +00002374 CollectCXXMemberFunctions(CXXDecl, DefUnit, EltTys, FwdDecl);
Guy Benyei11169dd2012-12-18 14:30:41 +00002375
2376 LexicalBlockStack.pop_back();
2377 RegionMap.erase(Ty->getDecl());
2378
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002379 llvm::DINodeArray Elements = DBuilder.getOrCreateArray(EltTys);
Duncan P. N. Exon Smithc8ee63e2014-12-18 00:48:56 +00002380 DBuilder.replaceArrays(FwdDecl, Elements);
Guy Benyei11169dd2012-12-18 14:30:41 +00002381
Adrian Prantl5f66bae2015-02-11 17:45:15 +00002382 if (FwdDecl->isTemporary())
Duncan P. N. Exon Smith4078ad42015-04-16 16:36:45 +00002383 FwdDecl =
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002384 llvm::MDNode::replaceWithPermanent(llvm::TempDICompositeType(FwdDecl));
Adrian Prantl5f66bae2015-02-11 17:45:15 +00002385
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00002386 RegionMap[Ty->getDecl()].reset(FwdDecl);
Eric Christopher5c7ee8b2013-04-02 22:59:11 +00002387 return FwdDecl;
Guy Benyei11169dd2012-12-18 14:30:41 +00002388}
2389
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002390llvm::DIType *CGDebugInfo::CreateType(const ObjCObjectType *Ty,
2391 llvm::DIFile *Unit) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002392 // Ignore protocols.
2393 return getOrCreateType(Ty->getBaseType(), Unit);
2394}
2395
Manman Rene6be26c2016-09-13 17:25:08 +00002396llvm::DIType *CGDebugInfo::CreateType(const ObjCTypeParamType *Ty,
2397 llvm::DIFile *Unit) {
2398 // Ignore protocols.
2399 SourceLocation Loc = Ty->getDecl()->getLocation();
2400
2401 // Use Typedefs to represent ObjCTypeParamType.
2402 return DBuilder.createTypedef(
2403 getOrCreateType(Ty->getDecl()->getUnderlyingType(), Unit),
2404 Ty->getDecl()->getName(), getOrCreateFile(Loc), getLineNumber(Loc),
Sam McCalld27a16e2019-11-18 15:53:22 +01002405 getDeclContextDescriptor(Ty->getDecl()));
Manman Rene6be26c2016-09-13 17:25:08 +00002406}
2407
Adrian Prantlb8fad1a2013-06-07 01:10:45 +00002408/// \return true if Getter has the default name for the property PD.
2409static bool hasDefaultGetterName(const ObjCPropertyDecl *PD,
2410 const ObjCMethodDecl *Getter) {
2411 assert(PD);
2412 if (!Getter)
2413 return true;
2414
2415 assert(Getter->getDeclName().isObjCZeroArgSelector());
2416 return PD->getName() ==
Eric Christophere7b87e52014-10-26 23:40:33 +00002417 Getter->getDeclName().getObjCSelector().getNameForSlot(0);
Adrian Prantlb8fad1a2013-06-07 01:10:45 +00002418}
2419
2420/// \return true if Setter has the default name for the property PD.
2421static bool hasDefaultSetterName(const ObjCPropertyDecl *PD,
2422 const ObjCMethodDecl *Setter) {
2423 assert(PD);
2424 if (!Setter)
2425 return true;
2426
2427 assert(Setter->getDeclName().isObjCOneArgSelector());
Adrian Prantla4ce9062013-06-07 22:29:12 +00002428 return SelectorTable::constructSetterName(PD->getName()) ==
Eric Christophere7b87e52014-10-26 23:40:33 +00002429 Setter->getDeclName().getObjCSelector().getNameForSlot(0);
Adrian Prantlb8fad1a2013-06-07 01:10:45 +00002430}
2431
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002432llvm::DIType *CGDebugInfo::CreateType(const ObjCInterfaceType *Ty,
2433 llvm::DIFile *Unit) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002434 ObjCInterfaceDecl *ID = Ty->getDecl();
2435 if (!ID)
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +00002436 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00002437
Adrian Prantl50fd1a82016-04-20 23:59:32 +00002438 // Return a forward declaration if this type was imported from a clang module,
2439 // and this is not the compile unit with the implementation of the type (which
2440 // may contain hidden ivars).
2441 if (DebugTypeExtRefs && ID->isFromASTFile() && ID->getDefinition() &&
2442 !ID->getImplementation())
Adrian Prantl5c8bd882015-09-11 17:23:08 +00002443 return DBuilder.createForwardDecl(llvm::dwarf::DW_TAG_structure_type,
2444 ID->getName(),
2445 getDeclContextDescriptor(ID), Unit, 0);
2446
Guy Benyei11169dd2012-12-18 14:30:41 +00002447 // Get overall information about the record type for the debug info.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002448 llvm::DIFile *DefUnit = getOrCreateFile(ID->getLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00002449 unsigned Line = getLineNumber(ID->getLocation());
Duncan P. N. Exon Smith798d5652015-04-15 23:19:15 +00002450 auto RuntimeLang =
2451 static_cast<llvm::dwarf::SourceLanguage>(TheCU->getSourceLanguage());
Guy Benyei11169dd2012-12-18 14:30:41 +00002452
2453 // If this is just a forward declaration return a special forward-declaration
2454 // debug type since we won't be able to lay out the entire type.
2455 ObjCInterfaceDecl *Def = ID->getDefinition();
David Blaikieef8a9512014-05-05 23:23:53 +00002456 if (!Def || !Def->getImplementation()) {
Adrian Prantl42ce2d32015-10-01 16:57:02 +00002457 llvm::DIScope *Mod = getParentModuleOrNull(ID);
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002458 llvm::DIType *FwdDecl = DBuilder.createReplaceableCompositeType(
Adrian Prantl42ce2d32015-10-01 16:57:02 +00002459 llvm::dwarf::DW_TAG_structure_type, ID->getName(), Mod ? Mod : TheCU,
2460 DefUnit, Line, RuntimeLang);
David Blaikieef8a9512014-05-05 23:23:53 +00002461 ObjCInterfaceCache.push_back(ObjCInterfaceCacheEntry(Ty, FwdDecl, Unit));
Guy Benyei11169dd2012-12-18 14:30:41 +00002462 return FwdDecl;
2463 }
2464
David Blaikieef8a9512014-05-05 23:23:53 +00002465 return CreateTypeDefinition(Ty, Unit);
2466}
2467
Reid Klecknerc915cb92020-02-27 18:13:54 -08002468llvm::DIModule *CGDebugInfo::getOrCreateModuleRef(ASTSourceDescriptor Mod,
2469 bool CreateSkeletonCU) {
Adrian Prantleb66a262015-09-24 16:10:04 +00002470 // Use the Module pointer as the key into the cache. This is a
2471 // nullptr if the "Module" is a PCH, which is safe because we don't
2472 // support chained PCH debug info, so there can only be a single PCH.
2473 const Module *M = Mod.getModuleOrNull();
Adrian Prantl9e8ea352015-09-29 20:44:46 +00002474 auto ModRef = ModuleCache.find(M);
2475 if (ModRef != ModuleCache.end())
2476 return cast<llvm::DIModule>(ModRef->second);
Adrian Prantl2388ead2015-06-30 18:01:05 +00002477
2478 // Macro definitions that were defined with "-D" on the command line.
2479 SmallString<128> ConfigMacros;
2480 {
2481 llvm::raw_svector_ostream OS(ConfigMacros);
2482 const auto &PPOpts = CGM.getPreprocessorOpts();
2483 unsigned I = 0;
Alexander Kornienko2a8c18d2018-04-06 15:14:32 +00002484 // Translate the macro definitions back into a command line.
Adrian Prantl2388ead2015-06-30 18:01:05 +00002485 for (auto &M : PPOpts.Macros) {
2486 if (++I > 1)
2487 OS << " ";
2488 const std::string &Macro = M.first;
2489 bool Undef = M.second;
2490 OS << "\"-" << (Undef ? 'U' : 'D');
2491 for (char c : Macro)
2492 switch (c) {
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00002493 case '\\':
2494 OS << "\\\\";
2495 break;
2496 case '"':
2497 OS << "\\\"";
2498 break;
2499 default:
2500 OS << c;
Adrian Prantl2388ead2015-06-30 18:01:05 +00002501 }
2502 OS << '\"';
Adrian Prantlc4bb47e2015-06-30 17:39:51 +00002503 }
Adrian Prantlc4bb47e2015-06-30 17:39:51 +00002504 }
Adrian Prantl66689202015-09-18 23:01:45 +00002505
Adrian Prantl835e6632015-09-24 16:10:10 +00002506 bool IsRootModule = M ? !M->Parent : true;
Adrian Prantl7b6b9a12019-02-08 23:15:42 +00002507 // When a module name is specified as -fmodule-name, that module gets a
2508 // clang::Module object, but it won't actually be built or imported; it will
2509 // be textual.
Adrian Prantle308e422019-02-15 20:24:26 +00002510 if (CreateSkeletonCU && IsRootModule && Mod.getASTFile().empty() && M)
2511 assert(StringRef(M->Name).startswith(CGM.getLangOpts().ModuleName) &&
Adrian Prantl7b6b9a12019-02-08 23:15:42 +00002512 "clang module without ASTFile must be specified by -fmodule-name");
2513
Adrian Prantl22d5bd02020-03-18 15:30:20 -07002514 // Return a StringRef to the remapped Path.
2515 auto RemapPath = [this](StringRef Path) -> std::string {
2516 std::string Remapped = remapDIPath(Path);
2517 StringRef Relative(Remapped);
2518 StringRef CompDir = TheCU->getDirectory();
2519 if (Relative.consume_front(CompDir))
2520 Relative.consume_front(llvm::sys::path::get_separator());
2521
2522 return Relative.str();
2523 };
2524
Adrian Prantl7b6b9a12019-02-08 23:15:42 +00002525 if (CreateSkeletonCU && IsRootModule && !Mod.getASTFile().empty()) {
Adrian Prantlc96da8f2016-01-22 17:43:43 +00002526 // PCH files don't have a signature field in the control block,
2527 // but LLVM detects skeleton CUs by looking for a non-zero DWO id.
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00002528 // We use the lower 64 bits for debug info.
2529 uint64_t Signature =
2530 Mod.getSignature()
2531 ? (uint64_t)Mod.getSignature()[1] << 32 | Mod.getSignature()[0]
2532 : ~1ULL;
Adrian Prantl66689202015-09-18 23:01:45 +00002533 llvm::DIBuilder DIB(CGM.getModule());
Adrian Prantl079c6dd2020-03-18 13:14:07 -07002534 SmallString<0> PCM;
Adrian Prantl43580a52020-03-18 13:15:14 -07002535 if (!llvm::sys::path::is_absolute(Mod.getASTFile()))
Adrian Prantl079c6dd2020-03-18 13:14:07 -07002536 PCM = Mod.getPath();
2537 llvm::sys::path::append(PCM, Mod.getASTFile());
Adrian Prantl22d5bd02020-03-18 15:30:20 -07002538 DIB.createCompileUnit(
2539 TheCU->getSourceLanguage(),
2540 // TODO: Support "Source" from external AST providers?
2541 DIB.createFile(Mod.getModuleName(), TheCU->getDirectory()),
2542 TheCU->getProducer(), false, StringRef(), 0, RemapPath(PCM),
2543 llvm::DICompileUnit::FullDebug, Signature);
Adrian Prantl66689202015-09-18 23:01:45 +00002544 DIB.finalize();
Adrian Prantl2f957ac2015-09-19 00:59:22 +00002545 }
Adrian Prantl7b6b9a12019-02-08 23:15:42 +00002546
Adrian Prantl835e6632015-09-24 16:10:10 +00002547 llvm::DIModule *Parent =
2548 IsRootModule ? nullptr
Reid Klecknerc915cb92020-02-27 18:13:54 -08002549 : getOrCreateModuleRef(ASTSourceDescriptor(*M->Parent),
2550 CreateSkeletonCU);
Adrian Prantl22d5bd02020-03-18 15:30:20 -07002551 std::string IncludePath = Mod.getPath().str();
Adrian Prantleb66a262015-09-24 16:10:04 +00002552 llvm::DIModule *DIMod =
Adrian Prantl835e6632015-09-24 16:10:10 +00002553 DBuilder.createModule(Parent, Mod.getModuleName(), ConfigMacros,
Adrian Prantl22d5bd02020-03-18 15:30:20 -07002554 RemapPath(IncludePath));
Adrian Prantl9e8ea352015-09-29 20:44:46 +00002555 ModuleCache[M].reset(DIMod);
Adrian Prantleb66a262015-09-24 16:10:04 +00002556 return DIMod;
Adrian Prantlc4bb47e2015-06-30 17:39:51 +00002557}
2558
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002559llvm::DIType *CGDebugInfo::CreateTypeDefinition(const ObjCInterfaceType *Ty,
2560 llvm::DIFile *Unit) {
David Blaikieef8a9512014-05-05 23:23:53 +00002561 ObjCInterfaceDecl *ID = Ty->getDecl();
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002562 llvm::DIFile *DefUnit = getOrCreateFile(ID->getLocation());
David Blaikieef8a9512014-05-05 23:23:53 +00002563 unsigned Line = getLineNumber(ID->getLocation());
Duncan P. N. Exon Smith798d5652015-04-15 23:19:15 +00002564 unsigned RuntimeLang = TheCU->getSourceLanguage();
Guy Benyei11169dd2012-12-18 14:30:41 +00002565
2566 // Bit size, align and offset of the type.
2567 uint64_t Size = CGM.getContext().getTypeSize(Ty);
Victor Leschuka7ece032016-10-20 00:13:19 +00002568 auto Align = getTypeAlignIfRequired(Ty, CGM.getContext());
Guy Benyei11169dd2012-12-18 14:30:41 +00002569
Leny Kholodov80c047d2016-09-06 10:48:04 +00002570 llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
Guy Benyei11169dd2012-12-18 14:30:41 +00002571 if (ID->getImplementation())
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002572 Flags |= llvm::DINode::FlagObjcClassComplete;
Guy Benyei11169dd2012-12-18 14:30:41 +00002573
Adrian Prantlfd696112015-10-01 00:48:51 +00002574 llvm::DIScope *Mod = getParentModuleOrNull(ID);
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002575 llvm::DICompositeType *RealDecl = DBuilder.createStructType(
Adrian Prantlfd696112015-10-01 00:48:51 +00002576 Mod ? Mod : Unit, ID->getName(), DefUnit, Line, Size, Align, Flags,
2577 nullptr, llvm::DINodeArray(), RuntimeLang);
Guy Benyei11169dd2012-12-18 14:30:41 +00002578
David Blaikieef8a9512014-05-05 23:23:53 +00002579 QualType QTy(Ty, 0);
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00002580 TypeCache[QTy.getAsOpaquePtr()].reset(RealDecl);
Guy Benyei11169dd2012-12-18 14:30:41 +00002581
Eric Christopher35f1f9f2013-07-14 21:00:07 +00002582 // Push the struct on region stack.
Duncan P. N. Exon Smith4078ad42015-04-16 16:36:45 +00002583 LexicalBlockStack.emplace_back(RealDecl);
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00002584 RegionMap[Ty->getDecl()].reset(RealDecl);
Guy Benyei11169dd2012-12-18 14:30:41 +00002585
2586 // Convert all the elements.
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00002587 SmallVector<llvm::Metadata *, 16> EltTys;
Guy Benyei11169dd2012-12-18 14:30:41 +00002588
2589 ObjCInterfaceDecl *SClass = ID->getSuperClass();
2590 if (SClass) {
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002591 llvm::DIType *SClassTy =
Eric Christophere7b87e52014-10-26 23:40:33 +00002592 getOrCreateType(CGM.getContext().getObjCInterfaceType(SClass), Unit);
Duncan P. N. Exon Smithb7470232015-04-15 23:48:50 +00002593 if (!SClassTy)
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +00002594 return nullptr;
Eric Christopherb2a008c2013-05-16 00:45:12 +00002595
Brock Wyma3db2b102018-05-14 21:21:22 +00002596 llvm::DIType *InhTag = DBuilder.createInheritance(RealDecl, SClassTy, 0, 0,
Leny Kholodovdf050fd2016-09-06 17:06:14 +00002597 llvm::DINode::FlagZero);
Guy Benyei11169dd2012-12-18 14:30:41 +00002598 EltTys.push_back(InhTag);
2599 }
2600
Eric Christopher35f1f9f2013-07-14 21:00:07 +00002601 // Create entries for all of the properties.
Nico Weber7123bca2015-12-04 19:14:14 +00002602 auto AddProperty = [&](const ObjCPropertyDecl *PD) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002603 SourceLocation Loc = PD->getLocation();
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002604 llvm::DIFile *PUnit = getOrCreateFile(Loc);
Guy Benyei11169dd2012-12-18 14:30:41 +00002605 unsigned PLine = getLineNumber(Loc);
2606 ObjCMethodDecl *Getter = PD->getGetterMethodDecl();
2607 ObjCMethodDecl *Setter = PD->getSetterMethodDecl();
Eric Christophere7b87e52014-10-26 23:40:33 +00002608 llvm::MDNode *PropertyNode = DBuilder.createObjCProperty(
2609 PD->getName(), PUnit, PLine,
2610 hasDefaultGetterName(PD, Getter) ? ""
2611 : getSelectorName(PD->getGetterName()),
2612 hasDefaultSetterName(PD, Setter) ? ""
2613 : getSelectorName(PD->getSetterName()),
2614 PD->getPropertyAttributes(), getOrCreateType(PD->getType(), PUnit));
Guy Benyei11169dd2012-12-18 14:30:41 +00002615 EltTys.push_back(PropertyNode);
Nico Weber7123bca2015-12-04 19:14:14 +00002616 };
2617 {
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00002618 llvm::SmallPtrSet<const IdentifierInfo *, 16> PropertySet;
Nico Weberde059e12015-12-04 19:35:45 +00002619 for (const ObjCCategoryDecl *ClassExt : ID->known_extensions())
Manman Renefe1bac2016-01-27 20:00:32 +00002620 for (auto *PD : ClassExt->properties()) {
Nico Weberde059e12015-12-04 19:35:45 +00002621 PropertySet.insert(PD->getIdentifier());
2622 AddProperty(PD);
2623 }
Manman Renefe1bac2016-01-27 20:00:32 +00002624 for (const auto *PD : ID->properties()) {
Nico Weber7123bca2015-12-04 19:14:14 +00002625 // Don't emit duplicate metadata for properties that were already in a
2626 // class extension.
2627 if (!PropertySet.insert(PD->getIdentifier()).second)
2628 continue;
2629 AddProperty(PD);
2630 }
Guy Benyei11169dd2012-12-18 14:30:41 +00002631 }
2632
2633 const ASTRecordLayout &RL = CGM.getContext().getASTObjCInterfaceLayout(ID);
2634 unsigned FieldNo = 0;
2635 for (ObjCIvarDecl *Field = ID->all_declared_ivar_begin(); Field;
2636 Field = Field->getNextIvar(), ++FieldNo) {
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002637 llvm::DIType *FieldTy = getOrCreateType(Field->getType(), Unit);
Duncan P. N. Exon Smithb7470232015-04-15 23:48:50 +00002638 if (!FieldTy)
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +00002639 return nullptr;
Eric Christopherb2a008c2013-05-16 00:45:12 +00002640
Guy Benyei11169dd2012-12-18 14:30:41 +00002641 StringRef FieldName = Field->getName();
2642
2643 // Ignore unnamed fields.
2644 if (FieldName.empty())
2645 continue;
2646
2647 // Get the location for the field.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002648 llvm::DIFile *FieldDefUnit = getOrCreateFile(Field->getLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00002649 unsigned FieldLine = getLineNumber(Field->getLocation());
2650 QualType FType = Field->getType();
2651 uint64_t FieldSize = 0;
Victor Leschuk802e4a52016-10-19 22:11:07 +00002652 uint32_t FieldAlign = 0;
Guy Benyei11169dd2012-12-18 14:30:41 +00002653
2654 if (!FType->isIncompleteArrayType()) {
2655
2656 // Bit size, align and offset of the type.
2657 FieldSize = Field->isBitField()
Eric Christopher35f1f9f2013-07-14 21:00:07 +00002658 ? Field->getBitWidthValue(CGM.getContext())
2659 : CGM.getContext().getTypeSize(FType);
Victor Leschuka7ece032016-10-20 00:13:19 +00002660 FieldAlign = getTypeAlignIfRequired(FType, CGM.getContext());
Guy Benyei11169dd2012-12-18 14:30:41 +00002661 }
2662
2663 uint64_t FieldOffset;
2664 if (CGM.getLangOpts().ObjCRuntime.isNonFragile()) {
2665 // We don't know the runtime offset of an ivar if we're using the
2666 // non-fragile ABI. For bitfields, use the bit offset into the first
2667 // byte of storage of the bitfield. For other fields, use zero.
2668 if (Field->isBitField()) {
Eric Christophere7b87e52014-10-26 23:40:33 +00002669 FieldOffset =
2670 CGM.getObjCRuntime().ComputeBitfieldBitOffset(CGM, ID, Field);
Guy Benyei11169dd2012-12-18 14:30:41 +00002671 FieldOffset %= CGM.getContext().getCharWidth();
2672 } else {
2673 FieldOffset = 0;
2674 }
2675 } else {
2676 FieldOffset = RL.getFieldOffset(FieldNo);
2677 }
2678
Leny Kholodov80c047d2016-09-06 10:48:04 +00002679 llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
Guy Benyei11169dd2012-12-18 14:30:41 +00002680 if (Field->getAccessControl() == ObjCIvarDecl::Protected)
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002681 Flags = llvm::DINode::FlagProtected;
Guy Benyei11169dd2012-12-18 14:30:41 +00002682 else if (Field->getAccessControl() == ObjCIvarDecl::Private)
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002683 Flags = llvm::DINode::FlagPrivate;
Adrian Prantl21361fb2014-08-29 22:44:27 +00002684 else if (Field->getAccessControl() == ObjCIvarDecl::Public)
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002685 Flags = llvm::DINode::FlagPublic;
Guy Benyei11169dd2012-12-18 14:30:41 +00002686
Craig Topper8a13c412014-05-21 05:09:00 +00002687 llvm::MDNode *PropertyNode = nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00002688 if (ObjCImplementationDecl *ImpD = ID->getImplementation()) {
Eric Christopherb2a008c2013-05-16 00:45:12 +00002689 if (ObjCPropertyImplDecl *PImpD =
Eric Christophere7b87e52014-10-26 23:40:33 +00002690 ImpD->FindPropertyImplIvarDecl(Field->getIdentifier())) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002691 if (ObjCPropertyDecl *PD = PImpD->getPropertyDecl()) {
Eric Christopherc0c5d462013-02-21 22:35:08 +00002692 SourceLocation Loc = PD->getLocation();
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002693 llvm::DIFile *PUnit = getOrCreateFile(Loc);
Eric Christopherc0c5d462013-02-21 22:35:08 +00002694 unsigned PLine = getLineNumber(Loc);
Adrian Prantl901cc4a2019-11-08 09:24:31 -08002695 ObjCMethodDecl *Getter = PImpD->getGetterMethodDecl();
2696 ObjCMethodDecl *Setter = PImpD->getSetterMethodDecl();
Eric Christophere7b87e52014-10-26 23:40:33 +00002697 PropertyNode = DBuilder.createObjCProperty(
2698 PD->getName(), PUnit, PLine,
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00002699 hasDefaultGetterName(PD, Getter)
2700 ? ""
2701 : getSelectorName(PD->getGetterName()),
2702 hasDefaultSetterName(PD, Setter)
2703 ? ""
2704 : getSelectorName(PD->getSetterName()),
Eric Christophere7b87e52014-10-26 23:40:33 +00002705 PD->getPropertyAttributes(),
2706 getOrCreateType(PD->getType(), PUnit));
Guy Benyei11169dd2012-12-18 14:30:41 +00002707 }
2708 }
2709 }
Eric Christophere7b87e52014-10-26 23:40:33 +00002710 FieldTy = DBuilder.createObjCIVar(FieldName, FieldDefUnit, FieldLine,
2711 FieldSize, FieldAlign, FieldOffset, Flags,
2712 FieldTy, PropertyNode);
Guy Benyei11169dd2012-12-18 14:30:41 +00002713 EltTys.push_back(FieldTy);
2714 }
2715
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002716 llvm::DINodeArray Elements = DBuilder.getOrCreateArray(EltTys);
Duncan P. N. Exon Smithc8ee63e2014-12-18 00:48:56 +00002717 DBuilder.replaceArrays(RealDecl, Elements);
Adrian Prantla03a85a2013-03-06 22:03:30 +00002718
Guy Benyei11169dd2012-12-18 14:30:41 +00002719 LexicalBlockStack.pop_back();
Eric Christopher5c7ee8b2013-04-02 22:59:11 +00002720 return RealDecl;
Guy Benyei11169dd2012-12-18 14:30:41 +00002721}
2722
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002723llvm::DIType *CGDebugInfo::CreateType(const VectorType *Ty,
2724 llvm::DIFile *Unit) {
2725 llvm::DIType *ElementTy = getOrCreateType(Ty->getElementType(), Unit);
Guy Benyei11169dd2012-12-18 14:30:41 +00002726 int64_t Count = Ty->getNumElements();
Guy Benyei11169dd2012-12-18 14:30:41 +00002727
Sander de Smalen891af03a2018-02-03 13:55:59 +00002728 llvm::Metadata *Subscript;
2729 QualType QTy(Ty, 0);
2730 auto SizeExpr = SizeExprCache.find(QTy);
2731 if (SizeExpr != SizeExprCache.end())
2732 Subscript = DBuilder.getOrCreateSubrange(0, SizeExpr->getSecond());
2733 else
2734 Subscript = DBuilder.getOrCreateSubrange(0, Count ? Count : -1);
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002735 llvm::DINodeArray SubscriptArray = DBuilder.getOrCreateArray(Subscript);
Guy Benyei11169dd2012-12-18 14:30:41 +00002736
2737 uint64_t Size = CGM.getContext().getTypeSize(Ty);
Victor Leschuka7ece032016-10-20 00:13:19 +00002738 auto Align = getTypeAlignIfRequired(Ty, CGM.getContext());
Guy Benyei11169dd2012-12-18 14:30:41 +00002739
2740 return DBuilder.createVectorType(Size, Align, ElementTy, SubscriptArray);
2741}
2742
Florian Hahn10658692020-05-11 17:45:51 +01002743llvm::DIType *CGDebugInfo::CreateType(const ConstantMatrixType *Ty,
2744 llvm::DIFile *Unit) {
2745 // FIXME: Create another debug type for matrices
2746 // For the time being, it treats it like a nested ArrayType.
2747
2748 llvm::DIType *ElementTy = getOrCreateType(Ty->getElementType(), Unit);
2749 uint64_t Size = CGM.getContext().getTypeSize(Ty);
2750 uint32_t Align = getTypeAlignIfRequired(Ty, CGM.getContext());
2751
2752 // Create ranges for both dimensions.
2753 llvm::SmallVector<llvm::Metadata *, 2> Subscripts;
2754 Subscripts.push_back(DBuilder.getOrCreateSubrange(0, Ty->getNumColumns()));
2755 Subscripts.push_back(DBuilder.getOrCreateSubrange(0, Ty->getNumRows()));
2756 llvm::DINodeArray SubscriptArray = DBuilder.getOrCreateArray(Subscripts);
2757 return DBuilder.createArrayType(Size, Align, ElementTy, SubscriptArray);
2758}
2759
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002760llvm::DIType *CGDebugInfo::CreateType(const ArrayType *Ty, llvm::DIFile *Unit) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002761 uint64_t Size;
Victor Leschuk802e4a52016-10-19 22:11:07 +00002762 uint32_t Align;
Guy Benyei11169dd2012-12-18 14:30:41 +00002763
2764 // FIXME: make getTypeAlign() aware of VLAs and incomplete array types
David Majnemer58ed0f32016-07-17 00:39:12 +00002765 if (const auto *VAT = dyn_cast<VariableArrayType>(Ty)) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002766 Size = 0;
Victor Leschuka7ece032016-10-20 00:13:19 +00002767 Align = getTypeAlignIfRequired(CGM.getContext().getBaseElementType(VAT),
2768 CGM.getContext());
Guy Benyei11169dd2012-12-18 14:30:41 +00002769 } else if (Ty->isIncompleteArrayType()) {
2770 Size = 0;
2771 if (Ty->getElementType()->isIncompleteType())
2772 Align = 0;
2773 else
Victor Leschuka7ece032016-10-20 00:13:19 +00002774 Align = getTypeAlignIfRequired(Ty->getElementType(), CGM.getContext());
David Blaikief03b2e82013-05-09 20:48:12 +00002775 } else if (Ty->isIncompleteType()) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002776 Size = 0;
2777 Align = 0;
2778 } else {
2779 // Size and align of the whole array, not the element type.
2780 Size = CGM.getContext().getTypeSize(Ty);
Victor Leschuka7ece032016-10-20 00:13:19 +00002781 Align = getTypeAlignIfRequired(Ty, CGM.getContext());
Guy Benyei11169dd2012-12-18 14:30:41 +00002782 }
2783
2784 // Add the dimensions of the array. FIXME: This loses CV qualifiers from
2785 // interior arrays, do we care? Why aren't nested arrays represented the
2786 // obvious/recursive way?
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00002787 SmallVector<llvm::Metadata *, 8> Subscripts;
Guy Benyei11169dd2012-12-18 14:30:41 +00002788 QualType EltTy(Ty, 0);
2789 while ((Ty = dyn_cast<ArrayType>(EltTy))) {
2790 // If the number of elements is known, then count is that number. Otherwise,
2791 // it's -1. This allows us to represent a subrange with an array of 0
2792 // elements, like this:
2793 //
2794 // struct foo {
2795 // int x[0];
2796 // };
Eric Christophere7b87e52014-10-26 23:40:33 +00002797 int64_t Count = -1; // Count == -1 is an unbounded array.
David Majnemer58ed0f32016-07-17 00:39:12 +00002798 if (const auto *CAT = dyn_cast<ConstantArrayType>(Ty))
Guy Benyei11169dd2012-12-18 14:30:41 +00002799 Count = CAT->getSize().getZExtValue();
David Blaikie87173f12016-08-22 17:49:56 +00002800 else if (const auto *VAT = dyn_cast<VariableArrayType>(Ty)) {
Eli Friedman01d6b962016-10-19 22:16:32 +00002801 if (Expr *Size = VAT->getSizeExpr()) {
Fangrui Song407659a2018-11-30 23:41:18 +00002802 Expr::EvalResult Result;
2803 if (Size->EvaluateAsInt(Result, CGM.getContext()))
2804 Count = Result.Val.getInt().getExtValue();
Eli Friedman01d6b962016-10-19 22:16:32 +00002805 }
David Blaikie87173f12016-08-22 17:49:56 +00002806 }
Eric Christopherb2a008c2013-05-16 00:45:12 +00002807
Sander de Smalen891af03a2018-02-03 13:55:59 +00002808 auto SizeNode = SizeExprCache.find(EltTy);
2809 if (SizeNode != SizeExprCache.end())
2810 Subscripts.push_back(
2811 DBuilder.getOrCreateSubrange(0, SizeNode->getSecond()));
2812 else
2813 Subscripts.push_back(DBuilder.getOrCreateSubrange(0, Count));
Guy Benyei11169dd2012-12-18 14:30:41 +00002814 EltTy = Ty->getElementType();
2815 }
2816
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002817 llvm::DINodeArray SubscriptArray = DBuilder.getOrCreateArray(Subscripts);
Guy Benyei11169dd2012-12-18 14:30:41 +00002818
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +00002819 return DBuilder.createArrayType(Size, Align, getOrCreateType(EltTy, Unit),
2820 SubscriptArray);
Guy Benyei11169dd2012-12-18 14:30:41 +00002821}
2822
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002823llvm::DIType *CGDebugInfo::CreateType(const LValueReferenceType *Ty,
2824 llvm::DIFile *Unit) {
Eric Christophere7b87e52014-10-26 23:40:33 +00002825 return CreatePointerLikeType(llvm::dwarf::DW_TAG_reference_type, Ty,
2826 Ty->getPointeeType(), Unit);
Guy Benyei11169dd2012-12-18 14:30:41 +00002827}
2828
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002829llvm::DIType *CGDebugInfo::CreateType(const RValueReferenceType *Ty,
2830 llvm::DIFile *Unit) {
Eric Christophere7b87e52014-10-26 23:40:33 +00002831 return CreatePointerLikeType(llvm::dwarf::DW_TAG_rvalue_reference_type, Ty,
2832 Ty->getPointeeType(), Unit);
Guy Benyei11169dd2012-12-18 14:30:41 +00002833}
2834
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002835llvm::DIType *CGDebugInfo::CreateType(const MemberPointerType *Ty,
2836 llvm::DIFile *U) {
Leny Kholodov80c047d2016-09-06 10:48:04 +00002837 llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
Reid Klecknerfb727182016-06-17 22:27:59 +00002838 uint64_t Size = 0;
2839
2840 if (!Ty->isIncompleteType()) {
2841 Size = CGM.getContext().getTypeSize(Ty);
2842
2843 // Set the MS inheritance model. There is no flag for the unspecified model.
2844 if (CGM.getTarget().getCXXABI().isMicrosoft()) {
2845 switch (Ty->getMostRecentCXXRecordDecl()->getMSInheritanceModel()) {
Reid Klecknera9cc64e2019-11-15 18:49:32 -08002846 case MSInheritanceModel::Single:
Reid Klecknerfb727182016-06-17 22:27:59 +00002847 Flags |= llvm::DINode::FlagSingleInheritance;
2848 break;
Reid Klecknera9cc64e2019-11-15 18:49:32 -08002849 case MSInheritanceModel::Multiple:
Reid Klecknerfb727182016-06-17 22:27:59 +00002850 Flags |= llvm::DINode::FlagMultipleInheritance;
2851 break;
Reid Klecknera9cc64e2019-11-15 18:49:32 -08002852 case MSInheritanceModel::Virtual:
Reid Klecknerfb727182016-06-17 22:27:59 +00002853 Flags |= llvm::DINode::FlagVirtualInheritance;
2854 break;
Reid Klecknera9cc64e2019-11-15 18:49:32 -08002855 case MSInheritanceModel::Unspecified:
Reid Klecknerfb727182016-06-17 22:27:59 +00002856 break;
2857 }
2858 }
2859 }
2860
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002861 llvm::DIType *ClassType = getOrCreateType(QualType(Ty->getClass(), 0), U);
David Majnemer5fd33e02015-04-24 01:25:08 +00002862 if (Ty->isMemberDataPointerType())
David Blaikie2c705ca2013-01-19 19:20:56 +00002863 return DBuilder.createMemberPointerType(
Reid Klecknerfb727182016-06-17 22:27:59 +00002864 getOrCreateType(Ty->getPointeeType(), U), ClassType, Size, /*Align=*/0,
2865 Flags);
Adrian Prantl0866acd2013-12-19 01:38:47 +00002866
2867 const FunctionProtoType *FPT =
Eric Christophere7b87e52014-10-26 23:40:33 +00002868 Ty->getPointeeType()->getAs<FunctionProtoType>();
2869 return DBuilder.createMemberPointerType(
Mikael Nilsson9d2872d2018-12-13 10:15:27 +00002870 getOrCreateInstanceMethodType(
2871 CXXMethodDecl::getThisType(FPT, Ty->getMostRecentCXXRecordDecl()),
Awanish Pandeyc83602f2020-01-23 16:06:52 +05302872 FPT, U, false),
Reid Klecknerfb727182016-06-17 22:27:59 +00002873 ClassType, Size, /*Align=*/0, Flags);
Guy Benyei11169dd2012-12-18 14:30:41 +00002874}
2875
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002876llvm::DIType *CGDebugInfo::CreateType(const AtomicType *Ty, llvm::DIFile *U) {
Victor Leschuk0df190372016-10-31 19:09:47 +00002877 auto *FromTy = getOrCreateType(Ty->getValueType(), U);
2878 return DBuilder.createQualifiedType(llvm::dwarf::DW_TAG_atomic_type, FromTy);
Guy Benyei11169dd2012-12-18 14:30:41 +00002879}
2880
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00002881llvm::DIType *CGDebugInfo::CreateType(const PipeType *Ty, llvm::DIFile *U) {
Xiuli Pan9c14e282016-01-09 12:53:17 +00002882 return getOrCreateType(Ty->getElementType(), U);
2883}
2884
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002885llvm::DIType *CGDebugInfo::CreateEnumType(const EnumType *Ty) {
Manman Ren1b457022013-08-28 21:20:28 +00002886 const EnumDecl *ED = Ty->getDecl();
Adrian Prantl5c8bd882015-09-11 17:23:08 +00002887
Guy Benyei11169dd2012-12-18 14:30:41 +00002888 uint64_t Size = 0;
Victor Leschuk802e4a52016-10-19 22:11:07 +00002889 uint32_t Align = 0;
Guy Benyei11169dd2012-12-18 14:30:41 +00002890 if (!ED->getTypeForDecl()->isIncompleteType()) {
2891 Size = CGM.getContext().getTypeSize(ED->getTypeForDecl());
Victor Leschuka7ece032016-10-20 00:13:19 +00002892 Align = getDeclAlignIfRequired(ED, CGM.getContext());
Guy Benyei11169dd2012-12-18 14:30:41 +00002893 }
2894
Brock Wyma8557ec52018-05-22 12:41:19 +00002895 SmallString<256> Identifier = getTypeIdentifier(Ty, CGM, TheCU);
Manman Rene0064d82013-08-29 23:19:58 +00002896
Adrian Prantl5c8bd882015-09-11 17:23:08 +00002897 bool isImportedFromModule =
2898 DebugTypeExtRefs && ED->isFromASTFile() && ED->getDefinition();
2899
Guy Benyei11169dd2012-12-18 14:30:41 +00002900 // If this is just a forward declaration, construct an appropriately
2901 // marked node and just return it.
Adrian Prantl5c8bd882015-09-11 17:23:08 +00002902 if (isImportedFromModule || !ED->getDefinition()) {
Adrian Prantl45946062016-02-23 19:30:08 +00002903 // Note that it is possible for enums to be created as part of
2904 // their own declcontext. In this case a FwdDecl will be created
2905 // twice. This doesn't cause a problem because both FwdDecls are
2906 // entered into the ReplaceMap: finalize() will replace the first
2907 // FwdDecl with the second and then replace the second with
2908 // complete type.
Amjad Abouddc4531e2016-04-30 01:44:38 +00002909 llvm::DIScope *EDContext = getDeclContextDescriptor(ED);
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002910 llvm::DIFile *DefUnit = getOrCreateFile(ED->getLocation());
Adrian Prantlff9d83c2016-02-08 17:03:28 +00002911 llvm::TempDIScope TmpContext(DBuilder.createReplaceableCompositeType(
2912 llvm::dwarf::DW_TAG_enumeration_type, "", TheCU, DefUnit, 0));
Adrian Prantla40030f2016-02-06 01:59:09 +00002913
Guy Benyei11169dd2012-12-18 14:30:41 +00002914 unsigned Line = getLineNumber(ED->getLocation());
2915 StringRef EDName = ED->getName();
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002916 llvm::DIType *RetTy = DBuilder.createReplaceableCompositeType(
Adrian Prantl45946062016-02-23 19:30:08 +00002917 llvm::dwarf::DW_TAG_enumeration_type, EDName, EDContext, DefUnit, Line,
Brock Wyma8557ec52018-05-22 12:41:19 +00002918 0, Size, Align, llvm::DINode::FlagFwdDecl, Identifier);
Adrian Prantla40030f2016-02-06 01:59:09 +00002919
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00002920 ReplaceMap.emplace_back(
2921 std::piecewise_construct, std::make_tuple(Ty),
2922 std::make_tuple(static_cast<llvm::Metadata *>(RetTy)));
David Blaikief427b002014-05-06 03:42:01 +00002923 return RetTy;
Guy Benyei11169dd2012-12-18 14:30:41 +00002924 }
2925
David Blaikie483a9da2014-05-06 18:35:21 +00002926 return CreateTypeDefinition(Ty);
2927}
2928
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002929llvm::DIType *CGDebugInfo::CreateTypeDefinition(const EnumType *Ty) {
David Blaikie483a9da2014-05-06 18:35:21 +00002930 const EnumDecl *ED = Ty->getDecl();
2931 uint64_t Size = 0;
Victor Leschuk802e4a52016-10-19 22:11:07 +00002932 uint32_t Align = 0;
David Blaikie483a9da2014-05-06 18:35:21 +00002933 if (!ED->getTypeForDecl()->isIncompleteType()) {
2934 Size = CGM.getContext().getTypeSize(ED->getTypeForDecl());
Victor Leschuka7ece032016-10-20 00:13:19 +00002935 Align = getDeclAlignIfRequired(ED, CGM.getContext());
David Blaikie483a9da2014-05-06 18:35:21 +00002936 }
2937
Brock Wyma8557ec52018-05-22 12:41:19 +00002938 SmallString<256> Identifier = getTypeIdentifier(Ty, CGM, TheCU);
David Blaikie483a9da2014-05-06 18:35:21 +00002939
Duncan P. N. Exon Smithdadc2b62015-04-21 18:43:54 +00002940 // Create elements for each enumerator.
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00002941 SmallVector<llvm::Metadata *, 16> Enumerators;
Guy Benyei11169dd2012-12-18 14:30:41 +00002942 ED = ED->getDefinition();
Momchil Velikov25f6be52018-02-12 16:12:52 +00002943 bool IsSigned = ED->getIntegerType()->isSignedIntegerType();
Aaron Ballman23a6dcb2014-03-08 18:45:14 +00002944 for (const auto *Enum : ED->enumerators()) {
Momchil Velikov25f6be52018-02-12 16:12:52 +00002945 const auto &InitVal = Enum->getInitVal();
2946 auto Value = IsSigned ? InitVal.getSExtValue() : InitVal.getZExtValue();
2947 Enumerators.push_back(
2948 DBuilder.createEnumerator(Enum->getName(), Value, !IsSigned));
Guy Benyei11169dd2012-12-18 14:30:41 +00002949 }
2950
2951 // Return a CompositeType for the enum itself.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002952 llvm::DINodeArray EltArray = DBuilder.getOrCreateArray(Enumerators);
Guy Benyei11169dd2012-12-18 14:30:41 +00002953
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00002954 llvm::DIFile *DefUnit = getOrCreateFile(ED->getLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00002955 unsigned Line = getLineNumber(ED->getLocation());
Amjad Abouddc4531e2016-04-30 01:44:38 +00002956 llvm::DIScope *EnumContext = getDeclContextDescriptor(ED);
Momchil Velikov25f6be52018-02-12 16:12:52 +00002957 llvm::DIType *ClassTy = getOrCreateType(ED->getIntegerType(), DefUnit);
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +00002958 return DBuilder.createEnumerationType(EnumContext, ED->getName(), DefUnit,
2959 Line, Size, Align, EltArray, ClassTy,
Paul Robinsonb1ce7c82019-01-08 16:28:11 +00002960 Identifier, ED->isScoped());
Guy Benyei11169dd2012-12-18 14:30:41 +00002961}
2962
Amjad Aboud546bc112017-02-09 22:07:24 +00002963llvm::DIMacro *CGDebugInfo::CreateMacro(llvm::DIMacroFile *Parent,
2964 unsigned MType, SourceLocation LineLoc,
2965 StringRef Name, StringRef Value) {
2966 unsigned Line = LineLoc.isInvalid() ? 0 : getLineNumber(LineLoc);
2967 return DBuilder.createMacro(Parent, Line, MType, Name, Value);
2968}
2969
2970llvm::DIMacroFile *CGDebugInfo::CreateTempMacroFile(llvm::DIMacroFile *Parent,
2971 SourceLocation LineLoc,
2972 SourceLocation FileLoc) {
2973 llvm::DIFile *FName = getOrCreateFile(FileLoc);
2974 unsigned Line = LineLoc.isInvalid() ? 0 : getLineNumber(LineLoc);
2975 return DBuilder.createTempMacroFile(Parent, Line, FName);
2976}
2977
David Blaikie05491062013-01-21 04:37:12 +00002978static QualType UnwrapTypeForDebugInfo(QualType T, const ASTContext &C) {
2979 Qualifiers Quals;
Guy Benyei11169dd2012-12-18 14:30:41 +00002980 do {
Adrian Prantl179af902013-09-26 21:35:50 +00002981 Qualifiers InnerQuals = T.getLocalQualifiers();
2982 // Qualifiers::operator+() doesn't like it if you add a Qualifier
2983 // that is already there.
2984 Quals += Qualifiers::removeCommonQualifiers(Quals, InnerQuals);
2985 Quals += InnerQuals;
Guy Benyei11169dd2012-12-18 14:30:41 +00002986 QualType LastT = T;
2987 switch (T->getTypeClass()) {
2988 default:
David Blaikie05491062013-01-21 04:37:12 +00002989 return C.getQualifiedType(T.getTypePtr(), Quals);
David Blaikief1b382e2014-04-06 17:14:06 +00002990 case Type::TemplateSpecialization: {
2991 const auto *Spec = cast<TemplateSpecializationType>(T);
2992 if (Spec->isTypeAlias())
2993 return C.getQualifiedType(T.getTypePtr(), Quals);
2994 T = Spec->desugar();
Eric Christophere7b87e52014-10-26 23:40:33 +00002995 break;
2996 }
Guy Benyei11169dd2012-12-18 14:30:41 +00002997 case Type::TypeOfExpr:
2998 T = cast<TypeOfExprType>(T)->getUnderlyingExpr()->getType();
2999 break;
3000 case Type::TypeOf:
3001 T = cast<TypeOfType>(T)->getUnderlyingType();
3002 break;
3003 case Type::Decltype:
3004 T = cast<DecltypeType>(T)->getUnderlyingType();
3005 break;
3006 case Type::UnaryTransform:
3007 T = cast<UnaryTransformType>(T)->getUnderlyingType();
3008 break;
3009 case Type::Attributed:
3010 T = cast<AttributedType>(T)->getEquivalentType();
3011 break;
3012 case Type::Elaborated:
3013 T = cast<ElaboratedType>(T)->getNamedType();
3014 break;
3015 case Type::Paren:
3016 T = cast<ParenType>(T)->getInnerType();
3017 break;
Leonard Chanc72aaf62019-05-07 03:20:17 +00003018 case Type::MacroQualified:
3019 T = cast<MacroQualifiedType>(T)->getUnderlyingType();
3020 break;
David Blaikie05491062013-01-21 04:37:12 +00003021 case Type::SubstTemplateTypeParm:
Guy Benyei11169dd2012-12-18 14:30:41 +00003022 T = cast<SubstTemplateTypeParmType>(T)->getReplacementType();
Guy Benyei11169dd2012-12-18 14:30:41 +00003023 break;
Richard Smitha0abc422017-02-22 00:13:14 +00003024 case Type::Auto:
3025 case Type::DeducedTemplateSpecialization: {
3026 QualType DT = cast<DeducedType>(T)->getDeducedType();
David Blaikie42edade2014-11-11 20:44:45 +00003027 assert(!DT.isNull() && "Undeduced types shouldn't reach here.");
David Blaikie22c460a02013-05-24 21:24:35 +00003028 T = DT;
Guy Benyei11169dd2012-12-18 14:30:41 +00003029 break;
3030 }
Jordan Rose303e2f12016-11-10 23:28:17 +00003031 case Type::Adjusted:
3032 case Type::Decayed:
3033 // Decayed and adjusted types use the adjusted type in LLVM and DWARF.
3034 T = cast<AdjustedType>(T)->getAdjustedType();
3035 break;
3036 }
Eric Christopherb2a008c2013-05-16 00:45:12 +00003037
Guy Benyei11169dd2012-12-18 14:30:41 +00003038 assert(T != LastT && "Type unwrapping failed to unwrap!");
NAKAMURA Takumi3e0a3632013-01-21 10:51:28 +00003039 (void)LastT;
Guy Benyei11169dd2012-12-18 14:30:41 +00003040 } while (true);
3041}
3042
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003043llvm::DIType *CGDebugInfo::getTypeOrNull(QualType Ty) {
Guy Benyei11169dd2012-12-18 14:30:41 +00003044
3045 // Unwrap the type as needed for debug information.
David Blaikie05491062013-01-21 04:37:12 +00003046 Ty = UnwrapTypeForDebugInfo(Ty, CGM.getContext());
Eric Christopherb2a008c2013-05-16 00:45:12 +00003047
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00003048 auto It = TypeCache.find(Ty.getAsOpaquePtr());
3049 if (It != TypeCache.end()) {
Guy Benyei11169dd2012-12-18 14:30:41 +00003050 // Verify that the debug info still exists.
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00003051 if (llvm::Metadata *V = It->second)
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003052 return cast<llvm::DIType>(V);
Guy Benyei11169dd2012-12-18 14:30:41 +00003053 }
3054
Duncan P. N. Exon Smithc7551282015-04-06 23:21:33 +00003055 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00003056}
3057
David Blaikie0e716b42014-03-03 23:48:23 +00003058void CGDebugInfo::completeTemplateDefinition(
3059 const ClassTemplateSpecializationDecl &SD) {
Benjamin Kramer8c305922016-02-02 11:06:51 +00003060 if (DebugKind <= codegenoptions::DebugLineTablesOnly)
David Blaikie0856f662014-03-04 22:01:08 +00003061 return;
David Blaikie1ac9c982017-04-11 21:13:37 +00003062 completeUnusedClass(SD);
3063}
David Blaikie0856f662014-03-04 22:01:08 +00003064
David Blaikie1ac9c982017-04-11 21:13:37 +00003065void CGDebugInfo::completeUnusedClass(const CXXRecordDecl &D) {
3066 if (DebugKind <= codegenoptions::DebugLineTablesOnly)
3067 return;
3068
3069 completeClassData(&D);
David Blaikie0e716b42014-03-03 23:48:23 +00003070 // In case this type has no member function definitions being emitted, ensure
3071 // it is retained
David Blaikie1ac9c982017-04-11 21:13:37 +00003072 RetainedTypes.push_back(CGM.getContext().getRecordType(&D).getAsOpaquePtr());
David Blaikie0e716b42014-03-03 23:48:23 +00003073}
3074
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003075llvm::DIType *CGDebugInfo::getOrCreateType(QualType Ty, llvm::DIFile *Unit) {
Guy Benyei11169dd2012-12-18 14:30:41 +00003076 if (Ty.isNull())
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +00003077 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00003078
Luboš Luňák4f2104c2019-11-02 16:39:59 +01003079 llvm::TimeTraceScope TimeScope("DebugType", [&]() {
3080 std::string Name;
3081 llvm::raw_string_ostream OS(Name);
3082 Ty.print(OS, getPrintingPolicy());
3083 return Name;
3084 });
3085
Guy Benyei11169dd2012-12-18 14:30:41 +00003086 // Unwrap the type as needed for debug information.
David Blaikie05491062013-01-21 04:37:12 +00003087 Ty = UnwrapTypeForDebugInfo(Ty, CGM.getContext());
Guy Benyei11169dd2012-12-18 14:30:41 +00003088
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +00003089 if (auto *T = getTypeOrNull(Ty))
Guy Benyei11169dd2012-12-18 14:30:41 +00003090 return T;
3091
Adrian Prantlca844182015-09-11 17:23:03 +00003092 llvm::DIType *Res = CreateTypeNode(Ty, Unit);
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00003093 void *TyPtr = Ty.getAsOpaquePtr();
Adrian Prantl73409ce2013-03-11 18:33:46 +00003094
3095 // And update the type cache.
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00003096 TypeCache[TyPtr].reset(Res);
Guy Benyei11169dd2012-12-18 14:30:41 +00003097
Guy Benyei11169dd2012-12-18 14:30:41 +00003098 return Res;
3099}
3100
Adrian Prantl5c8bd882015-09-11 17:23:08 +00003101llvm::DIModule *CGDebugInfo::getParentModuleOrNull(const Decl *D) {
Adrian Prantl335f5c72015-10-02 17:36:14 +00003102 // A forward declaration inside a module header does not belong to the module.
3103 if (isa<RecordDecl>(D) && !cast<RecordDecl>(D)->getDefinition())
3104 return nullptr;
Adrian Prantl85d938a2015-09-21 17:48:37 +00003105 if (DebugTypeExtRefs && D->isFromASTFile()) {
3106 // Record a reference to an imported clang module or precompiled header.
3107 auto *Reader = CGM.getContext().getExternalSource();
3108 auto Idx = D->getOwningModuleID();
3109 auto Info = Reader->getSourceDescriptor(Idx);
3110 if (Info)
3111 return getOrCreateModuleRef(*Info, /*SkeletonCU=*/true);
3112 } else if (ClangModuleMap) {
Adrian Prantl9402cef2015-09-20 16:51:35 +00003113 // We are building a clang module or a precompiled header.
3114 //
3115 // TODO: When D is a CXXRecordDecl or a C++ Enum, the ODR applies
3116 // and it wouldn't be necessary to specify the parent scope
3117 // because the type is already unique by definition (it would look
3118 // like the output of -fno-standalone-debug). On the other hand,
3119 // the parent scope helps a consumer to quickly locate the object
3120 // file where the type's definition is located, so it might be
3121 // best to make this behavior a command line or debugger tuning
3122 // option.
Richard Smith54f04402017-05-18 02:29:20 +00003123 if (Module *M = D->getOwningModule()) {
Adrian Prantlaa5d08d2016-01-22 21:14:41 +00003124 // This is a (sub-)module.
Reid Klecknerc915cb92020-02-27 18:13:54 -08003125 auto Info = ASTSourceDescriptor(*M);
Adrian Prantl9402cef2015-09-20 16:51:35 +00003126 return getOrCreateModuleRef(Info, /*SkeletonCU=*/false);
Adrian Prantlaa5d08d2016-01-22 21:14:41 +00003127 } else {
3128 // This the precompiled header being built.
3129 return getOrCreateModuleRef(PCHDescriptor, /*SkeletonCU=*/false);
Adrian Prantl9402cef2015-09-20 16:51:35 +00003130 }
3131 }
Adrian Prantl5c8bd882015-09-11 17:23:08 +00003132
Adrian Prantl9402cef2015-09-20 16:51:35 +00003133 return nullptr;
Adrian Prantl5c8bd882015-09-11 17:23:08 +00003134}
3135
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003136llvm::DIType *CGDebugInfo::CreateTypeNode(QualType Ty, llvm::DIFile *Unit) {
Guy Benyei11169dd2012-12-18 14:30:41 +00003137 // Handle qualifiers, which recursively handles what they refer to.
3138 if (Ty.hasLocalQualifiers())
David Blaikie99dab3b2013-09-04 22:03:57 +00003139 return CreateQualifiedType(Ty, Unit);
Guy Benyei11169dd2012-12-18 14:30:41 +00003140
Guy Benyei11169dd2012-12-18 14:30:41 +00003141 // Work out details of type.
3142 switch (Ty->getTypeClass()) {
3143#define TYPE(Class, Base)
3144#define ABSTRACT_TYPE(Class, Base)
3145#define NON_CANONICAL_TYPE(Class, Base)
3146#define DEPENDENT_TYPE(Class, Base) case Type::Class:
John McCall36b12a82019-10-02 06:35:23 +00003147#include "clang/AST/TypeNodes.inc"
Guy Benyei11169dd2012-12-18 14:30:41 +00003148 llvm_unreachable("Dependent types cannot show up in debug information");
3149
3150 case Type::ExtVector:
3151 case Type::Vector:
3152 return CreateType(cast<VectorType>(Ty), Unit);
Florian Hahn10658692020-05-11 17:45:51 +01003153 case Type::ConstantMatrix:
3154 return CreateType(cast<ConstantMatrixType>(Ty), Unit);
Guy Benyei11169dd2012-12-18 14:30:41 +00003155 case Type::ObjCObjectPointer:
3156 return CreateType(cast<ObjCObjectPointerType>(Ty), Unit);
3157 case Type::ObjCObject:
3158 return CreateType(cast<ObjCObjectType>(Ty), Unit);
Manman Rene6be26c2016-09-13 17:25:08 +00003159 case Type::ObjCTypeParam:
3160 return CreateType(cast<ObjCTypeParamType>(Ty), Unit);
Guy Benyei11169dd2012-12-18 14:30:41 +00003161 case Type::ObjCInterface:
3162 return CreateType(cast<ObjCInterfaceType>(Ty), Unit);
3163 case Type::Builtin:
3164 return CreateType(cast<BuiltinType>(Ty));
3165 case Type::Complex:
3166 return CreateType(cast<ComplexType>(Ty));
3167 case Type::Pointer:
3168 return CreateType(cast<PointerType>(Ty), Unit);
3169 case Type::BlockPointer:
3170 return CreateType(cast<BlockPointerType>(Ty), Unit);
3171 case Type::Typedef:
David Blaikie99dab3b2013-09-04 22:03:57 +00003172 return CreateType(cast<TypedefType>(Ty), Unit);
Guy Benyei11169dd2012-12-18 14:30:41 +00003173 case Type::Record:
David Blaikie99dab3b2013-09-04 22:03:57 +00003174 return CreateType(cast<RecordType>(Ty));
Guy Benyei11169dd2012-12-18 14:30:41 +00003175 case Type::Enum:
Manman Ren1b457022013-08-28 21:20:28 +00003176 return CreateEnumType(cast<EnumType>(Ty));
Guy Benyei11169dd2012-12-18 14:30:41 +00003177 case Type::FunctionProto:
3178 case Type::FunctionNoProto:
3179 return CreateType(cast<FunctionType>(Ty), Unit);
3180 case Type::ConstantArray:
3181 case Type::VariableArray:
3182 case Type::IncompleteArray:
3183 return CreateType(cast<ArrayType>(Ty), Unit);
3184
3185 case Type::LValueReference:
3186 return CreateType(cast<LValueReferenceType>(Ty), Unit);
3187 case Type::RValueReference:
3188 return CreateType(cast<RValueReferenceType>(Ty), Unit);
3189
3190 case Type::MemberPointer:
3191 return CreateType(cast<MemberPointerType>(Ty), Unit);
3192
3193 case Type::Atomic:
3194 return CreateType(cast<AtomicType>(Ty), Unit);
3195
Erich Keane5f0903e2020-04-17 10:44:19 -07003196 case Type::ExtInt:
3197 return CreateType(cast<ExtIntType>(Ty));
Xiuli Pan9c14e282016-01-09 12:53:17 +00003198 case Type::Pipe:
3199 return CreateType(cast<PipeType>(Ty), Unit);
3200
Guy Benyei11169dd2012-12-18 14:30:41 +00003201 case Type::TemplateSpecialization:
David Blaikief1b382e2014-04-06 17:14:06 +00003202 return CreateType(cast<TemplateSpecializationType>(Ty), Unit);
3203
David Blaikie42edade2014-11-11 20:44:45 +00003204 case Type::Auto:
David Blaikief1b382e2014-04-06 17:14:06 +00003205 case Type::Attributed:
Jordan Rose303e2f12016-11-10 23:28:17 +00003206 case Type::Adjusted:
3207 case Type::Decayed:
Richard Smith600b5262017-01-26 20:40:47 +00003208 case Type::DeducedTemplateSpecialization:
Guy Benyei11169dd2012-12-18 14:30:41 +00003209 case Type::Elaborated:
3210 case Type::Paren:
Leonard Chanc72aaf62019-05-07 03:20:17 +00003211 case Type::MacroQualified:
Guy Benyei11169dd2012-12-18 14:30:41 +00003212 case Type::SubstTemplateTypeParm:
3213 case Type::TypeOfExpr:
3214 case Type::TypeOf:
3215 case Type::Decltype:
3216 case Type::UnaryTransform:
David Blaikie66ed89d2013-07-13 21:08:08 +00003217 case Type::PackExpansion:
David Blaikie22c460a02013-05-24 21:24:35 +00003218 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00003219 }
Eric Christopherb2a008c2013-05-16 00:45:12 +00003220
David Blaikie42edade2014-11-11 20:44:45 +00003221 llvm_unreachable("type should have been unwrapped!");
Guy Benyei11169dd2012-12-18 14:30:41 +00003222}
3223
Duncan P. N. Exon Smithbd210e62015-07-24 20:34:41 +00003224llvm::DICompositeType *CGDebugInfo::getOrCreateLimitedType(const RecordType *Ty,
3225 llvm::DIFile *Unit) {
David Blaikie4a2b5ef2013-08-12 22:24:20 +00003226 QualType QTy(Ty, 0);
Guy Benyei11169dd2012-12-18 14:30:41 +00003227
Duncan P. N. Exon Smithbd210e62015-07-24 20:34:41 +00003228 auto *T = cast_or_null<llvm::DICompositeType>(getTypeOrNull(QTy));
Guy Benyei11169dd2012-12-18 14:30:41 +00003229
3230 // We may have cached a forward decl when we could have created
3231 // a non-forward decl. Go ahead and create a non-forward decl
3232 // now.
Duncan P. N. Exon Smith4caa7f22015-04-16 01:00:56 +00003233 if (T && !T->isForwardDecl())
Eric Christophere7b87e52014-10-26 23:40:33 +00003234 return T;
Guy Benyei11169dd2012-12-18 14:30:41 +00003235
3236 // Otherwise create the type.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003237 llvm::DICompositeType *Res = CreateLimitedType(Ty);
David Blaikie8d5e1282013-08-20 21:03:29 +00003238
3239 // Propagate members from the declaration to the definition
3240 // CreateType(const RecordType*) will overwrite this with the members in the
3241 // correct order if the full type is needed.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003242 DBuilder.replaceArrays(Res, T ? T->getElements() : llvm::DINodeArray());
Guy Benyei11169dd2012-12-18 14:30:41 +00003243
Guy Benyei11169dd2012-12-18 14:30:41 +00003244 // And update the type cache.
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00003245 TypeCache[QTy.getAsOpaquePtr()].reset(Res);
Guy Benyei11169dd2012-12-18 14:30:41 +00003246 return Res;
3247}
3248
3249// TODO: Currently used for context chains when limiting debug info.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003250llvm::DICompositeType *CGDebugInfo::CreateLimitedType(const RecordType *Ty) {
Guy Benyei11169dd2012-12-18 14:30:41 +00003251 RecordDecl *RD = Ty->getDecl();
Eric Christopherb2a008c2013-05-16 00:45:12 +00003252
Guy Benyei11169dd2012-12-18 14:30:41 +00003253 // Get overall information about the record type for the debug info.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003254 llvm::DIFile *DefUnit = getOrCreateFile(RD->getLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00003255 unsigned Line = getLineNumber(RD->getLocation());
3256 StringRef RDName = getClassName(RD);
3257
Amjad Abouddc4531e2016-04-30 01:44:38 +00003258 llvm::DIScope *RDContext = getDeclContextDescriptor(RD);
Guy Benyei11169dd2012-12-18 14:30:41 +00003259
David Blaikied2785892013-08-18 17:36:19 +00003260 // If we ended up creating the type during the context chain construction,
3261 // just return that.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003262 auto *T = cast_or_null<llvm::DICompositeType>(
Duncan P. N. Exon Smithc7551282015-04-06 23:21:33 +00003263 getTypeOrNull(CGM.getContext().getRecordType(RD)));
Duncan P. N. Exon Smith4caa7f22015-04-16 01:00:56 +00003264 if (T && (!T->isForwardDecl() || !RD->getDefinition()))
Eric Christophere7b87e52014-10-26 23:40:33 +00003265 return T;
David Blaikied2785892013-08-18 17:36:19 +00003266
Adrian Prantl381e7552014-02-04 21:29:50 +00003267 // If this is just a forward or incomplete declaration, construct an
3268 // appropriately marked node and just return it.
3269 const RecordDecl *D = RD->getDefinition();
3270 if (!D || !D->isCompleteDefinition())
Manman Ren1b457022013-08-28 21:20:28 +00003271 return getOrCreateRecordFwdDecl(Ty, RDContext);
Guy Benyei11169dd2012-12-18 14:30:41 +00003272
3273 uint64_t Size = CGM.getContext().getTypeSize(Ty);
Victor Leschuka7ece032016-10-20 00:13:19 +00003274 auto Align = getDeclAlignIfRequired(D, CGM.getContext());
Eric Christopherb2a008c2013-05-16 00:45:12 +00003275
Brock Wyma8557ec52018-05-22 12:41:19 +00003276 SmallString<256> Identifier = getTypeIdentifier(Ty, CGM, TheCU);
Manman Rene0064d82013-08-29 23:19:58 +00003277
Shafik Yaghmour528f5da2019-08-27 20:17:35 +00003278 // Explicitly record the calling convention and export symbols for C++
3279 // records.
Adrian Prantl6c5f03a2018-01-05 01:13:52 +00003280 auto Flags = llvm::DINode::FlagZero;
3281 if (auto CXXRD = dyn_cast<CXXRecordDecl>(RD)) {
3282 if (CGM.getCXXABI().getRecordArgABI(CXXRD) == CGCXXABI::RAA_Indirect)
3283 Flags |= llvm::DINode::FlagTypePassByReference;
3284 else
3285 Flags |= llvm::DINode::FlagTypePassByValue;
Aaron Smith044326c2018-07-23 20:49:07 +00003286
Aaron Smithfa7745b2019-04-11 20:24:54 +00003287 // Record if a C++ record is non-trivial type.
3288 if (!CXXRD->isTrivial())
Aaron Smithf0d27332019-02-26 03:49:05 +00003289 Flags |= llvm::DINode::FlagNonTrivial;
Shafik Yaghmour528f5da2019-08-27 20:17:35 +00003290
3291 // Record exports it symbols to the containing structure.
3292 if (CXXRD->isAnonymousStructOrUnion())
3293 Flags |= llvm::DINode::FlagExportSymbols;
Adrian Prantl6c5f03a2018-01-05 01:13:52 +00003294 }
3295
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003296 llvm::DICompositeType *RealDecl = DBuilder.createReplaceableCompositeType(
Leny Kholodov80c047d2016-09-06 10:48:04 +00003297 getTagForRecord(RD), RDName, RDContext, DefUnit, Line, 0, Size, Align,
Brock Wyma8557ec52018-05-22 12:41:19 +00003298 Flags, Identifier);
Guy Benyei11169dd2012-12-18 14:30:41 +00003299
Duncan P. N. Exon Smithf9521b02016-04-17 07:45:08 +00003300 // Elements of composite types usually have back to the type, creating
3301 // uniquing cycles. Distinct nodes are more efficient.
3302 switch (RealDecl->getTag()) {
3303 default:
3304 llvm_unreachable("invalid composite type tag");
3305
3306 case llvm::dwarf::DW_TAG_array_type:
3307 case llvm::dwarf::DW_TAG_enumeration_type:
3308 // Array elements and most enumeration elements don't have back references,
3309 // so they don't tend to be involved in uniquing cycles and there is some
3310 // chance of merging them when linking together two modules. Only make
3311 // them distinct if they are ODR-uniqued.
Brock Wyma8557ec52018-05-22 12:41:19 +00003312 if (Identifier.empty())
Duncan P. N. Exon Smithf9521b02016-04-17 07:45:08 +00003313 break;
Galina Kistanova0872d6c2017-06-03 06:30:46 +00003314 LLVM_FALLTHROUGH;
Duncan P. N. Exon Smithf9521b02016-04-17 07:45:08 +00003315
3316 case llvm::dwarf::DW_TAG_structure_type:
3317 case llvm::dwarf::DW_TAG_union_type:
3318 case llvm::dwarf::DW_TAG_class_type:
Alexander Kornienko2a8c18d2018-04-06 15:14:32 +00003319 // Immediately resolve to a distinct node.
Duncan P. N. Exon Smithf9521b02016-04-17 07:45:08 +00003320 RealDecl =
3321 llvm::MDNode::replaceWithDistinct(llvm::TempDICompositeType(RealDecl));
3322 break;
3323 }
3324
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00003325 RegionMap[Ty->getDecl()].reset(RealDecl);
3326 TypeCache[QualType(Ty, 0).getAsOpaquePtr()].reset(RealDecl);
Guy Benyei11169dd2012-12-18 14:30:41 +00003327
David Majnemer58ed0f32016-07-17 00:39:12 +00003328 if (const auto *TSpecial = dyn_cast<ClassTemplateSpecializationDecl>(RD))
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003329 DBuilder.replaceArrays(RealDecl, llvm::DINodeArray(),
Duncan P. N. Exon Smithc8ee63e2014-12-18 00:48:56 +00003330 CollectCXXTemplateParams(TSpecial, DefUnit));
David Blaikie952dac32013-08-15 22:42:12 +00003331 return RealDecl;
Guy Benyei11169dd2012-12-18 14:30:41 +00003332}
3333
David Blaikieadfbf992013-08-18 16:55:33 +00003334void CGDebugInfo::CollectContainingType(const CXXRecordDecl *RD,
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003335 llvm::DICompositeType *RealDecl) {
David Blaikieadfbf992013-08-18 16:55:33 +00003336 // A class's primary base or the class itself contains the vtable.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003337 llvm::DICompositeType *ContainingType = nullptr;
David Blaikieadfbf992013-08-18 16:55:33 +00003338 const ASTRecordLayout &RL = CGM.getContext().getASTRecordLayout(RD);
3339 if (const CXXRecordDecl *PBase = RL.getPrimaryBase()) {
Alp Tokerd4733632013-12-05 04:47:09 +00003340 // Seek non-virtual primary base root.
David Blaikieadfbf992013-08-18 16:55:33 +00003341 while (1) {
3342 const ASTRecordLayout &BRL = CGM.getContext().getASTRecordLayout(PBase);
3343 const CXXRecordDecl *PBT = BRL.getPrimaryBase();
3344 if (PBT && !BRL.isPrimaryBaseVirtual())
3345 PBase = PBT;
3346 else
3347 break;
3348 }
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003349 ContainingType = cast<llvm::DICompositeType>(
David Blaikieadfbf992013-08-18 16:55:33 +00003350 getOrCreateType(QualType(PBase->getTypeForDecl(), 0),
3351 getOrCreateFile(RD->getLocation())));
3352 } else if (RD->isDynamicClass())
3353 ContainingType = RealDecl;
3354
Duncan P. N. Exon Smithc8ee63e2014-12-18 00:48:56 +00003355 DBuilder.replaceVTableHolder(RealDecl, ContainingType);
David Blaikieadfbf992013-08-18 16:55:33 +00003356}
3357
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003358llvm::DIType *CGDebugInfo::CreateMemberType(llvm::DIFile *Unit, QualType FType,
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +00003359 StringRef Name, uint64_t *Offset) {
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003360 llvm::DIType *FieldTy = CGDebugInfo::getOrCreateType(FType, Unit);
Guy Benyei11169dd2012-12-18 14:30:41 +00003361 uint64_t FieldSize = CGM.getContext().getTypeSize(FType);
Victor Leschuka7ece032016-10-20 00:13:19 +00003362 auto FieldAlign = getTypeAlignIfRequired(FType, CGM.getContext());
Leny Kholodovdf050fd2016-09-06 17:06:14 +00003363 llvm::DIType *Ty =
3364 DBuilder.createMemberType(Unit, Name, Unit, 0, FieldSize, FieldAlign,
3365 *Offset, llvm::DINode::FlagZero, FieldTy);
Guy Benyei11169dd2012-12-18 14:30:41 +00003366 *Offset += FieldSize;
3367 return Ty;
3368}
3369
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003370void CGDebugInfo::collectFunctionDeclProps(GlobalDecl GD, llvm::DIFile *Unit,
Duncan P. N. Exon Smith8e47da42015-04-21 20:07:29 +00003371 StringRef &Name,
3372 StringRef &LinkageName,
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003373 llvm::DIScope *&FDContext,
3374 llvm::DINodeArray &TParamsArray,
Leny Kholodov80c047d2016-09-06 10:48:04 +00003375 llvm::DINode::DIFlags &Flags) {
David Majnemer58ed0f32016-07-17 00:39:12 +00003376 const auto *FD = cast<FunctionDecl>(GD.getDecl());
Frederic Riss9db79f12014-11-18 03:40:46 +00003377 Name = getFunctionName(FD);
3378 // Use mangled name as linkage name for C/C++ functions.
3379 if (FD->hasPrototype()) {
3380 LinkageName = CGM.getMangledName(GD);
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003381 Flags |= llvm::DINode::FlagPrototyped;
Frederic Riss9db79f12014-11-18 03:40:46 +00003382 }
3383 // No need to replicate the linkage name if it isn't different from the
3384 // subprogram name, no need to have it at all unless coverage is enabled or
Dehao Chenb3a70de2017-01-19 00:44:21 +00003385 // debug is set to more than just line tables or extra debug info is needed.
Benjamin Kramer8c305922016-02-02 11:06:51 +00003386 if (LinkageName == Name || (!CGM.getCodeGenOpts().EmitGcovArcs &&
3387 !CGM.getCodeGenOpts().EmitGcovNotes &&
Dehao Chenb3a70de2017-01-19 00:44:21 +00003388 !CGM.getCodeGenOpts().DebugInfoForProfiling &&
Benjamin Kramer8c305922016-02-02 11:06:51 +00003389 DebugKind <= codegenoptions::DebugLineTablesOnly))
Frederic Riss9db79f12014-11-18 03:40:46 +00003390 LinkageName = StringRef();
3391
Amy Huang53539bb2020-01-13 15:54:54 -08003392 if (CGM.getCodeGenOpts().hasReducedDebugInfo()) {
Frederic Riss9db79f12014-11-18 03:40:46 +00003393 if (const NamespaceDecl *NSDecl =
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00003394 dyn_cast_or_null<NamespaceDecl>(FD->getDeclContext()))
Adrian Prantlddb8e062017-05-12 16:23:53 +00003395 FDContext = getOrCreateNamespace(NSDecl);
Frederic Riss9db79f12014-11-18 03:40:46 +00003396 else if (const RecordDecl *RDecl =
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00003397 dyn_cast_or_null<RecordDecl>(FD->getDeclContext())) {
Adrian Prantl5c8bd882015-09-11 17:23:08 +00003398 llvm::DIScope *Mod = getParentModuleOrNull(RDecl);
3399 FDContext = getContextDescriptor(RDecl, Mod ? Mod : TheCU);
3400 }
Adrian Prantlfd5ac8a2016-08-17 16:20:32 +00003401 // Check if it is a noreturn-marked function
3402 if (FD->isNoReturn())
3403 Flags |= llvm::DINode::FlagNoReturn;
Frederic Riss9db79f12014-11-18 03:40:46 +00003404 // Collect template parameters.
3405 TParamsArray = CollectFunctionTemplateParams(FD, Unit);
3406 }
3407}
3408
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003409void CGDebugInfo::collectVarDeclProps(const VarDecl *VD, llvm::DIFile *&Unit,
Frederic Riss9db79f12014-11-18 03:40:46 +00003410 unsigned &LineNo, QualType &T,
3411 StringRef &Name, StringRef &LinkageName,
Matthew Voss20165362018-10-03 18:45:04 +00003412 llvm::MDTuple *&TemplateParameters,
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003413 llvm::DIScope *&VDContext) {
Frederic Riss9db79f12014-11-18 03:40:46 +00003414 Unit = getOrCreateFile(VD->getLocation());
3415 LineNo = getLineNumber(VD->getLocation());
3416
3417 setLocation(VD->getLocation());
3418
3419 T = VD->getType();
3420 if (T->isIncompleteArrayType()) {
3421 // CodeGen turns int[] into int[1] so we'll do the same here.
3422 llvm::APInt ConstVal(32, 1);
3423 QualType ET = CGM.getContext().getAsArrayType(T)->getElementType();
3424
Richard Smith772e2662019-10-04 01:25:59 +00003425 T = CGM.getContext().getConstantArrayType(ET, ConstVal, nullptr,
3426 ArrayType::Normal, 0);
Frederic Riss9db79f12014-11-18 03:40:46 +00003427 }
3428
3429 Name = VD->getName();
3430 if (VD->getDeclContext() && !isa<FunctionDecl>(VD->getDeclContext()) &&
3431 !isa<ObjCMethodDecl>(VD->getDeclContext()))
3432 LinkageName = CGM.getMangledName(VD);
3433 if (LinkageName == Name)
3434 LinkageName = StringRef();
3435
Matthew Voss20165362018-10-03 18:45:04 +00003436 if (isa<VarTemplateSpecializationDecl>(VD)) {
3437 llvm::DINodeArray parameterNodes = CollectVarTemplateParams(VD, &*Unit);
3438 TemplateParameters = parameterNodes.get();
3439 } else {
3440 TemplateParameters = nullptr;
3441 }
3442
Frederic Riss9db79f12014-11-18 03:40:46 +00003443 // Since we emit declarations (DW_AT_members) for static members, place the
3444 // definition of those static members in the namespace they were declared in
3445 // in the source code (the lexical decl context).
3446 // FIXME: Generalize this for even non-member global variables where the
3447 // declaration and definition may have different lexical decl contexts, once
3448 // we have support for emitting declarations of (non-member) global variables.
Saleem Abdulrasoolcd187f02015-02-28 00:13:13 +00003449 const DeclContext *DC = VD->isStaticDataMember() ? VD->getLexicalDeclContext()
3450 : VD->getDeclContext();
3451 // When a record type contains an in-line initialization of a static data
3452 // member, and the record type is marked as __declspec(dllexport), an implicit
3453 // definition of the member will be created in the record context. DWARF
3454 // doesn't seem to have a nice way to describe this in a form that consumers
3455 // are likely to understand, so fake the "normal" situation of a definition
3456 // outside the class by putting it in the global scope.
3457 if (DC->isRecord())
3458 DC = CGM.getContext().getTranslationUnitDecl();
Adrian Prantl5c8bd882015-09-11 17:23:08 +00003459
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00003460 llvm::DIScope *Mod = getParentModuleOrNull(VD);
3461 VDContext = getContextDescriptor(cast<Decl>(DC), Mod ? Mod : TheCU);
Frederic Riss9db79f12014-11-18 03:40:46 +00003462}
3463
Adrian Prantlb7acfc02017-02-27 21:30:05 +00003464llvm::DISubprogram *CGDebugInfo::getFunctionFwdDeclOrStub(GlobalDecl GD,
3465 bool Stub) {
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003466 llvm::DINodeArray TParamsArray;
Frederic Rissd253ed62014-11-18 03:40:51 +00003467 StringRef Name, LinkageName;
Leny Kholodov80c047d2016-09-06 10:48:04 +00003468 llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
Paul Robinsoncda54212018-11-19 18:29:28 +00003469 llvm::DISubprogram::DISPFlags SPFlags = llvm::DISubprogram::SPFlagZero;
Adrian Prantlb7acfc02017-02-27 21:30:05 +00003470 SourceLocation Loc = GD.getDecl()->getLocation();
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003471 llvm::DIFile *Unit = getOrCreateFile(Loc);
3472 llvm::DIScope *DContext = Unit;
Frederic Rissd253ed62014-11-18 03:40:51 +00003473 unsigned Line = getLineNumber(Loc);
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00003474 collectFunctionDeclProps(GD, Unit, Name, LinkageName, DContext, TParamsArray,
3475 Flags);
Simon Pilgrimcfee2ef2019-10-16 10:38:49 +00003476 auto *FD = cast<FunctionDecl>(GD.getDecl());
Adrian Prantlb7acfc02017-02-27 21:30:05 +00003477
Frederic Rissd253ed62014-11-18 03:40:51 +00003478 // Build function type.
3479 SmallVector<QualType, 16> ArgTypes;
Simon Pilgrimcfee2ef2019-10-16 10:38:49 +00003480 for (const ParmVarDecl *Parm : FD->parameters())
3481 ArgTypes.push_back(Parm->getType());
3482
Reid Klecknerf00f8032016-06-08 20:41:54 +00003483 CallingConv CC = FD->getType()->castAs<FunctionType>()->getCallConv();
3484 QualType FnType = CGM.getContext().getFunctionType(
3485 FD->getReturnType(), ArgTypes, FunctionProtoType::ExtProtoInfo(CC));
Paul Robinsoncda54212018-11-19 18:29:28 +00003486 if (!FD->isExternallyVisible())
3487 SPFlags |= llvm::DISubprogram::SPFlagLocalToUnit;
3488 if (CGM.getLangOpts().Optimize)
3489 SPFlags |= llvm::DISubprogram::SPFlagOptimized;
3490
Adrian Prantlb7acfc02017-02-27 21:30:05 +00003491 if (Stub) {
Vedant Kumar5931b4e2018-10-05 20:37:17 +00003492 Flags |= getCallSiteRelatedAttrs();
Paul Robinsoncda54212018-11-19 18:29:28 +00003493 SPFlags |= llvm::DISubprogram::SPFlagDefinition;
Adrian Prantlb7acfc02017-02-27 21:30:05 +00003494 return DBuilder.createFunction(
3495 DContext, Name, LinkageName, Unit, Line,
Paul Robinsoncda54212018-11-19 18:29:28 +00003496 getOrCreateFunctionType(GD.getDecl(), FnType, Unit), 0, Flags, SPFlags,
Adrian Prantlb7acfc02017-02-27 21:30:05 +00003497 TParamsArray.get(), getFunctionDeclaration(FD));
3498 }
3499
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003500 llvm::DISubprogram *SP = DBuilder.createTempFunctionFwdDecl(
Duncan P. N. Exon Smithebad0aa2015-04-07 16:50:49 +00003501 DContext, Name, LinkageName, Unit, Line,
Paul Robinsoncda54212018-11-19 18:29:28 +00003502 getOrCreateFunctionType(GD.getDecl(), FnType, Unit), 0, Flags, SPFlags,
Duncan P. N. Exon Smithebad0aa2015-04-07 16:50:49 +00003503 TParamsArray.get(), getFunctionDeclaration(FD));
George Burgess IV00f70bd2018-03-01 05:43:23 +00003504 const FunctionDecl *CanonDecl = FD->getCanonicalDecl();
Duncan P. N. Exon Smith4078ad42015-04-16 16:36:45 +00003505 FwdDeclReplaceMap.emplace_back(std::piecewise_construct,
3506 std::make_tuple(CanonDecl),
3507 std::make_tuple(SP));
Frederic Rissd253ed62014-11-18 03:40:51 +00003508 return SP;
3509}
3510
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00003511llvm::DISubprogram *CGDebugInfo::getFunctionForwardDeclaration(GlobalDecl GD) {
Adrian Prantlb7acfc02017-02-27 21:30:05 +00003512 return getFunctionFwdDeclOrStub(GD, /* Stub = */ false);
3513}
3514
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00003515llvm::DISubprogram *CGDebugInfo::getFunctionStub(GlobalDecl GD) {
Adrian Prantlb7acfc02017-02-27 21:30:05 +00003516 return getFunctionFwdDeclOrStub(GD, /* Stub = */ true);
3517}
3518
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003519llvm::DIGlobalVariable *
Frederic Rissd253ed62014-11-18 03:40:51 +00003520CGDebugInfo::getGlobalVariableForwardDeclaration(const VarDecl *VD) {
3521 QualType T;
3522 StringRef Name, LinkageName;
3523 SourceLocation Loc = VD->getLocation();
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003524 llvm::DIFile *Unit = getOrCreateFile(Loc);
3525 llvm::DIScope *DContext = Unit;
Frederic Rissd253ed62014-11-18 03:40:51 +00003526 unsigned Line = getLineNumber(Loc);
Matthew Voss20165362018-10-03 18:45:04 +00003527 llvm::MDTuple *TemplateParameters = nullptr;
Frederic Rissd253ed62014-11-18 03:40:51 +00003528
Matthew Voss20165362018-10-03 18:45:04 +00003529 collectVarDeclProps(VD, Unit, Line, T, Name, LinkageName, TemplateParameters,
3530 DContext);
Victor Leschuka7ece032016-10-20 00:13:19 +00003531 auto Align = getDeclAlignIfRequired(VD, CGM.getContext());
Duncan P. N. Exon Smithdadc2b62015-04-21 18:43:54 +00003532 auto *GV = DBuilder.createTempGlobalVariableFwdDecl(
3533 DContext, Name, LinkageName, Unit, Line, getOrCreateType(T, Unit),
Matthew Voss20165362018-10-03 18:45:04 +00003534 !VD->isExternallyVisible(), nullptr, TemplateParameters, Align);
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00003535 FwdDeclReplaceMap.emplace_back(
3536 std::piecewise_construct,
3537 std::make_tuple(cast<VarDecl>(VD->getCanonicalDecl())),
3538 std::make_tuple(static_cast<llvm::Metadata *>(GV)));
Frederic Rissd253ed62014-11-18 03:40:51 +00003539 return GV;
3540}
3541
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003542llvm::DINode *CGDebugInfo::getDeclarationOrDefinition(const Decl *D) {
David Blaikiebd483762013-05-20 04:58:53 +00003543 // We only need a declaration (not a definition) of the type - so use whatever
3544 // we would otherwise do to get a type for a pointee. (forward declarations in
3545 // limited debug info, full definitions (if the type definition is available)
3546 // in unlimited debug info)
David Majnemer58ed0f32016-07-17 00:39:12 +00003547 if (const auto *TD = dyn_cast<TypeDecl>(D))
David Blaikie6b7d060c2013-08-12 23:14:36 +00003548 return getOrCreateType(CGM.getContext().getTypeDeclType(TD),
David Blaikie99dab3b2013-09-04 22:03:57 +00003549 getOrCreateFile(TD->getLocation()));
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00003550 auto I = DeclCache.find(D->getCanonicalDecl());
Frederic Rissd253ed62014-11-18 03:40:51 +00003551
Adrian Prantl5f4740d2016-12-20 02:10:02 +00003552 if (I != DeclCache.end()) {
3553 auto N = I->second;
3554 if (auto *GVE = dyn_cast_or_null<llvm::DIGlobalVariableExpression>(N))
3555 return GVE->getVariable();
3556 return dyn_cast_or_null<llvm::DINode>(N);
3557 }
Frederic Rissd253ed62014-11-18 03:40:51 +00003558
3559 // No definition for now. Emit a forward definition that might be
3560 // merged with a potential upcoming definition.
David Majnemer58ed0f32016-07-17 00:39:12 +00003561 if (const auto *FD = dyn_cast<FunctionDecl>(D))
Frederic Rissd253ed62014-11-18 03:40:51 +00003562 return getFunctionForwardDeclaration(FD);
3563 else if (const auto *VD = dyn_cast<VarDecl>(D))
3564 return getGlobalVariableForwardDeclaration(VD);
3565
Duncan P. N. Exon Smith4078ad42015-04-16 16:36:45 +00003566 return nullptr;
David Blaikiebd483762013-05-20 04:58:53 +00003567}
3568
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003569llvm::DISubprogram *CGDebugInfo::getFunctionDeclaration(const Decl *D) {
Benjamin Kramer8c305922016-02-02 11:06:51 +00003570 if (!D || DebugKind <= codegenoptions::DebugLineTablesOnly)
Duncan P. N. Exon Smitha7fbcbf2015-04-20 22:09:57 +00003571 return nullptr;
David Blaikie18cfbc52013-06-22 00:09:36 +00003572
David Majnemer58ed0f32016-07-17 00:39:12 +00003573 const auto *FD = dyn_cast<FunctionDecl>(D);
Eric Christophere7b87e52014-10-26 23:40:33 +00003574 if (!FD)
Duncan P. N. Exon Smitha7fbcbf2015-04-20 22:09:57 +00003575 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00003576
3577 // Setup context.
Adrian Prantl6ec370a2015-09-10 18:39:45 +00003578 auto *S = getDeclContextDescriptor(D);
Guy Benyei11169dd2012-12-18 14:30:41 +00003579
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00003580 auto MI = SPCache.find(FD->getCanonicalDecl());
David Blaikiefd07c602013-08-09 17:20:05 +00003581 if (MI == SPCache.end()) {
David Majnemer58ed0f32016-07-17 00:39:12 +00003582 if (const auto *MD = dyn_cast<CXXMethodDecl>(FD->getCanonicalDecl())) {
Duncan P. N. Exon Smithc09c5482015-04-20 21:17:26 +00003583 return CreateCXXMemberFunction(MD, getOrCreateFile(MD->getLocation()),
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003584 cast<llvm::DICompositeType>(S));
David Blaikiefd07c602013-08-09 17:20:05 +00003585 }
3586 }
Guy Benyei11169dd2012-12-18 14:30:41 +00003587 if (MI != SPCache.end()) {
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003588 auto *SP = dyn_cast_or_null<llvm::DISubprogram>(MI->second);
Duncan P. N. Exon Smith87afdeb2015-04-14 03:24:14 +00003589 if (SP && !SP->isDefinition())
Guy Benyei11169dd2012-12-18 14:30:41 +00003590 return SP;
3591 }
3592
Aaron Ballman86c93902014-03-06 23:45:36 +00003593 for (auto NextFD : FD->redecls()) {
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00003594 auto MI = SPCache.find(NextFD->getCanonicalDecl());
Guy Benyei11169dd2012-12-18 14:30:41 +00003595 if (MI != SPCache.end()) {
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003596 auto *SP = dyn_cast_or_null<llvm::DISubprogram>(MI->second);
Duncan P. N. Exon Smith87afdeb2015-04-14 03:24:14 +00003597 if (SP && !SP->isDefinition())
Guy Benyei11169dd2012-12-18 14:30:41 +00003598 return SP;
3599 }
3600 }
Duncan P. N. Exon Smitha7fbcbf2015-04-20 22:09:57 +00003601 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00003602}
3603
Adrian Prantl901cc4a2019-11-08 09:24:31 -08003604llvm::DISubprogram *CGDebugInfo::getObjCMethodDeclaration(
3605 const Decl *D, llvm::DISubroutineType *FnType, unsigned LineNo,
3606 llvm::DINode::DIFlags Flags, llvm::DISubprogram::DISPFlags SPFlags) {
3607 if (!D || DebugKind <= codegenoptions::DebugLineTablesOnly)
3608 return nullptr;
3609
Adrian Prantle0cabe22019-11-21 09:56:01 -08003610 const auto *OMD = dyn_cast<ObjCMethodDecl>(D);
3611 if (!OMD)
3612 return nullptr;
3613
3614 if (CGM.getCodeGenOpts().DwarfVersion < 5 && !OMD->isDirectMethod())
Adrian Prantl901cc4a2019-11-08 09:24:31 -08003615 return nullptr;
3616
Raphael Isemannccfab8e2019-12-17 09:36:57 +01003617 if (OMD->isDirectMethod())
3618 SPFlags |= llvm::DISubprogram::SPFlagObjCDirect;
3619
Adrian Prantl901cc4a2019-11-08 09:24:31 -08003620 // Starting with DWARF V5 method declarations are emitted as children of
3621 // the interface type.
Adrian Prantl901cc4a2019-11-08 09:24:31 -08003622 auto *ID = dyn_cast_or_null<ObjCInterfaceDecl>(D->getDeclContext());
3623 if (!ID)
3624 ID = OMD->getClassInterface();
3625 if (!ID)
3626 return nullptr;
3627 QualType QTy(ID->getTypeForDecl(), 0);
3628 auto It = TypeCache.find(QTy.getAsOpaquePtr());
3629 if (It == TypeCache.end())
3630 return nullptr;
3631 auto *InterfaceType = cast<llvm::DICompositeType>(It->second);
3632 llvm::DISubprogram *FD = DBuilder.createFunction(
3633 InterfaceType, getObjCMethodName(OMD), StringRef(),
3634 InterfaceType->getFile(), LineNo, FnType, LineNo, Flags, SPFlags);
3635 DBuilder.finalizeSubprogram(FD);
Adrian Prantle0cabe22019-11-21 09:56:01 -08003636 ObjCMethodCache[ID].push_back({FD, OMD->isDirectMethod()});
Adrian Prantl901cc4a2019-11-08 09:24:31 -08003637 return FD;
3638}
3639
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +00003640// getOrCreateFunctionType - Construct type. If it is a c++ method, include
Guy Benyei11169dd2012-12-18 14:30:41 +00003641// implicit parameter "this".
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003642llvm::DISubroutineType *CGDebugInfo::getOrCreateFunctionType(const Decl *D,
Duncan P. N. Exon Smith4078ad42015-04-16 16:36:45 +00003643 QualType FnType,
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003644 llvm::DIFile *F) {
Benjamin Kramer8c305922016-02-02 11:06:51 +00003645 if (!D || DebugKind <= codegenoptions::DebugLineTablesOnly)
Duncan P. N. Exon Smitha7fbcbf2015-04-20 22:09:57 +00003646 // Create fake but valid subroutine type. Otherwise -verify would fail, and
3647 // subprogram DIE will miss DW_AT_decl_file and DW_AT_decl_line fields.
Eric Christopher28a6db52015-10-15 06:56:08 +00003648 return DBuilder.createSubroutineType(DBuilder.getOrCreateTypeArray(None));
Guy Benyei11169dd2012-12-18 14:30:41 +00003649
David Majnemer58ed0f32016-07-17 00:39:12 +00003650 if (const auto *Method = dyn_cast<CXXMethodDecl>(D))
Awanish Pandeyc83602f2020-01-23 16:06:52 +05303651 return getOrCreateMethodType(Method, F, false);
Reid Klecknerf00f8032016-06-08 20:41:54 +00003652
3653 const auto *FTy = FnType->getAs<FunctionType>();
3654 CallingConv CC = FTy ? FTy->getCallConv() : CallingConv::CC_C;
3655
David Majnemer58ed0f32016-07-17 00:39:12 +00003656 if (const auto *OMethod = dyn_cast<ObjCMethodDecl>(D)) {
Guy Benyei11169dd2012-12-18 14:30:41 +00003657 // Add "self" and "_cmd"
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00003658 SmallVector<llvm::Metadata *, 16> Elts;
Guy Benyei11169dd2012-12-18 14:30:41 +00003659
3660 // First element is always return type. For 'void' functions it is NULL.
Alp Toker314cc812014-01-25 16:55:45 +00003661 QualType ResultTy = OMethod->getReturnType();
Adrian Prantl5f360102013-05-22 21:37:49 +00003662
3663 // Replace the instancetype keyword with the actual type.
3664 if (ResultTy == CGM.getContext().getObjCInstanceType())
3665 ResultTy = CGM.getContext().getPointerType(
Eric Christophere7b87e52014-10-26 23:40:33 +00003666 QualType(OMethod->getClassInterface()->getTypeForDecl(), 0));
Adrian Prantl5f360102013-05-22 21:37:49 +00003667
Adrian Prantl7bec9032013-05-10 21:08:31 +00003668 Elts.push_back(getOrCreateType(ResultTy, F));
Guy Benyei11169dd2012-12-18 14:30:41 +00003669 // "self" pointer is always first argument.
Adrian Prantl748a6cd2015-09-08 20:41:52 +00003670 QualType SelfDeclTy;
3671 if (auto *SelfDecl = OMethod->getSelfDecl())
3672 SelfDeclTy = SelfDecl->getType();
3673 else if (auto *FPT = dyn_cast<FunctionProtoType>(FnType))
3674 if (FPT->getNumParams() > 1)
3675 SelfDeclTy = FPT->getParamType(0);
3676 if (!SelfDeclTy.isNull())
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00003677 Elts.push_back(
3678 CreateSelfType(SelfDeclTy, getOrCreateType(SelfDeclTy, F)));
Guy Benyei11169dd2012-12-18 14:30:41 +00003679 // "_cmd" pointer is always second argument.
Duncan P. N. Exon Smith0b6c3692015-04-20 18:51:48 +00003680 Elts.push_back(DBuilder.createArtificialType(
Adrian Prantl748a6cd2015-09-08 20:41:52 +00003681 getOrCreateType(CGM.getContext().getObjCSelType(), F)));
Guy Benyei11169dd2012-12-18 14:30:41 +00003682 // Get rest of the arguments.
David Majnemer59f77922016-06-24 04:05:48 +00003683 for (const auto *PI : OMethod->parameters())
Aaron Ballman43b68be2014-03-07 17:50:17 +00003684 Elts.push_back(getOrCreateType(PI->getType(), F));
Frederic Riss787d9d62014-08-12 04:42:23 +00003685 // Variadic methods need a special marker at the end of the type list.
3686 if (OMethod->isVariadic())
3687 Elts.push_back(DBuilder.createUnspecifiedParameter());
Guy Benyei11169dd2012-12-18 14:30:41 +00003688
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003689 llvm::DITypeRefArray EltTypeArray = DBuilder.getOrCreateTypeArray(Elts);
Leny Kholodov80c047d2016-09-06 10:48:04 +00003690 return DBuilder.createSubroutineType(EltTypeArray, llvm::DINode::FlagZero,
3691 getDwarfCC(CC));
Guy Benyei11169dd2012-12-18 14:30:41 +00003692 }
Adrian Prantld45ba252014-02-25 19:38:11 +00003693
Adrian Prantl800faef2014-02-25 23:42:18 +00003694 // Handle variadic function types; they need an additional
3695 // unspecified parameter.
David Majnemer58ed0f32016-07-17 00:39:12 +00003696 if (const auto *FD = dyn_cast<FunctionDecl>(D))
Adrian Prantld45ba252014-02-25 19:38:11 +00003697 if (FD->isVariadic()) {
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00003698 SmallVector<llvm::Metadata *, 16> EltTys;
Adrian Prantld45ba252014-02-25 19:38:11 +00003699 EltTys.push_back(getOrCreateType(FD->getReturnType(), F));
David Majnemer58ed0f32016-07-17 00:39:12 +00003700 if (const auto *FPT = dyn_cast<FunctionProtoType>(FnType))
3701 for (QualType ParamType : FPT->param_types())
3702 EltTys.push_back(getOrCreateType(ParamType, F));
Adrian Prantld45ba252014-02-25 19:38:11 +00003703 EltTys.push_back(DBuilder.createUnspecifiedParameter());
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003704 llvm::DITypeRefArray EltTypeArray = DBuilder.getOrCreateTypeArray(EltTys);
Leny Kholodov80c047d2016-09-06 10:48:04 +00003705 return DBuilder.createSubroutineType(EltTypeArray, llvm::DINode::FlagZero,
3706 getDwarfCC(CC));
Adrian Prantld45ba252014-02-25 19:38:11 +00003707 }
3708
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003709 return cast<llvm::DISubroutineType>(getOrCreateType(FnType, F));
Guy Benyei11169dd2012-12-18 14:30:41 +00003710}
3711
Eric Christophere7b87e52014-10-26 23:40:33 +00003712void CGDebugInfo::EmitFunctionStart(GlobalDecl GD, SourceLocation Loc,
3713 SourceLocation ScopeLoc, QualType FnType,
Brock Wyma94ece8f2018-04-16 16:53:57 +00003714 llvm::Function *Fn, bool CurFuncIsThunk,
3715 CGBuilderTy &Builder) {
Guy Benyei11169dd2012-12-18 14:30:41 +00003716
3717 StringRef Name;
3718 StringRef LinkageName;
3719
3720 FnBeginRegionCount.push_back(LexicalBlockStack.size());
3721
3722 const Decl *D = GD.getDecl();
Craig Topper8a13c412014-05-21 05:09:00 +00003723 bool HasDecl = (D != nullptr);
Eric Christopher885c41b2014-04-01 22:25:28 +00003724
Leny Kholodov80c047d2016-09-06 10:48:04 +00003725 llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
Paul Robinsoncda54212018-11-19 18:29:28 +00003726 llvm::DISubprogram::DISPFlags SPFlags = llvm::DISubprogram::SPFlagZero;
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003727 llvm::DIFile *Unit = getOrCreateFile(Loc);
3728 llvm::DIScope *FDContext = Unit;
3729 llvm::DINodeArray TParamsArray;
Guy Benyei11169dd2012-12-18 14:30:41 +00003730 if (!HasDecl) {
3731 // Use llvm function name.
David Blaikieebe87e12013-08-27 23:57:18 +00003732 LinkageName = Fn->getName();
David Majnemer58ed0f32016-07-17 00:39:12 +00003733 } else if (const auto *FD = dyn_cast<FunctionDecl>(D)) {
Duncan P. N. Exon Smitha7fbcbf2015-04-20 22:09:57 +00003734 // If there is a subprogram for this function available then use it.
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00003735 auto FI = SPCache.find(FD->getCanonicalDecl());
Guy Benyei11169dd2012-12-18 14:30:41 +00003736 if (FI != SPCache.end()) {
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003737 auto *SP = dyn_cast_or_null<llvm::DISubprogram>(FI->second);
Duncan P. N. Exon Smith87afdeb2015-04-14 03:24:14 +00003738 if (SP && SP->isDefinition()) {
Duncan P. N. Exon Smithd899f6e2015-04-18 00:07:30 +00003739 LexicalBlockStack.emplace_back(SP);
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00003740 RegionMap[D].reset(SP);
Guy Benyei11169dd2012-12-18 14:30:41 +00003741 return;
3742 }
3743 }
Frederic Riss9db79f12014-11-18 03:40:46 +00003744 collectFunctionDeclProps(GD, Unit, Name, LinkageName, FDContext,
3745 TParamsArray, Flags);
David Majnemer58ed0f32016-07-17 00:39:12 +00003746 } else if (const auto *OMD = dyn_cast<ObjCMethodDecl>(D)) {
Guy Benyei11169dd2012-12-18 14:30:41 +00003747 Name = getObjCMethodName(OMD);
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003748 Flags |= llvm::DINode::FlagPrototyped;
Reid Kleckner105c5652019-04-24 22:45:44 +00003749 } else if (isa<VarDecl>(D) &&
3750 GD.getDynamicInitKind() != DynamicInitKind::NoStub) {
3751 // This is a global initializer or atexit destructor for a global variable.
3752 Name = getDynamicInitializerName(cast<VarDecl>(D), GD.getDynamicInitKind(),
3753 Fn);
Guy Benyei11169dd2012-12-18 14:30:41 +00003754 } else {
Guy Benyei11169dd2012-12-18 14:30:41 +00003755 Name = Fn->getName();
shafik428583d2020-02-05 10:39:35 -08003756
Michael Liao318d0ed2020-02-06 12:19:55 -05003757 if (isa<BlockDecl>(D))
shafik428583d2020-02-05 10:39:35 -08003758 LinkageName = Name;
3759
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003760 Flags |= llvm::DINode::FlagPrototyped;
Guy Benyei11169dd2012-12-18 14:30:41 +00003761 }
David Majnemer58ed0f32016-07-17 00:39:12 +00003762 if (Name.startswith("\01"))
Guy Benyei11169dd2012-12-18 14:30:41 +00003763 Name = Name.substr(1);
3764
Alexandre Ganeacaf31662019-11-15 16:21:17 -05003765 if (!HasDecl || D->isImplicit() || D->hasAttr<ArtificialAttr>()) {
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003766 Flags |= llvm::DINode::FlagArtificial;
Adrian Prantldb763572016-11-09 21:43:51 +00003767 // Artificial functions should not silently reuse CurLoc.
3768 CurLoc = SourceLocation();
Adrian Prantl42d71b92014-04-10 23:21:53 +00003769 }
Brock Wyma94ece8f2018-04-16 16:53:57 +00003770
3771 if (CurFuncIsThunk)
3772 Flags |= llvm::DINode::FlagThunk;
3773
Paul Robinsoncda54212018-11-19 18:29:28 +00003774 if (Fn->hasLocalLinkage())
3775 SPFlags |= llvm::DISubprogram::SPFlagLocalToUnit;
3776 if (CGM.getLangOpts().Optimize)
3777 SPFlags |= llvm::DISubprogram::SPFlagOptimized;
3778
Vedant Kumar5931b4e2018-10-05 20:37:17 +00003779 llvm::DINode::DIFlags FlagsForDef = Flags | getCallSiteRelatedAttrs();
Paul Robinsoncda54212018-11-19 18:29:28 +00003780 llvm::DISubprogram::DISPFlags SPFlagsForDef =
3781 SPFlags | llvm::DISubprogram::SPFlagDefinition;
Vedant Kumar5931b4e2018-10-05 20:37:17 +00003782
Adrian Prantl42d71b92014-04-10 23:21:53 +00003783 unsigned LineNo = getLineNumber(Loc);
3784 unsigned ScopeLine = getLineNumber(ScopeLoc);
Adrian Prantl901cc4a2019-11-08 09:24:31 -08003785 llvm::DISubroutineType *DIFnType = getOrCreateFunctionType(D, FnType, Unit);
3786 llvm::DISubprogram *Decl = nullptr;
3787 if (D)
3788 Decl = isa<ObjCMethodDecl>(D)
3789 ? getObjCMethodDeclaration(D, DIFnType, LineNo, Flags, SPFlags)
3790 : getFunctionDeclaration(D);
Guy Benyei11169dd2012-12-18 14:30:41 +00003791
Eric Christopher8018e412014-03-27 18:50:35 +00003792 // FIXME: The function declaration we're constructing here is mostly reusing
3793 // declarations from CXXMethodDecl and not constructing new ones for arbitrary
3794 // FunctionDecls. When/if we fix this we can have FDContext be TheCU/null for
3795 // all subprograms instead of the actual context since subprogram definitions
3796 // are emitted as CU level entities by the backend.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003797 llvm::DISubprogram *SP = DBuilder.createFunction(
Adrian Prantl901cc4a2019-11-08 09:24:31 -08003798 FDContext, Name, LinkageName, Unit, LineNo, DIFnType, ScopeLine,
3799 FlagsForDef, SPFlagsForDef, TParamsArray.get(), Decl);
Peter Collingbourne0900fe02015-11-05 22:04:14 +00003800 Fn->setSubprogram(SP);
Frederic Rissb1ab28c2014-11-05 19:19:04 +00003801 // We might get here with a VarDecl in the case we're generating
3802 // code for the initialization of globals. Do not record these decls
3803 // as they will overwrite the actual VarDecl Decl in the cache.
3804 if (HasDecl && isa<FunctionDecl>(D))
David Majnemer58ed0f32016-07-17 00:39:12 +00003805 DeclCache[D->getCanonicalDecl()].reset(SP);
Guy Benyei11169dd2012-12-18 14:30:41 +00003806
Adrian Prantlbebb8932014-03-21 21:01:58 +00003807 // Push the function onto the lexical block stack.
Duncan P. N. Exon Smithd899f6e2015-04-18 00:07:30 +00003808 LexicalBlockStack.emplace_back(SP);
Adrian Prantlbebb8932014-03-21 21:01:58 +00003809
Guy Benyei11169dd2012-12-18 14:30:41 +00003810 if (HasDecl)
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00003811 RegionMap[D].reset(SP);
Guy Benyei11169dd2012-12-18 14:30:41 +00003812}
3813
Vedant Kumar8bd52142019-07-11 19:28:07 +00003814void CGDebugInfo::EmitFunctionDecl(GlobalDecl GD, SourceLocation Loc,
3815 QualType FnType, llvm::Function *Fn) {
Adrian Prantl748a6cd2015-09-08 20:41:52 +00003816 StringRef Name;
3817 StringRef LinkageName;
3818
3819 const Decl *D = GD.getDecl();
3820 if (!D)
Vedant Kumar8bd52142019-07-11 19:28:07 +00003821 return;
Adrian Prantl748a6cd2015-09-08 20:41:52 +00003822
Luboš Luňák4f2104c2019-11-02 16:39:59 +01003823 llvm::TimeTraceScope TimeScope("DebugFunction", [&]() {
3824 std::string Name;
3825 llvm::raw_string_ostream OS(Name);
3826 if (const NamedDecl *ND = dyn_cast<NamedDecl>(D))
3827 ND->getNameForDiagnostic(OS, getPrintingPolicy(),
3828 /*Qualified=*/true);
3829 return Name;
3830 });
3831
Leny Kholodov80c047d2016-09-06 10:48:04 +00003832 llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
Adrian Prantl748a6cd2015-09-08 20:41:52 +00003833 llvm::DIFile *Unit = getOrCreateFile(Loc);
Vedant Kumar8bd52142019-07-11 19:28:07 +00003834 bool IsDeclForCallSite = Fn ? true : false;
Djordje Todorovic0f651682019-06-27 06:44:44 +00003835 llvm::DIScope *FDContext =
3836 IsDeclForCallSite ? Unit : getDeclContextDescriptor(D);
Adrian Prantl748a6cd2015-09-08 20:41:52 +00003837 llvm::DINodeArray TParamsArray;
3838 if (isa<FunctionDecl>(D)) {
3839 // If there is a DISubprogram for this function available then use it.
3840 collectFunctionDeclProps(GD, Unit, Name, LinkageName, FDContext,
3841 TParamsArray, Flags);
David Majnemer58ed0f32016-07-17 00:39:12 +00003842 } else if (const auto *OMD = dyn_cast<ObjCMethodDecl>(D)) {
Adrian Prantl748a6cd2015-09-08 20:41:52 +00003843 Name = getObjCMethodName(OMD);
3844 Flags |= llvm::DINode::FlagPrototyped;
3845 } else {
3846 llvm_unreachable("not a function or ObjC method");
3847 }
3848 if (!Name.empty() && Name[0] == '\01')
3849 Name = Name.substr(1);
3850
3851 if (D->isImplicit()) {
3852 Flags |= llvm::DINode::FlagArtificial;
3853 // Artificial functions without a location should not silently reuse CurLoc.
3854 if (Loc.isInvalid())
3855 CurLoc = SourceLocation();
3856 }
3857 unsigned LineNo = getLineNumber(Loc);
3858 unsigned ScopeLine = 0;
Paul Robinsoncda54212018-11-19 18:29:28 +00003859 llvm::DISubprogram::DISPFlags SPFlags = llvm::DISubprogram::SPFlagZero;
3860 if (CGM.getLangOpts().Optimize)
3861 SPFlags |= llvm::DISubprogram::SPFlagOptimized;
Adrian Prantl748a6cd2015-09-08 20:41:52 +00003862
Djordje Todorovic0f651682019-06-27 06:44:44 +00003863 llvm::DISubprogram *SP = DBuilder.createFunction(
Adrian Prantle76bda52016-04-15 15:55:45 +00003864 FDContext, Name, LinkageName, Unit, LineNo,
Paul Robinsoncda54212018-11-19 18:29:28 +00003865 getOrCreateFunctionType(D, FnType, Unit), ScopeLine, Flags, SPFlags,
Djordje Todorovic0f651682019-06-27 06:44:44 +00003866 TParamsArray.get(), getFunctionDeclaration(D));
Vedant Kumar8bd52142019-07-11 19:28:07 +00003867
3868 if (IsDeclForCallSite)
3869 Fn->setSubprogram(SP);
3870
Djordje Todorovic0f651682019-06-27 06:44:44 +00003871 DBuilder.retainType(SP);
3872}
3873
3874void CGDebugInfo::EmitFuncDeclForCallSite(llvm::CallBase *CallOrInvoke,
3875 QualType CalleeType,
3876 const FunctionDecl *CalleeDecl) {
Vedant Kumar568db782019-11-13 18:19:32 -08003877 if (!CallOrInvoke)
Djordje Todorovic0f651682019-06-27 06:44:44 +00003878 return;
Djordje Todorovic0f651682019-06-27 06:44:44 +00003879 auto *Func = CallOrInvoke->getCalledFunction();
3880 if (!Func)
3881 return;
Vedant Kumar568db782019-11-13 18:19:32 -08003882 if (Func->getSubprogram())
3883 return;
3884
3885 // Do not emit a declaration subprogram for a builtin or if call site info
3886 // isn't required. Also, elide declarations for functions with reserved names,
3887 // as call site-related features aren't interesting in this case (& also, the
3888 // compiler may emit calls to these functions without debug locations, which
3889 // makes the verifier complain).
3890 if (CalleeDecl->getBuiltinID() != 0 ||
3891 getCallSiteRelatedAttrs() == llvm::DINode::FlagZero)
3892 return;
3893 if (const auto *Id = CalleeDecl->getIdentifier())
3894 if (Id->isReservedName())
3895 return;
Djordje Todorovic0f651682019-06-27 06:44:44 +00003896
3897 // If there is no DISubprogram attached to the function being called,
3898 // create the one describing the function in order to have complete
3899 // call site debug info.
Vedant Kumar8bd52142019-07-11 19:28:07 +00003900 if (!CalleeDecl->isStatic() && !CalleeDecl->isInlined())
Michael Liao4cf01ed2020-03-18 01:43:20 -04003901 EmitFunctionDecl(CalleeDecl, CalleeDecl->getLocation(), CalleeType, Func);
Adrian Prantl748a6cd2015-09-08 20:41:52 +00003902}
3903
Adrian Prantlb7acfc02017-02-27 21:30:05 +00003904void CGDebugInfo::EmitInlineFunctionStart(CGBuilderTy &Builder, GlobalDecl GD) {
3905 const auto *FD = cast<FunctionDecl>(GD.getDecl());
3906 // If there is a subprogram for this function available then use it.
3907 auto FI = SPCache.find(FD->getCanonicalDecl());
3908 llvm::DISubprogram *SP = nullptr;
3909 if (FI != SPCache.end())
3910 SP = dyn_cast_or_null<llvm::DISubprogram>(FI->second);
Adrian Prantl8040a212017-08-23 21:24:12 +00003911 if (!SP || !SP->isDefinition())
Adrian Prantlb7acfc02017-02-27 21:30:05 +00003912 SP = getFunctionStub(GD);
3913 FnBeginRegionCount.push_back(LexicalBlockStack.size());
3914 LexicalBlockStack.emplace_back(SP);
3915 setInlinedAt(Builder.getCurrentDebugLocation());
3916 EmitLocation(Builder, FD->getLocation());
3917}
3918
3919void CGDebugInfo::EmitInlineFunctionEnd(CGBuilderTy &Builder) {
3920 assert(CurInlinedAt && "unbalanced inline scope stack");
Keno Fischer41d4b4e2017-06-01 21:14:03 +00003921 EmitFunctionEnd(Builder, nullptr);
Adrian Prantlb7acfc02017-02-27 21:30:05 +00003922 setInlinedAt(llvm::DebugLoc(CurInlinedAt).getInlinedAt());
3923}
3924
Calixte Denizetfcd661d2018-09-24 18:24:18 +00003925void CGDebugInfo::EmitLocation(CGBuilderTy &Builder, SourceLocation Loc) {
Guy Benyei11169dd2012-12-18 14:30:41 +00003926 // Update our current location
3927 setLocation(Loc);
3928
Adrian Prantl42ab39f2018-11-09 21:17:38 +00003929 if (CurLoc.isInvalid() || CurLoc.isMacroID() || LexicalBlockStack.empty())
Eric Christophere7b87e52014-10-26 23:40:33 +00003930 return;
Guy Benyei11169dd2012-12-18 14:30:41 +00003931
Adrian Prantle83b1302014-01-07 22:05:52 +00003932 llvm::MDNode *Scope = LexicalBlockStack.back();
Calixte Denizetfcd661d2018-09-24 18:24:18 +00003933 Builder.SetCurrentDebugLocation(llvm::DebugLoc::get(
3934 getLineNumber(CurLoc), getColumnNumber(CurLoc), Scope, CurInlinedAt));
Guy Benyei11169dd2012-12-18 14:30:41 +00003935}
3936
Guy Benyei11169dd2012-12-18 14:30:41 +00003937void CGDebugInfo::CreateLexicalBlock(SourceLocation Loc) {
Duncan P. N. Exon Smitha66e3052014-12-09 19:22:40 +00003938 llvm::MDNode *Back = nullptr;
3939 if (!LexicalBlockStack.empty())
3940 Back = LexicalBlockStack.back().get();
Duncan P. N. Exon Smithd899f6e2015-04-18 00:07:30 +00003941 LexicalBlockStack.emplace_back(DBuilder.createLexicalBlock(
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00003942 cast<llvm::DIScope>(Back), getOrCreateFile(CurLoc), getLineNumber(CurLoc),
Duncan P. N. Exon Smithd899f6e2015-04-18 00:07:30 +00003943 getColumnNumber(CurLoc)));
Guy Benyei11169dd2012-12-18 14:30:41 +00003944}
3945
Konstantin Zhuravlyov2b4917f2017-03-09 18:06:23 +00003946void CGDebugInfo::AppendAddressSpaceXDeref(
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00003947 unsigned AddressSpace, SmallVectorImpl<int64_t> &Expr) const {
Konstantin Zhuravlyov2b4917f2017-03-09 18:06:23 +00003948 Optional<unsigned> DWARFAddressSpace =
3949 CGM.getTarget().getDWARFAddressSpace(AddressSpace);
3950 if (!DWARFAddressSpace)
3951 return;
3952
3953 Expr.push_back(llvm::dwarf::DW_OP_constu);
3954 Expr.push_back(DWARFAddressSpace.getValue());
3955 Expr.push_back(llvm::dwarf::DW_OP_swap);
3956 Expr.push_back(llvm::dwarf::DW_OP_xderef);
3957}
3958
Eric Christopher0fdcb312013-05-16 00:52:20 +00003959void CGDebugInfo::EmitLexicalBlockStart(CGBuilderTy &Builder,
3960 SourceLocation Loc) {
Guy Benyei11169dd2012-12-18 14:30:41 +00003961 // Set our current location.
3962 setLocation(Loc);
3963
Guy Benyei11169dd2012-12-18 14:30:41 +00003964 // Emit a line table change for the current location inside the new scope.
Adrian Prantlb7acfc02017-02-27 21:30:05 +00003965 Builder.SetCurrentDebugLocation(
3966 llvm::DebugLoc::get(getLineNumber(Loc), getColumnNumber(Loc),
3967 LexicalBlockStack.back(), CurInlinedAt));
David Blaikie60a877b2014-10-22 19:34:33 +00003968
Benjamin Kramer8c305922016-02-02 11:06:51 +00003969 if (DebugKind <= codegenoptions::DebugLineTablesOnly)
David Blaikie60a877b2014-10-22 19:34:33 +00003970 return;
3971
3972 // Create a new lexical block and push it on the stack.
3973 CreateLexicalBlock(Loc);
Guy Benyei11169dd2012-12-18 14:30:41 +00003974}
3975
Eric Christopher0fdcb312013-05-16 00:52:20 +00003976void CGDebugInfo::EmitLexicalBlockEnd(CGBuilderTy &Builder,
3977 SourceLocation Loc) {
Guy Benyei11169dd2012-12-18 14:30:41 +00003978 assert(!LexicalBlockStack.empty() && "Region stack mismatch, stack empty!");
3979
3980 // Provide an entry in the line table for the end of the block.
Calixte Denizetfcd661d2018-09-24 18:24:18 +00003981 EmitLocation(Builder, Loc);
Guy Benyei11169dd2012-12-18 14:30:41 +00003982
Benjamin Kramer8c305922016-02-02 11:06:51 +00003983 if (DebugKind <= codegenoptions::DebugLineTablesOnly)
David Blaikie60a877b2014-10-22 19:34:33 +00003984 return;
3985
Guy Benyei11169dd2012-12-18 14:30:41 +00003986 LexicalBlockStack.pop_back();
3987}
3988
Keno Fischer41d4b4e2017-06-01 21:14:03 +00003989void CGDebugInfo::EmitFunctionEnd(CGBuilderTy &Builder, llvm::Function *Fn) {
Guy Benyei11169dd2012-12-18 14:30:41 +00003990 assert(!LexicalBlockStack.empty() && "Region stack mismatch, stack empty!");
3991 unsigned RCount = FnBeginRegionCount.back();
3992 assert(RCount <= LexicalBlockStack.size() && "Region stack mismatch");
3993
3994 // Pop all regions for this function.
David Blaikie60a877b2014-10-22 19:34:33 +00003995 while (LexicalBlockStack.size() != RCount) {
3996 // Provide an entry in the line table for the end of the block.
Calixte Denizetfcd661d2018-09-24 18:24:18 +00003997 EmitLocation(Builder, CurLoc);
David Blaikie60a877b2014-10-22 19:34:33 +00003998 LexicalBlockStack.pop_back();
3999 }
Guy Benyei11169dd2012-12-18 14:30:41 +00004000 FnBeginRegionCount.pop_back();
Keno Fischer41d4b4e2017-06-01 21:14:03 +00004001
4002 if (Fn && Fn->getSubprogram())
4003 DBuilder.finalizeSubprogram(Fn->getSubprogram());
Guy Benyei11169dd2012-12-18 14:30:41 +00004004}
4005
Adrian Prantl05a623e2018-09-10 16:14:28 +00004006CGDebugInfo::BlockByRefType
4007CGDebugInfo::EmitTypeForVarWithBlocksAttr(const VarDecl *VD,
4008 uint64_t *XOffset) {
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00004009 SmallVector<llvm::Metadata *, 5> EltTys;
Guy Benyei11169dd2012-12-18 14:30:41 +00004010 QualType FType;
4011 uint64_t FieldSize, FieldOffset;
Victor Leschuk802e4a52016-10-19 22:11:07 +00004012 uint32_t FieldAlign;
Eric Christopherb2a008c2013-05-16 00:45:12 +00004013
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004014 llvm::DIFile *Unit = getOrCreateFile(VD->getLocation());
Eric Christopherb2a008c2013-05-16 00:45:12 +00004015 QualType Type = VD->getType();
Guy Benyei11169dd2012-12-18 14:30:41 +00004016
4017 FieldOffset = 0;
4018 FType = CGM.getContext().getPointerType(CGM.getContext().VoidTy);
4019 EltTys.push_back(CreateMemberType(Unit, FType, "__isa", &FieldOffset));
4020 EltTys.push_back(CreateMemberType(Unit, FType, "__forwarding", &FieldOffset));
4021 FType = CGM.getContext().IntTy;
4022 EltTys.push_back(CreateMemberType(Unit, FType, "__flags", &FieldOffset));
4023 EltTys.push_back(CreateMemberType(Unit, FType, "__size", &FieldOffset));
4024
4025 bool HasCopyAndDispose = CGM.getContext().BlockRequiresCopying(Type, VD);
4026 if (HasCopyAndDispose) {
4027 FType = CGM.getContext().getPointerType(CGM.getContext().VoidTy);
Eric Christophere7b87e52014-10-26 23:40:33 +00004028 EltTys.push_back(
4029 CreateMemberType(Unit, FType, "__copy_helper", &FieldOffset));
4030 EltTys.push_back(
4031 CreateMemberType(Unit, FType, "__destroy_helper", &FieldOffset));
Guy Benyei11169dd2012-12-18 14:30:41 +00004032 }
4033 bool HasByrefExtendedLayout;
4034 Qualifiers::ObjCLifetime Lifetime;
Eric Christophere7b87e52014-10-26 23:40:33 +00004035 if (CGM.getContext().getByrefLifetime(Type, Lifetime,
4036 HasByrefExtendedLayout) &&
4037 HasByrefExtendedLayout) {
Adrian Prantlead2ba42013-07-23 00:12:14 +00004038 FType = CGM.getContext().getPointerType(CGM.getContext().VoidTy);
Eric Christophere7b87e52014-10-26 23:40:33 +00004039 EltTys.push_back(
4040 CreateMemberType(Unit, FType, "__byref_variable_layout", &FieldOffset));
Adrian Prantlead2ba42013-07-23 00:12:14 +00004041 }
Eric Christopherb2a008c2013-05-16 00:45:12 +00004042
Guy Benyei11169dd2012-12-18 14:30:41 +00004043 CharUnits Align = CGM.getContext().getDeclAlign(VD);
4044 if (Align > CGM.getContext().toCharUnitsFromBits(
Eric Christophere7b87e52014-10-26 23:40:33 +00004045 CGM.getTarget().getPointerAlign(0))) {
4046 CharUnits FieldOffsetInBytes =
4047 CGM.getContext().toCharUnitsFromBits(FieldOffset);
Rui Ueyama83aa9792016-01-14 21:00:27 +00004048 CharUnits AlignedOffsetInBytes = FieldOffsetInBytes.alignTo(Align);
Eric Christophere7b87e52014-10-26 23:40:33 +00004049 CharUnits NumPaddingBytes = AlignedOffsetInBytes - FieldOffsetInBytes;
Eric Christopherb2a008c2013-05-16 00:45:12 +00004050
Guy Benyei11169dd2012-12-18 14:30:41 +00004051 if (NumPaddingBytes.isPositive()) {
4052 llvm::APInt pad(32, NumPaddingBytes.getQuantity());
Richard Smith772e2662019-10-04 01:25:59 +00004053 FType = CGM.getContext().getConstantArrayType(
4054 CGM.getContext().CharTy, pad, nullptr, ArrayType::Normal, 0);
Guy Benyei11169dd2012-12-18 14:30:41 +00004055 EltTys.push_back(CreateMemberType(Unit, FType, "", &FieldOffset));
4056 }
4057 }
Eric Christopherb2a008c2013-05-16 00:45:12 +00004058
Guy Benyei11169dd2012-12-18 14:30:41 +00004059 FType = Type;
Adrian Prantl05a623e2018-09-10 16:14:28 +00004060 llvm::DIType *WrappedTy = getOrCreateType(FType, Unit);
Guy Benyei11169dd2012-12-18 14:30:41 +00004061 FieldSize = CGM.getContext().getTypeSize(FType);
4062 FieldAlign = CGM.getContext().toBits(Align);
4063
Eric Christopherb2a008c2013-05-16 00:45:12 +00004064 *XOffset = FieldOffset;
Adrian Prantl05a623e2018-09-10 16:14:28 +00004065 llvm::DIType *FieldTy = DBuilder.createMemberType(
4066 Unit, VD->getName(), Unit, 0, FieldSize, FieldAlign, FieldOffset,
4067 llvm::DINode::FlagZero, WrappedTy);
Guy Benyei11169dd2012-12-18 14:30:41 +00004068 EltTys.push_back(FieldTy);
4069 FieldOffset += FieldSize;
Eric Christopherb2a008c2013-05-16 00:45:12 +00004070
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004071 llvm::DINodeArray Elements = DBuilder.getOrCreateArray(EltTys);
Adrian Prantl05a623e2018-09-10 16:14:28 +00004072 return {DBuilder.createStructType(Unit, "", Unit, 0, FieldOffset, 0,
4073 llvm::DINode::FlagZero, nullptr, Elements),
4074 WrappedTy};
Guy Benyei11169dd2012-12-18 14:30:41 +00004075}
4076
Sander de Smalen891af03a2018-02-03 13:55:59 +00004077llvm::DILocalVariable *CGDebugInfo::EmitDeclare(const VarDecl *VD,
4078 llvm::Value *Storage,
4079 llvm::Optional<unsigned> ArgNo,
Amy Huang7fac5c82019-06-20 17:15:21 +00004080 CGBuilderTy &Builder,
4081 const bool UsePointerValue) {
Amy Huang53539bb2020-01-13 15:54:54 -08004082 assert(CGM.getCodeGenOpts().hasReducedDebugInfo());
Guy Benyei11169dd2012-12-18 14:30:41 +00004083 assert(!LexicalBlockStack.empty() && "Region stack mismatch, stack empty!");
Paul Robinsonafd2dde2016-06-16 00:42:36 +00004084 if (VD->hasAttr<NoDebugAttr>())
Sander de Smalen891af03a2018-02-03 13:55:59 +00004085 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00004086
David Blaikie7fceebf2013-08-19 03:37:48 +00004087 bool Unwritten =
4088 VD->isImplicit() || (isa<Decl>(VD->getDeclContext()) &&
4089 cast<Decl>(VD->getDeclContext())->isImplicit());
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004090 llvm::DIFile *Unit = nullptr;
David Blaikie7fceebf2013-08-19 03:37:48 +00004091 if (!Unwritten)
4092 Unit = getOrCreateFile(VD->getLocation());
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004093 llvm::DIType *Ty;
Guy Benyei11169dd2012-12-18 14:30:41 +00004094 uint64_t XOffset = 0;
4095 if (VD->hasAttr<BlocksAttr>())
Adrian Prantl05a623e2018-09-10 16:14:28 +00004096 Ty = EmitTypeForVarWithBlocksAttr(VD, &XOffset).WrappedType;
Eric Christopherb2a008c2013-05-16 00:45:12 +00004097 else
Guy Benyei11169dd2012-12-18 14:30:41 +00004098 Ty = getOrCreateType(VD->getType(), Unit);
4099
4100 // If there is no debug info for this type then do not emit debug info
4101 // for this variable.
4102 if (!Ty)
Sander de Smalen891af03a2018-02-03 13:55:59 +00004103 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00004104
Guy Benyei11169dd2012-12-18 14:30:41 +00004105 // Get location information.
David Blaikie7fceebf2013-08-19 03:37:48 +00004106 unsigned Line = 0;
4107 unsigned Column = 0;
4108 if (!Unwritten) {
4109 Line = getLineNumber(VD->getLocation());
4110 Column = getColumnNumber(VD->getLocation());
4111 }
Konstantin Zhuravlyov2b4917f2017-03-09 18:06:23 +00004112 SmallVector<int64_t, 13> Expr;
Leny Kholodov80c047d2016-09-06 10:48:04 +00004113 llvm::DINode::DIFlags Flags = llvm::DINode::FlagZero;
Guy Benyei11169dd2012-12-18 14:30:41 +00004114 if (VD->isImplicit())
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004115 Flags |= llvm::DINode::FlagArtificial;
Victor Leschuka7ece032016-10-20 00:13:19 +00004116
4117 auto Align = getDeclAlignIfRequired(VD, CGM.getContext());
4118
Konstantin Zhuravlyov2b4917f2017-03-09 18:06:23 +00004119 unsigned AddressSpace = CGM.getContext().getTargetAddressSpace(VD->getType());
4120 AppendAddressSpaceXDeref(AddressSpace, Expr);
4121
Alexey Bataev24f710182017-06-09 13:55:08 +00004122 // If this is implicit parameter of CXXThis or ObjCSelf kind, then give it an
4123 // object pointer flag.
Alexey Bataev56223232017-06-09 13:40:18 +00004124 if (const auto *IPD = dyn_cast<ImplicitParamDecl>(VD)) {
4125 if (IPD->getParameterKind() == ImplicitParamDecl::CXXThis ||
4126 IPD->getParameterKind() == ImplicitParamDecl::ObjCSelf)
4127 Flags |= llvm::DINode::FlagObjectPointer;
4128 }
Guy Benyei11169dd2012-12-18 14:30:41 +00004129
Adrian Prantlc3782a12017-04-18 01:22:01 +00004130 // Note: Older versions of clang used to emit byval references with an extra
4131 // DW_OP_deref, because they referenced the IR arg directly instead of
4132 // referencing an alloca. Newer versions of LLVM don't treat allocas
4133 // differently from other function arguments when used in a dbg.declare.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004134 auto *Scope = cast<llvm::DIScope>(LexicalBlockStack.back());
Guy Benyei11169dd2012-12-18 14:30:41 +00004135 StringRef Name = VD->getName();
4136 if (!Name.empty()) {
4137 if (VD->hasAttr<BlocksAttr>()) {
Adrian Prantlc3782a12017-04-18 01:22:01 +00004138 // Here, we need an offset *into* the alloca.
Guy Benyei11169dd2012-12-18 14:30:41 +00004139 CharUnits offset = CharUnits::fromQuantity(32);
Florian Hahn3dbcced2017-06-13 18:06:15 +00004140 Expr.push_back(llvm::dwarf::DW_OP_plus_uconst);
Guy Benyei11169dd2012-12-18 14:30:41 +00004141 // offset of __forwarding field
4142 offset = CGM.getContext().toCharUnitsFromBits(
Eric Christophere7b87e52014-10-26 23:40:33 +00004143 CGM.getTarget().getPointerWidth(0));
Adrian Prantl7c6f9442015-01-19 17:51:58 +00004144 Expr.push_back(offset.getQuantity());
4145 Expr.push_back(llvm::dwarf::DW_OP_deref);
Florian Hahn3dbcced2017-06-13 18:06:15 +00004146 Expr.push_back(llvm::dwarf::DW_OP_plus_uconst);
Guy Benyei11169dd2012-12-18 14:30:41 +00004147 // offset of x field
4148 offset = CGM.getContext().toCharUnitsFromBits(XOffset);
Adrian Prantl7c6f9442015-01-19 17:51:58 +00004149 Expr.push_back(offset.getQuantity());
Adrian Prantlc3782a12017-04-18 01:22:01 +00004150 }
David Majnemer58ed0f32016-07-17 00:39:12 +00004151 } else if (const auto *RT = dyn_cast<RecordType>(VD->getType())) {
Adrian Prantl0d820892015-04-29 15:05:50 +00004152 // If VD is an anonymous union then Storage represents value for
4153 // all union fields.
George Burgess IV00f70bd2018-03-01 05:43:23 +00004154 const RecordDecl *RD = RT->getDecl();
Adrian Prantl0d820892015-04-29 15:05:50 +00004155 if (RD->isUnion() && RD->isAnonymousStructOrUnion()) {
Adrian Prantl00820ab2015-04-29 16:52:31 +00004156 // GDB has trouble finding local variables in anonymous unions, so we emit
Alexander Kornienko2a8c18d2018-04-06 15:14:32 +00004157 // artificial local variables for each of the members.
Adrian Prantl00820ab2015-04-29 16:52:31 +00004158 //
4159 // FIXME: Remove this code as soon as GDB supports this.
4160 // The debug info verifier in LLVM operates based on the assumption that a
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00004161 // variable has the same size as its storage and we had to disable the
4162 // check for artificial variables.
Adrian Prantl0d820892015-04-29 15:05:50 +00004163 for (const auto *Field : RD->fields()) {
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004164 llvm::DIType *FieldTy = getOrCreateType(Field->getType(), Unit);
Adrian Prantl0d820892015-04-29 15:05:50 +00004165 StringRef FieldName = Field->getName();
4166
4167 // Ignore unnamed fields. Do not ignore unnamed records.
4168 if (FieldName.empty() && !isa<RecordType>(Field->getType()))
4169 continue;
4170
4171 // Use VarDecl's Tag, Scope and Line number.
Victor Leschuka7ece032016-10-20 00:13:19 +00004172 auto FieldAlign = getDeclAlignIfRequired(Field, CGM.getContext());
Duncan P. N. Exon Smithe4306542015-07-31 17:56:14 +00004173 auto *D = DBuilder.createAutoVariable(
4174 Scope, FieldName, Unit, Line, FieldTy, CGM.getLangOpts().Optimize,
Victor Leschuka7ece032016-10-20 00:13:19 +00004175 Flags | llvm::DINode::FlagArtificial, FieldAlign);
Adrian Prantl0d820892015-04-29 15:05:50 +00004176
4177 // Insert an llvm.dbg.declare into the current block.
Adrian Prantlb7acfc02017-02-27 21:30:05 +00004178 DBuilder.insertDeclare(
4179 Storage, D, DBuilder.createExpression(Expr),
4180 llvm::DebugLoc::get(Line, Column, Scope, CurInlinedAt),
4181 Builder.GetInsertBlock());
Adrian Prantl0d820892015-04-29 15:05:50 +00004182 }
Adrian Prantl0d820892015-04-29 15:05:50 +00004183 }
Guy Benyei11169dd2012-12-18 14:30:41 +00004184 }
David Blaikiea76a7c92013-01-05 05:58:35 +00004185
Amy Huang7fac5c82019-06-20 17:15:21 +00004186 // Clang stores the sret pointer provided by the caller in a static alloca.
4187 // Use DW_OP_deref to tell the debugger to load the pointer and treat it as
4188 // the address of the variable.
4189 if (UsePointerValue) {
4190 assert(std::find(Expr.begin(), Expr.end(), llvm::dwarf::DW_OP_deref) ==
4191 Expr.end() &&
4192 "Debug info already contains DW_OP_deref.");
4193 Expr.push_back(llvm::dwarf::DW_OP_deref);
4194 }
4195
David Blaikiea76a7c92013-01-05 05:58:35 +00004196 // Create the descriptor for the variable.
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00004197 auto *D = ArgNo ? DBuilder.createParameterVariable(
4198 Scope, Name, *ArgNo, Unit, Line, Ty,
4199 CGM.getLangOpts().Optimize, Flags)
4200 : DBuilder.createAutoVariable(Scope, Name, Unit, Line, Ty,
4201 CGM.getLangOpts().Optimize,
4202 Flags, Align);
David Blaikiea76a7c92013-01-05 05:58:35 +00004203
4204 // Insert an llvm.dbg.declare into the current block.
Duncan P. N. Exon Smithfe88b482015-04-15 21:18:30 +00004205 DBuilder.insertDeclare(Storage, D, DBuilder.createExpression(Expr),
Adrian Prantlb7acfc02017-02-27 21:30:05 +00004206 llvm::DebugLoc::get(Line, Column, Scope, CurInlinedAt),
Duncan P. N. Exon Smithfe88b482015-04-15 21:18:30 +00004207 Builder.GetInsertBlock());
Sander de Smalen891af03a2018-02-03 13:55:59 +00004208
4209 return D;
Guy Benyei11169dd2012-12-18 14:30:41 +00004210}
4211
Sander de Smalen891af03a2018-02-03 13:55:59 +00004212llvm::DILocalVariable *
4213CGDebugInfo::EmitDeclareOfAutoVariable(const VarDecl *VD, llvm::Value *Storage,
Amy Huang7fac5c82019-06-20 17:15:21 +00004214 CGBuilderTy &Builder,
4215 const bool UsePointerValue) {
Amy Huang53539bb2020-01-13 15:54:54 -08004216 assert(CGM.getCodeGenOpts().hasReducedDebugInfo());
Amy Huang7fac5c82019-06-20 17:15:21 +00004217 return EmitDeclare(VD, Storage, llvm::None, Builder, UsePointerValue);
Guy Benyei11169dd2012-12-18 14:30:41 +00004218}
4219
Hsiangkai Wang35751492019-01-24 05:34:29 +00004220void CGDebugInfo::EmitLabel(const LabelDecl *D, CGBuilderTy &Builder) {
Amy Huang53539bb2020-01-13 15:54:54 -08004221 assert(CGM.getCodeGenOpts().hasReducedDebugInfo());
Hsiangkai Wang35751492019-01-24 05:34:29 +00004222 assert(!LexicalBlockStack.empty() && "Region stack mismatch, stack empty!");
4223
4224 if (D->hasAttr<NoDebugAttr>())
4225 return;
4226
4227 auto *Scope = cast<llvm::DIScope>(LexicalBlockStack.back());
4228 llvm::DIFile *Unit = getOrCreateFile(D->getLocation());
4229
4230 // Get location information.
4231 unsigned Line = getLineNumber(D->getLocation());
4232 unsigned Column = getColumnNumber(D->getLocation());
4233
4234 StringRef Name = D->getName();
4235
4236 // Create the descriptor for the label.
4237 auto *L =
4238 DBuilder.createLabel(Scope, Name, Unit, Line, CGM.getLangOpts().Optimize);
4239
4240 // Insert an llvm.dbg.label into the current block.
4241 DBuilder.insertLabel(L,
4242 llvm::DebugLoc::get(Line, Column, Scope, CurInlinedAt),
4243 Builder.GetInsertBlock());
4244}
4245
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004246llvm::DIType *CGDebugInfo::CreateSelfType(const QualType &QualTy,
4247 llvm::DIType *Ty) {
4248 llvm::DIType *CachedTy = getTypeOrNull(QualTy);
Eric Christophere7b87e52014-10-26 23:40:33 +00004249 if (CachedTy)
4250 Ty = CachedTy;
Adrian Prantlde17db32013-03-29 19:20:29 +00004251 return DBuilder.createObjectPointerType(Ty);
4252}
4253
Eric Christophere7b87e52014-10-26 23:40:33 +00004254void CGDebugInfo::EmitDeclareOfBlockDeclRefVariable(
4255 const VarDecl *VD, llvm::Value *Storage, CGBuilderTy &Builder,
Adrian Prantl88eec392014-11-21 00:35:25 +00004256 const CGBlockInfo &blockInfo, llvm::Instruction *InsertPoint) {
Amy Huang53539bb2020-01-13 15:54:54 -08004257 assert(CGM.getCodeGenOpts().hasReducedDebugInfo());
Guy Benyei11169dd2012-12-18 14:30:41 +00004258 assert(!LexicalBlockStack.empty() && "Region stack mismatch, stack empty!");
Eric Christopherb2a008c2013-05-16 00:45:12 +00004259
Craig Topper8a13c412014-05-21 05:09:00 +00004260 if (Builder.GetInsertBlock() == nullptr)
Guy Benyei11169dd2012-12-18 14:30:41 +00004261 return;
Paul Robinsonafd2dde2016-06-16 00:42:36 +00004262 if (VD->hasAttr<NoDebugAttr>())
4263 return;
Eric Christopherb2a008c2013-05-16 00:45:12 +00004264
Guy Benyei11169dd2012-12-18 14:30:41 +00004265 bool isByRef = VD->hasAttr<BlocksAttr>();
Eric Christopherb2a008c2013-05-16 00:45:12 +00004266
Guy Benyei11169dd2012-12-18 14:30:41 +00004267 uint64_t XOffset = 0;
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004268 llvm::DIFile *Unit = getOrCreateFile(VD->getLocation());
4269 llvm::DIType *Ty;
Guy Benyei11169dd2012-12-18 14:30:41 +00004270 if (isByRef)
Adrian Prantl05a623e2018-09-10 16:14:28 +00004271 Ty = EmitTypeForVarWithBlocksAttr(VD, &XOffset).WrappedType;
Eric Christopherb2a008c2013-05-16 00:45:12 +00004272 else
Guy Benyei11169dd2012-12-18 14:30:41 +00004273 Ty = getOrCreateType(VD->getType(), Unit);
4274
4275 // Self is passed along as an implicit non-arg variable in a
4276 // block. Mark it as the object pointer.
Alexey Bataev56223232017-06-09 13:40:18 +00004277 if (const auto *IPD = dyn_cast<ImplicitParamDecl>(VD))
4278 if (IPD->getParameterKind() == ImplicitParamDecl::ObjCSelf)
4279 Ty = CreateSelfType(VD->getType(), Ty);
Guy Benyei11169dd2012-12-18 14:30:41 +00004280
4281 // Get location information.
4282 unsigned Line = getLineNumber(VD->getLocation());
4283 unsigned Column = getColumnNumber(VD->getLocation());
4284
4285 const llvm::DataLayout &target = CGM.getDataLayout();
4286
4287 CharUnits offset = CharUnits::fromQuantity(
Eric Christophere7b87e52014-10-26 23:40:33 +00004288 target.getStructLayout(blockInfo.StructureType)
Guy Benyei11169dd2012-12-18 14:30:41 +00004289 ->getElementOffset(blockInfo.getCapture(VD).getIndex()));
4290
Duncan P. N. Exon Smithf3dc4292014-10-01 20:26:18 +00004291 SmallVector<int64_t, 9> addr;
Adrian Prantlc3782a12017-04-18 01:22:01 +00004292 addr.push_back(llvm::dwarf::DW_OP_deref);
Florian Hahn3dbcced2017-06-13 18:06:15 +00004293 addr.push_back(llvm::dwarf::DW_OP_plus_uconst);
Duncan P. N. Exon Smithf3dc4292014-10-01 20:26:18 +00004294 addr.push_back(offset.getQuantity());
Guy Benyei11169dd2012-12-18 14:30:41 +00004295 if (isByRef) {
Duncan P. N. Exon Smithf3dc4292014-10-01 20:26:18 +00004296 addr.push_back(llvm::dwarf::DW_OP_deref);
Florian Hahn3dbcced2017-06-13 18:06:15 +00004297 addr.push_back(llvm::dwarf::DW_OP_plus_uconst);
Guy Benyei11169dd2012-12-18 14:30:41 +00004298 // offset of __forwarding field
Eric Christophere7b87e52014-10-26 23:40:33 +00004299 offset =
4300 CGM.getContext().toCharUnitsFromBits(target.getPointerSizeInBits(0));
Duncan P. N. Exon Smithf3dc4292014-10-01 20:26:18 +00004301 addr.push_back(offset.getQuantity());
4302 addr.push_back(llvm::dwarf::DW_OP_deref);
Florian Hahn3dbcced2017-06-13 18:06:15 +00004303 addr.push_back(llvm::dwarf::DW_OP_plus_uconst);
Guy Benyei11169dd2012-12-18 14:30:41 +00004304 // offset of x field
4305 offset = CGM.getContext().toCharUnitsFromBits(XOffset);
Duncan P. N. Exon Smithf3dc4292014-10-01 20:26:18 +00004306 addr.push_back(offset.getQuantity());
Guy Benyei11169dd2012-12-18 14:30:41 +00004307 }
4308
4309 // Create the descriptor for the variable.
Victor Leschuka7ece032016-10-20 00:13:19 +00004310 auto Align = getDeclAlignIfRequired(VD, CGM.getContext());
Duncan P. N. Exon Smithe4306542015-07-31 17:56:14 +00004311 auto *D = DBuilder.createAutoVariable(
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004312 cast<llvm::DILocalScope>(LexicalBlockStack.back()), VD->getName(), Unit,
Victor Leschuka7ece032016-10-20 00:13:19 +00004313 Line, Ty, false, llvm::DINode::FlagZero, Align);
Adrian Prantl0f6df002013-03-29 19:20:35 +00004314
Guy Benyei11169dd2012-12-18 14:30:41 +00004315 // Insert an llvm.dbg.declare into the current block.
Adrian Prantlb7acfc02017-02-27 21:30:05 +00004316 auto DL =
4317 llvm::DebugLoc::get(Line, Column, LexicalBlockStack.back(), CurInlinedAt);
Adrian Prantlc3782a12017-04-18 01:22:01 +00004318 auto *Expr = DBuilder.createExpression(addr);
Duncan P. N. Exon Smithfe88b482015-04-15 21:18:30 +00004319 if (InsertPoint)
Adrian Prantlc3782a12017-04-18 01:22:01 +00004320 DBuilder.insertDeclare(Storage, D, Expr, DL, InsertPoint);
Duncan P. N. Exon Smithfe88b482015-04-15 21:18:30 +00004321 else
Adrian Prantlc3782a12017-04-18 01:22:01 +00004322 DBuilder.insertDeclare(Storage, D, Expr, DL, Builder.GetInsertBlock());
Guy Benyei11169dd2012-12-18 14:30:41 +00004323}
4324
Guy Benyei11169dd2012-12-18 14:30:41 +00004325void CGDebugInfo::EmitDeclareOfArgVariable(const VarDecl *VD, llvm::Value *AI,
4326 unsigned ArgNo,
4327 CGBuilderTy &Builder) {
Amy Huang53539bb2020-01-13 15:54:54 -08004328 assert(CGM.getCodeGenOpts().hasReducedDebugInfo());
Duncan P. N. Exon Smithe4306542015-07-31 17:56:14 +00004329 EmitDeclare(VD, AI, ArgNo, Builder);
Guy Benyei11169dd2012-12-18 14:30:41 +00004330}
4331
4332namespace {
Eric Christophere7b87e52014-10-26 23:40:33 +00004333struct BlockLayoutChunk {
4334 uint64_t OffsetInBits;
4335 const BlockDecl::Capture *Capture;
4336};
4337bool operator<(const BlockLayoutChunk &l, const BlockLayoutChunk &r) {
4338 return l.OffsetInBits < r.OffsetInBits;
4339}
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00004340} // namespace
Guy Benyei11169dd2012-12-18 14:30:41 +00004341
Scott Linder58df0e42018-08-08 15:56:12 +00004342void CGDebugInfo::collectDefaultFieldsForBlockLiteralDeclare(
4343 const CGBlockInfo &Block, const ASTContext &Context, SourceLocation Loc,
4344 const llvm::StructLayout &BlockLayout, llvm::DIFile *Unit,
4345 SmallVectorImpl<llvm::Metadata *> &Fields) {
4346 // Blocks in OpenCL have unique constraints which make the standard fields
4347 // redundant while requiring size and align fields for enqueue_kernel. See
4348 // initializeForBlockHeader in CGBlocks.cpp
4349 if (CGM.getLangOpts().OpenCL) {
4350 Fields.push_back(createFieldType("__size", Context.IntTy, Loc, AS_public,
4351 BlockLayout.getElementOffsetInBits(0),
4352 Unit, Unit));
4353 Fields.push_back(createFieldType("__align", Context.IntTy, Loc, AS_public,
4354 BlockLayout.getElementOffsetInBits(1),
4355 Unit, Unit));
4356 } else {
4357 Fields.push_back(createFieldType("__isa", Context.VoidPtrTy, Loc, AS_public,
4358 BlockLayout.getElementOffsetInBits(0),
4359 Unit, Unit));
4360 Fields.push_back(createFieldType("__flags", Context.IntTy, Loc, AS_public,
4361 BlockLayout.getElementOffsetInBits(1),
4362 Unit, Unit));
4363 Fields.push_back(
4364 createFieldType("__reserved", Context.IntTy, Loc, AS_public,
4365 BlockLayout.getElementOffsetInBits(2), Unit, Unit));
4366 auto *FnTy = Block.getBlockExpr()->getFunctionType();
4367 auto FnPtrType = CGM.getContext().getPointerType(FnTy->desugar());
4368 Fields.push_back(createFieldType("__FuncPtr", FnPtrType, Loc, AS_public,
4369 BlockLayout.getElementOffsetInBits(3),
4370 Unit, Unit));
4371 Fields.push_back(createFieldType(
4372 "__descriptor",
4373 Context.getPointerType(Block.NeedsCopyDispose
4374 ? Context.getBlockDescriptorExtendedType()
4375 : Context.getBlockDescriptorType()),
4376 Loc, AS_public, BlockLayout.getElementOffsetInBits(4), Unit, Unit));
4377 }
4378}
4379
Guy Benyei11169dd2012-12-18 14:30:41 +00004380void CGDebugInfo::EmitDeclareOfBlockLiteralArgVariable(const CGBlockInfo &block,
Adrian Prantl356347b2017-10-26 20:08:52 +00004381 StringRef Name,
David Blaikie77bbb5f2014-08-08 17:10:14 +00004382 unsigned ArgNo,
Adrian Prantl356347b2017-10-26 20:08:52 +00004383 llvm::AllocaInst *Alloca,
Guy Benyei11169dd2012-12-18 14:30:41 +00004384 CGBuilderTy &Builder) {
Amy Huang53539bb2020-01-13 15:54:54 -08004385 assert(CGM.getCodeGenOpts().hasReducedDebugInfo());
Guy Benyei11169dd2012-12-18 14:30:41 +00004386 ASTContext &C = CGM.getContext();
4387 const BlockDecl *blockDecl = block.getBlockDecl();
4388
4389 // Collect some general information about the block's location.
4390 SourceLocation loc = blockDecl->getCaretLocation();
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004391 llvm::DIFile *tunit = getOrCreateFile(loc);
Guy Benyei11169dd2012-12-18 14:30:41 +00004392 unsigned line = getLineNumber(loc);
4393 unsigned column = getColumnNumber(loc);
Eric Christopherb2a008c2013-05-16 00:45:12 +00004394
Guy Benyei11169dd2012-12-18 14:30:41 +00004395 // Build the debug-info type for the block literal.
Adrian Prantl6ec370a2015-09-10 18:39:45 +00004396 getDeclContextDescriptor(blockDecl);
Guy Benyei11169dd2012-12-18 14:30:41 +00004397
4398 const llvm::StructLayout *blockLayout =
Eric Christophere7b87e52014-10-26 23:40:33 +00004399 CGM.getDataLayout().getStructLayout(block.StructureType);
Guy Benyei11169dd2012-12-18 14:30:41 +00004400
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00004401 SmallVector<llvm::Metadata *, 16> fields;
Scott Linder58df0e42018-08-08 15:56:12 +00004402 collectDefaultFieldsForBlockLiteralDeclare(block, C, loc, *blockLayout, tunit,
4403 fields);
Guy Benyei11169dd2012-12-18 14:30:41 +00004404
4405 // We want to sort the captures by offset, not because DWARF
4406 // requires this, but because we're paranoid about debuggers.
4407 SmallVector<BlockLayoutChunk, 8> chunks;
4408
4409 // 'this' capture.
4410 if (blockDecl->capturesCXXThis()) {
4411 BlockLayoutChunk chunk;
4412 chunk.OffsetInBits =
Eric Christophere7b87e52014-10-26 23:40:33 +00004413 blockLayout->getElementOffsetInBits(block.CXXThisIndex);
Craig Topper8a13c412014-05-21 05:09:00 +00004414 chunk.Capture = nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00004415 chunks.push_back(chunk);
4416 }
4417
4418 // Variable captures.
Aaron Ballman9371dd22014-03-14 18:34:04 +00004419 for (const auto &capture : blockDecl->captures()) {
Guy Benyei11169dd2012-12-18 14:30:41 +00004420 const VarDecl *variable = capture.getVariable();
4421 const CGBlockInfo::Capture &captureInfo = block.getCapture(variable);
4422
4423 // Ignore constant captures.
4424 if (captureInfo.isConstant())
4425 continue;
4426
4427 BlockLayoutChunk chunk;
4428 chunk.OffsetInBits =
Eric Christophere7b87e52014-10-26 23:40:33 +00004429 blockLayout->getElementOffsetInBits(captureInfo.getIndex());
Guy Benyei11169dd2012-12-18 14:30:41 +00004430 chunk.Capture = &capture;
4431 chunks.push_back(chunk);
4432 }
4433
4434 // Sort by offset.
4435 llvm::array_pod_sort(chunks.begin(), chunks.end());
4436
David Majnemer58ed0f32016-07-17 00:39:12 +00004437 for (const BlockLayoutChunk &Chunk : chunks) {
4438 uint64_t offsetInBits = Chunk.OffsetInBits;
4439 const BlockDecl::Capture *capture = Chunk.Capture;
Guy Benyei11169dd2012-12-18 14:30:41 +00004440
4441 // If we have a null capture, this must be the C++ 'this' capture.
4442 if (!capture) {
Adrian Prantl2526fca2016-04-18 23:48:16 +00004443 QualType type;
4444 if (auto *Method =
4445 cast_or_null<CXXMethodDecl>(blockDecl->getNonClosureContext()))
Brian Gesiak5488ab42019-01-11 01:54:53 +00004446 type = Method->getThisType();
Adrian Prantl2526fca2016-04-18 23:48:16 +00004447 else if (auto *RDecl = dyn_cast<CXXRecordDecl>(blockDecl->getParent()))
4448 type = QualType(RDecl->getTypeForDecl(), 0);
4449 else
4450 llvm_unreachable("unexpected block declcontext");
Guy Benyei11169dd2012-12-18 14:30:41 +00004451
David Majnemerb4b671e2016-06-30 03:01:59 +00004452 fields.push_back(createFieldType("this", type, loc, AS_public,
Guy Benyei11169dd2012-12-18 14:30:41 +00004453 offsetInBits, tunit, tunit));
4454 continue;
4455 }
4456
4457 const VarDecl *variable = capture->getVariable();
4458 StringRef name = variable->getName();
4459
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004460 llvm::DIType *fieldType;
Guy Benyei11169dd2012-12-18 14:30:41 +00004461 if (capture->isByRef()) {
David Majnemer34b57492014-07-30 01:30:47 +00004462 TypeInfo PtrInfo = C.getTypeInfo(C.VoidPtrTy);
Victor Leschuka7ece032016-10-20 00:13:19 +00004463 auto Align = PtrInfo.AlignIsRequired ? PtrInfo.Align : 0;
Adrian Prantl05a623e2018-09-10 16:14:28 +00004464 // FIXME: This recomputes the layout of the BlockByRefWrapper.
Guy Benyei11169dd2012-12-18 14:30:41 +00004465 uint64_t xoffset;
Adrian Prantl05a623e2018-09-10 16:14:28 +00004466 fieldType =
4467 EmitTypeForVarWithBlocksAttr(variable, &xoffset).BlockByRefWrapper;
David Majnemer34b57492014-07-30 01:30:47 +00004468 fieldType = DBuilder.createPointerType(fieldType, PtrInfo.Width);
Victor Leschuka7ece032016-10-20 00:13:19 +00004469 fieldType = DBuilder.createMemberType(tunit, name, tunit, line,
4470 PtrInfo.Width, Align, offsetInBits,
4471 llvm::DINode::FlagZero, fieldType);
Guy Benyei11169dd2012-12-18 14:30:41 +00004472 } else {
Victor Leschuka7ece032016-10-20 00:13:19 +00004473 auto Align = getDeclAlignIfRequired(variable, CGM.getContext());
David Majnemerb4b671e2016-06-30 03:01:59 +00004474 fieldType = createFieldType(name, variable->getType(), loc, AS_public,
Victor Leschuka7ece032016-10-20 00:13:19 +00004475 offsetInBits, Align, tunit, tunit);
Guy Benyei11169dd2012-12-18 14:30:41 +00004476 }
4477 fields.push_back(fieldType);
4478 }
4479
4480 SmallString<36> typeName;
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00004481 llvm::raw_svector_ostream(typeName)
4482 << "__block_literal_" << CGM.getUniqueBlockCount();
Guy Benyei11169dd2012-12-18 14:30:41 +00004483
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004484 llvm::DINodeArray fieldsArray = DBuilder.getOrCreateArray(fields);
Guy Benyei11169dd2012-12-18 14:30:41 +00004485
Leny Kholodovdf050fd2016-09-06 17:06:14 +00004486 llvm::DIType *type =
4487 DBuilder.createStructType(tunit, typeName.str(), tunit, line,
Victor Leschuka7ece032016-10-20 00:13:19 +00004488 CGM.getContext().toBits(block.BlockSize), 0,
Leny Kholodovdf050fd2016-09-06 17:06:14 +00004489 llvm::DINode::FlagZero, nullptr, fieldsArray);
Guy Benyei11169dd2012-12-18 14:30:41 +00004490 type = DBuilder.createPointerType(type, CGM.PointerWidthInBits);
4491
4492 // Get overall information about the block.
Leny Kholodov80c047d2016-09-06 10:48:04 +00004493 llvm::DINode::DIFlags flags = llvm::DINode::FlagArtificial;
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004494 auto *scope = cast<llvm::DILocalScope>(LexicalBlockStack.back());
Guy Benyei11169dd2012-12-18 14:30:41 +00004495
4496 // Create the descriptor for the parameter.
Duncan P. N. Exon Smithe4306542015-07-31 17:56:14 +00004497 auto *debugVar = DBuilder.createParameterVariable(
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00004498 scope, Name, ArgNo, tunit, line, type, CGM.getLangOpts().Optimize, flags);
Adrian Prantl51936dd2013-03-14 17:53:33 +00004499
Adrian Prantl616bef42013-03-14 21:52:59 +00004500 // Insert an llvm.dbg.declare into the current block.
Adrian Prantl356347b2017-10-26 20:08:52 +00004501 DBuilder.insertDeclare(Alloca, debugVar, DBuilder.createExpression(),
Adrian Prantlb7acfc02017-02-27 21:30:05 +00004502 llvm::DebugLoc::get(line, column, scope, CurInlinedAt),
Duncan P. N. Exon Smithfe88b482015-04-15 21:18:30 +00004503 Builder.GetInsertBlock());
Guy Benyei11169dd2012-12-18 14:30:41 +00004504}
4505
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004506llvm::DIDerivedType *
David Blaikie6943dea2013-08-20 01:28:15 +00004507CGDebugInfo::getOrCreateStaticDataMemberDeclarationOrNull(const VarDecl *D) {
Amy Huangdd3a9ca2019-05-30 22:04:11 +00004508 if (!D || !D->isStaticDataMember())
Duncan P. N. Exon Smithc09c5482015-04-20 21:17:26 +00004509 return nullptr;
Saleem Abdulrasoolcd187f02015-02-28 00:13:13 +00004510
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00004511 auto MI = StaticDataMemberCache.find(D->getCanonicalDecl());
David Blaikie6943dea2013-08-20 01:28:15 +00004512 if (MI != StaticDataMemberCache.end()) {
4513 assert(MI->second && "Static data member declaration should still exist");
Duncan P. N. Exon Smithac346ba2015-07-24 18:05:58 +00004514 return MI->second;
Evgeniy Stepanov37b3f732013-08-16 10:35:31 +00004515 }
David Blaikiece763042013-08-20 21:49:21 +00004516
4517 // If the member wasn't found in the cache, lazily construct and add it to the
4518 // type (used when a limited form of the type is emitted).
Adrian Prantl21361fb2014-08-29 22:44:27 +00004519 auto DC = D->getDeclContext();
Adrian Prantl6ec370a2015-09-10 18:39:45 +00004520 auto *Ctxt = cast<llvm::DICompositeType>(getDeclContextDescriptor(D));
Adrian Prantl21361fb2014-08-29 22:44:27 +00004521 return CreateRecordStaticField(D, Ctxt, cast<RecordDecl>(DC));
David Blaikie6943dea2013-08-20 01:28:15 +00004522}
4523
Adrian Prantl5f4740d2016-12-20 02:10:02 +00004524llvm::DIGlobalVariableExpression *CGDebugInfo::CollectAnonRecordDecls(
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004525 const RecordDecl *RD, llvm::DIFile *Unit, unsigned LineNo,
4526 StringRef LinkageName, llvm::GlobalVariable *Var, llvm::DIScope *DContext) {
Adrian Prantl5f4740d2016-12-20 02:10:02 +00004527 llvm::DIGlobalVariableExpression *GVE = nullptr;
Eric Christophercab9fae2014-04-10 05:20:00 +00004528
4529 for (const auto *Field : RD->fields()) {
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004530 llvm::DIType *FieldTy = getOrCreateType(Field->getType(), Unit);
Eric Christophercab9fae2014-04-10 05:20:00 +00004531 StringRef FieldName = Field->getName();
4532
4533 // Ignore unnamed fields, but recurse into anonymous records.
4534 if (FieldName.empty()) {
David Majnemer58ed0f32016-07-17 00:39:12 +00004535 if (const auto *RT = dyn_cast<RecordType>(Field->getType()))
Adrian Prantl5f4740d2016-12-20 02:10:02 +00004536 GVE = CollectAnonRecordDecls(RT->getDecl(), Unit, LineNo, LinkageName,
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00004537 Var, DContext);
Eric Christophercab9fae2014-04-10 05:20:00 +00004538 continue;
4539 }
4540 // Use VarDecl's Tag, Scope and Line number.
Adrian Prantl5f4740d2016-12-20 02:10:02 +00004541 GVE = DBuilder.createGlobalVariableExpression(
4542 DContext, FieldName, LinkageName, Unit, LineNo, FieldTy,
4543 Var->hasLocalLinkage());
4544 Var->addDebugInfo(GVE);
Eric Christophercab9fae2014-04-10 05:20:00 +00004545 }
Adrian Prantl5f4740d2016-12-20 02:10:02 +00004546 return GVE;
Eric Christophercab9fae2014-04-10 05:20:00 +00004547}
4548
Yunzhong Gao0ebf1bb2013-08-30 08:53:09 +00004549void CGDebugInfo::EmitGlobalVariable(llvm::GlobalVariable *Var,
Guy Benyei11169dd2012-12-18 14:30:41 +00004550 const VarDecl *D) {
Amy Huang53539bb2020-01-13 15:54:54 -08004551 assert(CGM.getCodeGenOpts().hasReducedDebugInfo());
Paul Robinsonb17327d2016-04-27 17:37:12 +00004552 if (D->hasAttr<NoDebugAttr>())
4553 return;
Adrian Prantl338ef7a2016-11-09 00:42:03 +00004554
Luboš Luňák4f2104c2019-11-02 16:39:59 +01004555 llvm::TimeTraceScope TimeScope("DebugGlobalVariable", [&]() {
4556 std::string Name;
4557 llvm::raw_string_ostream OS(Name);
4558 D->getNameForDiagnostic(OS, getPrintingPolicy(),
4559 /*Qualified=*/true);
4560 return Name;
4561 });
4562
Adrian Prantl338ef7a2016-11-09 00:42:03 +00004563 // If we already created a DIGlobalVariable for this declaration, just attach
4564 // it to the llvm::GlobalVariable.
4565 auto Cached = DeclCache.find(D->getCanonicalDecl());
4566 if (Cached != DeclCache.end())
Adrian Prantl5f4740d2016-12-20 02:10:02 +00004567 return Var->addDebugInfo(
4568 cast<llvm::DIGlobalVariableExpression>(Cached->second));
Adrian Prantl338ef7a2016-11-09 00:42:03 +00004569
Guy Benyei11169dd2012-12-18 14:30:41 +00004570 // Create global variable debug descriptor.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004571 llvm::DIFile *Unit = nullptr;
4572 llvm::DIScope *DContext = nullptr;
Frederic Riss9db79f12014-11-18 03:40:46 +00004573 unsigned LineNo;
4574 StringRef DeclName, LinkageName;
4575 QualType T;
Matthew Voss20165362018-10-03 18:45:04 +00004576 llvm::MDTuple *TemplateParameters = nullptr;
4577 collectVarDeclProps(D, Unit, LineNo, T, DeclName, LinkageName,
4578 TemplateParameters, DContext);
Eric Christophercab9fae2014-04-10 05:20:00 +00004579
4580 // Attempt to store one global variable for the declaration - even if we
4581 // emit a lot of fields.
Adrian Prantl5f4740d2016-12-20 02:10:02 +00004582 llvm::DIGlobalVariableExpression *GVE = nullptr;
Eric Christophercab9fae2014-04-10 05:20:00 +00004583
4584 // If this is an anonymous union then we'll want to emit a global
4585 // variable for each member of the anonymous union so that it's possible
4586 // to find the name of any field in the union.
4587 if (T->isUnionType() && DeclName.empty()) {
Reid Kleckner43ecd7c2015-11-20 17:41:12 +00004588 const RecordDecl *RD = T->castAs<RecordType>()->getDecl();
Eric Christophere7b87e52014-10-26 23:40:33 +00004589 assert(RD->isAnonymousStructOrUnion() &&
4590 "unnamed non-anonymous struct or union?");
Adrian Prantl5f4740d2016-12-20 02:10:02 +00004591 GVE = CollectAnonRecordDecls(RD, Unit, LineNo, LinkageName, Var, DContext);
Eric Christophercab9fae2014-04-10 05:20:00 +00004592 } else {
Victor Leschuka7ece032016-10-20 00:13:19 +00004593 auto Align = getDeclAlignIfRequired(D, CGM.getContext());
Konstantin Zhuravlyov2b4917f2017-03-09 18:06:23 +00004594
4595 SmallVector<int64_t, 4> Expr;
4596 unsigned AddressSpace =
4597 CGM.getContext().getTargetAddressSpace(D->getType());
Alexey Bataev1a9e05d2019-02-05 19:45:57 +00004598 if (CGM.getLangOpts().CUDA && CGM.getLangOpts().CUDAIsDevice) {
4599 if (D->hasAttr<CUDASharedAttr>())
4600 AddressSpace =
4601 CGM.getContext().getTargetAddressSpace(LangAS::cuda_shared);
4602 else if (D->hasAttr<CUDAConstantAttr>())
4603 AddressSpace =
4604 CGM.getContext().getTargetAddressSpace(LangAS::cuda_constant);
4605 }
Konstantin Zhuravlyov2b4917f2017-03-09 18:06:23 +00004606 AppendAddressSpaceXDeref(AddressSpace, Expr);
4607
Adrian Prantl5f4740d2016-12-20 02:10:02 +00004608 GVE = DBuilder.createGlobalVariableExpression(
Eric Christophercab9fae2014-04-10 05:20:00 +00004609 DContext, DeclName, LinkageName, Unit, LineNo, getOrCreateType(T, Unit),
Yonghong Songe3d8ee32019-11-22 08:45:37 -08004610 Var->hasLocalLinkage(), true,
Konstantin Zhuravlyov2b4917f2017-03-09 18:06:23 +00004611 Expr.empty() ? nullptr : DBuilder.createExpression(Expr),
Matthew Voss20165362018-10-03 18:45:04 +00004612 getOrCreateStaticDataMemberDeclarationOrNull(D), TemplateParameters,
4613 Align);
Adrian Prantl5f4740d2016-12-20 02:10:02 +00004614 Var->addDebugInfo(GVE);
Eric Christophercab9fae2014-04-10 05:20:00 +00004615 }
Adrian Prantl5f4740d2016-12-20 02:10:02 +00004616 DeclCache[D->getCanonicalDecl()].reset(GVE);
Guy Benyei11169dd2012-12-18 14:30:41 +00004617}
4618
Peter Collingbourneeeb56ab2016-09-13 01:13:19 +00004619void CGDebugInfo::EmitGlobalVariable(const ValueDecl *VD, const APValue &Init) {
Amy Huang53539bb2020-01-13 15:54:54 -08004620 assert(CGM.getCodeGenOpts().hasReducedDebugInfo());
Paul Robinsonb17327d2016-04-27 17:37:12 +00004621 if (VD->hasAttr<NoDebugAttr>())
4622 return;
Luboš Luňák4f2104c2019-11-02 16:39:59 +01004623 llvm::TimeTraceScope TimeScope("DebugConstGlobalVariable", [&]() {
4624 std::string Name;
4625 llvm::raw_string_ostream OS(Name);
4626 VD->getNameForDiagnostic(OS, getPrintingPolicy(),
4627 /*Qualified=*/true);
4628 return Name;
4629 });
4630
Victor Leschuka7ece032016-10-20 00:13:19 +00004631 auto Align = getDeclAlignIfRequired(VD, CGM.getContext());
Yunzhong Gao0ebf1bb2013-08-30 08:53:09 +00004632 // Create the descriptor for the variable.
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004633 llvm::DIFile *Unit = getOrCreateFile(VD->getLocation());
Yunzhong Gao0ebf1bb2013-08-30 08:53:09 +00004634 StringRef Name = VD->getName();
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004635 llvm::DIType *Ty = getOrCreateType(VD->getType(), Unit);
Amy Huang63305c82019-05-22 15:48:59 +00004636
David Majnemer58ed0f32016-07-17 00:39:12 +00004637 if (const auto *ECD = dyn_cast<EnumConstantDecl>(VD)) {
4638 const auto *ED = cast<EnumDecl>(ECD->getDeclContext());
Yunzhong Gao0ebf1bb2013-08-30 08:53:09 +00004639 assert(isa<EnumType>(ED->getTypeForDecl()) && "Enum without EnumType?");
Amy Huangdd3a9ca2019-05-30 22:04:11 +00004640
Yuanfang Chen48c6fad2019-09-04 20:58:15 +00004641 if (CGM.getCodeGenOpts().EmitCodeView) {
4642 // If CodeView, emit enums as global variables, unless they are defined
4643 // inside a class. We do this because MSVC doesn't emit S_CONSTANTs for
4644 // enums in classes, and because it is difficult to attach this scope
4645 // information to the global variable.
4646 if (isa<RecordDecl>(ED->getDeclContext()))
4647 return;
4648 } else {
4649 // If not CodeView, emit DW_TAG_enumeration_type if necessary. For
4650 // example: for "enum { ZERO };", a DW_TAG_enumeration_type is created the
4651 // first time `ZERO` is referenced in a function.
4652 llvm::DIType *EDTy =
4653 getOrCreateType(QualType(ED->getTypeForDecl(), 0), Unit);
4654 assert (EDTy->getTag() == llvm::dwarf::DW_TAG_enumeration_type);
4655 (void)EDTy;
Amy Huangdd3a9ca2019-05-30 22:04:11 +00004656 return;
Yuanfang Chen48c6fad2019-09-04 20:58:15 +00004657 }
Amy Huang63305c82019-05-22 15:48:59 +00004658 }
4659
Amy Huang325003b2019-05-29 21:45:34 +00004660 llvm::DIScope *DContext = nullptr;
4661
4662 // Do not emit separate definitions for function local consts.
David Blaikiea15565562014-04-04 20:56:17 +00004663 if (isa<FunctionDecl>(VD->getDeclContext()))
4664 return;
Amy Huang325003b2019-05-29 21:45:34 +00004665
4666 // Emit definition for static members in CodeView.
David Blaikiebb113912014-04-05 07:23:17 +00004667 VD = cast<ValueDecl>(VD->getCanonicalDecl());
Amy Huangdd3a9ca2019-05-30 22:04:11 +00004668 auto *VarD = dyn_cast<VarDecl>(VD);
4669 if (VarD && VarD->isStaticDataMember()) {
David Blaikieaf080852014-11-21 00:20:58 +00004670 auto *RD = cast<RecordDecl>(VarD->getDeclContext());
Adrian Prantl6ec370a2015-09-10 18:39:45 +00004671 getDeclContextDescriptor(VarD);
David Blaikie423eb5a2014-11-19 19:42:40 +00004672 // Ensure that the type is retained even though it's otherwise unreferenced.
Duncan P. N. Exon Smith383f8412016-04-23 21:08:27 +00004673 //
4674 // FIXME: This is probably unnecessary, since Ty should reference RD
4675 // through its scope.
David Blaikie423eb5a2014-11-19 19:42:40 +00004676 RetainedTypes.push_back(
David Blaikieaf080852014-11-21 00:20:58 +00004677 CGM.getContext().getRecordType(RD).getAsOpaquePtr());
David Blaikie423eb5a2014-11-19 19:42:40 +00004678
Amy Huang325003b2019-05-29 21:45:34 +00004679 if (!CGM.getCodeGenOpts().EmitCodeView)
4680 return;
4681
4682 // Use the global scope for static members.
4683 DContext = getContextDescriptor(
4684 cast<Decl>(CGM.getContext().getTranslationUnitDecl()), TheCU);
4685 } else {
4686 DContext = getDeclContextDescriptor(VD);
4687 }
David Blaikieaf080852014-11-21 00:20:58 +00004688
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00004689 auto &GV = DeclCache[VD];
4690 if (GV)
David Blaikiebb113912014-04-05 07:23:17 +00004691 return;
Peter Collingbourneeeb56ab2016-09-13 01:13:19 +00004692 llvm::DIExpression *InitExpr = nullptr;
Peter Collingbourneb7013632016-12-16 22:10:52 +00004693 if (CGM.getContext().getTypeSize(VD->getType()) <= 64) {
4694 // FIXME: Add a representation for integer constants wider than 64 bits.
4695 if (Init.isInt())
4696 InitExpr =
4697 DBuilder.createConstantValueExpression(Init.getInt().getExtValue());
4698 else if (Init.isFloat())
4699 InitExpr = DBuilder.createConstantValueExpression(
4700 Init.getFloat().bitcastToAPInt().getZExtValue());
4701 }
Matthew Voss20165362018-10-03 18:45:04 +00004702
4703 llvm::MDTuple *TemplateParameters = nullptr;
4704
4705 if (isa<VarTemplateSpecializationDecl>(VD))
4706 if (VarD) {
4707 llvm::DINodeArray parameterNodes = CollectVarTemplateParams(VarD, &*Unit);
4708 TemplateParameters = parameterNodes.get();
4709 }
4710
Adrian Prantl5f4740d2016-12-20 02:10:02 +00004711 GV.reset(DBuilder.createGlobalVariableExpression(
David Blaikie506a7452014-04-05 07:46:57 +00004712 DContext, Name, StringRef(), Unit, getLineNumber(VD->getLocation()), Ty,
Yonghong Songe3d8ee32019-11-22 08:45:37 -08004713 true, true, InitExpr, getOrCreateStaticDataMemberDeclarationOrNull(VarD),
Matthew Voss20165362018-10-03 18:45:04 +00004714 TemplateParameters, Align));
David Blaikiebd483762013-05-20 04:58:53 +00004715}
4716
Yonghong Songe3d8ee32019-11-22 08:45:37 -08004717void CGDebugInfo::EmitExternalVariable(llvm::GlobalVariable *Var,
4718 const VarDecl *D) {
Amy Huang53539bb2020-01-13 15:54:54 -08004719 assert(CGM.getCodeGenOpts().hasReducedDebugInfo());
Yonghong Songe3d8ee32019-11-22 08:45:37 -08004720 if (D->hasAttr<NoDebugAttr>())
4721 return;
4722
4723 auto Align = getDeclAlignIfRequired(D, CGM.getContext());
4724 llvm::DIFile *Unit = getOrCreateFile(D->getLocation());
4725 StringRef Name = D->getName();
4726 llvm::DIType *Ty = getOrCreateType(D->getType(), Unit);
4727
4728 llvm::DIScope *DContext = getDeclContextDescriptor(D);
4729 llvm::DIGlobalVariableExpression *GVE =
4730 DBuilder.createGlobalVariableExpression(
4731 DContext, Name, StringRef(), Unit, getLineNumber(D->getLocation()),
4732 Ty, false, false, nullptr, nullptr, nullptr, Align);
4733 Var->addDebugInfo(GVE);
4734}
4735
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004736llvm::DIScope *CGDebugInfo::getCurrentContextDescriptor(const Decl *D) {
David Blaikiebd483762013-05-20 04:58:53 +00004737 if (!LexicalBlockStack.empty())
Duncan P. N. Exon Smithfc8d9d92015-04-20 18:32:15 +00004738 return LexicalBlockStack.back();
Adrian Prantl5c8bd882015-09-11 17:23:08 +00004739 llvm::DIScope *Mod = getParentModuleOrNull(D);
4740 return getContextDescriptor(D, Mod ? Mod : TheCU);
Guy Benyei11169dd2012-12-18 14:30:41 +00004741}
4742
David Blaikie9f88fe82013-04-22 06:13:21 +00004743void CGDebugInfo::EmitUsingDirective(const UsingDirectiveDecl &UD) {
Amy Huang53539bb2020-01-13 15:54:54 -08004744 if (!CGM.getCodeGenOpts().hasReducedDebugInfo())
David Blaikiebd483762013-05-20 04:58:53 +00004745 return;
Ekaterina Romanova9218a3b2015-12-10 18:52:50 +00004746 const NamespaceDecl *NSDecl = UD.getNominatedNamespace();
Adrian McCarthyab1e7862016-07-21 18:43:20 +00004747 if (!NSDecl->isAnonymousNamespace() ||
4748 CGM.getCodeGenOpts().DebugExplicitImport) {
Adrian Prantl5649b0e2017-07-19 00:09:58 +00004749 auto Loc = UD.getLocation();
Ekaterina Romanova9218a3b2015-12-10 18:52:50 +00004750 DBuilder.createImportedModule(
4751 getCurrentContextDescriptor(cast<Decl>(UD.getDeclContext())),
Adrian Prantl5649b0e2017-07-19 00:09:58 +00004752 getOrCreateNamespace(NSDecl), getOrCreateFile(Loc), getLineNumber(Loc));
Ekaterina Romanova9218a3b2015-12-10 18:52:50 +00004753 }
David Blaikie9f88fe82013-04-22 06:13:21 +00004754}
4755
David Blaikiebd483762013-05-20 04:58:53 +00004756void CGDebugInfo::EmitUsingDecl(const UsingDecl &UD) {
Amy Huang53539bb2020-01-13 15:54:54 -08004757 if (!CGM.getCodeGenOpts().hasReducedDebugInfo())
David Blaikiebd483762013-05-20 04:58:53 +00004758 return;
4759 assert(UD.shadow_size() &&
4760 "We shouldn't be codegening an invalid UsingDecl containing no decls");
4761 // Emitting one decl is sufficient - debuggers can detect that this is an
4762 // overloaded name & provide lookup for all the overloads.
4763 const UsingShadowDecl &USD = **UD.shadow_begin();
David Blaikie2a58a182016-08-05 19:03:01 +00004764
4765 // FIXME: Skip functions with undeduced auto return type for now since we
4766 // don't currently have the plumbing for separate declarations & definitions
4767 // of free functions and mismatched types (auto in the declaration, concrete
4768 // return type in the definition)
4769 if (const auto *FD = dyn_cast<FunctionDecl>(USD.getUnderlyingDecl()))
4770 if (const auto *AT =
Simon Pilgrim7e38f0c2019-10-07 16:42:25 +00004771 FD->getType()->castAs<FunctionProtoType>()->getContainedAutoType())
David Blaikie2a58a182016-08-05 19:03:01 +00004772 if (AT->getDeducedType().isNull())
4773 return;
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004774 if (llvm::DINode *Target =
Adrian Prantl5649b0e2017-07-19 00:09:58 +00004775 getDeclarationOrDefinition(USD.getUnderlyingDecl())) {
4776 auto Loc = USD.getLocation();
David Blaikiebd483762013-05-20 04:58:53 +00004777 DBuilder.createImportedDeclaration(
4778 getCurrentContextDescriptor(cast<Decl>(USD.getDeclContext())), Target,
Adrian Prantl5649b0e2017-07-19 00:09:58 +00004779 getOrCreateFile(Loc), getLineNumber(Loc));
4780 }
David Blaikiebd483762013-05-20 04:58:53 +00004781}
4782
Adrian Prantlc4bb47e2015-06-30 17:39:51 +00004783void CGDebugInfo::EmitImportDecl(const ImportDecl &ID) {
David Blaikieaf09f4a2016-05-03 23:06:40 +00004784 if (CGM.getCodeGenOpts().getDebuggerTuning() != llvm::DebuggerKind::LLDB)
4785 return;
Adrian Prantl8a634c12015-12-18 19:44:31 +00004786 if (Module *M = ID.getImportedModule()) {
Reid Klecknerc915cb92020-02-27 18:13:54 -08004787 auto Info = ASTSourceDescriptor(*M);
Adrian Prantl5649b0e2017-07-19 00:09:58 +00004788 auto Loc = ID.getLocation();
Adrian Prantl8a634c12015-12-18 19:44:31 +00004789 DBuilder.createImportedDeclaration(
4790 getCurrentContextDescriptor(cast<Decl>(ID.getDeclContext())),
Adrian Prantl5649b0e2017-07-19 00:09:58 +00004791 getOrCreateModuleRef(Info, DebugTypeExtRefs), getOrCreateFile(Loc),
4792 getLineNumber(Loc));
Adrian Prantl8a634c12015-12-18 19:44:31 +00004793 }
Adrian Prantlc4bb47e2015-06-30 17:39:51 +00004794}
4795
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004796llvm::DIImportedEntity *
David Blaikief121b932013-05-20 22:50:41 +00004797CGDebugInfo::EmitNamespaceAlias(const NamespaceAliasDecl &NA) {
Amy Huang53539bb2020-01-13 15:54:54 -08004798 if (!CGM.getCodeGenOpts().hasReducedDebugInfo())
Duncan P. N. Exon Smithdadc2b62015-04-21 18:43:54 +00004799 return nullptr;
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00004800 auto &VH = NamespaceAliasCache[&NA];
David Blaikief121b932013-05-20 22:50:41 +00004801 if (VH)
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004802 return cast<llvm::DIImportedEntity>(VH);
4803 llvm::DIImportedEntity *R;
Adrian Prantl5649b0e2017-07-19 00:09:58 +00004804 auto Loc = NA.getLocation();
David Majnemer58ed0f32016-07-17 00:39:12 +00004805 if (const auto *Underlying =
David Blaikief121b932013-05-20 22:50:41 +00004806 dyn_cast<NamespaceAliasDecl>(NA.getAliasedNamespace()))
4807 // This could cache & dedup here rather than relying on metadata deduping.
David Blaikie551fb0a2014-04-06 06:30:03 +00004808 R = DBuilder.createImportedDeclaration(
David Blaikief121b932013-05-20 22:50:41 +00004809 getCurrentContextDescriptor(cast<Decl>(NA.getDeclContext())),
Adrian Prantl5649b0e2017-07-19 00:09:58 +00004810 EmitNamespaceAlias(*Underlying), getOrCreateFile(Loc),
4811 getLineNumber(Loc), NA.getName());
David Blaikief121b932013-05-20 22:50:41 +00004812 else
David Blaikie551fb0a2014-04-06 06:30:03 +00004813 R = DBuilder.createImportedDeclaration(
David Blaikief121b932013-05-20 22:50:41 +00004814 getCurrentContextDescriptor(cast<Decl>(NA.getDeclContext())),
Adrian Prantlddb8e062017-05-12 16:23:53 +00004815 getOrCreateNamespace(cast<NamespaceDecl>(NA.getAliasedNamespace())),
Adrian Prantl5649b0e2017-07-19 00:09:58 +00004816 getOrCreateFile(Loc), getLineNumber(Loc), NA.getName());
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00004817 VH.reset(R);
David Blaikief121b932013-05-20 22:50:41 +00004818 return R;
4819}
4820
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004821llvm::DINamespace *
Adrian Prantlddb8e062017-05-12 16:23:53 +00004822CGDebugInfo::getOrCreateNamespace(const NamespaceDecl *NSDecl) {
4823 // Don't canonicalize the NamespaceDecl here: The DINamespace will be uniqued
4824 // if necessary, and this way multiple declarations of the same namespace in
4825 // different parent modules stay distinct.
4826 auto I = NamespaceCache.find(NSDecl);
Adrian Prantld8870552017-05-11 22:59:19 +00004827 if (I != NamespaceCache.end())
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004828 return cast<llvm::DINamespace>(I->second);
Eric Christopherb2a008c2013-05-16 00:45:12 +00004829
Adrian Prantl6ec370a2015-09-10 18:39:45 +00004830 llvm::DIScope *Context = getDeclContextDescriptor(NSDecl);
Adrian Prantld8870552017-05-11 22:59:19 +00004831 // Don't trust the context if it is a DIModule (see comment above).
Adrian Prantlddb8e062017-05-12 16:23:53 +00004832 llvm::DINamespace *NS =
4833 DBuilder.createNameSpace(Context, NSDecl->getName(), NSDecl->isInline());
4834 NamespaceCache[NSDecl].reset(NS);
Guy Benyei11169dd2012-12-18 14:30:41 +00004835 return NS;
4836}
4837
Adrian Prantla5206ce2015-09-22 23:26:43 +00004838void CGDebugInfo::setDwoId(uint64_t Signature) {
4839 assert(TheCU && "no main compile unit");
4840 TheCU->setDWOId(Signature);
4841}
4842
Guy Benyei11169dd2012-12-18 14:30:41 +00004843void CGDebugInfo::finalize() {
David Blaikie87dab872014-05-07 16:56:58 +00004844 // Creating types might create further types - invalidating the current
4845 // element and the size(), so don't cache/reference them.
4846 for (size_t i = 0; i != ObjCInterfaceCache.size(); ++i) {
4847 ObjCInterfaceCacheEntry E = ObjCInterfaceCache[i];
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004848 llvm::DIType *Ty = E.Type->getDecl()->getDefinition()
Duncan P. N. Exon Smith497d4d462015-04-11 19:05:04 +00004849 ? CreateTypeDefinition(E.Type, E.Unit)
4850 : E.Decl;
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004851 DBuilder.replaceTemporary(llvm::TempDIType(E.Decl), Ty);
David Blaikie87dab872014-05-07 16:56:58 +00004852 }
4853
Adrian Prantle0cabe22019-11-21 09:56:01 -08004854 // Add methods to interface.
4855 for (const auto &P : ObjCMethodCache) {
4856 if (P.second.empty())
4857 continue;
Jonas Devlieghered8ba8ae2018-06-27 17:31:59 +00004858
Adrian Prantle0cabe22019-11-21 09:56:01 -08004859 QualType QTy(P.first->getTypeForDecl(), 0);
4860 auto It = TypeCache.find(QTy.getAsOpaquePtr());
4861 assert(It != TypeCache.end());
Jonas Devlieghered8ba8ae2018-06-27 17:31:59 +00004862
Adrian Prantle0cabe22019-11-21 09:56:01 -08004863 llvm::DICompositeType *InterfaceDecl =
4864 cast<llvm::DICompositeType>(It->second);
Jonas Devlieghered8ba8ae2018-06-27 17:31:59 +00004865
Adrian Prantle0cabe22019-11-21 09:56:01 -08004866 auto CurElts = InterfaceDecl->getElements();
4867 SmallVector<llvm::Metadata *, 16> EltTys(CurElts.begin(), CurElts.end());
4868
4869 // For DWARF v4 or earlier, only add objc_direct methods.
4870 for (auto &SubprogramDirect : P.second)
4871 if (CGM.getCodeGenOpts().DwarfVersion >= 5 || SubprogramDirect.getInt())
4872 EltTys.push_back(SubprogramDirect.getPointer());
4873
4874 llvm::DINodeArray Elements = DBuilder.getOrCreateArray(EltTys);
4875 DBuilder.replaceArrays(InterfaceDecl, Elements);
Jonas Devlieghered8ba8ae2018-06-27 17:31:59 +00004876 }
4877
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00004878 for (const auto &P : ReplaceMap) {
4879 assert(P.second);
4880 auto *Ty = cast<llvm::DIType>(P.second);
Duncan P. N. Exon Smith4caa7f22015-04-16 01:00:56 +00004881 assert(Ty->isForwardDecl());
Eric Christopherb2a008c2013-05-16 00:45:12 +00004882
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00004883 auto It = TypeCache.find(P.first);
4884 assert(It != TypeCache.end());
4885 assert(It->second);
Adrian Prantl73409ce2013-03-11 18:33:46 +00004886
Duncan P. N. Exon Smith9dd4e4e2015-04-29 16:40:08 +00004887 DBuilder.replaceTemporary(llvm::TempDIType(Ty),
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00004888 cast<llvm::DIType>(It->second));
Guy Benyei11169dd2012-12-18 14:30:41 +00004889 }
Adrian Prantl73409ce2013-03-11 18:33:46 +00004890
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00004891 for (const auto &P : FwdDeclReplaceMap) {
4892 assert(P.second);
4893 llvm::TempMDNode FwdDecl(cast<llvm::MDNode>(P.second));
Duncan P. N. Exon Smithfb494912014-12-09 18:39:32 +00004894 llvm::Metadata *Repl;
Frederic Rissd253ed62014-11-18 03:40:51 +00004895
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00004896 auto It = DeclCache.find(P.first);
Adrian Prantl97f76852014-12-19 01:02:11 +00004897 // If there has been no definition for the declaration, call RAUW
Frederic Rissd253ed62014-11-18 03:40:51 +00004898 // with ourselves, that will destroy the temporary MDNode and
4899 // replace it with a standard one, avoiding leaking memory.
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00004900 if (It == DeclCache.end())
4901 Repl = P.second;
Frederic Rissd253ed62014-11-18 03:40:51 +00004902 else
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00004903 Repl = It->second;
Frederic Rissdce60a72014-11-19 18:53:46 +00004904
Adrian Prantl5f4740d2016-12-20 02:10:02 +00004905 if (auto *GVE = dyn_cast_or_null<llvm::DIGlobalVariableExpression>(Repl))
4906 Repl = GVE->getVariable();
Duncan P. N. Exon Smithd899f6e2015-04-18 00:07:30 +00004907 DBuilder.replaceTemporary(std::move(FwdDecl), cast<llvm::MDNode>(Repl));
Frederic Rissd253ed62014-11-18 03:40:51 +00004908 }
4909
Adrian Prantl73409ce2013-03-11 18:33:46 +00004910 // We keep our own list of retained types, because we need to look
4911 // up the final type in the type cache.
Adrian Prantl3a884fa2015-08-27 22:56:46 +00004912 for (auto &RT : RetainedTypes)
Adrian Prantlad9a195e2015-08-27 21:21:19 +00004913 if (auto MD = TypeCache[RT])
4914 DBuilder.retainType(cast<llvm::DIType>(MD));
Adrian Prantl73409ce2013-03-11 18:33:46 +00004915
Guy Benyei11169dd2012-12-18 14:30:41 +00004916 DBuilder.finalize();
4917}
David Blaikie66088d52014-09-24 17:01:27 +00004918
4919void CGDebugInfo::EmitExplicitCastType(QualType Ty) {
Amy Huang53539bb2020-01-13 15:54:54 -08004920 if (!CGM.getCodeGenOpts().hasReducedDebugInfo())
David Blaikie66088d52014-09-24 17:01:27 +00004921 return;
Duncan P. N. Exon Smith5043f912015-03-27 22:58:05 +00004922
Adrian Prantlc2a44ec2018-12-11 16:58:46 +00004923 if (auto *DieTy = getOrCreateType(Ty, TheCU->getFile()))
Duncan P. N. Exon Smith5043f912015-03-27 22:58:05 +00004924 // Don't ignore in case of explicit cast where it is referenced indirectly.
4925 DBuilder.retainType(DieTy);
David Blaikie66088d52014-09-24 17:01:27 +00004926}
Amara Emerson652795d2016-11-10 14:44:30 +00004927
4928llvm::DebugLoc CGDebugInfo::SourceLocToDebugLoc(SourceLocation Loc) {
4929 if (LexicalBlockStack.empty())
4930 return llvm::DebugLoc();
4931
4932 llvm::MDNode *Scope = LexicalBlockStack.back();
Jonas Devlieghere9ef49652018-06-28 10:56:40 +00004933 return llvm::DebugLoc::get(getLineNumber(Loc), getColumnNumber(Loc), Scope);
Amara Emerson652795d2016-11-10 14:44:30 +00004934}
Vedant Kumar5931b4e2018-10-05 20:37:17 +00004935
4936llvm::DINode::DIFlags CGDebugInfo::getCallSiteRelatedAttrs() const {
4937 // Call site-related attributes are only useful in optimized programs, and
4938 // when there's a possibility of debugging backtraces.
4939 if (!CGM.getLangOpts().Optimize || DebugKind == codegenoptions::NoDebugInfo ||
4940 DebugKind == codegenoptions::LocTrackingOnly)
4941 return llvm::DINode::FlagZero;
4942
4943 // Call site-related attributes are available in DWARF v5. Some debuggers,
4944 // while not fully DWARF v5-compliant, may accept these attributes as if they
4945 // were part of DWARF v4.
4946 bool SupportsDWARFv4Ext =
4947 CGM.getCodeGenOpts().DwarfVersion == 4 &&
Djordje Todorovic639d36b2019-06-26 09:38:09 +00004948 (CGM.getCodeGenOpts().getDebuggerTuning() == llvm::DebuggerKind::LLDB ||
Vedant Kumar568db782019-11-13 18:19:32 -08004949 CGM.getCodeGenOpts().getDebuggerTuning() == llvm::DebuggerKind::GDB);
Djordje Todorovic639d36b2019-06-26 09:38:09 +00004950
Djordje Todorovicd9b96212020-03-19 12:13:18 +01004951 if (!SupportsDWARFv4Ext && CGM.getCodeGenOpts().DwarfVersion < 5)
Vedant Kumar5931b4e2018-10-05 20:37:17 +00004952 return llvm::DINode::FlagZero;
4953
4954 return llvm::DINode::FlagAllCallsDescribed;
4955}