Skip to content

Commit 8860620

Browse files
committed
Apply suggestions
1 parent 5569ace commit 8860620

File tree

2 files changed

+24
-18
lines changed

2 files changed

+24
-18
lines changed

llvm/lib/Transforms/InstCombine/InstCombinePHI.cpp

+2-4
Original file line numberDiff line numberDiff line change
@@ -574,10 +574,8 @@ Instruction *InstCombinerImpl::foldPHIArgGEPIntoPHI(PHINode &PN) {
574574
// substantially cheaper to compute for the constants, so making it a
575575
// variable index could pessimize the path. This also handles the case
576576
// for struct indices, which must always be constant.
577-
if (isa<ConstantInt>(FirstInst->getOperand(Op)) ||
578-
isa<ConstantInt>(GEP->getOperand(Op)) ||
579-
isa<ConstantDataVector>(FirstInst->getOperand(Op)) ||
580-
isa<ConstantDataVector>(GEP->getOperand(Op)))
577+
if (isa<Constant>(FirstInst->getOperand(Op)) ||
578+
isa<Constant>(GEP->getOperand(Op)))
581579
return nullptr;
582580

583581
if (FirstInst->getOperand(Op)->getType() !=

llvm/test/Transforms/InstCombine/fold-phi-arg-gep-to-phi-negative.ll

+22-14
Original file line numberDiff line numberDiff line change
@@ -1,35 +1,43 @@
1+
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
12
; RUN: opt < %s -passes=instcombine -S | FileCheck %s
23

34
%vec = type { %vec_base }
45
%vec_base = type { [4 x float] }
56
%foo = type { %vec, %vec}
67

7-
define void @test(i1 %tobool, ptr addrspace(1) %add.ptr.i) {
8+
define void @test(i1 %tobool, ptr addrspace(1) %add.ptr) {
9+
; CHECK-LABEL: define void @test(
10+
; CHECK-SAME: i1 [[TOBOOL:%.*]], ptr addrspace(1) [[ADD_PTR:%.*]]) {
11+
; CHECK-NEXT: [[ENTRY:.*:]]
12+
; CHECK-NEXT: [[LANE_0:%.*]] = alloca [[FOO:%.*]], align 16
13+
; CHECK-NEXT: [[LANE_15:%.*]] = insertelement <16 x ptr> poison, ptr [[LANE_0]], i64 0
14+
; CHECK-NEXT: br i1 [[TOBOOL]], label %[[F1:.*]], label %[[F0:.*]]
15+
; CHECK: [[F0]]:
16+
; CHECK-NEXT: [[MM_VECTORGEP:%.*]] = getelementptr inbounds [[FOO]], <16 x ptr> [[LANE_15]], <16 x i64> zeroinitializer, <16 x i32> splat (i32 1), <16 x i32> zeroinitializer, <16 x i32> zeroinitializer, <16 x i64> splat (i64 1)
17+
; CHECK-NEXT: br label %[[MERGE:.*]]
18+
; CHECK: [[F1]]:
19+
; CHECK-NEXT: [[MM_VECTORGEP2:%.*]] = getelementptr inbounds [[FOO]], <16 x ptr> [[LANE_15]], <16 x i64> zeroinitializer, <16 x i32> zeroinitializer, <16 x i32> zeroinitializer, <16 x i32> zeroinitializer, <16 x i64> splat (i64 1)
20+
; CHECK-NEXT: br label %[[MERGE]]
21+
; CHECK: [[MERGE]]:
22+
; CHECK-NEXT: [[VEC_PHI:%.*]] = phi <16 x ptr> [ [[MM_VECTORGEP]], %[[F0]] ], [ [[MM_VECTORGEP2]], %[[F1]] ]
23+
; CHECK-NEXT: store <16 x ptr> [[VEC_PHI]], ptr addrspace(1) [[ADD_PTR]], align 128
24+
; CHECK-NEXT: ret void
25+
;
826
entry:
927
%lane.0 = alloca %foo, align 16
10-
%lane.15 = insertelement <16 x ptr> undef, ptr %lane.0, i64 0
28+
%lane.15 = insertelement <16 x ptr> poison, ptr %lane.0, i64 0
1129
%mm_vectorGEP = getelementptr inbounds %foo, <16 x ptr> %lane.15, <16 x i64> zeroinitializer, <16 x i32> splat (i32 1), <16 x i32> zeroinitializer, <16 x i32> zeroinitializer, <16 x i64> splat (i64 1)
1230
%mm_vectorGEP2 = getelementptr inbounds %foo, <16 x ptr> %lane.15, <16 x i64> zeroinitializer, <16 x i32> zeroinitializer, <16 x i32> zeroinitializer, <16 x i32> zeroinitializer, <16 x i64> splat (i64 1)
1331
br i1 %tobool, label %f1, label %f0
1432

1533
f0:
16-
; CHECK: f0:
17-
; CHECK-NEXT: %mm_vectorGEP = getelementptr inbounds %foo, <16 x ptr> %lane.15, <16 x i64> zeroinitializer, <16 x i32> splat (i32 1), <16 x i32> zeroinitializer, <16 x i32> zeroinitializer, <16 x i64> splat (i64 1)
1834
br label %merge
1935

2036
f1:
21-
; CHECK: f1:
22-
; CHECK-NEXT: %mm_vectorGEP2 = getelementptr inbounds %foo, <16 x ptr> %lane.15, <16 x i64> zeroinitializer, <16 x i32> zeroinitializer, <16 x i32> zeroinitializer, <16 x i32> zeroinitializer, <16 x i64> splat (i64 1)
2337
br label %merge
2438

2539
merge:
26-
; CHECK: merge:
27-
; CHECK-NEXT: %vec.phi14 = phi <16 x ptr> [ %mm_vectorGEP, %f0 ], [ %mm_vectorGEP2, %f1 ]
28-
%vec.phi14 = phi <16 x ptr> [ %mm_vectorGEP, %f0], [ %mm_vectorGEP2, %f1 ]
29-
%wide.masked.gather15 = call <16 x float> @llvm.masked.gather.v16f32.v16p0(<16 x ptr> %vec.phi14, i32 4, <16 x i1> splat (i1 true), <16 x float> poison)
30-
%wide.masked.gather15.extract.15. = extractelement <16 x float> %wide.masked.gather15, i32 15
31-
store float %wide.masked.gather15.extract.15., ptr addrspace(1) %add.ptr.i, align 4
40+
%vec.phi = phi <16 x ptr> [ %mm_vectorGEP, %f0], [ %mm_vectorGEP2, %f1 ]
41+
store <16 x ptr> %vec.phi, ptr addrspace(1) %add.ptr
3242
ret void
3343
}
34-
35-
declare <16 x float> @llvm.masked.gather.v16f32.v16p0(<16 x ptr>, i32 immarg, <16 x i1>, <16 x float>)

0 commit comments

Comments
 (0)