[llvm] [memprof] Report an error when buildid and profile do not match (PR #132504)
via llvm-commits
llvm-commits at lists.llvm.org
Sat Mar 22 04:10:59 PDT 2025
https://github.com/zcfh updated https://github.com/llvm/llvm-project/pull/132504
>From 12a5154ccafea71a4accb3770eb3ff953afc21e0 Mon Sep 17 00:00:00 2001
From: wuminghui <wuminghui1412 at qq.com>
Date: Sat, 22 Mar 2025 02:48:32 +0000
Subject: [PATCH] [memprof] Report an error when buildid and profile do not
match
---
llvm/lib/ProfileData/MemProfReader.cpp | 6 +++++-
llvm/test/tools/llvm-profdata/memprof-buildid.test | 8 ++++++++
2 files changed, 13 insertions(+), 1 deletion(-)
diff --git a/llvm/lib/ProfileData/MemProfReader.cpp b/llvm/lib/ProfileData/MemProfReader.cpp
index 16502a4f1e8af..c57f9b22273d4 100644
--- a/llvm/lib/ProfileData/MemProfReader.cpp
+++ b/llvm/lib/ProfileData/MemProfReader.cpp
@@ -444,7 +444,11 @@ Error RawMemProfReader::setupForSymbolization() {
ProfiledTextSegmentEnd = Entry.End;
}
}
- assert(NumMatched != 0 && "No matching executable segments in segment info.");
+ if (NumMatched == 0)
+ return make_error<StringError>(
+ Twine("No matching executable segments found in binary ") +
+ Binary.getBinary()->getFileName(),
+ inconvertibleErrorCode());
assert((PreferredTextSegmentAddress == 0 ||
(PreferredTextSegmentAddress == ProfiledTextSegmentStart)) &&
"Expect text segment address to be 0 or equal to profiled text "
diff --git a/llvm/test/tools/llvm-profdata/memprof-buildid.test b/llvm/test/tools/llvm-profdata/memprof-buildid.test
index a5abe6ea7dcb6..fc78eb56a5a04 100644
--- a/llvm/test/tools/llvm-profdata/memprof-buildid.test
+++ b/llvm/test/tools/llvm-profdata/memprof-buildid.test
@@ -14,3 +14,11 @@ CHECK: Build ID: [[ID:[[:xdigit:]]+]]
COM: Then match it with the profdata output.
CHECK-COUNT-1: BuildId: {{.*}}[[ID]]
+
+Test that profile build id does not match build id in the binary
+RUN: not llvm-profdata show --memory %p/Inputs/buildid.memprofraw --profiled-binary %p/Inputs/basic.memprofexe -o - 2>&1 | FileCheck %s -check-prefix=BUILDID-NOT-MATCH
+
+Test error message when profile build id does not match build id in a different binary.
+RUN: not llvm-profdata merge %p/Inputs/buildid.memprofraw %p/Inputs/basic.memprofraw --profiled-binary %p/Inputs/basic.memprofexe -o %t4.prof 2>&1 | FileCheck %s -check-prefix=BUILDID-NOT-MATCH
+
+BUILDID-NOT-MATCH: No matching executable segments found in binary
More information about the llvm-commits
mailing list