1 //===--- CodeGenModule.h - Per-Module state for LLVM CodeGen ----*- C++ -*-===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // This is the internal per-translation-unit state used for llvm translation.
11 //
12 //===----------------------------------------------------------------------===//
13 
14 #ifndef LLVM_CLANG_LIB_CODEGEN_CODEGENMODULE_H
15 #define LLVM_CLANG_LIB_CODEGEN_CODEGENMODULE_H
16 
17 #include "CGVTables.h"
18 #include "CodeGenTypeCache.h"
19 #include "CodeGenTypes.h"
20 #include "SanitizerMetadata.h"
21 #include "clang/AST/Attr.h"
22 #include "clang/AST/DeclCXX.h"
23 #include "clang/AST/DeclObjC.h"
24 #include "clang/AST/GlobalDecl.h"
25 #include "clang/AST/Mangle.h"
26 #include "clang/Basic/ABI.h"
27 #include "clang/Basic/LangOptions.h"
28 #include "clang/Basic/Module.h"
29 #include "clang/Basic/SanitizerBlacklist.h"
30 #include "llvm/ADT/DenseMap.h"
31 #include "llvm/ADT/SetVector.h"
32 #include "llvm/ADT/SmallPtrSet.h"
33 #include "llvm/ADT/StringMap.h"
34 #include "llvm/IR/Module.h"
35 #include "llvm/IR/ValueHandle.h"
36 
37 namespace llvm {
38 class Module;
39 class Constant;
40 class ConstantInt;
41 class Function;
42 class GlobalValue;
43 class DataLayout;
44 class FunctionType;
45 class LLVMContext;
46 class IndexedInstrProfReader;
47 }
48 
49 namespace clang {
50 class TargetCodeGenInfo;
51 class ASTContext;
52 class AtomicType;
53 class FunctionDecl;
54 class IdentifierInfo;
55 class ObjCMethodDecl;
56 class ObjCImplementationDecl;
57 class ObjCCategoryImplDecl;
58 class ObjCProtocolDecl;
59 class ObjCEncodeExpr;
60 class BlockExpr;
61 class CharUnits;
62 class Decl;
63 class Expr;
64 class Stmt;
65 class InitListExpr;
66 class StringLiteral;
67 class NamedDecl;
68 class ValueDecl;
69 class VarDecl;
70 class LangOptions;
71 class CodeGenOptions;
72 class HeaderSearchOptions;
73 class PreprocessorOptions;
74 class DiagnosticsEngine;
75 class AnnotateAttr;
76 class CXXDestructorDecl;
77 class Module;
78 class CoverageSourceInfo;
79 
80 namespace CodeGen {
81 
82 class CallArgList;
83 class CodeGenFunction;
84 class CodeGenTBAA;
85 class CGCXXABI;
86 class CGDebugInfo;
87 class CGObjCRuntime;
88 class CGOpenCLRuntime;
89 class CGOpenMPRuntime;
90 class CGCUDARuntime;
91 class BlockFieldFlags;
92 class FunctionArgList;
93 class CoverageMappingModuleGen;
94 
95 struct OrderGlobalInits {
96   unsigned int priority;
97   unsigned int lex_order;
98   OrderGlobalInits(unsigned int p, unsigned int l)
99       : priority(p), lex_order(l) {}
100 
101   bool operator==(const OrderGlobalInits &RHS) const {
102     return priority == RHS.priority && lex_order == RHS.lex_order;
103   }
104 
105   bool operator<(const OrderGlobalInits &RHS) const {
106     return std::tie(priority, lex_order) <
107            std::tie(RHS.priority, RHS.lex_order);
108   }
109 };
110 
111 struct ObjCEntrypoints {
112   ObjCEntrypoints() { memset(this, 0, sizeof(*this)); }
113 
114     /// void objc_autoreleasePoolPop(void*);
115   llvm::Constant *objc_autoreleasePoolPop;
116 
117   /// void *objc_autoreleasePoolPush(void);
118   llvm::Constant *objc_autoreleasePoolPush;
119 
120   /// id objc_autorelease(id);
121   llvm::Constant *objc_autorelease;
122 
123   /// id objc_autoreleaseReturnValue(id);
124   llvm::Constant *objc_autoreleaseReturnValue;
125 
126   /// void objc_copyWeak(id *dest, id *src);
127   llvm::Constant *objc_copyWeak;
128 
129   /// void objc_destroyWeak(id*);
130   llvm::Constant *objc_destroyWeak;
131 
132   /// id objc_initWeak(id*, id);
133   llvm::Constant *objc_initWeak;
134 
135   /// id objc_loadWeak(id*);
136   llvm::Constant *objc_loadWeak;
137 
138   /// id objc_loadWeakRetained(id*);
139   llvm::Constant *objc_loadWeakRetained;
140 
141   /// void objc_moveWeak(id *dest, id *src);
142   llvm::Constant *objc_moveWeak;
143 
144   /// id objc_retain(id);
145   llvm::Constant *objc_retain;
146 
147   /// id objc_retainAutorelease(id);
148   llvm::Constant *objc_retainAutorelease;
149 
150   /// id objc_retainAutoreleaseReturnValue(id);
151   llvm::Constant *objc_retainAutoreleaseReturnValue;
152 
153   /// id objc_retainAutoreleasedReturnValue(id);
154   llvm::Constant *objc_retainAutoreleasedReturnValue;
155 
156   /// id objc_retainBlock(id);
157   llvm::Constant *objc_retainBlock;
158 
159   /// void objc_release(id);
160   llvm::Constant *objc_release;
161 
162   /// id objc_storeStrong(id*, id);
163   llvm::Constant *objc_storeStrong;
164 
165   /// id objc_storeWeak(id*, id);
166   llvm::Constant *objc_storeWeak;
167 
168   /// A void(void) inline asm to use to mark that the return value of
169   /// a call will be immediately retain.
170   llvm::InlineAsm *retainAutoreleasedReturnValueMarker;
171 
172   /// void clang.arc.use(...);
173   llvm::Constant *clang_arc_use;
174 };
175 
176 /// This class records statistics on instrumentation based profiling.
177 class InstrProfStats {
178   uint32_t VisitedInMainFile;
179   uint32_t MissingInMainFile;
180   uint32_t Visited;
181   uint32_t Missing;
182   uint32_t Mismatched;
183 
184 public:
185   InstrProfStats()
186       : VisitedInMainFile(0), MissingInMainFile(0), Visited(0), Missing(0),
187         Mismatched(0) {}
188   /// Record that we've visited a function and whether or not that function was
189   /// in the main source file.
190   void addVisited(bool MainFile) {
191     if (MainFile)
192       ++VisitedInMainFile;
193     ++Visited;
194   }
195   /// Record that a function we've visited has no profile data.
196   void addMissing(bool MainFile) {
197     if (MainFile)
198       ++MissingInMainFile;
199     ++Missing;
200   }
201   /// Record that a function we've visited has mismatched profile data.
202   void addMismatched(bool MainFile) { ++Mismatched; }
203   /// Whether or not the stats we've gathered indicate any potential problems.
204   bool hasDiagnostics() { return Missing || Mismatched; }
205   /// Report potential problems we've found to \c Diags.
206   void reportDiagnostics(DiagnosticsEngine &Diags, StringRef MainFile);
207 };
208 
209 /// A pair of helper functions for a __block variable.
210 class BlockByrefHelpers : public llvm::FoldingSetNode {
211   // MSVC requires this type to be complete in order to process this
212   // header.
213 public:
214   llvm::Constant *CopyHelper;
215   llvm::Constant *DisposeHelper;
216 
217   /// The alignment of the field.  This is important because
218   /// different offsets to the field within the byref struct need to
219   /// have different helper functions.
220   CharUnits Alignment;
221 
222   BlockByrefHelpers(CharUnits alignment) : Alignment(alignment) {}
223   BlockByrefHelpers(const BlockByrefHelpers &) = default;
224   virtual ~BlockByrefHelpers();
225 
226   void Profile(llvm::FoldingSetNodeID &id) const {
227     id.AddInteger(Alignment.getQuantity());
228     profileImpl(id);
229   }
230   virtual void profileImpl(llvm::FoldingSetNodeID &id) const = 0;
231 
232   virtual bool needsCopy() const { return true; }
233   virtual void emitCopy(CodeGenFunction &CGF, Address dest, Address src) = 0;
234 
235   virtual bool needsDispose() const { return true; }
236   virtual void emitDispose(CodeGenFunction &CGF, Address field) = 0;
237 };
238 
239 /// This class organizes the cross-function state that is used while generating
240 /// LLVM code.
241 class CodeGenModule : public CodeGenTypeCache {
242   CodeGenModule(const CodeGenModule &) = delete;
243   void operator=(const CodeGenModule &) = delete;
244 
245 public:
246   struct Structor {
247     Structor() : Priority(0), Initializer(nullptr), AssociatedData(nullptr) {}
248     Structor(int Priority, llvm::Constant *Initializer,
249              llvm::Constant *AssociatedData)
250         : Priority(Priority), Initializer(Initializer),
251           AssociatedData(AssociatedData) {}
252     int Priority;
253     llvm::Constant *Initializer;
254     llvm::Constant *AssociatedData;
255   };
256 
257   typedef std::vector<Structor> CtorList;
258 
259 private:
260   ASTContext &Context;
261   const LangOptions &LangOpts;
262   const HeaderSearchOptions &HeaderSearchOpts; // Only used for debug info.
263   const PreprocessorOptions &PreprocessorOpts; // Only used for debug info.
264   const CodeGenOptions &CodeGenOpts;
265   llvm::Module &TheModule;
266   DiagnosticsEngine &Diags;
267   const TargetInfo &Target;
268   std::unique_ptr<CGCXXABI> ABI;
269   llvm::LLVMContext &VMContext;
270 
271   CodeGenTBAA *TBAA;
272 
273   mutable const TargetCodeGenInfo *TheTargetCodeGenInfo;
274 
275   // This should not be moved earlier, since its initialization depends on some
276   // of the previous reference members being already initialized and also checks
277   // if TheTargetCodeGenInfo is NULL
278   CodeGenTypes Types;
279 
280   /// Holds information about C++ vtables.
281   CodeGenVTables VTables;
282 
283   CGObjCRuntime* ObjCRuntime;
284   CGOpenCLRuntime* OpenCLRuntime;
285   CGOpenMPRuntime* OpenMPRuntime;
286   CGCUDARuntime* CUDARuntime;
287   CGDebugInfo* DebugInfo;
288   ObjCEntrypoints *ObjCData;
289   llvm::MDNode *NoObjCARCExceptionsMetadata;
290   std::unique_ptr<llvm::IndexedInstrProfReader> PGOReader;
291   InstrProfStats PGOStats;
292 
293   // A set of references that have only been seen via a weakref so far. This is
294   // used to remove the weak of the reference if we ever see a direct reference
295   // or a definition.
296   llvm::SmallPtrSet<llvm::GlobalValue*, 10> WeakRefReferences;
297 
298   /// This contains all the decls which have definitions but/ which are deferred
299   /// for emission and therefore should only be output if they are actually
300   /// used. If a decl is in this, then it is known to have not been referenced
301   /// yet.
302   std::map<StringRef, GlobalDecl> DeferredDecls;
303 
304   /// This is a list of deferred decls which we have seen that *are* actually
305   /// referenced. These get code generated when the module is done.
306   struct DeferredGlobal {
307     DeferredGlobal(llvm::GlobalValue *GV, GlobalDecl GD) : GV(GV), GD(GD) {}
308     llvm::TrackingVH<llvm::GlobalValue> GV;
309     GlobalDecl GD;
310   };
311   std::vector<DeferredGlobal> DeferredDeclsToEmit;
312   void addDeferredDeclToEmit(llvm::GlobalValue *GV, GlobalDecl GD) {
313     DeferredDeclsToEmit.emplace_back(GV, GD);
314   }
315 
316   /// List of alias we have emitted. Used to make sure that what they point to
317   /// is defined once we get to the end of the of the translation unit.
318   std::vector<GlobalDecl> Aliases;
319 
320   typedef llvm::StringMap<llvm::TrackingVH<llvm::Constant> > ReplacementsTy;
321   ReplacementsTy Replacements;
322 
323   /// List of global values to be replaced with something else. Used when we
324   /// want to replace a GlobalValue but can't identify it by its mangled name
325   /// anymore (because the name is already taken).
326   llvm::SmallVector<std::pair<llvm::GlobalValue *, llvm::Constant *>, 8>
327     GlobalValReplacements;
328 
329   /// Set of global decls for which we already diagnosed mangled name conflict.
330   /// Required to not issue a warning (on a mangling conflict) multiple times
331   /// for the same decl.
332   llvm::DenseSet<GlobalDecl> DiagnosedConflictingDefinitions;
333 
334   /// A queue of (optional) vtables to consider emitting.
335   std::vector<const CXXRecordDecl*> DeferredVTables;
336 
337   /// List of global values which are required to be present in the object file;
338   /// bitcast to i8*. This is used for forcing visibility of symbols which may
339   /// otherwise be optimized out.
340   std::vector<llvm::WeakVH> LLVMUsed;
341   std::vector<llvm::WeakVH> LLVMCompilerUsed;
342 
343   /// Store the list of global constructors and their respective priorities to
344   /// be emitted when the translation unit is complete.
345   CtorList GlobalCtors;
346 
347   /// Store the list of global destructors and their respective priorities to be
348   /// emitted when the translation unit is complete.
349   CtorList GlobalDtors;
350 
351   /// An ordered map of canonical GlobalDecls to their mangled names.
352   llvm::MapVector<GlobalDecl, StringRef> MangledDeclNames;
353   llvm::StringMap<GlobalDecl, llvm::BumpPtrAllocator> Manglings;
354 
355   /// Global annotations.
356   std::vector<llvm::Constant*> Annotations;
357 
358   /// Map used to get unique annotation strings.
359   llvm::StringMap<llvm::Constant*> AnnotationStrings;
360 
361   llvm::StringMap<llvm::GlobalVariable *> CFConstantStringMap;
362 
363   llvm::DenseMap<llvm::Constant *, llvm::GlobalVariable *> ConstantStringMap;
364   llvm::DenseMap<const Decl*, llvm::Constant *> StaticLocalDeclMap;
365   llvm::DenseMap<const Decl*, llvm::GlobalVariable*> StaticLocalDeclGuardMap;
366   llvm::DenseMap<const Expr*, llvm::Constant *> MaterializedGlobalTemporaryMap;
367 
368   llvm::DenseMap<QualType, llvm::Constant *> AtomicSetterHelperFnMap;
369   llvm::DenseMap<QualType, llvm::Constant *> AtomicGetterHelperFnMap;
370 
371   /// Map used to get unique type descriptor constants for sanitizers.
372   llvm::DenseMap<QualType, llvm::Constant *> TypeDescriptorMap;
373 
374   /// Map used to track internal linkage functions declared within
375   /// extern "C" regions.
376   typedef llvm::MapVector<IdentifierInfo *,
377                           llvm::GlobalValue *> StaticExternCMap;
378   StaticExternCMap StaticExternCValues;
379 
380   /// \brief thread_local variables defined or used in this TU.
381   std::vector<std::pair<const VarDecl *, llvm::GlobalVariable *> >
382     CXXThreadLocals;
383 
384   /// \brief thread_local variables with initializers that need to run
385   /// before any thread_local variable in this TU is odr-used.
386   std::vector<llvm::Function *> CXXThreadLocalInits;
387   std::vector<llvm::GlobalVariable *> CXXThreadLocalInitVars;
388 
389   /// Global variables with initializers that need to run before main.
390   std::vector<llvm::Function *> CXXGlobalInits;
391 
392   /// When a C++ decl with an initializer is deferred, null is
393   /// appended to CXXGlobalInits, and the index of that null is placed
394   /// here so that the initializer will be performed in the correct
395   /// order. Once the decl is emitted, the index is replaced with ~0U to ensure
396   /// that we don't re-emit the initializer.
397   llvm::DenseMap<const Decl*, unsigned> DelayedCXXInitPosition;
398 
399   typedef std::pair<OrderGlobalInits, llvm::Function*> GlobalInitData;
400 
401   struct GlobalInitPriorityCmp {
402     bool operator()(const GlobalInitData &LHS,
403                     const GlobalInitData &RHS) const {
404       return LHS.first.priority < RHS.first.priority;
405     }
406   };
407 
408   /// Global variables with initializers whose order of initialization is set by
409   /// init_priority attribute.
410   SmallVector<GlobalInitData, 8> PrioritizedCXXGlobalInits;
411 
412   /// Global destructor functions and arguments that need to run on termination.
413   std::vector<std::pair<llvm::WeakVH,llvm::Constant*> > CXXGlobalDtors;
414 
415   /// \brief The complete set of modules that has been imported.
416   llvm::SetVector<clang::Module *> ImportedModules;
417 
418   /// \brief A vector of metadata strings.
419   SmallVector<llvm::Metadata *, 16> LinkerOptionsMetadata;
420 
421   /// @name Cache for Objective-C runtime types
422   /// @{
423 
424   /// Cached reference to the class for constant strings. This value has type
425   /// int * but is actually an Obj-C class pointer.
426   llvm::WeakVH CFConstantStringClassRef;
427 
428   /// Cached reference to the class for constant strings. This value has type
429   /// int * but is actually an Obj-C class pointer.
430   llvm::WeakVH ConstantStringClassRef;
431 
432   /// \brief The LLVM type corresponding to NSConstantString.
433   llvm::StructType *NSConstantStringType;
434 
435   /// \brief The type used to describe the state of a fast enumeration in
436   /// Objective-C's for..in loop.
437   QualType ObjCFastEnumerationStateType;
438 
439   /// @}
440 
441   /// Lazily create the Objective-C runtime
442   void createObjCRuntime();
443 
444   void createOpenCLRuntime();
445   void createOpenMPRuntime();
446   void createCUDARuntime();
447 
448   bool isTriviallyRecursive(const FunctionDecl *F);
449   bool shouldEmitFunction(GlobalDecl GD);
450 
451   /// @name Cache for Blocks Runtime Globals
452   /// @{
453 
454   llvm::Constant *NSConcreteGlobalBlock;
455   llvm::Constant *NSConcreteStackBlock;
456 
457   llvm::Constant *BlockObjectAssign;
458   llvm::Constant *BlockObjectDispose;
459 
460   llvm::Type *BlockDescriptorType;
461   llvm::Type *GenericBlockLiteralType;
462 
463   struct {
464     int GlobalUniqueCount;
465   } Block;
466 
467   /// void @llvm.lifetime.start(i64 %size, i8* nocapture <ptr>)
468   llvm::Constant *LifetimeStartFn;
469 
470   /// void @llvm.lifetime.end(i64 %size, i8* nocapture <ptr>)
471   llvm::Constant *LifetimeEndFn;
472 
473   GlobalDecl initializedGlobalDecl;
474 
475   std::unique_ptr<SanitizerMetadata> SanitizerMD;
476 
477   /// @}
478 
479   llvm::DenseMap<const Decl *, bool> DeferredEmptyCoverageMappingDecls;
480 
481   std::unique_ptr<CoverageMappingModuleGen> CoverageMapping;
482 
483   /// Mapping from canonical types to their metadata identifiers. We need to
484   /// maintain this mapping because identifiers may be formed from distinct
485   /// MDNodes.
486   llvm::DenseMap<QualType, llvm::Metadata *> MetadataIdMap;
487 
488 public:
489   CodeGenModule(ASTContext &C, const HeaderSearchOptions &headersearchopts,
490                 const PreprocessorOptions &ppopts,
491                 const CodeGenOptions &CodeGenOpts, llvm::Module &M,
492                 DiagnosticsEngine &Diags,
493                 CoverageSourceInfo *CoverageInfo = nullptr);
494 
495   ~CodeGenModule();
496 
497   void clear();
498 
499   /// Finalize LLVM code generation.
500   void Release();
501 
502   /// Return a reference to the configured Objective-C runtime.
503   CGObjCRuntime &getObjCRuntime() {
504     if (!ObjCRuntime) createObjCRuntime();
505     return *ObjCRuntime;
506   }
507 
508   /// Return true iff an Objective-C runtime has been configured.
509   bool hasObjCRuntime() { return !!ObjCRuntime; }
510 
511   /// Return a reference to the configured OpenCL runtime.
512   CGOpenCLRuntime &getOpenCLRuntime() {
513     assert(OpenCLRuntime != nullptr);
514     return *OpenCLRuntime;
515   }
516 
517   /// Return a reference to the configured OpenMP runtime.
518   CGOpenMPRuntime &getOpenMPRuntime() {
519     assert(OpenMPRuntime != nullptr);
520     return *OpenMPRuntime;
521   }
522 
523   /// Return a reference to the configured CUDA runtime.
524   CGCUDARuntime &getCUDARuntime() {
525     assert(CUDARuntime != nullptr);
526     return *CUDARuntime;
527   }
528 
529   ObjCEntrypoints &getObjCEntrypoints() const {
530     assert(ObjCData != nullptr);
531     return *ObjCData;
532   }
533 
534   InstrProfStats &getPGOStats() { return PGOStats; }
535   llvm::IndexedInstrProfReader *getPGOReader() const { return PGOReader.get(); }
536 
537   CoverageMappingModuleGen *getCoverageMapping() const {
538     return CoverageMapping.get();
539   }
540 
541   llvm::Constant *getStaticLocalDeclAddress(const VarDecl *D) {
542     return StaticLocalDeclMap[D];
543   }
544   void setStaticLocalDeclAddress(const VarDecl *D,
545                                  llvm::Constant *C) {
546     StaticLocalDeclMap[D] = C;
547   }
548 
549   llvm::Constant *
550   getOrCreateStaticVarDecl(const VarDecl &D,
551                            llvm::GlobalValue::LinkageTypes Linkage);
552 
553   llvm::GlobalVariable *getStaticLocalDeclGuardAddress(const VarDecl *D) {
554     return StaticLocalDeclGuardMap[D];
555   }
556   void setStaticLocalDeclGuardAddress(const VarDecl *D,
557                                       llvm::GlobalVariable *C) {
558     StaticLocalDeclGuardMap[D] = C;
559   }
560 
561   bool lookupRepresentativeDecl(StringRef MangledName,
562                                 GlobalDecl &Result) const;
563 
564   llvm::Constant *getAtomicSetterHelperFnMap(QualType Ty) {
565     return AtomicSetterHelperFnMap[Ty];
566   }
567   void setAtomicSetterHelperFnMap(QualType Ty,
568                             llvm::Constant *Fn) {
569     AtomicSetterHelperFnMap[Ty] = Fn;
570   }
571 
572   llvm::Constant *getAtomicGetterHelperFnMap(QualType Ty) {
573     return AtomicGetterHelperFnMap[Ty];
574   }
575   void setAtomicGetterHelperFnMap(QualType Ty,
576                             llvm::Constant *Fn) {
577     AtomicGetterHelperFnMap[Ty] = Fn;
578   }
579 
580   llvm::Constant *getTypeDescriptorFromMap(QualType Ty) {
581     return TypeDescriptorMap[Ty];
582   }
583   void setTypeDescriptorInMap(QualType Ty, llvm::Constant *C) {
584     TypeDescriptorMap[Ty] = C;
585   }
586 
587   CGDebugInfo *getModuleDebugInfo() { return DebugInfo; }
588 
589   llvm::MDNode *getNoObjCARCExceptionsMetadata() {
590     if (!NoObjCARCExceptionsMetadata)
591       NoObjCARCExceptionsMetadata = llvm::MDNode::get(getLLVMContext(), None);
592     return NoObjCARCExceptionsMetadata;
593   }
594 
595   ASTContext &getContext() const { return Context; }
596   const LangOptions &getLangOpts() const { return LangOpts; }
597   const HeaderSearchOptions &getHeaderSearchOpts()
598     const { return HeaderSearchOpts; }
599   const PreprocessorOptions &getPreprocessorOpts()
600     const { return PreprocessorOpts; }
601   const CodeGenOptions &getCodeGenOpts() const { return CodeGenOpts; }
602   llvm::Module &getModule() const { return TheModule; }
603   DiagnosticsEngine &getDiags() const { return Diags; }
604   const llvm::DataLayout &getDataLayout() const {
605     return TheModule.getDataLayout();
606   }
607   const TargetInfo &getTarget() const { return Target; }
608   const llvm::Triple &getTriple() const;
609   bool supportsCOMDAT() const;
610   void maybeSetTrivialComdat(const Decl &D, llvm::GlobalObject &GO);
611 
612   CGCXXABI &getCXXABI() const { return *ABI; }
613   llvm::LLVMContext &getLLVMContext() { return VMContext; }
614 
615   bool shouldUseTBAA() const { return TBAA != nullptr; }
616 
617   const TargetCodeGenInfo &getTargetCodeGenInfo();
618 
619   CodeGenTypes &getTypes() { return Types; }
620 
621   CodeGenVTables &getVTables() { return VTables; }
622 
623   ItaniumVTableContext &getItaniumVTableContext() {
624     return VTables.getItaniumVTableContext();
625   }
626 
627   MicrosoftVTableContext &getMicrosoftVTableContext() {
628     return VTables.getMicrosoftVTableContext();
629   }
630 
631   CtorList &getGlobalCtors() { return GlobalCtors; }
632   CtorList &getGlobalDtors() { return GlobalDtors; }
633 
634   llvm::MDNode *getTBAAInfo(QualType QTy);
635   llvm::MDNode *getTBAAInfoForVTablePtr();
636   llvm::MDNode *getTBAAStructInfo(QualType QTy);
637   /// Return the path-aware tag for given base type, access node and offset.
638   llvm::MDNode *getTBAAStructTagInfo(QualType BaseTy, llvm::MDNode *AccessN,
639                                      uint64_t O);
640 
641   bool isTypeConstant(QualType QTy, bool ExcludeCtorDtor);
642 
643   bool isPaddedAtomicType(QualType type);
644   bool isPaddedAtomicType(const AtomicType *type);
645 
646   /// Decorate the instruction with a TBAA tag. For scalar TBAA, the tag
647   /// is the same as the type. For struct-path aware TBAA, the tag
648   /// is different from the type: base type, access type and offset.
649   /// When ConvertTypeToTag is true, we create a tag based on the scalar type.
650   void DecorateInstructionWithTBAA(llvm::Instruction *Inst,
651                                    llvm::MDNode *TBAAInfo,
652                                    bool ConvertTypeToTag = true);
653 
654   /// Adds !invariant.barrier !tag to instruction
655   void DecorateInstructionWithInvariantGroup(llvm::Instruction *I,
656                                              const CXXRecordDecl *RD);
657 
658   /// Emit the given number of characters as a value of type size_t.
659   llvm::ConstantInt *getSize(CharUnits numChars);
660 
661   /// Set the visibility for the given LLVM GlobalValue.
662   void setGlobalVisibility(llvm::GlobalValue *GV, const NamedDecl *D) const;
663 
664   /// Set the TLS mode for the given LLVM GlobalValue for the thread-local
665   /// variable declaration D.
666   void setTLSMode(llvm::GlobalValue *GV, const VarDecl &D) const;
667 
668   static llvm::GlobalValue::VisibilityTypes GetLLVMVisibility(Visibility V) {
669     switch (V) {
670     case DefaultVisibility:   return llvm::GlobalValue::DefaultVisibility;
671     case HiddenVisibility:    return llvm::GlobalValue::HiddenVisibility;
672     case ProtectedVisibility: return llvm::GlobalValue::ProtectedVisibility;
673     }
674     llvm_unreachable("unknown visibility!");
675   }
676 
677   llvm::Constant *GetAddrOfGlobal(GlobalDecl GD, bool IsForDefinition = false);
678 
679   /// Will return a global variable of the given type. If a variable with a
680   /// different type already exists then a new  variable with the right type
681   /// will be created and all uses of the old variable will be replaced with a
682   /// bitcast to the new variable.
683   llvm::GlobalVariable *
684   CreateOrReplaceCXXRuntimeVariable(StringRef Name, llvm::Type *Ty,
685                                     llvm::GlobalValue::LinkageTypes Linkage);
686 
687   llvm::Function *
688   CreateGlobalInitOrDestructFunction(llvm::FunctionType *ty, const Twine &name,
689                                      const CGFunctionInfo &FI,
690                                      SourceLocation Loc = SourceLocation(),
691                                      bool TLS = false);
692 
693   /// Return the address space of the underlying global variable for D, as
694   /// determined by its declaration. Normally this is the same as the address
695   /// space of D's type, but in CUDA, address spaces are associated with
696   /// declarations, not types.
697   unsigned GetGlobalVarAddressSpace(const VarDecl *D, unsigned AddrSpace);
698 
699   /// Return the llvm::Constant for the address of the given global variable.
700   /// If Ty is non-null and if the global doesn't exist, then it will be greated
701   /// with the specified type instead of whatever the normal requested type
702   /// would be.
703   llvm::Constant *GetAddrOfGlobalVar(const VarDecl *D,
704                                      llvm::Type *Ty = nullptr);
705 
706   /// Return the address of the given function. If Ty is non-null, then this
707   /// function will use the specified type if it has to create it.
708   llvm::Constant *GetAddrOfFunction(GlobalDecl GD, llvm::Type *Ty = nullptr,
709                                     bool ForVTable = false,
710                                     bool DontDefer = false,
711                                     bool IsForDefinition = false);
712 
713   /// Get the address of the RTTI descriptor for the given type.
714   llvm::Constant *GetAddrOfRTTIDescriptor(QualType Ty, bool ForEH = false);
715 
716   /// Get the address of a uuid descriptor .
717   ConstantAddress GetAddrOfUuidDescriptor(const CXXUuidofExpr* E);
718 
719   /// Get the address of the thunk for the given global decl.
720   llvm::Constant *GetAddrOfThunk(GlobalDecl GD, const ThunkInfo &Thunk);
721 
722   /// Get a reference to the target of VD.
723   ConstantAddress GetWeakRefReference(const ValueDecl *VD);
724 
725   /// Returns the assumed alignment of an opaque pointer to the given class.
726   CharUnits getClassPointerAlignment(const CXXRecordDecl *CD);
727 
728   /// Returns the assumed alignment of a virtual base of a class.
729   CharUnits getVBaseAlignment(CharUnits DerivedAlign,
730                               const CXXRecordDecl *Derived,
731                               const CXXRecordDecl *VBase);
732 
733   /// Given a class pointer with an actual known alignment, and the
734   /// expected alignment of an object at a dynamic offset w.r.t that
735   /// pointer, return the alignment to assume at the offset.
736   CharUnits getDynamicOffsetAlignment(CharUnits ActualAlign,
737                                       const CXXRecordDecl *Class,
738                                       CharUnits ExpectedTargetAlign);
739 
740   CharUnits
741   computeNonVirtualBaseClassOffset(const CXXRecordDecl *DerivedClass,
742                                    CastExpr::path_const_iterator Start,
743                                    CastExpr::path_const_iterator End);
744 
745   /// Returns the offset from a derived class to  a class. Returns null if the
746   /// offset is 0.
747   llvm::Constant *
748   GetNonVirtualBaseClassOffset(const CXXRecordDecl *ClassDecl,
749                                CastExpr::path_const_iterator PathBegin,
750                                CastExpr::path_const_iterator PathEnd);
751 
752   llvm::FoldingSet<BlockByrefHelpers> ByrefHelpersCache;
753 
754   /// Fetches the global unique block count.
755   int getUniqueBlockCount() { return ++Block.GlobalUniqueCount; }
756 
757   /// Fetches the type of a generic block descriptor.
758   llvm::Type *getBlockDescriptorType();
759 
760   /// The type of a generic block literal.
761   llvm::Type *getGenericBlockLiteralType();
762 
763   /// Gets the address of a block which requires no captures.
764   llvm::Constant *GetAddrOfGlobalBlock(const BlockExpr *BE, const char *);
765 
766   /// Return a pointer to a constant CFString object for the given string.
767   ConstantAddress GetAddrOfConstantCFString(const StringLiteral *Literal);
768 
769   /// Return a pointer to a constant NSString object for the given string. Or a
770   /// user defined String object as defined via
771   /// -fconstant-string-class=class_name option.
772   ConstantAddress GetAddrOfConstantString(const StringLiteral *Literal);
773 
774   /// Return a constant array for the given string.
775   llvm::Constant *GetConstantArrayFromStringLiteral(const StringLiteral *E);
776 
777   /// Return a pointer to a constant array for the given string literal.
778   ConstantAddress
779   GetAddrOfConstantStringFromLiteral(const StringLiteral *S,
780                                      StringRef Name = ".str");
781 
782   /// Return a pointer to a constant array for the given ObjCEncodeExpr node.
783   ConstantAddress
784   GetAddrOfConstantStringFromObjCEncode(const ObjCEncodeExpr *);
785 
786   /// Returns a pointer to a character array containing the literal and a
787   /// terminating '\0' character. The result has pointer to array type.
788   ///
789   /// \param GlobalName If provided, the name to use for the global (if one is
790   /// created).
791   ConstantAddress
792   GetAddrOfConstantCString(const std::string &Str,
793                            const char *GlobalName = nullptr);
794 
795   /// Returns a pointer to a constant global variable for the given file-scope
796   /// compound literal expression.
797   ConstantAddress GetAddrOfConstantCompoundLiteral(const CompoundLiteralExpr*E);
798 
799   /// \brief Returns a pointer to a global variable representing a temporary
800   /// with static or thread storage duration.
801   ConstantAddress GetAddrOfGlobalTemporary(const MaterializeTemporaryExpr *E,
802                                            const Expr *Inner);
803 
804   /// \brief Retrieve the record type that describes the state of an
805   /// Objective-C fast enumeration loop (for..in).
806   QualType getObjCFastEnumerationStateType();
807 
808   // Produce code for this constructor/destructor. This method doesn't try
809   // to apply any ABI rules about which other constructors/destructors
810   // are needed or if they are alias to each other.
811   llvm::Function *codegenCXXStructor(const CXXMethodDecl *MD,
812                                      StructorType Type);
813 
814   /// Return the address of the constructor/destructor of the given type.
815   llvm::Constant *
816   getAddrOfCXXStructor(const CXXMethodDecl *MD, StructorType Type,
817                        const CGFunctionInfo *FnInfo = nullptr,
818                        llvm::FunctionType *FnType = nullptr,
819                        bool DontDefer = false, bool IsForDefinition = false);
820 
821   /// Given a builtin id for a function like "__builtin_fabsf", return a
822   /// Function* for "fabsf".
823   llvm::Value *getBuiltinLibFunction(const FunctionDecl *FD,
824                                      unsigned BuiltinID);
825 
826   llvm::Function *getIntrinsic(unsigned IID, ArrayRef<llvm::Type*> Tys = None);
827 
828   /// Emit code for a single top level declaration.
829   void EmitTopLevelDecl(Decl *D);
830 
831   /// \brief Stored a deferred empty coverage mapping for an unused
832   /// and thus uninstrumented top level declaration.
833   void AddDeferredUnusedCoverageMapping(Decl *D);
834 
835   /// \brief Remove the deferred empty coverage mapping as this
836   /// declaration is actually instrumented.
837   void ClearUnusedCoverageMapping(const Decl *D);
838 
839   /// \brief Emit all the deferred coverage mappings
840   /// for the uninstrumented functions.
841   void EmitDeferredUnusedCoverageMappings();
842 
843   /// Tell the consumer that this variable has been instantiated.
844   void HandleCXXStaticMemberVarInstantiation(VarDecl *VD);
845 
846   /// \brief If the declaration has internal linkage but is inside an
847   /// extern "C" linkage specification, prepare to emit an alias for it
848   /// to the expected name.
849   template<typename SomeDecl>
850   void MaybeHandleStaticInExternC(const SomeDecl *D, llvm::GlobalValue *GV);
851 
852   /// Add a global to a list to be added to the llvm.used metadata.
853   void addUsedGlobal(llvm::GlobalValue *GV);
854 
855   /// Add a global to a list to be added to the llvm.compiler.used metadata.
856   void addCompilerUsedGlobal(llvm::GlobalValue *GV);
857 
858   /// Add a destructor and object to add to the C++ global destructor function.
859   void AddCXXDtorEntry(llvm::Constant *DtorFn, llvm::Constant *Object) {
860     CXXGlobalDtors.emplace_back(DtorFn, Object);
861   }
862 
863   /// Create a new runtime function with the specified type and name.
864   llvm::Constant *CreateRuntimeFunction(llvm::FunctionType *Ty,
865                                         StringRef Name,
866                                         llvm::AttributeSet ExtraAttrs =
867                                           llvm::AttributeSet());
868   /// Create a new compiler builtin function with the specified type and name.
869   llvm::Constant *CreateBuiltinFunction(llvm::FunctionType *Ty,
870                                         StringRef Name,
871                                         llvm::AttributeSet ExtraAttrs =
872                                           llvm::AttributeSet());
873   /// Create a new runtime global variable with the specified type and name.
874   llvm::Constant *CreateRuntimeVariable(llvm::Type *Ty,
875                                         StringRef Name);
876 
877   ///@name Custom Blocks Runtime Interfaces
878   ///@{
879 
880   llvm::Constant *getNSConcreteGlobalBlock();
881   llvm::Constant *getNSConcreteStackBlock();
882   llvm::Constant *getBlockObjectAssign();
883   llvm::Constant *getBlockObjectDispose();
884 
885   ///@}
886 
887   llvm::Constant *getLLVMLifetimeStartFn();
888   llvm::Constant *getLLVMLifetimeEndFn();
889 
890   // Make sure that this type is translated.
891   void UpdateCompletedType(const TagDecl *TD);
892 
893   llvm::Constant *getMemberPointerConstant(const UnaryOperator *e);
894 
895   /// Try to emit the initializer for the given declaration as a constant;
896   /// returns 0 if the expression cannot be emitted as a constant.
897   llvm::Constant *EmitConstantInit(const VarDecl &D,
898                                    CodeGenFunction *CGF = nullptr);
899 
900   /// Try to emit the given expression as a constant; returns 0 if the
901   /// expression cannot be emitted as a constant.
902   llvm::Constant *EmitConstantExpr(const Expr *E, QualType DestType,
903                                    CodeGenFunction *CGF = nullptr);
904 
905   /// Emit the given constant value as a constant, in the type's scalar
906   /// representation.
907   llvm::Constant *EmitConstantValue(const APValue &Value, QualType DestType,
908                                     CodeGenFunction *CGF = nullptr);
909 
910   /// Emit the given constant value as a constant, in the type's memory
911   /// representation.
912   llvm::Constant *EmitConstantValueForMemory(const APValue &Value,
913                                              QualType DestType,
914                                              CodeGenFunction *CGF = nullptr);
915 
916   /// \brief Emit type info if type of an expression is a variably modified
917   /// type. Also emit proper debug info for cast types.
918   void EmitExplicitCastExprType(const ExplicitCastExpr *E,
919                                 CodeGenFunction *CGF = nullptr);
920 
921   /// Return the result of value-initializing the given type, i.e. a null
922   /// expression of the given type.  This is usually, but not always, an LLVM
923   /// null constant.
924   llvm::Constant *EmitNullConstant(QualType T);
925 
926   /// Return a null constant appropriate for zero-initializing a base class with
927   /// the given type. This is usually, but not always, an LLVM null constant.
928   llvm::Constant *EmitNullConstantForBase(const CXXRecordDecl *Record);
929 
930   /// Emit a general error that something can't be done.
931   void Error(SourceLocation loc, StringRef error);
932 
933   /// Print out an error that codegen doesn't support the specified stmt yet.
934   void ErrorUnsupported(const Stmt *S, const char *Type);
935 
936   /// Print out an error that codegen doesn't support the specified decl yet.
937   void ErrorUnsupported(const Decl *D, const char *Type);
938 
939   /// Set the attributes on the LLVM function for the given decl and function
940   /// info. This applies attributes necessary for handling the ABI as well as
941   /// user specified attributes like section.
942   void SetInternalFunctionAttributes(const Decl *D, llvm::Function *F,
943                                      const CGFunctionInfo &FI);
944 
945   /// Set the LLVM function attributes (sext, zext, etc).
946   void SetLLVMFunctionAttributes(const Decl *D,
947                                  const CGFunctionInfo &Info,
948                                  llvm::Function *F);
949 
950   /// Set the LLVM function attributes which only apply to a function
951   /// definition.
952   void SetLLVMFunctionAttributesForDefinition(const Decl *D, llvm::Function *F);
953 
954   /// Return true iff the given type uses 'sret' when used as a return type.
955   bool ReturnTypeUsesSRet(const CGFunctionInfo &FI);
956 
957   /// Return true iff the given type uses an argument slot when 'sret' is used
958   /// as a return type.
959   bool ReturnSlotInterferesWithArgs(const CGFunctionInfo &FI);
960 
961   /// Return true iff the given type uses 'fpret' when used as a return type.
962   bool ReturnTypeUsesFPRet(QualType ResultType);
963 
964   /// Return true iff the given type uses 'fp2ret' when used as a return type.
965   bool ReturnTypeUsesFP2Ret(QualType ResultType);
966 
967   /// Get the LLVM attributes and calling convention to use for a particular
968   /// function type.
969   ///
970   /// \param Info - The function type information.
971   /// \param TargetDecl - The decl these attributes are being constructed
972   /// for. If supplied the attributes applied to this decl may contribute to the
973   /// function attributes and calling convention.
974   /// \param PAL [out] - On return, the attribute list to use.
975   /// \param CallingConv [out] - On return, the LLVM calling convention to use.
976   void ConstructAttributeList(const CGFunctionInfo &Info,
977                               const Decl *TargetDecl,
978                               AttributeListType &PAL,
979                               unsigned &CallingConv,
980                               bool AttrOnCallSite);
981 
982   StringRef getMangledName(GlobalDecl GD);
983   StringRef getBlockMangledName(GlobalDecl GD, const BlockDecl *BD);
984 
985   void EmitTentativeDefinition(const VarDecl *D);
986 
987   void EmitVTable(CXXRecordDecl *Class);
988 
989   /// \brief Appends Opts to the "Linker Options" metadata value.
990   void AppendLinkerOptions(StringRef Opts);
991 
992   /// \brief Appends a detect mismatch command to the linker options.
993   void AddDetectMismatch(StringRef Name, StringRef Value);
994 
995   /// \brief Appends a dependent lib to the "Linker Options" metadata value.
996   void AddDependentLib(StringRef Lib);
997 
998   llvm::GlobalVariable::LinkageTypes getFunctionLinkage(GlobalDecl GD);
999 
1000   void setFunctionLinkage(GlobalDecl GD, llvm::Function *F) {
1001     F->setLinkage(getFunctionLinkage(GD));
1002   }
1003 
1004   /// Set the DLL storage class on F.
1005   void setFunctionDLLStorageClass(GlobalDecl GD, llvm::Function *F);
1006 
1007   /// Return the appropriate linkage for the vtable, VTT, and type information
1008   /// of the given class.
1009   llvm::GlobalVariable::LinkageTypes getVTableLinkage(const CXXRecordDecl *RD);
1010 
1011   /// Return the store size, in character units, of the given LLVM type.
1012   CharUnits GetTargetTypeStoreSize(llvm::Type *Ty) const;
1013 
1014   /// Returns LLVM linkage for a declarator.
1015   llvm::GlobalValue::LinkageTypes
1016   getLLVMLinkageForDeclarator(const DeclaratorDecl *D, GVALinkage Linkage,
1017                               bool IsConstantVariable);
1018 
1019   /// Returns LLVM linkage for a declarator.
1020   llvm::GlobalValue::LinkageTypes
1021   getLLVMLinkageVarDefinition(const VarDecl *VD, bool IsConstant);
1022 
1023   /// Emit all the global annotations.
1024   void EmitGlobalAnnotations();
1025 
1026   /// Emit an annotation string.
1027   llvm::Constant *EmitAnnotationString(StringRef Str);
1028 
1029   /// Emit the annotation's translation unit.
1030   llvm::Constant *EmitAnnotationUnit(SourceLocation Loc);
1031 
1032   /// Emit the annotation line number.
1033   llvm::Constant *EmitAnnotationLineNo(SourceLocation L);
1034 
1035   /// Generate the llvm::ConstantStruct which contains the annotation
1036   /// information for a given GlobalValue. The annotation struct is
1037   /// {i8 *, i8 *, i8 *, i32}. The first field is a constant expression, the
1038   /// GlobalValue being annotated. The second field is the constant string
1039   /// created from the AnnotateAttr's annotation. The third field is a constant
1040   /// string containing the name of the translation unit. The fourth field is
1041   /// the line number in the file of the annotated value declaration.
1042   llvm::Constant *EmitAnnotateAttr(llvm::GlobalValue *GV,
1043                                    const AnnotateAttr *AA,
1044                                    SourceLocation L);
1045 
1046   /// Add global annotations that are set on D, for the global GV. Those
1047   /// annotations are emitted during finalization of the LLVM code.
1048   void AddGlobalAnnotations(const ValueDecl *D, llvm::GlobalValue *GV);
1049 
1050   bool isInSanitizerBlacklist(llvm::Function *Fn, SourceLocation Loc) const;
1051 
1052   bool isInSanitizerBlacklist(llvm::GlobalVariable *GV, SourceLocation Loc,
1053                               QualType Ty,
1054                               StringRef Category = StringRef()) const;
1055 
1056   SanitizerMetadata *getSanitizerMetadata() {
1057     return SanitizerMD.get();
1058   }
1059 
1060   void addDeferredVTable(const CXXRecordDecl *RD) {
1061     DeferredVTables.push_back(RD);
1062   }
1063 
1064   /// Emit code for a singal global function or var decl. Forward declarations
1065   /// are emitted lazily.
1066   void EmitGlobal(GlobalDecl D);
1067 
1068   bool TryEmitDefinitionAsAlias(GlobalDecl Alias, GlobalDecl Target,
1069                                 bool InEveryTU);
1070   bool TryEmitBaseDestructorAsAlias(const CXXDestructorDecl *D);
1071 
1072   /// Set attributes for a global definition.
1073   void setFunctionDefinitionAttributes(const FunctionDecl *D,
1074                                        llvm::Function *F);
1075 
1076   llvm::GlobalValue *GetGlobalValue(StringRef Ref);
1077 
1078   /// Set attributes which are common to any form of a global definition (alias,
1079   /// Objective-C method, function, global variable).
1080   ///
1081   /// NOTE: This should only be called for definitions.
1082   void SetCommonAttributes(const Decl *D, llvm::GlobalValue *GV);
1083 
1084   /// Set attributes which must be preserved by an alias. This includes common
1085   /// attributes (i.e. it includes a call to SetCommonAttributes).
1086   ///
1087   /// NOTE: This should only be called for definitions.
1088   void setAliasAttributes(const Decl *D, llvm::GlobalValue *GV);
1089 
1090   void addReplacement(StringRef Name, llvm::Constant *C);
1091 
1092   void addGlobalValReplacement(llvm::GlobalValue *GV, llvm::Constant *C);
1093 
1094   /// \brief Emit a code for threadprivate directive.
1095   /// \param D Threadprivate declaration.
1096   void EmitOMPThreadPrivateDecl(const OMPThreadPrivateDecl *D);
1097 
1098   /// Returns whether the given record is blacklisted from control flow
1099   /// integrity checks.
1100   bool IsCFIBlacklistedRecord(const CXXRecordDecl *RD);
1101 
1102   /// Emit bit set entries for the given vtable using the given layout if
1103   /// vptr CFI is enabled.
1104   void EmitVTableBitSetEntries(llvm::GlobalVariable *VTable,
1105                                const VTableLayout &VTLayout);
1106 
1107   /// Create a metadata identifier for the given type. This may either be an
1108   /// MDString (for external identifiers) or a distinct unnamed MDNode (for
1109   /// internal identifiers).
1110   llvm::Metadata *CreateMetadataIdentifierForType(QualType T);
1111 
1112   /// Create a bitset entry for the given vtable.
1113   llvm::MDTuple *CreateVTableBitSetEntry(llvm::GlobalVariable *VTable,
1114                                          CharUnits Offset,
1115                                          const CXXRecordDecl *RD);
1116 
1117   /// \breif Get the declaration of std::terminate for the platform.
1118   llvm::Constant *getTerminateFn();
1119 
1120 private:
1121   llvm::Constant *
1122   GetOrCreateLLVMFunction(StringRef MangledName, llvm::Type *Ty, GlobalDecl D,
1123                           bool ForVTable, bool DontDefer = false,
1124                           bool IsThunk = false,
1125                           llvm::AttributeSet ExtraAttrs = llvm::AttributeSet(),
1126                           bool IsForDefinition = false);
1127 
1128   llvm::Constant *GetOrCreateLLVMGlobal(StringRef MangledName,
1129                                         llvm::PointerType *PTy,
1130                                         const VarDecl *D);
1131 
1132   void setNonAliasAttributes(const Decl *D, llvm::GlobalObject *GO);
1133 
1134   /// Set function attributes for a function declaration.
1135   void SetFunctionAttributes(GlobalDecl GD, llvm::Function *F,
1136                              bool IsIncompleteFunction, bool IsThunk);
1137 
1138   void EmitGlobalDefinition(GlobalDecl D, llvm::GlobalValue *GV = nullptr);
1139 
1140   void EmitGlobalFunctionDefinition(GlobalDecl GD, llvm::GlobalValue *GV);
1141   void EmitGlobalVarDefinition(const VarDecl *D);
1142   void EmitAliasDefinition(GlobalDecl GD);
1143   void EmitObjCPropertyImplementations(const ObjCImplementationDecl *D);
1144   void EmitObjCIvarInitializations(ObjCImplementationDecl *D);
1145 
1146   // C++ related functions.
1147 
1148   void EmitNamespace(const NamespaceDecl *D);
1149   void EmitLinkageSpec(const LinkageSpecDecl *D);
1150   void CompleteDIClassType(const CXXMethodDecl* D);
1151 
1152   /// \brief Emit the function that initializes C++ thread_local variables.
1153   void EmitCXXThreadLocalInitFunc();
1154 
1155   /// Emit the function that initializes C++ globals.
1156   void EmitCXXGlobalInitFunc();
1157 
1158   /// Emit the function that destroys C++ globals.
1159   void EmitCXXGlobalDtorFunc();
1160 
1161   /// Emit the function that initializes the specified global (if PerformInit is
1162   /// true) and registers its destructor.
1163   void EmitCXXGlobalVarDeclInitFunc(const VarDecl *D,
1164                                     llvm::GlobalVariable *Addr,
1165                                     bool PerformInit);
1166 
1167   void EmitPointerToInitFunc(const VarDecl *VD, llvm::GlobalVariable *Addr,
1168                              llvm::Function *InitFunc, InitSegAttr *ISA);
1169 
1170   // FIXME: Hardcoding priority here is gross.
1171   void AddGlobalCtor(llvm::Function *Ctor, int Priority = 65535,
1172                      llvm::Constant *AssociatedData = nullptr);
1173   void AddGlobalDtor(llvm::Function *Dtor, int Priority = 65535);
1174 
1175   /// Generates a global array of functions and priorities using the given list
1176   /// and name. This array will have appending linkage and is suitable for use
1177   /// as a LLVM constructor or destructor array.
1178   void EmitCtorList(const CtorList &Fns, const char *GlobalName);
1179 
1180   /// Emit any needed decls for which code generation was deferred.
1181   void EmitDeferred();
1182 
1183   /// Call replaceAllUsesWith on all pairs in Replacements.
1184   void applyReplacements();
1185 
1186   /// Call replaceAllUsesWith on all pairs in GlobalValReplacements.
1187   void applyGlobalValReplacements();
1188 
1189   void checkAliases();
1190 
1191   /// Emit any vtables which we deferred and still have a use for.
1192   void EmitDeferredVTables();
1193 
1194   /// Emit the llvm.used and llvm.compiler.used metadata.
1195   void emitLLVMUsed();
1196 
1197   /// \brief Emit the link options introduced by imported modules.
1198   void EmitModuleLinkOptions();
1199 
1200   /// \brief Emit aliases for internal-linkage declarations inside "C" language
1201   /// linkage specifications, giving them the "expected" name where possible.
1202   void EmitStaticExternCAliases();
1203 
1204   void EmitDeclMetadata();
1205 
1206   /// \brief Emit the Clang version as llvm.ident metadata.
1207   void EmitVersionIdentMetadata();
1208 
1209   /// Emits target specific Metadata for global declarations.
1210   void EmitTargetMetadata();
1211 
1212   /// Emit the llvm.gcov metadata used to tell LLVM where to emit the .gcno and
1213   /// .gcda files in a way that persists in .bc files.
1214   void EmitCoverageFile();
1215 
1216   /// Emits the initializer for a uuidof string.
1217   llvm::Constant *EmitUuidofInitializer(StringRef uuidstr);
1218 
1219   /// Determine whether the definition must be emitted; if this returns \c
1220   /// false, the definition can be emitted lazily if it's used.
1221   bool MustBeEmitted(const ValueDecl *D);
1222 
1223   /// Determine whether the definition can be emitted eagerly, or should be
1224   /// delayed until the end of the translation unit. This is relevant for
1225   /// definitions whose linkage can change, e.g. implicit function instantions
1226   /// which may later be explicitly instantiated.
1227   bool MayBeEmittedEagerly(const ValueDecl *D);
1228 
1229   /// Check whether we can use a "simpler", more core exceptions personality
1230   /// function.
1231   void SimplifyPersonality();
1232 };
1233 }  // end namespace CodeGen
1234 }  // end namespace clang
1235 
1236 #endif // LLVM_CLANG_LIB_CODEGEN_CODEGENMODULE_H
1237