69 : DstStructTypesSet(DstStructTypesSet) {}
74 void addTypeMapping(
Type *DstTy,
Type *SrcTy);
78 Error linkDefinedTypeBodies();
86 return cast<FunctionType>(
get((
Type *)
T));
92 bool areTypesIsomorphic(
Type *DstTy,
Type *SrcTy);
96void TypeMapTy::addTypeMapping(
Type *DstTy,
Type *SrcTy) {
102 if (!areTypesIsomorphic(DstTy, SrcTy)) {
105 for (
Type *Ty : SpeculativeTypes)
106 MappedTypes.
erase(Ty);
108 SrcDefinitionsToResolve.
resize(SrcDefinitionsToResolve.
size() -
109 SpeculativeDstOpaqueTypes.
size());
110 for (
StructType *Ty : SpeculativeDstOpaqueTypes)
111 DstResolvedOpaqueTypes.
erase(Ty);
119 for (
Type *Ty : SpeculativeTypes)
120 if (
auto *STy = dyn_cast<StructType>(Ty))
124 SpeculativeTypes.clear();
125 SpeculativeDstOpaqueTypes.clear();
130bool TypeMapTy::areTypesIsomorphic(
Type *DstTy,
Type *SrcTy) {
138 return Entry == DstTy;
142 if (DstTy == SrcTy) {
150 if (
StructType *SSTy = dyn_cast<StructType>(SrcTy)) {
152 if (SSTy->isOpaque()) {
154 SpeculativeTypes.push_back(SrcTy);
162 if (cast<StructType>(DstTy)->isOpaque()) {
164 if (!DstResolvedOpaqueTypes.
insert(cast<StructType>(DstTy)).second)
167 SpeculativeTypes.push_back(SrcTy);
168 SpeculativeDstOpaqueTypes.push_back(cast<StructType>(DstTy));
179 if (isa<IntegerType>(DstTy))
181 if (
PointerType *PT = dyn_cast<PointerType>(DstTy)) {
182 if (PT->getAddressSpace() != cast<PointerType>(SrcTy)->getAddressSpace())
184 }
else if (
FunctionType *FT = dyn_cast<FunctionType>(DstTy)) {
185 if (FT->isVarArg() != cast<FunctionType>(SrcTy)->isVarArg())
187 }
else if (
StructType *DSTy = dyn_cast<StructType>(DstTy)) {
189 if (DSTy->isLiteral() != SSTy->
isLiteral() ||
190 DSTy->isPacked() != SSTy->
isPacked())
192 }
else if (
auto *DArrTy = dyn_cast<ArrayType>(DstTy)) {
193 if (DArrTy->getNumElements() != cast<ArrayType>(SrcTy)->getNumElements())
195 }
else if (
auto *DVecTy = dyn_cast<VectorType>(DstTy)) {
196 if (DVecTy->getElementCount() != cast<VectorType>(SrcTy)->getElementCount())
203 SpeculativeTypes.push_back(SrcTy);
214Error TypeMapTy::linkDefinedTypeBodies() {
216 for (
StructType *SrcSTy : SrcDefinitionsToResolve) {
217 StructType *DstSTy = cast<StructType>(MappedTypes[SrcSTy]);
221 Elements.resize(SrcSTy->getNumElements());
222 for (
unsigned I = 0, E =
Elements.size();
I != E; ++
I)
225 if (
auto E = DstSTy->
setBodyOrError(Elements, SrcSTy->isPacked()))
229 SrcDefinitionsToResolve.clear();
230 DstResolvedOpaqueTypes.
clear();
236 return get(Ty, Visited);
246 bool IsUniqued = !isa<StructType>(Ty) || cast<StructType>(Ty)->isLiteral();
250 for (
auto &Pair : MappedTypes) {
251 assert(!(Pair.first != Ty && Pair.second == Ty) &&
252 "mapping to a source type");
256 if (!Visited.
insert(cast<StructType>(Ty)).second) {
272 bool AnyChange =
false;
280 Entry = &MappedTypes[Ty];
281 assert(!*Entry &&
"Recursive type!");
285 if (!AnyChange && IsUniqued)
293 return *
Entry = ArrayType::get(ElementTypes[0],
297 return *
Entry = VectorType::get(ElementTypes[0],
298 cast<VectorType>(Ty)->getElementCount());
300 return *
Entry = FunctionType::get(ElementTypes[0],
302 cast<FunctionType>(Ty)->isVarArg());
304 auto *STy = cast<StructType>(Ty);
310 if (STy->isOpaque()) {
318 return *
Entry = OldT;
330 if (STy->hasName()) {
358 IRLinker &TheIRLinker;
361 GlobalValueMaterializer(IRLinker &TheIRLinker) : TheIRLinker(TheIRLinker) {}
366 IRLinker &TheIRLinker;
369 LocalValueMaterializer(IRLinker &TheIRLinker) : TheIRLinker(TheIRLinker) {}
380 std::unique_ptr<Module> SrcM;
386 GlobalValueMaterializer GValMaterializer;
387 LocalValueMaterializer LValMaterializer;
400 std::vector<GlobalValue *> Worklist;
401 std::vector<std::pair<GlobalValue *, Value*>> RAUWWorklist;
408 if (ValuesToLink.
insert(GV).second)
409 Worklist.push_back(GV);
417 bool IsPerformingImport;
422 bool DoneLinkingBodies =
false;
426 std::optional<Error> FoundError;
429 FoundError = std::move(
E);
434 unsigned IndirectSymbolMCID;
440 void emitWarning(
const Twine &Message) {
464 if (
auto *FDGV = dyn_cast<Function>(DGV))
465 if (FDGV->isIntrinsic())
466 if (
const auto *FSrcGV = dyn_cast<Function>(SrcGV))
467 if (FDGV->getFunctionType() != TypeMap.get(FSrcGV->getFunctionType()))
474 void computeTypeMapping();
486 bool ForIndirectSymbol);
488 Error linkModuleFlagsMetadata();
512 void flushRAUWWorklist();
517 void prepareCompileUnitsForImport();
518 void linkNamedMDNodes();
524 IRLinker(
Module &DstM, MDMapT &SharedMDs,
528 : DstM(DstM), SrcM(
std::
move(SrcM)), AddLazyFor(
std::
move(AddLazyFor)),
529 TypeMap(
Set), GValMaterializer(*this), LValMaterializer(*this),
530 SharedMDs(SharedMDs), IsPerformingImport(IsPerformingImport),
532 &TypeMap, &GValMaterializer),
533 IndirectSymbolMCID(Mapper.registerAlternateMappingContext(
534 IndirectSymbolValueMap, &LValMaterializer)) {
538 if (IsPerformingImport)
539 prepareCompileUnitsForImport();
544 Value *materialize(
Value *V,
bool ForIndirectSymbol);
562 ConflictGV->setName(
Name);
563 assert(ConflictGV->getName() !=
Name &&
"forceRenaming didn't work");
569Value *GlobalValueMaterializer::materialize(
Value *SGV) {
570 return TheIRLinker.materialize(SGV,
false);
573Value *LocalValueMaterializer::materialize(
Value *SGV) {
574 return TheIRLinker.materialize(SGV,
true);
577Value *IRLinker::materialize(
Value *V,
bool ForIndirectSymbol) {
578 auto *SGV = dyn_cast<GlobalValue>(V);
583 if (SGV->getParent() == &DstM)
590 if (SGV->getParent() != SrcM.get())
606 if (
auto *
F = dyn_cast<Function>(New)) {
607 if (!
F->isDeclaration())
609 }
else if (
auto *V = dyn_cast<GlobalVariable>(New)) {
610 if (
V->hasInitializer() ||
V->hasAppendingLinkage())
612 }
else if (
auto *GA = dyn_cast<GlobalAlias>(New)) {
613 if (GA->getAliasee())
615 }
else if (
auto *GI = dyn_cast<GlobalIFunc>(New)) {
616 if (GI->getResolver())
631 (!ForIndirectSymbol && IndirectSymbolValueMap.
lookup(SGV) == New))
634 if (ForIndirectSymbol || shouldLink(New, *SGV))
635 setError(linkGlobalValueBody(*New, *SGV));
637 updateAttributes(*New);
659 for (
unsigned i = 0; i <
Attrs.getNumAttrSets(); ++i) {
660 for (
int AttrIdx = Attribute::FirstTypeAttr;
661 AttrIdx <= Attribute::LastTypeAttr; AttrIdx++) {
663 if (
Attrs.hasAttributeAtIndex(i, TypedAttr)) {
665 Attrs.getAttributeAtIndex(i, TypedAttr).getValueAsType()) {
666 Attrs =
Attrs.replaceAttributeTypeAtIndex(
C, i, TypedAttr,
684 F->copyAttributesFrom(SF);
685 F->setAttributes(mapAttributeTypes(
F->getContext(),
F->getAttributes()));
697 if (
auto *GA = dyn_cast<GlobalAlias>(SGV)) {
701 DGA->copyAttributesFrom(GA);
705 if (
auto *GI = dyn_cast<GlobalIFunc>(SGV)) {
708 SGV->
getName(),
nullptr, &DstM);
709 DGI->copyAttributesFrom(GI);
717 bool ForDefinition) {
719 if (
auto *SGVar = dyn_cast<GlobalVariable>(SGV)) {
720 NewGV = copyGlobalVariableProto(SGVar);
721 }
else if (
auto *SF = dyn_cast<Function>(SGV)) {
722 NewGV = copyFunctionProto(SF);
725 NewGV = copyIndirectSymbolProto(SGV);
745 if (
auto *NewGO = dyn_cast<GlobalObject>(NewGV)) {
748 NewGO->copyMetadata(cast<GlobalObject>(SGV), 0);
750 UnmappedMetadata.
insert(NewGO);
757 if (
auto *NewF = dyn_cast<Function>(NewGV)) {
758 NewF->setPersonalityFn(
nullptr);
759 NewF->setPrefixData(
nullptr);
760 NewF->setPrologueData(
nullptr);
767 size_t DotPos =
Name.rfind(
'.');
769 !isdigit(
static_cast<unsigned char>(
Name[DotPos + 1])))
771 :
Name.substr(0, DotPos);
778void IRLinker::computeTypeMapping() {
792 TypeMap.addTypeMapping(DAT->getElementType(),
SAT->getElementType());
817 std::vector<StructType *>
Types = SrcM->getIdentifiedStructTypes();
822 if (TypeMap.DstStructTypesSet.hasType(ST)) {
831 if (STTypePrefix.size() ==
ST->getName().size())
856 if (TypeMap.DstStructTypesSet.hasType(DST))
857 TypeMap.addTypeMapping(DST, ST);
862 setError(TypeMap.linkDefinedTypeBodies());
867 unsigned NumElements = cast<ArrayType>(
C->getType())->getNumElements();
869 for (
unsigned i = 0; i != NumElements; ++i)
881 "Linking globals named '" + SrcGV->
getName() +
882 "': can only link appending global with another appending "
886 return stringErr(
"Appending variables linked with different const'ness!");
890 "Appending variables with different alignment need to be linked!");
894 "Appending variables with different visibility need to be linked!");
898 "Appending variables with different unnamed_addr need to be linked!");
902 "Appending variables with different section name need to be linked!");
905 return stringErr(
"Appending variables with different address spaces need "
921 bool IsNewStructor =
false;
922 bool IsOldStructor =
false;
923 if (
Name ==
"llvm.global_ctors" ||
Name ==
"llvm.global_dtors") {
925 IsNewStructor =
true;
927 IsOldStructor =
true;
932 auto &
ST = *cast<StructType>(EltTy);
933 Type *
Tys[3] = {
ST.getElementType(0),
ST.getElementType(1), VoidPtrTy};
940 DstNumElements = DstTy->getNumElements();
943 if (EltTy != DstTy->getElementType())
944 return stringErr(
"Appending variables with different element types!");
957 return !shouldLink(DGV, *Key);
977 IsOldStructor, SrcElements);
982 RAUWWorklist.push_back(std::make_pair(DstGV, NG));
1000 bool LazilyAdded =
false;
1002 AddLazyFor(SGV, [
this, &LazilyAdded](
GlobalValue &GV) {
1010 bool ForIndirectSymbol) {
1013 bool ShouldLink = shouldLink(DGV, *SGV);
1019 return cast<Constant>(
I->second);
1021 I = IndirectSymbolValueMap.
find(SGV);
1022 if (
I != IndirectSymbolValueMap.
end())
1023 return cast<Constant>(
I->second);
1026 if (!ShouldLink && ForIndirectSymbol)
1031 return linkAppendingVarProto(cast_or_null<GlobalVariable>(DGV),
1032 cast<GlobalVariable>(SGV));
1034 bool NeedsRenaming =
false;
1036 if (DGV && !ShouldLink) {
1042 if (DoneLinkingBodies)
1045 NewGV = copyGlobalValueProto(SGV, ShouldLink || ForIndirectSymbol);
1046 if (ShouldLink || !ForIndirectSymbol)
1047 NeedsRenaming =
true;
1053 if (
Function *
F = dyn_cast<Function>(NewGV))
1058 assert(!UnmappedMetadata.
count(
F) &&
"intrinsic has unmapped metadata");
1061 NeedsRenaming =
false;
1067 if (ShouldLink || ForIndirectSymbol) {
1069 if (
auto *GO = dyn_cast<GlobalObject>(NewGV)) {
1077 if (!ShouldLink && ForIndirectSymbol)
1086 if (DGV && NewGV != SGV) {
1088 NewGV, TypeMap.get(SGV->
getType()));
1091 if (DGV && NewGV != DGV) {
1095 RAUWWorklist.push_back(std::make_pair(
1114 assert(Dst.isDeclaration() && !Src.isDeclaration());
1117 if (
Error Err = Src.materialize())
1121 if (Src.hasPrefixData())
1122 Dst.setPrefixData(Src.getPrefixData());
1123 if (Src.hasPrologueData())
1124 Dst.setPrologueData(Src.getPrologueData());
1125 if (Src.hasPersonalityFn())
1126 Dst.setPersonalityFn(Src.getPersonalityFn());
1127 assert(Src.IsNewDbgInfoFormat == Dst.IsNewDbgInfoFormat);
1130 Dst.copyMetadata(&Src, 0);
1133 Dst.stealArgumentListFrom(Src);
1134 Dst.splice(Dst.end(), &Src);
1150 if (
auto *
F = dyn_cast<Function>(&Src))
1151 return linkFunctionBody(cast<Function>(Dst), *
F);
1152 if (
auto *GVar = dyn_cast<GlobalVariable>(&Src)) {
1153 linkGlobalVariable(cast<GlobalVariable>(Dst), *GVar);
1156 if (
auto *GA = dyn_cast<GlobalAlias>(&Src)) {
1157 linkAliasAliasee(cast<GlobalAlias>(Dst), *GA);
1160 linkIFuncResolver(cast<GlobalIFunc>(Dst), cast<GlobalIFunc>(Src));
1164void IRLinker::flushRAUWWorklist() {
1165 for (
const auto &Elem : RAUWWorklist) {
1168 std::tie(Old, New) = Elem;
1173 RAUWWorklist.clear();
1176void IRLinker::prepareCompileUnitsForImport() {
1177 NamedMDNode *SrcCompileUnits = SrcM->getNamedMetadata(
"llvm.dbg.cu");
1178 if (!SrcCompileUnits)
1184 auto *
CU = cast<DICompileUnit>(
N);
1185 assert(
CU &&
"Expected valid compile unit");
1189 CU->replaceEnumTypes(
nullptr);
1190 CU->replaceMacros(
nullptr);
1191 CU->replaceRetainedTypes(
nullptr);
1202 CU->replaceGlobalVariables(
nullptr);
1204 CU->replaceImportedEntities(
nullptr);
1209void IRLinker::linkNamedMDNodes() {
1210 const NamedMDNode *SrcModFlags = SrcM->getModuleFlagsMetadata();
1211 for (
const NamedMDNode &NMD : SrcM->named_metadata()) {
1213 if (&NMD == SrcModFlags)
1219 emitWarning(
"Pseudo-probe ignored: source module '" +
1220 SrcM->getModuleIdentifier() +
1221 "' is compiled with -fpseudo-probe-for-profiling while "
1222 "destination module '" +
1228 if (IsPerformingImport && NMD.getName() ==
"llvm.stats")
1233 for (
const MDNode *
Op : NMD.operands())
1239Error IRLinker::linkModuleFlagsMetadata() {
1241 const NamedMDNode *SrcModFlags = SrcM->getModuleFlagsMetadata();
1266 mdconst::extract<ConstantInt>(
Op->getOperand(0))->getZExtValue();
1270 Requirements.
insert(cast<MDNode>(
Op->getOperand(2)));
1283 mdconst::extract<ConstantInt>(
SrcOp->getOperand(0));
1288 unsigned SrcBehaviorValue = SrcBehavior->
getZExtValue();
1295 if (Requirements.
insert(cast<MDNode>(
SrcOp->getOperand(2)))) {
1314 mdconst::extract<ConstantInt>(
DstOp->getOperand(0));
1315 unsigned DstBehaviorValue = DstBehavior->
getZExtValue();
1317 auto overrideDstValue = [&]() {
1326 SrcOp->getOperand(2) !=
DstOp->getOperand(2))
1327 return stringErr(
"linking module flags '" +
ID->getString() +
1328 "': IDs have conflicting override values in '" +
1329 SrcM->getModuleIdentifier() +
"' and '" +
1339 if (SrcBehaviorValue != DstBehaviorValue) {
1340 bool MinAndWarn = (SrcBehaviorValue ==
Module::Min &&
1344 bool MaxAndWarn = (SrcBehaviorValue ==
Module::Max &&
1348 if (!(MaxAndWarn || MinAndWarn))
1349 return stringErr(
"linking module flags '" +
ID->getString() +
1350 "': IDs have conflicting behaviors in '" +
1351 SrcM->getModuleIdentifier() +
"' and '" +
1355 auto ensureDistinctOp = [&](
MDNode *DstValue) {
1356 assert(isa<MDTuple>(DstValue) &&
1357 "Expected MDTuple when appending module flags");
1358 if (DstValue->isDistinct())
1359 return dyn_cast<MDTuple>(DstValue);
1374 SrcOp->getOperand(2) !=
DstOp->getOperand(2)) {
1377 <<
"linking module flags '" <<
ID->getString()
1378 <<
"': IDs have conflicting values ('" << *
SrcOp->getOperand(2)
1379 <<
"' from " << SrcM->getModuleIdentifier() <<
" with '"
1388 mdconst::extract<ConstantInt>(
DstOp->getOperand(2));
1390 mdconst::extract<ConstantInt>(
SrcOp->getOperand(2));
1407 mdconst::extract<ConstantInt>(
DstOp->getOperand(2));
1409 mdconst::extract<ConstantInt>(
SrcOp->getOperand(2));
1424 switch (SrcBehaviorValue) {
1430 if (
SrcOp->getOperand(2) !=
DstOp->getOperand(2)) {
1433 <<
"linking module flags '" <<
ID->getString()
1434 <<
"': IDs have conflicting values: '" << *
SrcOp->getOperand(2)
1435 <<
"' from " << SrcM->getModuleIdentifier() <<
", and '"
1448 MDTuple *DstValue = ensureDistinctOp(cast<MDNode>(
DstOp->getOperand(2)));
1449 MDNode *SrcValue = cast<MDNode>(
SrcOp->getOperand(2));
1450 for (
const auto &O : SrcValue->
operands())
1456 MDTuple *DstValue = ensureDistinctOp(cast<MDNode>(
DstOp->getOperand(2)));
1457 MDNode *SrcValue = cast<MDNode>(
SrcOp->getOperand(2));
1470 for (
auto Idx : Mins) {
1474 ConstantInt *
V = mdconst::extract<ConstantInt>(
Op->getOperand(2));
1476 Op->getOperand(0),
ID,
1483 for (
MDNode *Requirement : Requirements) {
1484 MDString *
Flag = cast<MDString>(Requirement->getOperand(0));
1485 Metadata *ReqValue = Requirement->getOperand(1);
1488 if (!
Op ||
Op->getOperand(2) != ReqValue)
1489 return stringErr(
"linking module flags '" +
Flag->getString() +
1490 "': does not have the required value");
1501 return ".text\n.balign 2\n.thumb\n" +
InlineAsm;
1503 return ".text\n.balign 4\n.arm\n" +
InlineAsm;
1522 if (
auto *
F = dyn_cast<Function>(&GV)) {
1523 if (!
F->isIntrinsic())
1524 F->removeFnAttr(llvm::Attribute::NoCallback);
1529 if (
CallBase *CI = dyn_cast<CallBase>(&
I))
1530 CI->removeFnAttr(Attribute::NoCallback);
1534Error IRLinker::run() {
1536 if (SrcM->getMaterializer())
1537 if (
Error Err = SrcM->getMaterializer()->materializeMetadata())
1549 if (DstM.
getTargetTriple().empty() && !SrcM->getTargetTriple().empty())
1559 bool EnableDLWarning =
true;
1560 bool EnableTripleWarning =
true;
1561 if (SrcTriple.isNVPTX() && DstTriple.isNVPTX()) {
1562 bool SrcHasLibDeviceDL =
1563 (SrcM->getDataLayoutStr().empty() ||
1564 SrcM->getDataLayoutStr() ==
"e-i64:64-v16:16-v32:32-n16:32:64");
1568 bool SrcHasLibDeviceTriple = (SrcTriple.getVendor() ==
Triple::NVIDIA &&
1569 SrcTriple.getOSName() ==
"gpulibs") ||
1570 (SrcTriple.getVendorName() ==
"unknown" &&
1571 SrcTriple.getOSName() ==
"unknown");
1572 EnableTripleWarning = !SrcHasLibDeviceTriple;
1573 EnableDLWarning = !(SrcHasLibDeviceTriple && SrcHasLibDeviceDL);
1576 if (EnableDLWarning && (SrcM->getDataLayout() != DstM.
getDataLayout())) {
1577 emitWarning(
"Linking two modules of different data layouts: '" +
1578 SrcM->getModuleIdentifier() +
"' is '" +
1579 SrcM->getDataLayoutStr() +
"' whereas '" +
1584 if (EnableTripleWarning && !SrcM->getTargetTriple().empty() &&
1585 !SrcTriple.isCompatibleWith(DstTriple))
1586 emitWarning(
"Linking two modules of different target triples: '" +
1587 SrcM->getModuleIdentifier() +
"' is '" +
1588 SrcM->getTargetTriple() +
"' whereas '" +
1595 computeTypeMapping();
1597 std::reverse(Worklist.begin(), Worklist.end());
1598 while (!Worklist.empty()) {
1600 Worklist.pop_back();
1604 IndirectSymbolValueMap.
find(GV) != IndirectSymbolValueMap.
end())
1610 return std::move(*FoundError);
1611 flushRAUWWorklist();
1616 DoneLinkingBodies =
true;
1627 if (NGO->isDeclaration())
1631 if (!IsPerformingImport && !SrcM->getModuleInlineAsm().empty()) {
1635 }
else if (IsPerformingImport) {
1640 SmallString<256> S(
".symver ");
1644 DstM.appendModuleInlineAsm(S);
1665 return linkModuleFlagsMetadata();
1669 : ETypes(E), IsPacked(
P) {}
1672 : ETypes(ST->elements()), IsPacked(ST->isPacked()) {}
1682StructType *IRMover::StructTypeKeyInfo::getEmptyKey() {
1686StructType *IRMover::StructTypeKeyInfo::getTombstoneKey() {
1690unsigned IRMover::StructTypeKeyInfo::getHashValue(
const KeyTy &Key) {
1695unsigned IRMover::StructTypeKeyInfo::getHashValue(
const StructType *ST) {
1696 return getHashValue(KeyTy(ST));
1699bool IRMover::StructTypeKeyInfo::isEqual(
const KeyTy &LHS,
1701 if (RHS == getEmptyKey() || RHS == getTombstoneKey())
1703 return LHS == KeyTy(RHS);
1706bool IRMover::StructTypeKeyInfo::isEqual(
const StructType *LHS,
1708 if (RHS == getEmptyKey() || RHS == getTombstoneKey())
1710 return KeyTy(LHS) == KeyTy(RHS);
1715 NonOpaqueStructTypes.insert(Ty);
1720 NonOpaqueStructTypes.insert(Ty);
1721 bool Removed = OpaqueStructTypes.erase(Ty);
1728 OpaqueStructTypes.insert(Ty);
1735 auto I = NonOpaqueStructTypes.find_as(Key);
1736 return I == NonOpaqueStructTypes.end() ? nullptr : *
I;
1741 return OpaqueStructTypes.count(Ty);
1742 auto I = NonOpaqueStructTypes.find(Ty);
1743 return I == NonOpaqueStructTypes.end() ?
false : *
I == Ty;
1748 StructTypes.
run(M,
false);
1759 SharedMDs[MD].reset(
const_cast<MDNode *
>(MD));
1766 IRLinker TheIRLinker(Composite, SharedMDs, IdentifiedStructTypes,
1767 std::move(Src), ValuesToLink, std::move(AddLazyFor),
1768 IsPerformingImport);
1769 Error E = TheIRLinker.run();
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
This file contains the declarations for the subclasses of Constant, which represent the different fla...
Returns the sub type a function will return at a given Idx Should correspond to the result type of an ExtractValue instruction executed with just that one unsigned Idx
static void forceRenaming(GlobalValue *GV, StringRef Name)
The LLVM SymbolTable class autorenames globals that conflict in the symbol table.
static void getArrayElements(const Constant *C, SmallVectorImpl< Constant * > &Dest)
static std::string adjustInlineAsm(const std::string &InlineAsm, const Triple &Triple)
Return InlineAsm adjusted with target-specific directives if required.
static StringRef getTypeNamePrefix(StringRef Name)
static Error stringErr(const Twine &T)
Most of the errors produced by this module are inconvertible StringErrors.
Module.h This file contains the declarations for the Module class.
assert(ImpDefSCC.getReg()==AMDGPU::SCC &&ImpDefSCC.isDef())
static unsigned getNumElements(Type *Ty)
This file defines the make_scope_exit function, which executes user-defined cleanup logic at scope ex...
This file implements a set that has insertion order iteration characteristics.
This file defines the SmallPtrSet class.
This file defines the SmallString class.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
static ArrayType * get(Type *ElementType, uint64_t NumElements)
This static method is the primary way to construct an ArrayType.
AttrKind
This enumeration lists the attributes that can be associated with parameters, function results,...
LLVM Basic Block Representation.
Base class for all callable instructions (InvokeInst and CallInst) Holds everything related to callin...
void setSelectionKind(SelectionKind Val)
static Constant * getPointerBitCastOrAddrSpaceCast(Constant *C, Type *Ty)
Create a BitCast or AddrSpaceCast for a pointer type depending on the address space.
static Constant * getBitCast(Constant *C, Type *Ty, bool OnlyIfReduced=false)
This is the shared class of boolean and integer constants.
uint64_t getZExtValue() const
Return the constant as a 64-bit unsigned integer value after it has been zero extended as appropriate...
This is an important base class in LLVM.
const Constant * stripPointerCasts() const
Constant * getAggregateElement(unsigned Elt) const
For aggregates (struct/array/vector) return the constant that corresponds to the specified element if...
This class represents an Operation in the Expression.
bool isDefault() const
Test if the DataLayout was constructed from an empty string.
bool erase(const KeyT &Val)
Implements a dense probed hash-table based set.
This is the base abstract class for diagnostic reporting in the backend.
Interface for custom diagnostic printing.
Lightweight error class with error context and mandatory checking.
static ErrorSuccess success()
Create a success value.
Tagged union holding either a T or a Error.
Error takeError()
Take ownership of the stored error.
static Function * Create(FunctionType *Ty, LinkageTypes Linkage, unsigned AddrSpace, const Twine &N="", Module *M=nullptr)
FunctionType * getFunctionType() const
Returns the FunctionType for me.
bool IsNewDbgInfoFormat
Is this function using intrinsics to record the position of debugging information,...
static GlobalAlias * create(Type *Ty, unsigned AddressSpace, LinkageTypes Linkage, const Twine &Name, Constant *Aliasee, Module *Parent)
If a parent module is specified, the alias is automatically inserted into the end of the specified mo...
static GlobalIFunc * create(Type *Ty, unsigned AddressSpace, LinkageTypes Linkage, const Twine &Name, Constant *Resolver, Module *Parent)
If a parent module is specified, the ifunc is automatically inserted into the end of the specified mo...
StringRef getSection() const
Get the custom section of this global if it has one.
MaybeAlign getAlign() const
Returns the alignment of the given variable or function.
void setAlignment(Align Align)
Sets the alignment attribute of the GlobalObject.
VisibilityTypes getVisibility() const
bool isDeclaration() const
Return true if the primary definition of this global value is outside of the current translation unit...
LinkageTypes getLinkage() const
bool hasLocalLinkage() const
const Comdat * getComdat() const
bool hasExternalWeakLinkage() const
ThreadLocalMode getThreadLocalMode() const
void setLinkage(LinkageTypes LT)
bool isDeclarationForLinker() const
unsigned getAddressSpace() const
Module * getParent()
Get the module that this global value is contained inside of...
void eraseFromParent()
This method unlinks 'this' from the containing module and deletes it.
PointerType * getType() const
Global values are always pointers.
bool hasGlobalUnnamedAddr() const
bool hasAppendingLinkage() const
void removeFromParent()
This method unlinks 'this' from the containing module, but does not delete it.
@ InternalLinkage
Rename collisions when linking (static functions).
@ ExternalLinkage
Externally visible function.
@ ExternalWeakLinkage
ExternalWeak linkage description.
Type * getValueType() const
const Constant * getInitializer() const
getInitializer - Return the initializer for this global variable.
void copyAttributesFrom(const GlobalVariable *Src)
copyAttributesFrom - copy all additional attributes (those not needed to create a GlobalVariable) fro...
bool isConstant() const
If the value is a global constant, its value is immutable throughout the runtime execution of the pro...
void addNonOpaque(StructType *Ty)
bool hasType(StructType *Ty)
void switchToNonOpaque(StructType *Ty)
void addOpaque(StructType *Ty)
StructType * findNonOpaque(ArrayRef< Type * > ETypes, bool IsPacked)
Error move(std::unique_ptr< Module > Src, ArrayRef< GlobalValue * > ValuesToLink, LazyCallback AddLazyFor, bool IsPerformingImport)
Move in the provide values in ValuesToLink from Src.
This is an important class for using LLVM in a threaded context.
LinkDiagnosticInfo(DiagnosticSeverity Severity, const Twine &Msg)
void print(DiagnosticPrinter &DP) const override
Print using the given DP a user-friendly message.
ArrayRef< MDOperand > operands() const
op_iterator op_end() const
static MDTuple * get(LLVMContext &Context, ArrayRef< Metadata * > MDs)
unsigned getNumOperands() const
Return number of MDNode operands.
op_iterator op_begin() const
static MDTuple * getDistinct(LLVMContext &Context, ArrayRef< Metadata * > MDs)
Return a distinct node.
void push_back(Metadata *MD)
Append an element to the tuple. This will resize the node.
static void CollectAsmSymvers(const Module &M, function_ref< void(StringRef, StringRef)> AsmSymver)
Parse inline ASM and collect the symvers directives that are defined in the current module.
A Module instance is used to store all the information related to an LLVM module.
NamedMDNode * getNamedMetadata(StringRef Name) const
Return the first NamedMDNode in the module with the specified name.
@ AppendUnique
Appends the two values, which are required to be metadata nodes.
@ Override
Uses the specified value, regardless of the behavior or value of the other module.
@ Warning
Emits a warning if two values disagree.
@ Error
Emits an error if two values disagree, otherwise the resulting value is that of the operands.
@ Min
Takes the min of the two values, which are required to be integers.
@ Append
Appends the two values, which are required to be metadata nodes.
@ Max
Takes the max of the two values, which are required to be integers.
@ Require
Adds a requirement that another module flag be present and have a specified value after linking is pe...
LLVMContext & getContext() const
Get the global data context.
bool IsNewDbgInfoFormat
Is this Module using intrinsics to record the position of debugging information, or non-intrinsic rec...
void dropTriviallyDeadConstantArrays()
Destroy ConstantArrays in LLVMContext if they are not used.
NamedMDNode * getOrInsertModuleFlagsMetadata()
Returns the NamedMDNode in the module that represents module-level flags.
const std::string & getTargetTriple() const
Get the target triple which is a string describing the target host.
const std::string & getModuleIdentifier() const
Get the module identifier which is, essentially, the name of the module.
void setDataLayout(StringRef Desc)
Set the data layout.
void insertGlobalVariable(GlobalVariable *GV)
Insert global variable GV at the end of the global variable list and take ownership.
GlobalValue * getNamedValue(StringRef Name) const
Return the global value in the module with the specified name, of arbitrary type.
NamedMDNode * getOrInsertNamedMetadata(StringRef Name)
Return the named MDNode in the module with the specified name.
Comdat * getOrInsertComdat(StringRef Name)
Return the Comdat in the module with the specified name.
const DataLayout & getDataLayout() const
Get the data layout for the module's target platform.
const std::string & getDataLayoutStr() const
Get the data layout string for the module's target platform.
void appendModuleInlineAsm(StringRef Asm)
Append to the module-scope inline assembly blocks.
void setTargetTriple(StringRef T)
Set the target triple.
void setOperand(unsigned I, MDNode *New)
MDNode * getOperand(unsigned i) const
unsigned getNumOperands() const
iterator_range< op_iterator > operands()
void addOperand(MDNode *M)
static PointerType * get(Type *ElementType, unsigned AddressSpace)
This constructs a pointer to an object of the specified type in a numbered address space.
size_type size() const
Determine the number of elements in the SetVector.
bool insert(const value_type &X)
Insert a new element into the SetVector.
bool erase(PtrType Ptr)
Remove pointer from the set.
std::pair< iterator, bool > insert(PtrType Ptr)
Inserts Ptr if and only if there is no element in the container equal to Ptr.
SmallPtrSet - This class implements a set which is optimized for holding SmallSize or less elements.
A SetVector that performs no allocations if smaller than a certain size.
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringRef - Represent a constant reference to a string, i.e.
static constexpr size_t npos
Class to represent struct types.
static StructType * get(LLVMContext &Context, ArrayRef< Type * > Elements, bool isPacked=false)
This static method is the primary way to create a literal StructType.
static StructType * getTypeByName(LLVMContext &C, StringRef Name)
Return the type with the specified name, or null if there is none by that name.
static StructType * create(LLVMContext &Context, StringRef Name)
This creates an identified struct.
void setName(StringRef Name)
Change the name of this type to the specified name, or to a name with a suffix if there is a collisio...
Error setBodyOrError(ArrayRef< Type * > Elements, bool isPacked=false)
Specify a body for an opaque identified type or return an error if it would make the type recursive.
bool isLiteral() const
Return true if this type is uniqued by structural equivalence, false if it is a struct definition.
bool isOpaque() const
Return true if this is a type with an identity that has no body specified yet.
Triple - Helper class for working with autoconf configuration names.
ArchType getArch() const
Get the parsed architecture type of this triple.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
TypeFinder - Walk over a module, identifying all of the types that are used by the module.
DenseSet< const MDNode * > & getVisitedMetadata()
void run(const Module &M, bool onlyNamed)
The instances of the Type class are immutable: once they are created, they are never changed.
@ ScalableVectorTyID
Scalable SIMD vector type.
@ FixedVectorTyID
Fixed width SIMD vector type.
unsigned getNumContainedTypes() const
Return the number of types in the derived type.
LLVMContext & getContext() const
Return the LLVMContext in which this type was uniqued.
bool isFunctionTy() const
True if this is an instance of FunctionType.
TypeID getTypeID() const
Return the type id for the type.
Type * getContainedType(unsigned i) const
This method is used to implement the type iterator (defined at the end of the file).
This is a class that can be implemented by clients to remap types when cloning constants and instruct...
virtual Type * remapType(Type *SrcTy)=0
The client should implement this method if they want to remap types while mapping values.
ValueT lookup(const KeyT &Val) const
lookup - Return the entry for the specified key, or a default constructed value if no such entry exis...
std::optional< MDMapT > & getMDMap()
iterator find(const KeyT &Val)
Context for (re-)mapping values (and metadata).
MDNode * mapMDNode(const MDNode &N)
void scheduleMapGlobalInitializer(GlobalVariable &GV, Constant &Init, unsigned MappingContextID=0)
void scheduleRemapFunction(Function &F, unsigned MappingContextID=0)
void scheduleMapGlobalIFunc(GlobalIFunc &GI, Constant &Resolver, unsigned MappingContextID=0)
void scheduleMapAppendingVariable(GlobalVariable &GV, Constant *InitPrefix, bool IsOldCtorDtor, ArrayRef< Constant * > NewMembers, unsigned MappingContextID=0)
void scheduleMapGlobalAlias(GlobalAlias &GA, Constant &Aliasee, unsigned MappingContextID=0)
void remapGlobalObjectMetadata(GlobalObject &GO)
Value * mapValue(const Value &V)
void addFlags(RemapFlags Flags)
Add to the current RemapFlags.
This is a class that can be implemented by clients to materialize Values on demand.
LLVM Value Representation.
void setName(const Twine &Name)
Change the name of the value.
void replaceAllUsesWith(Value *V)
Change all uses of this to point to a new Value.
const Value * stripPointerCasts() const
Strip off pointer casts, all-zero GEPs and address space casts.
LLVMContext & getContext() const
All values hold a context through their type.
StringRef getName() const
Return a constant reference to the value's name.
void takeName(Value *V)
Transfer the name from V to this value.
std::pair< iterator, bool > insert(const ValueT &V)
bool erase(const ValueT &V)
size_type count(const_arg_type_t< ValueT > V) const
Return 1 if the specified key is in the set, 0 otherwise.
A raw_ostream that writes to an std::string.
unique_function is a type-erasing functor similar to std::function.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
constexpr char Attrs[]
Key for Kernel::Metadata::mAttrs.
@ C
The default llvm calling convention, compatible with C.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
ID ArrayRef< Type * > Tys
std::optional< Function * > remangleIntrinsicFunction(Function *F)
Flag
These should be considered private to the implementation of the MCInstrDesc class.
@ SC
CHAIN = SC CHAIN, Imm128 - System call.
PointerTypeMap run(const Module &M)
Compute the PointerTypeMap for the module M.
This is an optimization pass for GlobalISel generic memory operations.
std::error_code inconvertibleErrorCode()
The value returned by this function can be returned from convertToErrorCode for Error values where no...
bool UpgradeModuleFlags(Module &M)
This checks for module flags which should be upgraded.
bool operator==(const AddressRangeValuePair &LHS, const AddressRangeValuePair &RHS)
decltype(auto) get(const PointerIntPair< PointerTy, IntBits, IntType, PtrTraits, Info > &Pair)
@ RF_IgnoreMissingLocals
If this flag is set, the remapper ignores missing function-local entries (Argument,...
@ RF_NullMapMissingGlobalValues
Any global values not in value map are mapped to null instead of mapping to self.
@ RF_ReuseAndMutateDistinctMDs
Instruct the remapper to reuse and mutate distinct metadata (remapping them in place) instead of clon...
OutputIt move(R &&Range, OutputIt Out)
Provide wrappers to std::move which take ranges instead of having to pass begin/end explicitly.
DiagnosticSeverity
Defines the different supported severity of a diagnostic.
void erase_if(Container &C, UnaryPredicate P)
Provide a container algorithm similar to C++ Library Fundamentals v2's erase_if which is equivalent t...
hash_code hash_combine(const Ts &...args)
Combine values into a single hash_code.
hash_code hash_combine_range(InputIteratorT first, InputIteratorT last)
Compute a hash_code for a sequence of values.
constexpr const char * PseudoProbeDescMetadataName
Implement std::hash so that hash_code can be used in STL containers.
An information struct used to provide DenseMap with the various necessary components for a given valu...
KeyTy(ArrayRef< Type * > E, bool P)
bool operator==(const KeyTy &that) const
ArrayRef< Type * > ETypes
bool operator!=(const KeyTy &that) const