62 : DstStructTypesSet(DstStructTypesSet) {}
67 void addTypeMapping(
Type *DstTy,
Type *SrcTy);
71 void linkDefinedTypeBodies();
81 return cast<FunctionType>(
get((
Type *)
T));
87 bool areTypesIsomorphic(
Type *DstTy,
Type *SrcTy);
91void TypeMapTy::addTypeMapping(
Type *DstTy,
Type *SrcTy) {
97 if (!areTypesIsomorphic(DstTy, SrcTy)) {
100 for (
Type *Ty : SpeculativeTypes)
101 MappedTypes.
erase(Ty);
103 SrcDefinitionsToResolve.
resize(SrcDefinitionsToResolve.
size() -
104 SpeculativeDstOpaqueTypes.
size());
105 for (
StructType *Ty : SpeculativeDstOpaqueTypes)
106 DstResolvedOpaqueTypes.
erase(Ty);
114 for (
Type *Ty : SpeculativeTypes)
115 if (
auto *STy = dyn_cast<StructType>(Ty))
119 SpeculativeTypes.clear();
120 SpeculativeDstOpaqueTypes.clear();
125bool TypeMapTy::areTypesIsomorphic(
Type *DstTy,
Type *SrcTy) {
131 Type *&Entry = MappedTypes[SrcTy];
133 return Entry == DstTy;
137 if (DstTy == SrcTy) {
145 if (
StructType *SSTy = dyn_cast<StructType>(SrcTy)) {
147 if (SSTy->isOpaque()) {
149 SpeculativeTypes.push_back(SrcTy);
157 if (cast<StructType>(DstTy)->isOpaque()) {
159 if (!DstResolvedOpaqueTypes.
insert(cast<StructType>(DstTy)).second)
162 SpeculativeTypes.push_back(SrcTy);
163 SpeculativeDstOpaqueTypes.push_back(cast<StructType>(DstTy));
174 if (isa<IntegerType>(DstTy))
176 if (
PointerType *PT = dyn_cast<PointerType>(DstTy)) {
177 if (PT->getAddressSpace() != cast<PointerType>(SrcTy)->getAddressSpace())
179 }
else if (
FunctionType *FT = dyn_cast<FunctionType>(DstTy)) {
180 if (FT->isVarArg() != cast<FunctionType>(SrcTy)->isVarArg())
182 }
else if (
StructType *DSTy = dyn_cast<StructType>(DstTy)) {
184 if (DSTy->isLiteral() != SSTy->
isLiteral() ||
185 DSTy->isPacked() != SSTy->
isPacked())
187 }
else if (
auto *DArrTy = dyn_cast<ArrayType>(DstTy)) {
188 if (DArrTy->getNumElements() != cast<ArrayType>(SrcTy)->getNumElements())
190 }
else if (
auto *DVecTy = dyn_cast<VectorType>(DstTy)) {
191 if (DVecTy->getElementCount() != cast<VectorType>(SrcTy)->getElementCount())
198 SpeculativeTypes.push_back(SrcTy);
209void TypeMapTy::linkDefinedTypeBodies() {
211 for (
StructType *SrcSTy : SrcDefinitionsToResolve) {
212 StructType *DstSTy = cast<StructType>(MappedTypes[SrcSTy]);
216 Elements.resize(SrcSTy->getNumElements());
220 DstSTy->
setBody(Elements, SrcSTy->isPacked());
223 SrcDefinitionsToResolve.clear();
224 DstResolvedOpaqueTypes.
clear();
243 return get(Ty, Visited);
248 Type **Entry = &MappedTypes[Ty];
253 bool IsUniqued = !isa<StructType>(Ty) || cast<StructType>(Ty)->isLiteral();
257 for (
auto &Pair : MappedTypes) {
258 assert(!(Pair.first != Ty && Pair.second == Ty) &&
259 "mapping to a source type");
263 if (!Visited.
insert(cast<StructType>(Ty)).second) {
279 bool AnyChange =
false;
287 Entry = &MappedTypes[Ty];
289 if (
auto *DTy = dyn_cast<StructType>(*Entry)) {
291 auto *STy = cast<StructType>(Ty);
292 finishType(DTy, STy, ElementTypes);
300 if (!AnyChange && IsUniqued)
308 return *Entry = ArrayType::get(ElementTypes[0],
309 cast<ArrayType>(Ty)->getNumElements());
312 return *Entry = VectorType::get(ElementTypes[0],
313 cast<VectorType>(Ty)->getElementCount());
315 return *Entry = PointerType::get(ElementTypes[0],
318 return *Entry = FunctionType::get(ElementTypes[0],
320 cast<FunctionType>(Ty)->isVarArg());
322 auto *STy = cast<StructType>(Ty);
336 return *Entry = OldT;
345 finishType(DTy, STy, ElementTypes);
367 IRLinker &TheIRLinker;
370 GlobalValueMaterializer(IRLinker &TheIRLinker) : TheIRLinker(TheIRLinker) {}
375 IRLinker &TheIRLinker;
378 LocalValueMaterializer(IRLinker &TheIRLinker) : TheIRLinker(TheIRLinker) {}
389 std::unique_ptr<Module> SrcM;
395 GlobalValueMaterializer GValMaterializer;
396 LocalValueMaterializer LValMaterializer;
409 std::vector<GlobalValue *> Worklist;
410 std::vector<std::pair<GlobalValue *, Value*>> RAUWWorklist;
417 if (ValuesToLink.
insert(GV).second)
418 Worklist.push_back(GV);
426 bool IsPerformingImport;
431 bool DoneLinkingBodies =
false;
435 std::optional<Error> FoundError;
438 FoundError = std::move(
E);
449 unsigned IndirectSymbolMCID;
455 void emitWarning(
const Twine &Message) {
479 if (
auto *FDGV = dyn_cast<Function>(DGV))
480 if (FDGV->isIntrinsic())
481 if (
const auto *FSrcGV = dyn_cast<Function>(SrcGV))
482 if (FDGV->getFunctionType() != TypeMap.get(FSrcGV->getFunctionType()))
489 void computeTypeMapping();
501 bool ForIndirectSymbol);
503 Error linkModuleFlagsMetadata();
527 void flushRAUWWorklist();
532 void prepareCompileUnitsForImport();
533 void linkNamedMDNodes();
539 IRLinker(
Module &DstM, MDMapT &SharedMDs,
543 : DstM(DstM), SrcM(
std::
move(SrcM)), AddLazyFor(
std::
move(AddLazyFor)),
544 TypeMap(Set), GValMaterializer(*this), LValMaterializer(*this),
545 SharedMDs(SharedMDs), IsPerformingImport(IsPerformingImport),
547 &TypeMap, &GValMaterializer),
548 IndirectSymbolMCID(Mapper.registerAlternateMappingContext(
549 IndirectSymbolValueMap, &LValMaterializer)) {
553 if (IsPerformingImport)
554 prepareCompileUnitsForImport();
559 Value *materialize(
Value *V,
bool ForIndirectSymbol);
577 ConflictGV->setName(
Name);
578 assert(ConflictGV->getName() !=
Name &&
"forceRenaming didn't work");
584Value *GlobalValueMaterializer::materialize(
Value *SGV) {
585 return TheIRLinker.materialize(SGV,
false);
588Value *LocalValueMaterializer::materialize(
Value *SGV) {
589 return TheIRLinker.materialize(SGV,
true);
592Value *IRLinker::materialize(
Value *V,
bool ForIndirectSymbol) {
593 auto *SGV = dyn_cast<GlobalValue>(V);
601 if (SGV->getParent() != &DstM && SGV->getParent() != SrcM.get())
617 if (
auto *
F = dyn_cast<Function>(New)) {
618 if (!
F->isDeclaration())
620 }
else if (
auto *V = dyn_cast<GlobalVariable>(New)) {
621 if (
V->hasInitializer() ||
V->hasAppendingLinkage())
623 }
else if (
auto *GA = dyn_cast<GlobalAlias>(New)) {
624 if (GA->getAliasee())
626 }
else if (
auto *GI = dyn_cast<GlobalIFunc>(New)) {
627 if (GI->getResolver())
642 (!ForIndirectSymbol && IndirectSymbolValueMap.
lookup(SGV) == New))
645 if (ForIndirectSymbol || shouldLink(New, *SGV))
646 setError(linkGlobalValueBody(*New, *SGV));
648 updateAttributes(*New);
670 for (
unsigned i = 0; i <
Attrs.getNumAttrSets(); ++i) {
671 for (
int AttrIdx = Attribute::FirstTypeAttr;
672 AttrIdx <= Attribute::LastTypeAttr; AttrIdx++) {
674 if (
Attrs.hasAttributeAtIndex(i, TypedAttr)) {
676 Attrs.getAttributeAtIndex(i, TypedAttr).getValueAsType()) {
677 Attrs =
Attrs.replaceAttributeTypeAtIndex(
C, i, TypedAttr,
695 F->copyAttributesFrom(SF);
696 F->setAttributes(mapAttributeTypes(
F->getContext(),
F->getAttributes()));
707 if (
auto *GA = dyn_cast<GlobalAlias>(SGV)) {
711 DGA->copyAttributesFrom(GA);
715 if (
auto *GI = dyn_cast<GlobalIFunc>(SGV)) {
718 SGV->
getName(),
nullptr, &DstM);
719 DGI->copyAttributesFrom(GI);
727 bool ForDefinition) {
729 if (
auto *SGVar = dyn_cast<GlobalVariable>(SGV)) {
730 NewGV = copyGlobalVariableProto(SGVar);
731 }
else if (
auto *SF = dyn_cast<Function>(SGV)) {
732 NewGV = copyFunctionProto(SF);
735 NewGV = copyIndirectSymbolProto(SGV);
755 if (
auto *NewGO = dyn_cast<GlobalObject>(NewGV)) {
758 NewGO->copyMetadata(cast<GlobalObject>(SGV), 0);
760 UnmappedMetadata.
insert(NewGO);
767 if (
auto *NewF = dyn_cast<Function>(NewGV)) {
768 NewF->setPersonalityFn(
nullptr);
769 NewF->setPrefixData(
nullptr);
770 NewF->setPrologueData(
nullptr);
777 size_t DotPos =
Name.rfind(
'.');
779 !isdigit(
static_cast<unsigned char>(
Name[DotPos + 1])))
781 :
Name.substr(0, DotPos);
788void IRLinker::computeTypeMapping() {
802 TypeMap.addTypeMapping(DAT->getElementType(), SAT->getElementType());
827 std::vector<StructType *>
Types = SrcM->getIdentifiedStructTypes();
832 if (TypeMap.DstStructTypesSet.hasType(ST)) {
841 if (STTypePrefix.size() ==
ST->getName().size())
866 if (TypeMap.DstStructTypesSet.hasType(DST))
867 TypeMap.addTypeMapping(DST, ST);
872 TypeMap.linkDefinedTypeBodies();
877 unsigned NumElements = cast<ArrayType>(
C->getType())->getNumElements();
879 for (
unsigned i = 0; i != NumElements; ++i)
891 "Linking globals named '" + SrcGV->
getName() +
892 "': can only link appending global with another appending "
896 return stringErr(
"Appending variables linked with different const'ness!");
900 "Appending variables with different alignment need to be linked!");
904 "Appending variables with different visibility need to be linked!");
908 "Appending variables with different unnamed_addr need to be linked!");
912 "Appending variables with different section name need to be linked!");
915 return stringErr(
"Appending variables with different address spaces need "
931 bool IsNewStructor =
false;
932 bool IsOldStructor =
false;
933 if (
Name ==
"llvm.global_ctors" ||
Name ==
"llvm.global_dtors") {
934 if (cast<StructType>(EltTy)->getNumElements() == 3)
935 IsNewStructor =
true;
937 IsOldStructor =
true;
942 auto &
ST = *cast<StructType>(EltTy);
943 Type *Tys[3] = {
ST.getElementType(0),
ST.getElementType(1), VoidPtrTy};
950 DstNumElements = DstTy->getNumElements();
953 if (EltTy != DstTy->getElementType())
954 return stringErr(
"Appending variables with different element types!");
963 dyn_cast<GlobalValue>(
E->getAggregateElement(2)->stripPointerCasts());
967 return !shouldLink(DGV, *Key);
987 IsOldStructor, SrcElements);
992 RAUWWorklist.push_back(
1011 bool LazilyAdded =
false;
1013 AddLazyFor(SGV, [
this, &LazilyAdded](
GlobalValue &GV) {
1021 bool ForIndirectSymbol) {
1024 bool ShouldLink = shouldLink(DGV, *SGV);
1030 return cast<Constant>(
I->second);
1032 I = IndirectSymbolValueMap.
find(SGV);
1033 if (
I != IndirectSymbolValueMap.
end())
1034 return cast<Constant>(
I->second);
1037 if (!ShouldLink && ForIndirectSymbol)
1042 return linkAppendingVarProto(cast_or_null<GlobalVariable>(DGV),
1043 cast<GlobalVariable>(SGV));
1045 bool NeedsRenaming =
false;
1047 if (DGV && !ShouldLink) {
1053 if (DoneLinkingBodies)
1056 NewGV = copyGlobalValueProto(SGV, ShouldLink || ForIndirectSymbol);
1057 if (ShouldLink || !ForIndirectSymbol)
1058 NeedsRenaming =
true;
1064 if (
Function *
F = dyn_cast<Function>(NewGV))
1069 assert(!UnmappedMetadata.
count(
F) &&
"intrinsic has unmapped metadata");
1072 NeedsRenaming =
false;
1078 if (ShouldLink || ForIndirectSymbol) {
1080 if (
auto *GO = dyn_cast<GlobalObject>(NewGV)) {
1088 if (!ShouldLink && ForIndirectSymbol)
1097 if (DGV && NewGV != SGV) {
1099 NewGV, TypeMap.get(SGV->
getType()));
1102 if (DGV && NewGV != DGV) {
1106 RAUWWorklist.push_back(std::make_pair(
1125 assert(Dst.isDeclaration() && !Src.isDeclaration());
1128 if (
Error Err = Src.materialize())
1132 if (Src.hasPrefixData())
1133 Dst.setPrefixData(Src.getPrefixData());
1134 if (Src.hasPrologueData())
1135 Dst.setPrologueData(Src.getPrologueData());
1136 if (Src.hasPersonalityFn())
1137 Dst.setPersonalityFn(Src.getPersonalityFn());
1140 Dst.copyMetadata(&Src, 0);
1143 Dst.stealArgumentListFrom(Src);
1144 Dst.splice(Dst.end(), &Src);
1160 if (
auto *
F = dyn_cast<Function>(&Src))
1161 return linkFunctionBody(cast<Function>(Dst), *
F);
1162 if (
auto *GVar = dyn_cast<GlobalVariable>(&Src)) {
1163 linkGlobalVariable(cast<GlobalVariable>(Dst), *GVar);
1166 if (
auto *GA = dyn_cast<GlobalAlias>(&Src)) {
1167 linkAliasAliasee(cast<GlobalAlias>(Dst), *GA);
1170 linkIFuncResolver(cast<GlobalIFunc>(Dst), cast<GlobalIFunc>(Src));
1174void IRLinker::flushRAUWWorklist() {
1175 for (
const auto &Elem : RAUWWorklist) {
1178 std::tie(Old, New) = Elem;
1183 RAUWWorklist.clear();
1186void IRLinker::prepareCompileUnitsForImport() {
1187 NamedMDNode *SrcCompileUnits = SrcM->getNamedMetadata(
"llvm.dbg.cu");
1188 if (!SrcCompileUnits)
1194 auto *
CU = cast<DICompileUnit>(SrcCompileUnits->
getOperand(
I));
1195 assert(
CU &&
"Expected valid compile unit");
1199 CU->replaceEnumTypes(
nullptr);
1200 CU->replaceMacros(
nullptr);
1201 CU->replaceRetainedTypes(
nullptr);
1212 CU->replaceGlobalVariables(
nullptr);
1214 CU->replaceImportedEntities(
nullptr);
1219void IRLinker::linkNamedMDNodes() {
1220 const NamedMDNode *SrcModFlags = SrcM->getModuleFlagsMetadata();
1221 for (
const NamedMDNode &NMD : SrcM->named_metadata()) {
1223 if (&NMD == SrcModFlags)
1229 emitWarning(
"Pseudo-probe ignored: source module '" +
1230 SrcM->getModuleIdentifier() +
1231 "' is compiled with -fpseudo-probe-for-profiling while "
1232 "destination module '" +
1238 if (IsPerformingImport && NMD.getName() ==
"llvm.stats")
1243 for (
const MDNode *
Op : NMD.operands())
1249Error IRLinker::linkModuleFlagsMetadata() {
1251 const NamedMDNode *SrcModFlags = SrcM->getModuleFlagsMetadata();
1276 mdconst::extract<ConstantInt>(
Op->getOperand(0))->getZExtValue();
1280 Requirements.
insert(cast<MDNode>(
Op->getOperand(2)));
1293 mdconst::extract<ConstantInt>(
SrcOp->getOperand(0));
1298 unsigned SrcBehaviorValue = SrcBehavior->
getZExtValue();
1305 if (Requirements.
insert(cast<MDNode>(
SrcOp->getOperand(2)))) {
1324 mdconst::extract<ConstantInt>(
DstOp->getOperand(0));
1325 unsigned DstBehaviorValue = DstBehavior->
getZExtValue();
1327 auto overrideDstValue = [&]() {
1336 SrcOp->getOperand(2) !=
DstOp->getOperand(2))
1337 return stringErr(
"linking module flags '" +
ID->getString() +
1338 "': IDs have conflicting override values in '" +
1339 SrcM->getModuleIdentifier() +
"' and '" +
1349 if (SrcBehaviorValue != DstBehaviorValue) {
1350 bool MinAndWarn = (SrcBehaviorValue ==
Module::Min &&
1354 bool MaxAndWarn = (SrcBehaviorValue ==
Module::Max &&
1358 if (!(MaxAndWarn || MinAndWarn))
1359 return stringErr(
"linking module flags '" +
ID->getString() +
1360 "': IDs have conflicting behaviors in '" +
1361 SrcM->getModuleIdentifier() +
"' and '" +
1365 auto ensureDistinctOp = [&](
MDNode *DstValue) {
1366 assert(isa<MDTuple>(DstValue) &&
1367 "Expected MDTuple when appending module flags");
1368 if (DstValue->isDistinct())
1369 return dyn_cast<MDTuple>(DstValue);
1385 SrcOp->getOperand(2) !=
DstOp->getOperand(2)) {
1388 <<
"linking module flags '" <<
ID->getString()
1389 <<
"': IDs have conflicting values ('" << *
SrcOp->getOperand(2)
1390 <<
"' from " << SrcM->getModuleIdentifier() <<
" with '"
1399 mdconst::extract<ConstantInt>(
DstOp->getOperand(2));
1401 mdconst::extract<ConstantInt>(
SrcOp->getOperand(2));
1418 mdconst::extract<ConstantInt>(
DstOp->getOperand(2));
1420 mdconst::extract<ConstantInt>(
SrcOp->getOperand(2));
1435 switch (SrcBehaviorValue) {
1441 if (
SrcOp->getOperand(2) !=
DstOp->getOperand(2))
1442 return stringErr(
"linking module flags '" +
ID->getString() +
1443 "': IDs have conflicting values in '" +
1444 SrcM->getModuleIdentifier() +
"' and '" +
1455 MDTuple *DstValue = ensureDistinctOp(cast<MDNode>(
DstOp->getOperand(2)));
1456 MDNode *SrcValue = cast<MDNode>(
SrcOp->getOperand(2));
1457 for (
const auto &O : SrcValue->
operands())
1463 MDTuple *DstValue = ensureDistinctOp(cast<MDNode>(
DstOp->getOperand(2)));
1464 MDNode *SrcValue = cast<MDNode>(
SrcOp->getOperand(2));
1477 for (
auto Idx : Mins) {
1481 ConstantInt *
V = mdconst::extract<ConstantInt>(
Op->getOperand(2));
1483 Op->getOperand(0),
ID,
1490 for (
unsigned I = 0,
E = Requirements.
size();
I !=
E; ++
I) {
1491 MDNode *Requirement = Requirements[
I];
1496 if (!
Op ||
Op->getOperand(2) != ReqValue)
1497 return stringErr(
"linking module flags '" +
Flag->getString() +
1498 "': does not have the required value");
1509 return ".text\n.balign 2\n.thumb\n" +
InlineAsm;
1511 return ".text\n.balign 4\n.arm\n" +
InlineAsm;
1530 if (
auto *
F = dyn_cast<Function>(&GV)) {
1531 if (!
F->isIntrinsic())
1532 F->removeFnAttr(llvm::Attribute::NoCallback);
1537 if (
CallBase *CI = dyn_cast<CallBase>(&
I))
1538 CI->removeFnAttr(Attribute::NoCallback);
1542Error IRLinker::run() {
1544 if (SrcM->getMaterializer())
1545 if (
Error Err = SrcM->getMaterializer()->materializeMetadata())
1554 if (DstM.
getTargetTriple().empty() && !SrcM->getTargetTriple().empty())
1564 bool EnableDLWarning =
true;
1565 bool EnableTripleWarning =
true;
1566 if (SrcTriple.isNVPTX() && DstTriple.isNVPTX()) {
1567 std::string ModuleId = SrcM->getModuleIdentifier();
1569 bool SrcIsLibDevice =
1571 bool SrcHasLibDeviceDL =
1572 (SrcM->getDataLayoutStr().empty() ||
1573 SrcM->getDataLayoutStr() ==
"e-i64:64-v16:16-v32:32-n16:32:64");
1577 bool SrcHasLibDeviceTriple = (SrcTriple.getVendor() ==
Triple::NVIDIA &&
1578 SrcTriple.getOSName() ==
"gpulibs") ||
1579 (SrcTriple.getVendorName() ==
"unknown" &&
1580 SrcTriple.getOSName() ==
"unknown");
1581 EnableTripleWarning = !(SrcIsLibDevice && SrcHasLibDeviceTriple);
1582 EnableDLWarning = !(SrcIsLibDevice && SrcHasLibDeviceDL);
1585 if (EnableDLWarning && (SrcM->getDataLayout() != DstM.
getDataLayout())) {
1586 emitWarning(
"Linking two modules of different data layouts: '" +
1587 SrcM->getModuleIdentifier() +
"' is '" +
1588 SrcM->getDataLayoutStr() +
"' whereas '" +
1593 if (EnableTripleWarning && !SrcM->getTargetTriple().empty() &&
1594 !SrcTriple.isCompatibleWith(DstTriple))
1595 emitWarning(
"Linking two modules of different target triples: '" +
1596 SrcM->getModuleIdentifier() +
"' is '" +
1597 SrcM->getTargetTriple() +
"' whereas '" +
1604 computeTypeMapping();
1606 std::reverse(Worklist.begin(), Worklist.end());
1607 while (!Worklist.empty()) {
1609 Worklist.pop_back();
1613 IndirectSymbolValueMap.
find(GV) != IndirectSymbolValueMap.
end())
1619 return std::move(*FoundError);
1620 flushRAUWWorklist();
1625 DoneLinkingBodies =
true;
1636 if (NGO->isDeclaration())
1640 if (!IsPerformingImport && !SrcM->getModuleInlineAsm().empty()) {
1644 }
else if (IsPerformingImport) {
1649 SmallString<256> S(
".symver ");
1653 DstM.appendModuleInlineAsm(S);
1674 return linkModuleFlagsMetadata();
1678 : ETypes(
E), IsPacked(
P) {}
1681 : ETypes(ST->elements()), IsPacked(ST->isPacked()) {}
1691StructType *IRMover::StructTypeKeyInfo::getEmptyKey() {
1695StructType *IRMover::StructTypeKeyInfo::getTombstoneKey() {
1699unsigned IRMover::StructTypeKeyInfo::getHashValue(
const KeyTy &Key) {
1704unsigned IRMover::StructTypeKeyInfo::getHashValue(
const StructType *ST) {
1705 return getHashValue(KeyTy(ST));
1708bool IRMover::StructTypeKeyInfo::isEqual(
const KeyTy &LHS,
1710 if (RHS == getEmptyKey() || RHS == getTombstoneKey())
1712 return LHS == KeyTy(RHS);
1715bool IRMover::StructTypeKeyInfo::isEqual(
const StructType *LHS,
1717 if (RHS == getEmptyKey() || RHS == getTombstoneKey())
1719 return KeyTy(LHS) == KeyTy(RHS);
1724 NonOpaqueStructTypes.insert(Ty);
1729 NonOpaqueStructTypes.insert(Ty);
1730 bool Removed = OpaqueStructTypes.erase(Ty);
1737 OpaqueStructTypes.insert(Ty);
1744 auto I = NonOpaqueStructTypes.find_as(Key);
1745 return I == NonOpaqueStructTypes.end() ? nullptr : *
I;
1750 return OpaqueStructTypes.count(Ty);
1751 auto I = NonOpaqueStructTypes.find(Ty);
1752 return I == NonOpaqueStructTypes.end() ?
false : *
I == Ty;
1757 StructTypes.
run(M,
false);
1768 SharedMDs[MD].reset(
const_cast<MDNode *
>(MD));
1775 IRLinker TheIRLinker(Composite, SharedMDs, IdentifiedStructTypes,
1776 std::move(Src), ValuesToLink, std::move(AddLazyFor),
1777 IsPerformingImport);
1778 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)
Module.h This file contains the declarations for the Module class.
assert(ImpDefSCC.getReg()==AMDGPU::SCC &&ImpDefSCC.isDef())
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.
static Constant * get(Type *Ty, uint64_t V, bool IsSigned=false)
If Ty is a vector type, return a Constant with a splat of the given value.
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.
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.
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.
const MDOperand & getOperand(unsigned I) const
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.
@ 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.
void dropTriviallyDeadConstantArrays()
Destroy ConstantArrays in LLVMContext if they are not used.
NamedMDNode * getNamedMetadata(const Twine &Name) const
Return the first NamedMDNode in the module with the specified name.
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
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)
erase - If the set contains the specified pointer, remove it and return true, otherwise return false.
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.
bool startswith(StringRef Prefix) const
bool endswith(StringRef Suffix) const
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.
void setBody(ArrayRef< Type * > Elements, bool isPacked=false)
Specify a body for an opaque identified type.
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...
bool hasName() const
Return true if this is a named struct that has a non-empty name.
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.
StringRef getName() const
Return the name for this struct type if it has an identity.
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.
AddressSpace getAddressSpace(T *V)
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
@ C
The default llvm calling convention, compatible with C.
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.
StringRef filename(StringRef path, Style style=Style::native)
Get filename.
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