[PATCH] D138523: CloneModule: Handling cloning ifuncs
Matt Arsenault via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Nov 22 19:44:21 PST 2022
arsenm updated this revision to Diff 477373.
arsenm added a comment.
Herald added a subscriber: hiraditya.
correct patch
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D138523/new/
https://reviews.llvm.org/D138523
Files:
llvm/lib/Transforms/Utils/CloneModule.cpp
Index: llvm/lib/Transforms/Utils/CloneModule.cpp
===================================================================
--- llvm/lib/Transforms/Utils/CloneModule.cpp
+++ llvm/lib/Transforms/Utils/CloneModule.cpp
@@ -109,6 +109,15 @@
VMap[&I] = GA;
}
+ for (const GlobalIFunc &I : M.ifuncs()) {
+ // Defer setting the resolver function until after functions are cloned.
+ auto *GI =
+ GlobalIFunc::create(I.getValueType(), I.getAddressSpace(),
+ I.getLinkage(), I.getName(), nullptr, New.get());
+ GI->copyAttributesFrom(&I);
+ VMap[&I] = GI;
+ }
+
// Now that all of the things that global variable initializer can refer to
// have been created, loop through and copy the global variable referrers
// over... We also set the attributes on the global now.
@@ -184,6 +193,12 @@
GA->setAliasee(MapValue(C, VMap));
}
+ for (const GlobalIFunc &I : M.ifuncs()) {
+ GlobalIFunc *GI = cast<GlobalIFunc>(VMap[&I]);
+ if (const Constant *Resolver = I.getResolver())
+ GI->setResolver(MapValue(Resolver, VMap));
+ }
+
// And named metadata....
for (const NamedMDNode &NMD : M.named_metadata()) {
NamedMDNode *NewNMD = New->getOrInsertNamedMetadata(NMD.getName());
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D138523.477373.patch
Type: text/x-patch
Size: 1254 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20221123/fdc923f8/attachment.bin>
More information about the llvm-commits
mailing list