Skip to content

Commit 053c2a0

Browse files
committed
[SimplifyCFG][OpaquePtr] Check store type when merging conditional store
1 parent ec91075 commit 053c2a0

File tree

2 files changed

+36
-1
lines changed

2 files changed

+36
-1
lines changed

llvm/lib/Transforms/Utils/SimplifyCFG.cpp

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -3732,7 +3732,9 @@ static bool mergeConditionalStoreToAddress(
37323732
return false;
37333733

37343734
// Now check the stores are compatible.
3735-
if (!QStore->isUnordered() || !PStore->isUnordered())
3735+
if (!QStore->isUnordered() || !PStore->isUnordered() ||
3736+
PStore->getValueOperand()->getType() !=
3737+
QStore->getValueOperand()->getType())
37363738
return false;
37373739

37383740
// Check that sinking the store won't cause program behavior changes. Sinking

llvm/test/Transforms/SimplifyCFG/opaque-ptr.ll

Lines changed: 33 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -44,3 +44,36 @@ join:
4444
%phi = phi ptr [ %gep1, %if ], [ %gep2, %else]
4545
ret ptr %phi
4646
}
47+
48+
define void @test_cond_store_merge(i1 %arg, i1 %arg2, ptr %p) {
49+
; CHECK-LABEL: @test_cond_store_merge(
50+
; CHECK-NEXT: bb:
51+
; CHECK-NEXT: br i1 [[ARG:%.*]], label [[BB2:%.*]], label [[BB3:%.*]]
52+
; CHECK: bb2:
53+
; CHECK-NEXT: store i64 0, ptr [[P:%.*]], align 32
54+
; CHECK-NEXT: br label [[BB3]]
55+
; CHECK: bb3:
56+
; CHECK-NEXT: br i1 [[ARG2:%.*]], label [[BB4:%.*]], label [[BB5:%.*]]
57+
; CHECK: bb4:
58+
; CHECK-NEXT: store double 0.000000e+00, ptr [[P]], align 32
59+
; CHECK-NEXT: br label [[BB5]]
60+
; CHECK: bb5:
61+
; CHECK-NEXT: ret void
62+
;
63+
bb:
64+
br i1 %arg, label %bb2, label %bb3
65+
66+
bb2: ; preds = %bb
67+
store i64 0, ptr %p, align 32
68+
br label %bb3
69+
70+
bb3: ; preds = %bb2, %bb
71+
br i1 %arg2, label %bb4, label %bb5
72+
73+
bb4: ; preds = %bb3
74+
store double 0.000000e+00, ptr %p, align 32
75+
br label %bb5
76+
77+
bb5: ; preds = %bb4, %bb3
78+
ret void
79+
}

0 commit comments

Comments
 (0)