Skip to content

Commit 7163857

Browse files
author
git apple-llvm automerger
committed
Merge commit '481358974fb0' from llvm.org/release/17.x into stable/20230725
2 parents c482304 + 4813589 commit 7163857

File tree

2 files changed

+74
-1
lines changed

2 files changed

+74
-1
lines changed

llvm/lib/Transforms/Scalar/GVN.cpp

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2780,8 +2780,10 @@ bool GVNPass::processBlock(BasicBlock *BB) {
27802780
// identical phis, and the second or later passes can eliminate them.
27812781
SmallPtrSet<PHINode *, 8> PHINodesToRemove;
27822782
ChangedFunction |= EliminateDuplicatePHINodes(BB, PHINodesToRemove);
2783-
for (PHINode *PN : PHINodesToRemove)
2783+
for (PHINode *PN : PHINodesToRemove) {
2784+
VN.erase(PN);
27842785
removeInstruction(PN);
2786+
}
27852787

27862788
for (BasicBlock::iterator BI = BB->begin(), BE = BB->end();
27872789
BI != BE;) {

llvm/test/Transforms/GVN/pr65447.ll

Lines changed: 71 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,71 @@
1+
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 3
2+
; RUN: opt -S -passes=gvn < %s | FileCheck %s
3+
4+
; Make sure deduplicated phi nodes are removed from the VN map.
5+
define i64 @f() {
6+
; CHECK-LABEL: define i64 @f() {
7+
; CHECK-NEXT: BB:
8+
; CHECK-NEXT: store i1 false, ptr null, align 1
9+
; CHECK-NEXT: br label [[BB2D:%.*]]
10+
; CHECK: BB2a:
11+
; CHECK-NEXT: br label [[BB2B:%.*]]
12+
; CHECK: BB2b:
13+
; CHECK-NEXT: [[L93_PRE_PRE:%.*]] = load i1, ptr inttoptr (i64 -1 to ptr), align 1
14+
; CHECK-NEXT: br label [[BB2C:%.*]]
15+
; CHECK: BB2c:
16+
; CHECK-NEXT: [[L93_PRE:%.*]] = phi i1 [ [[L93_PRE_PRE]], [[BB2B]] ], [ true, [[BB2D]] ]
17+
; CHECK-NEXT: [[AZ2:%.*]] = phi i1 [ true, [[BB2B]] ], [ [[AZ:%.*]], [[BB2D]] ]
18+
; CHECK-NEXT: [[DOTPHI_TRANS_INSERT:%.*]] = sext i1 [[AZ2]] to i64
19+
; CHECK-NEXT: [[GEP2_PHI_TRANS_INSERT:%.*]] = getelementptr i1, ptr null, i64 [[DOTPHI_TRANS_INSERT]]
20+
; CHECK-NEXT: br label [[BB2D]]
21+
; CHECK: BB2d:
22+
; CHECK-NEXT: [[L93_PRE5:%.*]] = phi i1 [ [[L93_PRE]], [[BB2C]] ], [ false, [[BB:%.*]] ]
23+
; CHECK-NEXT: [[AZ]] = phi i1 [ [[AZ2]], [[BB2C]] ], [ false, [[BB]] ]
24+
; CHECK-NEXT: [[TMP0:%.*]] = sext i1 [[AZ]] to i64
25+
; CHECK-NEXT: [[GEP2:%.*]] = getelementptr i1, ptr null, i64 [[TMP0]]
26+
; CHECK-NEXT: store i1 [[AZ]], ptr null, align 2
27+
; CHECK-NEXT: br i1 [[L93_PRE5]], label [[BB2C]], label [[BB1E:%.*]]
28+
; CHECK: BB1e:
29+
; CHECK-NEXT: br i1 [[AZ]], label [[BB2F:%.*]], label [[BB4:%.*]]
30+
; CHECK: BB2f:
31+
; CHECK-NEXT: store i1 true, ptr null, align 2
32+
; CHECK-NEXT: br label [[BB2B]]
33+
; CHECK: BB4:
34+
; CHECK-NEXT: br label [[BB4]]
35+
;
36+
BB:
37+
store i1 false, ptr null, align 1
38+
br label %BB2d
39+
40+
BB2a: ; No predecessors!
41+
br label %BB2b
42+
43+
BB2b: ; preds = %BB2f, %BB2a
44+
br label %BB2c
45+
46+
BB2c: ; preds = %BB2d, %BB2b
47+
%0 = phi i1 [ true, %BB2b ], [ %1, %BB2d ]
48+
br label %BB2d
49+
50+
BB2d: ; preds = %BB2c, %BB
51+
%1 = phi i1 [ %0, %BB2c ], [ false, %BB ]
52+
%2 = sext i1 %1 to i64
53+
%gep2 = getelementptr i1, ptr null, i64 %2
54+
%L93 = load i1, ptr %gep2, align 1
55+
%Az = load i1, ptr null, align 2
56+
store i1 %1, ptr null, align 2
57+
br i1 %L93, label %BB2c, label %BB1e
58+
59+
BB1e: ; preds = %BB2d
60+
br i1 %Az, label %BB2f, label %BB4
61+
62+
BB2f: ; preds = %BB1e
63+
store i1 true, ptr null, align 2
64+
br label %BB2b
65+
66+
BB4: ; preds = %BB1e, %BB4
67+
br label %BB4
68+
69+
; uselistorder directives
70+
uselistorder label %BB4, { 1, 0 }
71+
}

0 commit comments

Comments
 (0)