[llvm] [memprof] Teach extractCallsFromIR to recognize heap allocation functions (PR #115938)
Snehasish Kumar via llvm-commits
llvm-commits at lists.llvm.org
Tue Nov 12 13:28:17 PST 2024
================
@@ -820,16 +820,26 @@ memprof::extractCallsFromIR(Module &M) {
continue;
StringRef CalleeName = CalledFunction->getName();
+ bool IsAlloc =
+ isAllocationWithHotColdVariant(CalledFunction, GetTLI(F));
for (const DILocation *DIL = I.getDebugLoc(); DIL;
DIL = DIL->getInlinedAt()) {
StringRef CallerName = DIL->getSubprogramLinkageName();
assert(!CallerName.empty() &&
"Be sure to enable -fdebug-info-for-profiling");
uint64_t CallerGUID = IndexedMemProfRecord::getGUID(CallerName);
uint64_t CalleeGUID = IndexedMemProfRecord::getGUID(CalleeName);
+ // Pretend that we are calling a function with GUID == 0 if we are
+ // calling a heap allocation function.
+ if (IsAlloc)
+ CalleeGUID = 0;
LineLocation Loc = {GetOffset(DIL), DIL->getColumn()};
Calls[CallerGUID].emplace_back(Loc, CalleeGUID);
CalleeName = CallerName;
+ // FIXME: Recognize other frames that are associated with heap
+ // allocation functions. It may be too early to reset IsAlloc to
+ // false here.
+ IsAlloc = false;
----------------
snehasish wrote:
Are you referring to the internal interceptor methods? These should be trimmed by the llvm-profdata logic here: https://github.com/llvm/llvm-project/blob/main/llvm/lib/ProfileData/MemProfReader.cpp#L209-L216
I think it's safe to assume the following:
* The operator new we want to replace will always be a direct call
* The internal frames of the memprof runtime will be dropped.
Do these assumptions change the logic you have here?
https://github.com/llvm/llvm-project/pull/115938
More information about the llvm-commits
mailing list