;
27using namespaceCodeGen;
32(
D.hasGlobalStorage() ||
34 "VarDecl must have global or local (in the case of OpenCL) storage!");
35assert(!
D.getType()->isReferenceType() &&
36 "Should not call EmitDeclInit on a reference!");
47DeclPtr,
D.getTLSKind());
66llvm_unreachable(
"bad evaluation kind");
94assert(!
D.getTLSKind() &&
"should have rejected this");
98llvm::FunctionCallee
Func;
99llvm::Constant *Argument;
109 boolCanRegisterDestructor =
117 if(
Record&& (CanRegisterDestructor || UsingExternalHelper)) {
118assert(!
Record->hasTrivialDestructor());
125 autoDestTy = llvm::PointerType::get(
127 autoSrcAS =
D.getType().getQualifiers().getAddressSpace();
133Argument = llvm::ConstantPointerNull::get(DestTy);
143Argument = llvm::Constant::getNullValue(CGF.
Int8PtrTy);
152llvm::Constant *Addr) {
157voidCodeGenFunction::EmitInvariantStart(llvm::Constant *Addr,
CharUnitsSize) {
163llvm::Intrinsic::ID InvStartID = llvm::Intrinsic::invariant_start;
165assert(Addr->getType()->isPointerTy() &&
"Address must be a pointer");
166llvm::Type *ObjectPtr[1] = {Addr->getType()};
167llvm::Function *InvariantStart =
CGM.
getIntrinsic(InvStartID, ObjectPtr);
171llvm::Value *Args[2] = {llvm::ConstantInt::getSigned(
Int64Ty, Width), Addr};
172 Builder.CreateCall(InvariantStart, Args);
176llvm::GlobalVariable *GV,
198 unsignedActualAddrSpace = GV->getAddressSpace();
199llvm::Constant *DeclPtr = GV;
200 if(ActualAddrSpace != ExpectedAddrSpace) {
201llvm::PointerType *PTy =
203DeclPtr = llvm::ConstantExpr::getAddrSpaceCast(DeclPtr, PTy);
207DeclPtr, GV->getValueType(),
getContext().getDeclAlign(&
D));
211 D.
hasAttr<OMPThreadPrivateDeclAttr>()) {
213&
D, DeclAddr,
D.
getAttr<OMPThreadPrivateDeclAttr>()->getLocation(),
220 if(
D.getType().isConstantStorage(
getContext(),
true, !NeedsDtor))
227assert(PerformInit &&
"cannot have constant initializer which needs " 228 "destruction for reference");
236llvm::FunctionCallee dtor,
237llvm::Constant *addr) {
239llvm::FunctionType *ty = llvm::FunctionType::get(
CGM.
VoidTy,
false);
242llvm::raw_svector_ostream Out(FnName);
258llvm::CallInst *call = CGF.Builder.CreateCall(dtor, addr);
261 if(
auto*dtorFn = dyn_cast<llvm::Function>(
262dtor.getCallee()->stripPointerCastsAndAliases()))
263call->setCallingConv(dtorFn->getCallingConv());
265CGF.FinishFunction();
278 const VarDecl&
D, llvm::FunctionCallee Dtor, llvm::Constant *Addr,
279llvm::FunctionCallee &
AtExit) {
282llvm::raw_svector_ostream Out(FnName);
291llvm::FunctionType *StubTy =
292llvm::FunctionType::get(
CGM.
IntTy, {CGM.IntTy},
true);
302Args.push_back(&IPD);
311llvm::CallInst *call = CGF.Builder.CreateCall(Dtor, Addr);
314 if(
auto*DtorFn = dyn_cast<llvm::Function>(
315Dtor.getCallee()->stripPointerCastsAndAliases()))
316call->setCallingConv(DtorFn->getCallingConv());
319CGF.Builder.CreateStore(llvm::Constant::getNullValue(
CGM.
IntTy),
322CGF.FinishFunction();
329llvm::FunctionCallee dtor,
330llvm::Constant *addr) {
338llvm::FunctionCallee Dtor,
339llvm::Constant *Addr) {
341llvm::Function *dtorStub =
348assert(dtorStub->getType() ==
349llvm::PointerType::get(
350llvm::FunctionType::get(
CGM.
VoidTy,
false),
351dtorStub->getType()->getPointerAddressSpace()) &&
352 "Argument to atexit has a wrong type.");
354llvm::FunctionType *atexitTy =
355llvm::FunctionType::get(
IntTy, dtorStub->getType(),
false);
357llvm::FunctionCallee atexit =
360 if(llvm::Function *atexitFn = dyn_cast<llvm::Function>(atexit.getCallee()))
361atexitFn->setDoesNotThrow();
375assert(dtorStub->getType() ==
376llvm::PointerType::get(
377llvm::FunctionType::get(
CGM.
VoidTy,
false),
378dtorStub->getType()->getPointerAddressSpace()) &&
379 "Argument to unatexit has a wrong type.");
381llvm::FunctionType *unatexitTy =
382llvm::FunctionType::get(
IntTy, {dtorStub->getType()},
false);
384llvm::FunctionCallee unatexit =
387cast<llvm::Function>(unatexit.getCallee())->setDoesNotThrow();
393llvm::GlobalVariable *DeclPtr,
400 "this initialization requires a guard variable, which " 401 "the kernel does not support");
407llvm::BasicBlock *InitBlock,
408llvm::BasicBlock *NoInitBlock,
415 static const uint64_tInitsPerTLSVar = 1024;
416 static const uint64_tInitsPerLocalVar = 1024 * 1024;
418llvm::MDNode *Weights;
430NumInits = InitsPerTLSVar;
432NumInits = InitsPerLocalVar;
437Weights = MDHelper.createBranchWeights(1, NumInits - 1);
440 Builder.CreateCondBr(NeedsInit, InitBlock, NoInitBlock, Weights);
444llvm::FunctionType *FTy,
constTwine &Name,
const CGFunctionInfo&FI,
446llvm::Function *Fn = llvm::Function::Create(FTy,
Linkage, Name, &
getModule());
450 if(
const char*Section =
getTarget().getStaticInitSectionSpecifier())
451Fn->setSection(Section);
454 if(
Linkage== llvm::GlobalVariable::InternalLinkage)
460Fn->setDoesNotThrow();
462 if(
getLangOpts().Sanitize.has(SanitizerKind::Address) &&
464Fn->addFnAttr(llvm::Attribute::SanitizeAddress);
466 if(
getLangOpts().Sanitize.has(SanitizerKind::KernelAddress) &&
468Fn->addFnAttr(llvm::Attribute::SanitizeAddress);
470 if(
getLangOpts().Sanitize.has(SanitizerKind::HWAddress) &&
472Fn->addFnAttr(llvm::Attribute::SanitizeHWAddress);
474 if(
getLangOpts().Sanitize.has(SanitizerKind::KernelHWAddress) &&
476Fn->addFnAttr(llvm::Attribute::SanitizeHWAddress);
478 if(
getLangOpts().Sanitize.has(SanitizerKind::MemtagStack) &&
480Fn->addFnAttr(llvm::Attribute::SanitizeMemTag);
482 if(
getLangOpts().Sanitize.has(SanitizerKind::Type) &&
484Fn->addFnAttr(llvm::Attribute::SanitizeType);
486 if(
getLangOpts().Sanitize.has(SanitizerKind::Thread) &&
488Fn->addFnAttr(llvm::Attribute::SanitizeThread);
490 if(
getLangOpts().Sanitize.has(SanitizerKind::NumericalStability) &&
492Fn->addFnAttr(llvm::Attribute::SanitizeNumericalStability);
494 if(
getLangOpts().Sanitize.has(SanitizerKind::Memory) &&
496Fn->addFnAttr(llvm::Attribute::SanitizeMemory);
498 if(
getLangOpts().Sanitize.has(SanitizerKind::KernelMemory) &&
500Fn->addFnAttr(llvm::Attribute::SanitizeMemory);
502 if(
getLangOpts().Sanitize.has(SanitizerKind::SafeStack) &&
504Fn->addFnAttr(llvm::Attribute::SafeStack);
506 if(
getLangOpts().Sanitize.has(SanitizerKind::ShadowCallStack) &&
508Fn->addFnAttr(llvm::Attribute::ShadowCallStack);
516voidCodeGenModule::EmitPointerToInitFunc(
const VarDecl*
D,
517llvm::GlobalVariable *GV,
518llvm::Function *InitFunc,
520llvm::GlobalVariable *PtrArray =
newllvm::GlobalVariable(
521TheModule, InitFunc->getType(),
true,
522llvm::GlobalValue::PrivateLinkage, InitFunc,
"__cxx_init_fn_ptr");
523PtrArray->setSection(ISA->getSection());
527 if(llvm::Comdat *
C= GV->getComdat())
528PtrArray->setComdat(
C);
532CodeGenModule::EmitCXXGlobalVarDeclInitFunc(
const VarDecl*
D,
533llvm::GlobalVariable *Addr,
547 autoI = DelayedCXXInitPosition.find(
D);
548 if(I != DelayedCXXInitPosition.end() && I->second == ~0
U)
551llvm::FunctionType *FTy = llvm::FunctionType::get(
VoidTy,
false);
554llvm::raw_svector_ostream Out(FnName);
562 auto*ISA =
D->
getAttr<InitSegAttr>();
566llvm::GlobalVariable *COMDATKey =
569 if(
D->getTLSKind()) {
573CXXThreadLocalInits.push_back(Fn);
574CXXThreadLocalInitVars.push_back(
D);
575}
else if(PerformInit && ISA) {
579 if(ISA->getSection() ==
".CRT$XCC")
581 else if(ISA->getSection() ==
".CRT$XCL")
587EmitPointerToInitFunc(
D, Addr, Fn, ISA);
588}
else if(
auto*IPA =
D->
getAttr<InitPriorityAttr>()) {
590PrioritizedCXXGlobalInits.size());
591PrioritizedCXXGlobalInits.push_back(std::make_pair(Key, Fn));
636I = DelayedCXXInitPosition.find(
D);
638I == DelayedCXXInitPosition.end() ? CXXGlobalInits.size() : I->second;
640 if(COMDATKey && (
getTriple().isOSBinFormatELF() ||
650llvm::Comdat *
C= Addr->getComdat();
651 if(COMDATKey &&
C&&
657I = DelayedCXXInitPosition.find(
D);
658 if(I == DelayedCXXInitPosition.end()) {
659CXXGlobalInits.push_back(Fn);
660}
else if(I->second != ~0
U) {
661assert(I->second < CXXGlobalInits.size() &&
662CXXGlobalInits[I->second] ==
nullptr);
663CXXGlobalInits[I->second] =
Fn;
668DelayedCXXInitPosition[
D] = ~0
U;
671voidCodeGenModule::EmitCXXThreadLocalInitFunc() {
673*
this, CXXThreadLocals, CXXThreadLocalInits, CXXThreadLocalInitVars);
675CXXThreadLocalInits.clear();
676CXXThreadLocalInitVars.clear();
677CXXThreadLocals.clear();
695voidCodeGenModule::EmitCXXModuleInitFunc(
Module*Primary) {
697 "The function should only be called for C++20 named module interface" 700 while(!CXXGlobalInits.empty() && !CXXGlobalInits.back())
701CXXGlobalInits.pop_back();
709 for(
autoI : Primary->
Exports)
710AllImports.insert(I.getPointer());
713AllImports.insert(M);
717assert((SubM->isGlobalModule() || SubM->isPrivateModule()) &&
718 "The sub modules of C++20 module unit should only be global module " 719 "fragments or private module framents.");
720assert(SubM->Exports.empty() &&
721 "The global mdoule fragments and the private module fragments are " 722 "not allowed to export import modules.");
724AllImports.insert(M);
728 for(
Module*M : AllImports) {
736llvm::FunctionType *FTy = llvm::FunctionType::get(
VoidTy,
false);
739llvm::raw_svector_ostream Out(FnName);
740cast<ItaniumMangleContext>(
getCXXABI().getMangleContext())
741.mangleModuleInitializer(M, Out);
744 "We should only have one use of the initializer call");
745llvm::Function *
Fn= llvm::Function::Create(
746FTy, llvm::Function::ExternalLinkage, FnName.str(), &
getModule());
747ModuleInits.push_back(Fn);
752 if(!PrioritizedCXXGlobalInits.empty()) {
754llvm::array_pod_sort(PrioritizedCXXGlobalInits.begin(),
755PrioritizedCXXGlobalInits.end());
757I = PrioritizedCXXGlobalInits.begin(),
758 E= PrioritizedCXXGlobalInits.end();
761std::upper_bound(I + 1,
E, *I, GlobalInitPriorityCmp());
763 for(; I < PrioE; ++I)
764ModuleInits.push_back(I->second);
769 for(
auto*F : CXXGlobalInits)
770ModuleInits.push_back(F);
772llvm::FunctionType *FTy = llvm::FunctionType::get(
VoidTy,
false);
779llvm::Function *
Fn;
782llvm::raw_svector_ostream Out(InitFnName);
783cast<ItaniumMangleContext>(
getCXXABI().getMangleContext())
784.mangleModuleInitializer(Primary, Out);
787llvm::GlobalVariable::ExternalLinkage);
792 if(!ModuleInits.empty()) {
794llvm::GlobalVariable *Guard =
newllvm::GlobalVariable(
796llvm::GlobalVariable::InternalLinkage,
797llvm::ConstantInt::get(
Int8Ty, 0), InitFnName.str() +
"__in_chrg");
799Guard->setAlignment(GuardAlign.
getAsAlign());
816 Fn->setCallingConv(llvm::CallingConv::SPIR_KERNEL);
823 Fn->setCallingConv(llvm::CallingConv::SPIR_KERNEL);
825 Fn->setCallingConv(llvm::CallingConv::AMDGPU_KERNEL);
826 Fn->addFnAttr(
"device-init");
831PrioritizedCXXGlobalInits.clear();
832CXXGlobalInits.clear();
842 for(
size_ti = 0; i <
FileName.size(); ++i) {
853assert(
Priority<= 65535 &&
"Priority should always be <= 65535.");
857std::string PrioritySuffix = llvm::utostr(
Priority);
858PrioritySuffix = std::string(6 - PrioritySuffix.size(),
'0') + PrioritySuffix;
860 returnPrioritySuffix;
864CodeGenModule::EmitCXXGlobalInitFunc() {
865 while(!CXXGlobalInits.empty() && !CXXGlobalInits.back())
866CXXGlobalInits.pop_back();
870 if(CXX20ModuleInits)
871 for(
Module*M : ImportedModules) {
879llvm::FunctionType *FTy = llvm::FunctionType::get(
VoidTy,
false);
882llvm::raw_svector_ostream Out(FnName);
883cast<ItaniumMangleContext>(
getCXXABI().getMangleContext())
884.mangleModuleInitializer(M, Out);
887 "We should only have one use of the initializer call");
888llvm::Function *
Fn= llvm::Function::Create(
889FTy, llvm::Function::ExternalLinkage, FnName.str(), &
getModule());
890ModuleInits.push_back(Fn);
893 if(ModuleInits.empty() && CXXGlobalInits.empty() &&
894PrioritizedCXXGlobalInits.empty())
897llvm::FunctionType *FTy = llvm::FunctionType::get(
VoidTy,
false);
901 if(!PrioritizedCXXGlobalInits.empty()) {
903llvm::array_pod_sort(PrioritizedCXXGlobalInits.begin(),
904PrioritizedCXXGlobalInits.end());
909I = PrioritizedCXXGlobalInits.begin(),
910 E= PrioritizedCXXGlobalInits.end(); I !=
E; ) {
912PrioE = std::upper_bound(I + 1,
E, *I, GlobalInitPriorityCmp());
914LocalCXXGlobalInits.clear();
916 unsigned int Priority= I->first.priority;
921 if(!ModuleInits.empty()) {
922 for(
auto*F : ModuleInits)
923LocalCXXGlobalInits.push_back(F);
927 for(; I < PrioE; ++I)
928LocalCXXGlobalInits.push_back(I->second);
933PrioritizedCXXGlobalInits.clear();
936 if(
getCXXABI().useSinitAndSterm() && ModuleInits.empty() &&
937CXXGlobalInits.empty())
940 for(
auto*F : CXXGlobalInits)
941ModuleInits.push_back(F);
942CXXGlobalInits.clear();
948llvm::Function *
Fn;
949 if(CXX20ModuleInits &&
getContext().getCurrentNamedModule() &&
950!
getContext().getCurrentNamedModule()->isModuleImplementation()) {
952llvm::raw_svector_ostream Out(InitFnName);
953cast<ItaniumMangleContext>(
getCXXABI().getMangleContext())
954.mangleModuleInitializer(
getContext().getCurrentNamedModule(), Out);
957llvm::GlobalVariable::ExternalLinkage);
977 Fn->setCallingConv(llvm::CallingConv::SPIR_KERNEL);
984 Fn->setCallingConv(llvm::CallingConv::SPIR_KERNEL);
986 Fn->setCallingConv(llvm::CallingConv::AMDGPU_KERNEL);
987 Fn->addFnAttr(
"device-init");
993voidCodeGenModule::EmitCXXGlobalCleanUpFunc() {
994 if(CXXGlobalDtorsOrStermFinalizers.empty() &&
995PrioritizedCXXStermFinalizers.empty())
998llvm::FunctionType *FTy = llvm::FunctionType::get(
VoidTy,
false);
1002 if(!PrioritizedCXXStermFinalizers.empty()) {
1004llvm::array_pod_sort(PrioritizedCXXStermFinalizers.begin(),
1005PrioritizedCXXStermFinalizers.end());
1010I = PrioritizedCXXStermFinalizers.begin(),
1011 E= PrioritizedCXXStermFinalizers.end();
1014std::upper_bound(I + 1,
E, *I, StermFinalizerPriorityCmp());
1016LocalCXXStermFinalizers.clear();
1018 unsigned int Priority= I->first.priority;
1022 for(; I < PrioE; ++I) {
1023llvm::FunctionCallee DtorFn = I->second;
1024LocalCXXStermFinalizers.emplace_back(DtorFn.getFunctionType(),
1025DtorFn.getCallee(),
nullptr);
1029Fn, LocalCXXStermFinalizers);
1032PrioritizedCXXStermFinalizers.clear();
1035 if(CXXGlobalDtorsOrStermFinalizers.empty())
1039llvm::Function *
Fn=
1043Fn, CXXGlobalDtorsOrStermFinalizers);
1045CXXGlobalDtorsOrStermFinalizers.clear();
1051llvm::GlobalVariable *Addr,
1055DebugInfo =
nullptr;
1072 if(Addr->hasWeakLinkage() || Addr->hasLinkOnceLinkage() ||
1097llvm::BasicBlock *ExitBlock =
nullptr;
1103 "guard.uninitialized");
1121RunCleanupsScope
Scope(*
this);
1130 for(
unsignedi = 0, e = Decls.size(); i != e; ++i)
1134 Scope.ForceCleanup();
1147 ArrayRef<std::tuple<llvm::FunctionType *, llvm::WeakTrackingVH,
1149DtorsOrStermFinalizers) {
1158 for(
unsignedi = 0, e = DtorsOrStermFinalizers.size(); i != e; ++i) {
1159llvm::FunctionType *CalleeTy;
1161llvm::Constant *Arg;
1162std::tie(CalleeTy, Callee, Arg) = DtorsOrStermFinalizers[e - i - 1];
1164llvm::CallInst *CI =
nullptr;
1165 if(Arg ==
nullptr) {
1168 "Arg could not be nullptr unless using sinit and sterm functions.");
1169CI =
Builder.CreateCall(CalleeTy, Callee);
1171CI =
Builder.CreateCall(CalleeTy, Callee, Arg);
1174 if(llvm::Function *F = dyn_cast<llvm::Function>(Callee))
1175CI->setCallingConv(F->getCallingConv());
1187 booluseEHCleanupForArray,
const VarDecl*VD) {
1191args.push_back(&Dst);
1197FTy,
"__cxx_global_array_dtor", FI, VD->
getLocation());
static std::string getPrioritySuffix(unsigned int Priority)
static void EmitDeclInit(CodeGenFunction &CGF, const VarDecl &D, ConstantAddress DeclPtr)
static SmallString< 128 > getTransformedFileName(llvm::Module &M)
static void EmitDeclDestroy(CodeGenFunction &CGF, const VarDecl &D, ConstantAddress Addr)
Emit code to cause the destruction of the given variable with static storage duration.
static void EmitDeclInvariant(CodeGenFunction &CGF, const VarDecl &D, llvm::Constant *Addr)
Emit code to cause the variable at the given address to be considered as constant from this point onw...
Defines the clang::LangOptions interface.
llvm::MachO::Record Record
const LangOptions & getLangOpts() const
CharUnits getTypeSizeInChars(QualType T) const
Return the size of the specified (complete) type T, in characters.
QualType getFunctionType(QualType ResultTy, ArrayRef< QualType > Args, const FunctionProtoType::ExtProtoInfo &EPI) const
Return a normal function type with a typed argument list.
unsigned getTargetAddressSpace(LangAS AS) const
Represents a C++ destructor within a class.
Represents a C++ struct/union/class.
CharUnits - This is an opaque type for sizes expressed in character units.
llvm::Align getAsAlign() const
getAsAlign - Returns Quantity as a valid llvm::Align, Beware llvm::Align assumes power of two 8-bit b...
static CharUnits One()
One - Construct a CharUnits quantity of one.
static CharUnits fromQuantity(QuantityType Quantity)
fromQuantity - Construct a CharUnits quantity from a raw integer type.
Like RawAddress, an abstract representation of an aligned address, but the pointer contained in this ...
static AggValueSlot forLValue(const LValue &LV, IsDestructed_t isDestructed, NeedsGCBarriers_t needsGC, IsAliased_t isAliased, Overlap_t mayOverlap, IsZeroed_t isZeroed=IsNotZeroed, IsSanitizerChecked_t isChecked=IsNotSanitizerChecked)
static ApplyDebugLocation CreateArtificial(CodeGenFunction &CGF)
Apply TemporaryLocation if it is valid.
static ApplyDebugLocation CreateEmpty(CodeGenFunction &CGF)
Set the IRBuilder to not attach debug locations.
llvm::StoreInst * CreateStore(llvm::Value *Val, Address Addr, bool IsVolatile=false)
llvm::Value * CreateIsNull(Address Addr, const Twine &Name="")
llvm::LoadInst * CreateLoad(Address Addr, const llvm::Twine &Name="")
virtual bool HasThisReturn(GlobalDecl GD) const
Returns true if the given constructor or destructor is one of the kinds that the ABI says returns 'th...
virtual bool useSinitAndSterm() const
virtual void EmitGuardedInit(CodeGenFunction &CGF, const VarDecl &D, llvm::GlobalVariable *DeclPtr, bool PerformInit)=0
Emits the guarded initializer and destructor setup for the given variable, given that it couldn't be ...
virtual void registerGlobalDtor(CodeGenFunction &CGF, const VarDecl &D, llvm::FunctionCallee Dtor, llvm::Constant *Addr)=0
Emit code to force the execution of a destructor during global teardown.
virtual bool canCallMismatchedFunctionType() const
Returns true if the target allows calling a function through a pointer with a different signature tha...
virtual void EmitThreadLocalInitFuncs(CodeGenModule &CGM, ArrayRef< const VarDecl * > CXXThreadLocals, ArrayRef< llvm::Function * > CXXThreadLocalInits, ArrayRef< const VarDecl * > CXXThreadLocalInitVars)=0
Emits ABI-required functions necessary to initialize thread_local variables in this translation unit.
MangleContext & getMangleContext()
Gets the mangle context.
CGFunctionInfo - Class to encapsulate the information about a function definition.
void annotateHLSLResource(const VarDecl *D, llvm::GlobalVariable *GV)
virtual void EmitObjCWeakAssign(CodeGen::CodeGenFunction &CGF, llvm::Value *src, Address dest)=0
virtual void EmitObjCGlobalAssign(CodeGen::CodeGenFunction &CGF, llvm::Value *src, Address dest, bool threadlocal=false)=0
virtual llvm::Function * emitThreadPrivateVarDefinition(const VarDecl *VD, Address VDAddr, SourceLocation Loc, bool PerformInit, CodeGenFunction *CGF=nullptr)
Emit a code for initialization of threadprivate variable.
CodeGenFunction - This class organizes the per-function state that is used while generating LLVM code...
void GenerateCXXGlobalInitFunc(llvm::Function *Fn, ArrayRef< llvm::Function * > CXXThreadLocals, ConstantAddress Guard=ConstantAddress::invalid())
GenerateCXXGlobalInitFunc - Generates code for initializing global variables.
void FinishFunction(SourceLocation EndLoc=SourceLocation())
FinishFunction - Complete IR generation of the current function.
static TypeEvaluationKind getEvaluationKind(QualType T)
getEvaluationKind - Return the TypeEvaluationKind of QualType T.
llvm::Constant * createAtExitStub(const VarDecl &VD, llvm::FunctionCallee Dtor, llvm::Constant *Addr)
llvm::Value * EmitObjCAutoreleasePoolPush()
llvm::BasicBlock * createBasicBlock(const Twine &name="", llvm::Function *parent=nullptr, llvm::BasicBlock *before=nullptr)
createBasicBlock - Create an LLVM basic block.
const LangOptions & getLangOpts() const
void EmitBlock(llvm::BasicBlock *BB, bool IsFinished=false)
EmitBlock - Emit the given block.
llvm::Type * ConvertTypeForMem(QualType T)
llvm::Function * createTLSAtExitStub(const VarDecl &VD, llvm::FunctionCallee Dtor, llvm::Constant *Addr, llvm::FunctionCallee &AtExit)
void EmitScalarInit(const Expr *init, const ValueDecl *D, LValue lvalue, bool capturedByInit)
void registerGlobalDtorWithLLVM(const VarDecl &D, llvm::FunctionCallee fn, llvm::Constant *addr)
Registers the dtor using 'llvm.global_dtors' for platforms that do not support an 'atexit()' function...
Destroyer * getDestroyer(QualType::DestructionKind destructionKind)
void emitDestroy(Address addr, QualType type, Destroyer *destroyer, bool useEHCleanupForArray)
llvm::Function * generateDestroyHelper(Address addr, QualType type, Destroyer *destroyer, bool useEHCleanupForArray, const VarDecl *VD)
void GenerateCXXGlobalCleanUpFunc(llvm::Function *Fn, ArrayRef< std::tuple< llvm::FunctionType *, llvm::WeakTrackingVH, llvm::Constant * > > DtorsOrStermFinalizers)
GenerateCXXGlobalCleanUpFunc - Generates code for cleaning up global variables.
void EmitCXXGuardedInit(const VarDecl &D, llvm::GlobalVariable *DeclPtr, bool PerformInit)
Emit code in this function to perform a guarded variable initialization.
void EmitCXXGlobalVarDeclInit(const VarDecl &D, llvm::GlobalVariable *GV, bool PerformInit)
EmitCXXGlobalVarDeclInit - Create the initializer for a C++ variable with global storage.
void EmitComplexExprIntoLValue(const Expr *E, LValue dest, bool isInit)
EmitComplexExprIntoLValue - Emit the given expression of complex type and place its result into the s...
void StartFunction(GlobalDecl GD, QualType RetTy, llvm::Function *Fn, const CGFunctionInfo &FnInfo, const FunctionArgList &Args, SourceLocation Loc=SourceLocation(), SourceLocation StartLoc=SourceLocation())
Emit code for the start of a function.
void registerGlobalDtorWithAtExit(const VarDecl &D, llvm::FunctionCallee fn, llvm::Constant *addr)
Call atexit() with a function that passes the given argument to the given function.
llvm::Value * unregisterGlobalDtorWithUnAtExit(llvm::Constant *dtorStub)
Call unatexit() with function dtorStub.
RValue EmitReferenceBindingToExpr(const Expr *E)
Emits a reference binding to the passed in expression.
void EmitAggExpr(const Expr *E, AggValueSlot AS)
EmitAggExpr - Emit the computation of the specified expression of aggregate type.
llvm::CallInst * EmitNounwindRuntimeCall(llvm::FunctionCallee callee, const Twine &name="")
ASTContext & getContext() const
bool needsEHCleanup(QualType::DestructionKind kind)
Determines whether an EH cleanup is required to destroy a type with the given destruction kind.
llvm::CallInst * EmitRuntimeCall(llvm::FunctionCallee callee, const Twine &name="")
void EmitInvariantStart(llvm::Constant *Addr, CharUnits Size)
CodeGenTypes & getTypes() const
void GenerateCXXGlobalVarDeclInitFunc(llvm::Function *Fn, const VarDecl *D, llvm::GlobalVariable *Addr, bool PerformInit)
LValue MakeAddrLValue(Address Addr, QualType T, AlignmentSource Source=AlignmentSource::Type)
void EmitObjCAutoreleasePoolCleanup(llvm::Value *Ptr)
llvm::LLVMContext & getLLVMContext()
llvm::Value * EmitScalarExpr(const Expr *E, bool IgnoreResultAssign=false)
EmitScalarExpr - Emit the computation of the specified expression of LLVM scalar type,...
void EmitStoreOfScalar(llvm::Value *Value, Address Addr, bool Volatile, QualType Ty, AlignmentSource Source=AlignmentSource::Type, bool isInit=false, bool isNontemporal=false)
EmitStoreOfScalar - Store a scalar value to an address, taking care to appropriately convert from the...
void EmitCXXGuardedInitBranch(llvm::Value *NeedsInit, llvm::BasicBlock *InitBlock, llvm::BasicBlock *NoInitBlock, GuardKind Kind, const VarDecl *D)
Emit a branch to select whether or not to perform guarded initialization.
This class organizes the cross-function state that is used while generating LLVM code.
void SetInternalFunctionAttributes(GlobalDecl GD, llvm::Function *F, const CGFunctionInfo &FI)
Set the attributes on the LLVM function for the given decl and function info.
CGHLSLRuntime & getHLSLRuntime()
Return a reference to the configured HLSL runtime.
llvm::Module & getModule() const
llvm::FunctionCallee CreateRuntimeFunction(llvm::FunctionType *Ty, StringRef Name, llvm::AttributeList ExtraAttrs=llvm::AttributeList(), bool Local=false, bool AssumeConvergent=false)
Create or return a runtime function declaration with the specified type and name.
llvm::FunctionCallee getAddrAndTypeOfCXXStructor(GlobalDecl GD, const CGFunctionInfo *FnInfo=nullptr, llvm::FunctionType *FnType=nullptr, bool DontDefer=false, ForDefinition_t IsForDefinition=NotForDefinition)
llvm::Constant * getFunctionPointer(GlobalDecl GD, llvm::Type *Ty=nullptr)
Return the ABI-correct function pointer value for a reference to the given function.
bool isInNoSanitizeList(SanitizerMask Kind, llvm::Function *Fn, SourceLocation Loc) const
const LangOptions & getLangOpts() const
CodeGenTypes & getTypes()
const TargetInfo & getTarget() const
void addUsedGlobal(llvm::GlobalValue *GV)
Add a global to a list to be added to the llvm.used metadata.
const llvm::DataLayout & getDataLayout() const
void Error(SourceLocation loc, StringRef error)
Emit a general error that something can't be done.
CGCXXABI & getCXXABI() const
CGOpenMPRuntime & getOpenMPRuntime()
Return a reference to the configured OpenMP runtime.
const llvm::Triple & getTriple() const
void AddGlobalDtor(llvm::Function *Dtor, int Priority=65535, bool IsDtorAttrFunc=false)
AddGlobalDtor - Add a function to the list that will be called when the module is unloaded.
ASTContext & getContext() const
bool supportsCOMDAT() const
const TargetCodeGenInfo & getTargetCodeGenInfo()
const CodeGenOptions & getCodeGenOpts() const
llvm::LLVMContext & getLLVMContext()
llvm::GlobalValue * GetGlobalValue(StringRef Ref)
void GenKernelArgMetadata(llvm::Function *FN, const FunctionDecl *FD=nullptr, CodeGenFunction *CGF=nullptr)
OpenCL v1.2 s5.6.4.6 allows the compiler to store kernel argument information in the program executab...
llvm::Function * getIntrinsic(unsigned IID, ArrayRef< llvm::Type * > Tys={})
CGObjCRuntime & getObjCRuntime()
Return a reference to the configured Objective-C runtime.
void AddGlobalCtor(llvm::Function *Ctor, int Priority=65535, unsigned LexOrder=~0U, llvm::Constant *AssociatedData=nullptr)
AddGlobalCtor - Add a function to the list that will be called before main() runs.
llvm::Function * CreateGlobalInitOrCleanUpFunction(llvm::FunctionType *ty, const Twine &name, const CGFunctionInfo &FI, SourceLocation Loc=SourceLocation(), bool TLS=false, llvm::GlobalVariable::LinkageTypes Linkage=llvm::GlobalVariable::InternalLinkage)
const CGFunctionInfo & arrangeLLVMFunctionInfo(CanQualType returnType, FnInfoOpts opts, ArrayRef< CanQualType > argTypes, FunctionType::ExtInfo info, ArrayRef< FunctionProtoType::ExtParameterInfo > paramInfos, RequiredArgs args)
"Arrange" the LLVM information for a call or type with the given signature.
llvm::FunctionType * GetFunctionType(const CGFunctionInfo &Info)
GetFunctionType - Get the LLVM function type for.
const CGFunctionInfo & arrangeBuiltinFunctionDeclaration(QualType resultType, const FunctionArgList &args)
A builtin function is a freestanding function using the default C conventions.
unsigned getTargetAddressSpace(QualType T) const
const CGFunctionInfo & arrangeNullaryFunction()
A nullary function is a freestanding function of type 'void ()'.
A specialization of Address that requires the address to be an LLVM Constant.
ConstantAddress withElementType(llvm::Type *ElemTy) const
static ConstantAddress invalid()
llvm::Constant * getPointer() const
FunctionArgList - Type for representing both the decl and type of parameters to a function.
LValue - This represents an lvalue references.
bool isObjCStrong() const
RValue - This trivial value class is used to represent the result of an expression that is evaluated.
llvm::Value * getScalarVal() const
getScalarVal() - Return the Value* of this scalar value.
virtual LangAS getAddrSpaceOfCxaAtexitPtrParam() const
Get address space of pointer parameter for __cxa_atexit.
SourceLocation getLocation() const
SourceLocation getBeginLoc() const LLVM_READONLY
SourceLocation getBeginLoc() const LLVM_READONLY
This represents one expression.
SourceLocation getExprLoc() const LLVM_READONLY
getExprLoc - Return the preferred location for the arrow when diagnosing a problem with a generic exp...
A class which abstracts out some details necessary for making a call.
GlobalDecl - represents a global declaration.
virtual void mangleDynamicAtExitDestructor(const VarDecl *D, raw_ostream &)=0
virtual void mangleDynamicInitializer(const VarDecl *D, raw_ostream &)=0
Describes a module or submodule.
SmallVector< ExportDecl, 2 > Exports
The set of export declarations.
bool isNamedModuleInterfaceHasInit() const
bool isInterfaceOrPartition() const
llvm::SmallSetVector< Module *, 2 > Imports
The set of modules imported by this module, and on which this module depends.
llvm::iterator_range< submodule_iterator > submodules()
bool isHeaderLikeModule() const
Is this module have similar semantics as headers.
A (possibly-)qualified type.
@ DK_objc_strong_lifetime
Scope - A scope is a transient data structure that is used while parsing the program.
Encodes a location in the source.
The base class of the type hierarchy.
CXXRecordDecl * getAsCXXRecordDecl() const
Retrieves the CXXRecordDecl that this type refers to, either because the type is a RecordType or beca...
bool isReferenceType() const
Represents a variable declaration or definition.
const Expr * getInit() const
@ TLS_Dynamic
TLS with a dynamic initializer.
const internal::VariadicAllOfMatcher< Type > type
Matches Types in the clang AST.
The JSON file list parser is used to communicate input to InstallAPI.
bool isTemplateInstantiation(TemplateSpecializationKind Kind)
Determine whether this template specialization kind refers to an instantiation of an entity (as oppos...
bool isUniqueGVALinkage(GVALinkage L)
Do we know that this will be the only definition of this symbol (excluding inlining-only definitions)...
Linkage
Describes the different kinds of linkage (C++ [basic.link], C99 6.2.2) that an entity may have.
@ Dtor_Complete
Complete object dtor.
LLVM_READONLY bool isPreprocessingNumberBody(unsigned char c)
Return true if this is the body character of a C preprocessing number, which is [a-zA-Z0-9_.
const FunctionProtoType * T
@ Other
Other implicit parameter.
llvm::PointerType * VoidPtrTy
llvm::IntegerType * Int64Ty
llvm::IntegerType * Int8Ty
i8, i16, i32, and i64
llvm::CallingConv::ID getRuntimeCC() const
llvm::IntegerType * IntTy
int
llvm::PointerType * Int8PtrTy
Extra information about a function prototype.
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4