[llvm] 58a70df - [msan] Add debugging for handleUnknownIntrinsic (#123381)
via llvm-commits
llvm-commits at lists.llvm.org
Fri Jan 17 11:27:42 PST 2025
Author: Thurston Dang
Date: 2025-01-17T11:27:39-08:00
New Revision: 58a70dffcc096b54537aa99a045346ee28ad2592
URL: https://github.com/llvm/llvm-project/commit/58a70dffcc096b54537aa99a045346ee28ad2592
DIFF: https://github.com/llvm/llvm-project/commit/58a70dffcc096b54537aa99a045346ee28ad2592.diff
LOG: [msan] Add debugging for handleUnknownIntrinsic (#123381)
This adds an experimental flag, msan-dump-strict-intrinsics (modeled
after msan-dump-strict-instructions), which prints out any intrinsics
that are heuristically handled. Additionally, MSan will print out
heuristically handled intrinsics when -debug is passed as a flag in
debug builds.
MSan's intrinsic handling can be broken down into:
1) special cases (usually highly accurate)
2) heuristic handling (sometimes erroneous)
3) not handled
This patch's -msan-dump-strict-intrinsics is intended to help debug Case
2. Case 3) (which includes all the heuristics that are not handled by
special cases nor heuristics) can be debugged using the existing
-msan-dump-strict-instructions.
Added:
Modified:
llvm/lib/Transforms/Instrumentation/MemorySanitizer.cpp
Removed:
################################################################################
diff --git a/llvm/lib/Transforms/Instrumentation/MemorySanitizer.cpp b/llvm/lib/Transforms/Instrumentation/MemorySanitizer.cpp
index 0169320deae46c..6daee7a3b6e815 100644
--- a/llvm/lib/Transforms/Instrumentation/MemorySanitizer.cpp
+++ b/llvm/lib/Transforms/Instrumentation/MemorySanitizer.cpp
@@ -318,6 +318,13 @@ static cl::opt<bool> ClDumpStrictInstructions(
cl::desc("print out instructions with default strict semantics"),
cl::Hidden, cl::init(false));
+static cl::opt<bool> ClDumpStrictIntrinsics(
+ "msan-dump-strict-intrinsics",
+ cl::desc("Prints 'unknown' intrinsics that were handled heuristically. "
+ "Use -msan-dump-strict-instructions to print intrinsics that "
+ "could not be handled exactly nor heuristically."),
+ cl::Hidden, cl::init(false));
+
static cl::opt<int> ClInstrumentationWithCallThreshold(
"msan-instrumentation-with-call-threshold",
cl::desc(
@@ -3014,7 +3021,7 @@ struct MemorySanitizerVisitor : public InstVisitor<MemorySanitizerVisitor> {
///
/// We special-case intrinsics where this approach fails. See llvm.bswap
/// handling as an example of that.
- bool handleUnknownIntrinsic(IntrinsicInst &I) {
+ bool handleUnknownIntrinsicUnlogged(IntrinsicInst &I) {
unsigned NumArgOperands = I.arg_size();
if (NumArgOperands == 0)
return false;
@@ -3040,6 +3047,18 @@ struct MemorySanitizerVisitor : public InstVisitor<MemorySanitizerVisitor> {
return false;
}
+ bool handleUnknownIntrinsic(IntrinsicInst &I) {
+ if (handleUnknownIntrinsicUnlogged(I)) {
+ if (ClDumpStrictIntrinsics)
+ dumpInst(I);
+
+ LLVM_DEBUG(dbgs() << "UNKNOWN INTRINSIC HANDLED HEURISTICALLY: " << I
+ << "\n");
+ return true;
+ } else
+ return false;
+ }
+
void handleInvariantGroup(IntrinsicInst &I) {
setShadow(&I, getShadow(&I, 0));
setOrigin(&I, getOrigin(&I, 0));
More information about the llvm-commits
mailing list