Skip to content

Commit 4fe2c3f

Browse files
committed
[MergeICmps] Fix miss-compile in MergeICmps in presence of blockaddresses
1 parent 88bb8ca commit 4fe2c3f

File tree

2 files changed

+23
-11
lines changed

2 files changed

+23
-11
lines changed

llvm/lib/Transforms/Scalar/MergeICmps.cpp

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -479,6 +479,10 @@ BCECmpChain::BCECmpChain(const std::vector<BasicBlock *> &Blocks, PHINode &Phi,
479479
BaseIdentifier BaseId;
480480
for (BasicBlock *const Block : Blocks) {
481481
assert(Block && "invalid block");
482+
if (Block->hasAddressTaken()) {
483+
LLVM_DEBUG(dbgs() << "cannot merge blocks with blockaddress\n");
484+
return;
485+
}
482486
std::optional<BCECmpBlock> Comparison = visitCmpBlock(
483487
Phi.getIncomingValueForBlock(Block), Block, Phi.getParent(), BaseId);
484488
if (!Comparison) {

llvm/test/Transforms/MergeICmps/X86/blockaddresses.ll

Lines changed: 19 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -10,28 +10,36 @@ define fastcc i1 @test(ptr byval(%type) %a, ptr byval(%type) %b, i1 %cond) {
1010
; CHECK-LABEL: define fastcc i1 @test(
1111
; CHECK-SAME: ptr byval([[TYPE:%.*]]) [[A:%.*]], ptr byval([[TYPE]]) [[B:%.*]], i1 [[COND:%.*]]) {
1212
; CHECK-NEXT: [[ENTRY:.*:]]
13-
; CHECK-NEXT: [[VALUE401:%.*]] = select i1 [[COND]], ptr inttoptr (i32 1 to ptr), ptr blockaddress(@test, %[[EXIT:.*]])
14-
; CHECK-NEXT: indirectbr ptr [[VALUE401]], [label %[[BLOCK3072:.*]], label %exit]
15-
; CHECK: [[BLOCK3072]]:
13+
; CHECK-NEXT: [[VALUE401:%.*]] = select i1 [[COND]], ptr blockaddress(@test, %[[BLOCK307:.*]]), ptr blockaddress(@test, %[[EXIT:.*]])
14+
; CHECK-NEXT: indirectbr ptr [[VALUE401]], [label %[[BLOCK307]], label %exit]
15+
; CHECK: [[BLOCK307]]:
1616
; CHECK-NEXT: [[VALUE403:%.*]] = load i64, ptr [[A]], align 8
1717
; CHECK-NEXT: [[VALUE404:%.*]] = load i64, ptr [[A]], align 8
1818
; CHECK-NEXT: [[CMP_I:%.*]] = icmp eq i64 [[VALUE403]], [[VALUE404]]
19-
; CHECK-NEXT: br i1 [[CMP_I]], label %[[LAND_LHS_TRUE_I1:.*]], label %[[TEST_EXIT:.*]]
20-
; CHECK: [[LAND_LHS_TRUE_I1]]:
19+
; CHECK-NEXT: br i1 [[CMP_I]], label %[[LAND_LHS_TRUE_I:.*]], label %[[TEST_EXIT:.*]]
20+
; CHECK: [[LAND_LHS_TRUE_I]]:
2121
; CHECK-NEXT: [[B_I:%.*]] = getelementptr [[TYPE]], ptr [[A]], i64 0, i32 0
22-
; CHECK-NEXT: [[B3_I:%.*]] = getelementptr [[TYPE]], ptr [[B]], i64 0, i32 0
2322
; CHECK-NEXT: [[VALUE405:%.*]] = load i64, ptr [[B_I]], align 8
23+
; CHECK-NEXT: [[B3_I:%.*]] = getelementptr [[TYPE]], ptr [[B]], i64 0, i32 0
2424
; CHECK-NEXT: [[VALUE406:%.*]] = load i64, ptr [[B3_I]], align 8
2525
; CHECK-NEXT: [[CMP4_I:%.*]] = icmp eq i64 [[VALUE405]], [[VALUE406]]
26-
; CHECK-NEXT: br i1 [[CMP4_I]], label %"land.lhs.true5.i+land.rhs.i", label %[[TEST_EXIT]]
27-
; CHECK: "land.lhs.true5.i+land.rhs.i":
26+
; CHECK-NEXT: br i1 [[CMP4_I]], label %[[LAND_LHS_TRUE5_I:.*]], label %[[TEST_EXIT]]
27+
; CHECK: [[LAND_LHS_TRUE5_I]]:
2828
; CHECK-NEXT: [[C_I:%.*]] = getelementptr [[TYPE]], ptr [[A]], i64 0, i32 2
29+
; CHECK-NEXT: [[VALUE407:%.*]] = load i64, ptr [[C_I]], align 8
2930
; CHECK-NEXT: [[C6_I:%.*]] = getelementptr [[TYPE]], ptr [[B]], i64 0, i32 2
30-
; CHECK-NEXT: [[MEMCMP:%.*]] = call i32 @memcmp(ptr [[C_I]], ptr [[C6_I]], i64 16)
31-
; CHECK-NEXT: [[TMP10:%.*]] = icmp eq i32 [[MEMCMP]], 0
31+
; CHECK-NEXT: [[VALUE408:%.*]] = load i64, ptr [[C6_I]], align 8
32+
; CHECK-NEXT: [[CMP7_I:%.*]] = icmp eq i64 [[VALUE407]], [[VALUE408]]
33+
; CHECK-NEXT: br i1 [[CMP7_I]], label %[[LAND_RHS_I:.*]], label %[[TEST_EXIT]]
34+
; CHECK: [[LAND_RHS_I]]:
35+
; CHECK-NEXT: [[D_I:%.*]] = getelementptr [[TYPE]], ptr [[A]], i64 0, i32 3
36+
; CHECK-NEXT: [[VALUE409:%.*]] = load i64, ptr [[D_I]], align 8
37+
; CHECK-NEXT: [[D8_I:%.*]] = getelementptr [[TYPE]], ptr [[B]], i64 0, i32 3
38+
; CHECK-NEXT: [[VALUE410:%.*]] = load i64, ptr [[D8_I]], align 8
39+
; CHECK-NEXT: [[CMP9_I:%.*]] = icmp eq i64 [[VALUE409]], [[VALUE410]]
3240
; CHECK-NEXT: br label %[[TEST_EXIT]]
3341
; CHECK: [[TEST_EXIT]]:
34-
; CHECK-NEXT: [[VALUE411:%.*]] = phi i1 [ [[TMP10]], %"land.lhs.true5.i+land.rhs.i" ], [ false, %[[LAND_LHS_TRUE_I1]] ], [ false, %[[BLOCK3072]] ]
42+
; CHECK-NEXT: [[VALUE411:%.*]] = phi i1 [ false, %[[LAND_LHS_TRUE5_I]] ], [ false, %[[LAND_LHS_TRUE_I]] ], [ false, %[[BLOCK307]] ], [ [[CMP9_I]], %[[LAND_RHS_I]] ]
3543
; CHECK-NEXT: ret i1 false
3644
; CHECK: [[EXIT]]:
3745
; CHECK-NEXT: ret i1 false

0 commit comments

Comments
 (0)