[llvm] df26417 - [ObjC][ProvenanceEval] Only evaluate pointers (#136876)
via llvm-commits
llvm-commits at lists.llvm.org
Fri May 2 02:01:41 PDT 2025
Author: Nikita Popov
Date: 2025-05-02T11:01:38+02:00
New Revision: df264170f7f83530e03fb1ac22b3241797e86fe4
URL: https://github.com/llvm/llvm-project/commit/df264170f7f83530e03fb1ac22b3241797e86fe4
DIFF: https://github.com/llvm/llvm-project/commit/df264170f7f83530e03fb1ac22b3241797e86fe4.diff
LOG: [ObjC][ProvenanceEval] Only evaluate pointers (#136876)
I believe this pass should only be calling PA.related() on pointer
arguments -- the operation is not really meaningful for non-pointers.
I've adjusted the test to use ptr loads instead of i8 loads, which I
believe aligns with how these special globals would actually be used,
and which is probably what this was intending to test.
Ran into this while trying to eliminate illegal non-pointer AA queries.
Added:
Modified:
llvm/lib/Transforms/ObjCARC/ProvenanceAnalysisEvaluator.cpp
llvm/test/Transforms/ObjCARC/provenance.ll
Removed:
################################################################################
diff --git a/llvm/lib/Transforms/ObjCARC/ProvenanceAnalysisEvaluator.cpp b/llvm/lib/Transforms/ObjCARC/ProvenanceAnalysisEvaluator.cpp
index e563ecfb16228..8906fb87147a2 100644
--- a/llvm/lib/Transforms/ObjCARC/ProvenanceAnalysisEvaluator.cpp
+++ b/llvm/lib/Transforms/ObjCARC/ProvenanceAnalysisEvaluator.cpp
@@ -27,6 +27,8 @@ static StringRef getName(Value *V) {
static void insertIfNamed(SetVector<Value *> &Values, Value *V) {
if (!V->hasName())
return;
+ if (!V->getType()->isPointerTy())
+ return;
Values.insert(V);
}
diff --git a/llvm/test/Transforms/ObjCARC/provenance.ll b/llvm/test/Transforms/ObjCARC/provenance.ll
index 4e54f2771e6b3..5dac39c6a43ce 100644
--- a/llvm/test/Transforms/ObjCARC/provenance.ll
+++ b/llvm/test/Transforms/ObjCARC/provenance.ll
@@ -7,32 +7,32 @@
@g4 = global i8 0, section "__TEXT,__objc_methname,cstring_literals"
@g5 = global i8 0, section "__TEXT,__cstring,cstring_literals"
-declare void @g(i8)
+declare void @g(ptr)
define void @f(ptr %a, ptr %b, ptr %c) {
- %y1 = load i8, ptr %a
- call void @g(i8 %y1)
+ %y1 = load ptr, ptr %a
+ call void @g(ptr %y1)
%y2 = load ptr, ptr %b
%y3 = load ptr, ptr %c
- %x0 = load i8, ptr @"\01l_objc_msgSend_fixup_"
- call void @g(i8 %x0)
+ %x0 = load ptr, ptr @"\01l_objc_msgSend_fixup_"
+ call void @g(ptr %x0)
- %x1 = load i8, ptr @g1
- call void @g(i8 %x1)
+ %x1 = load ptr, ptr @g1
+ call void @g(ptr %x1)
- %x2 = load i8, ptr @g2
- call void @g(i8 %x2)
+ %x2 = load ptr, ptr @g2
+ call void @g(ptr %x2)
- %x3 = load i8, ptr @g3
- call void @g(i8 %x3)
+ %x3 = load ptr, ptr @g3
+ call void @g(ptr %x3)
- %x4 = load i8, ptr @g4
- call void @g(i8 %x4)
+ %x4 = load ptr, ptr @g4
+ call void @g(ptr %x4)
- %x5 = load i8, ptr @g5
- call void @g(i8 %x5)
+ %x5 = load ptr, ptr @g5
+ call void @g(ptr %x5)
ret void
}
More information about the llvm-commits
mailing list