xref: /llvm-project/llvm/test/Transforms/LoopDistribute/pointer-phi-in-loop.ll (revision 3a4376b8f90686f754ee51b296a064ab03c12895)
13e60d216SFlorian Hahn; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
234493031SRamkumar Ramachandra; RUN: opt -aa-pipeline=basic-aa -passes=loop-distribute -enable-loop-distribute -verify-loop-info -verify-dom-info -S %s | FileCheck %s
33e60d216SFlorian Hahn
43e60d216SFlorian Hahn; Testcases inspired by PR50296, PR50288.
53e60d216SFlorian Hahn
6*3a4376b8SRamkumar Ramachandradefine void @phi_load_store_distribute(i1 %cond, ptr %A, ptr %B, ptr %C) {
73e60d216SFlorian Hahn; CHECK-LABEL: @phi_load_store_distribute(
83e60d216SFlorian Hahn; CHECK-NEXT:  entry:
93e60d216SFlorian Hahn; CHECK-NEXT:    br label [[FOR_BODY:%.*]]
10*3a4376b8SRamkumar Ramachandra; CHECK:       for.body.lver.check:
11*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[SCEVGEP:%.*]] = getelementptr i8, ptr [[A:%.*]], i64 2
12*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[SCEVGEP1:%.*]] = getelementptr i8, ptr [[C:%.*]], i64 2
13*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[SCEVGEP2:%.*]] = getelementptr i8, ptr [[B:%.*]], i64 2
14*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[BOUND0:%.*]] = icmp ult ptr [[A]], [[SCEVGEP1]]
15*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[BOUND1:%.*]] = icmp ult ptr [[C]], [[SCEVGEP]]
16*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[FOUND_CONFLICT:%.*]] = and i1 [[BOUND0]], [[BOUND1]]
17*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[BOUND03:%.*]] = icmp ult ptr [[A]], [[SCEVGEP2]]
18*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[BOUND14:%.*]] = icmp ult ptr [[B]], [[SCEVGEP]]
19*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[FOUND_CONFLICT5:%.*]] = and i1 [[BOUND03]], [[BOUND14]]
20*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[CONFLICT_RDX:%.*]] = or i1 [[FOUND_CONFLICT]], [[FOUND_CONFLICT5]]
21*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    br i1 [[CONFLICT_RDX]], label [[ENTRY:%.*]], label [[FOR_BODY_PH_LDIST1:%.*]]
22*3a4376b8SRamkumar Ramachandra; CHECK:       for.body.ph.lver.orig:
23*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    br label [[FOR_BODY_LVER_ORIG:%.*]]
24*3a4376b8SRamkumar Ramachandra; CHECK:       for.body.lver.orig:
25*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[IV:%.*]] = phi i16 [ 0, [[ENTRY]] ], [ [[IV_NEXT:%.*]], [[IF_END:%.*]] ]
26*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[LV:%.*]] = load i16, ptr [[A]], align 1
27055fb779SNikita Popov; CHECK-NEXT:    store i16 [[LV]], ptr [[A]], align 1
28*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    br i1 [[COND:%.*]], label [[IF_THEN:%.*]], label [[IF_END]]
29*3a4376b8SRamkumar Ramachandra; CHECK:       if.then.lver.orig:
30055fb779SNikita Popov; CHECK-NEXT:    [[LV2:%.*]] = load i16, ptr [[A]], align 1
313e60d216SFlorian Hahn; CHECK-NEXT:    br label [[IF_END]]
32*3a4376b8SRamkumar Ramachandra; CHECK:       if.end.lver.orig:
33*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[C_SINK_LVER_ORIG:%.*]] = phi ptr [ [[B]], [[IF_THEN]] ], [ [[C]], [[FOR_BODY_LVER_ORIG]] ]
34*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[LV3_LVER_ORIG:%.*]] = load i16, ptr [[C_SINK_LVER_ORIG]], align 2
35*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[ADD_LVER_ORIG:%.*]] = add i16 [[LV3_LVER_ORIG]], 10
36*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    store i16 [[ADD_LVER_ORIG]], ptr [[C_SINK_LVER_ORIG]], align 1
37*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[IV_NEXT]] = add nuw nsw i16 [[IV]], 1
38*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[TOBOOL_NOT_LVER_ORIG:%.*]] = icmp eq i16 [[IV_NEXT]], 1000
39*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    br i1 [[TOBOOL_NOT_LVER_ORIG]], label [[FOR_END_LOOPEXIT_LOOPEXIT:%.*]], label [[FOR_BODY_LVER_ORIG]]
40*3a4376b8SRamkumar Ramachandra; CHECK:       for.body.ph.ldist1:
41*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    br label [[FOR_BODY_LDIST1:%.*]]
42*3a4376b8SRamkumar Ramachandra; CHECK:       for.body.ldist1:
43*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[IV_LDIST1:%.*]] = phi i16 [ 0, [[FOR_BODY_PH_LDIST1]] ], [ [[IV_NEXT_LDIST1:%.*]], [[IF_END_LDIST1:%.*]] ]
44*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[LV_LDIST1:%.*]] = load i16, ptr [[A]], align 1, !alias.scope [[META0:![0-9]+]], !noalias [[META3:![0-9]+]]
45*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    store i16 [[LV_LDIST1]], ptr [[A]], align 1, !alias.scope [[META0]], !noalias [[META3]]
46*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    br i1 [[COND]], label [[IF_THEN_LDIST1:%.*]], label [[IF_END_LDIST1]]
47*3a4376b8SRamkumar Ramachandra; CHECK:       if.then.ldist1:
48*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[LV2_LDIST1:%.*]] = load i16, ptr [[A]], align 1, !alias.scope [[META0]], !noalias [[META3]]
49*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    br label [[IF_END_LDIST1]]
50*3a4376b8SRamkumar Ramachandra; CHECK:       if.end.ldist1:
51*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[IV_NEXT_LDIST1]] = add nuw nsw i16 [[IV_LDIST1]], 1
52*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[TOBOOL_NOT_LDIST1:%.*]] = icmp eq i16 [[IV_NEXT_LDIST1]], 1000
53*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    br i1 [[TOBOOL_NOT_LDIST1]], label [[FOR_BODY_PH:%.*]], label [[FOR_BODY_LDIST1]]
54*3a4376b8SRamkumar Ramachandra; CHECK:       for.body.ph:
55*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    br label [[FOR_BODY1:%.*]]
56*3a4376b8SRamkumar Ramachandra; CHECK:       for.body:
57*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[IV1:%.*]] = phi i16 [ 0, [[FOR_BODY_PH]] ], [ [[IV_NEXT1:%.*]], [[IF_END1:%.*]] ]
58*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    br i1 [[COND]], label [[IF_THEN1:%.*]], label [[IF_END1]]
59*3a4376b8SRamkumar Ramachandra; CHECK:       if.then:
60*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    br label [[IF_END1]]
613e60d216SFlorian Hahn; CHECK:       if.end:
62*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[C_SINK:%.*]] = phi ptr [ [[B]], [[IF_THEN1]] ], [ [[C]], [[FOR_BODY1]] ]
63055fb779SNikita Popov; CHECK-NEXT:    [[LV3:%.*]] = load i16, ptr [[C_SINK]], align 2
643e60d216SFlorian Hahn; CHECK-NEXT:    [[ADD:%.*]] = add i16 [[LV3]], 10
65055fb779SNikita Popov; CHECK-NEXT:    store i16 [[ADD]], ptr [[C_SINK]], align 1
66*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[IV_NEXT1]] = add nuw nsw i16 [[IV1]], 1
67*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[TOBOOL_NOT:%.*]] = icmp eq i16 [[IV_NEXT1]], 1000
68*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    br i1 [[TOBOOL_NOT]], label [[FOR_END_LOOPEXIT_LOOPEXIT6:%.*]], label [[FOR_BODY1]]
69*3a4376b8SRamkumar Ramachandra; CHECK:       for.end.loopexit.loopexit:
70*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    br label [[FOR_END_LOOPEXIT:%.*]]
71*3a4376b8SRamkumar Ramachandra; CHECK:       for.end.loopexit.loopexit6:
72*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    br label [[FOR_END_LOOPEXIT]]
733e60d216SFlorian Hahn; CHECK:       for.end.loopexit:
743e60d216SFlorian Hahn; CHECK-NEXT:    ret void
753e60d216SFlorian Hahn;
763e60d216SFlorian Hahnentry:
773e60d216SFlorian Hahn  br label %for.body
783e60d216SFlorian Hahn
793e60d216SFlorian Hahnfor.body:                                         ; preds = %if.end, %entry
803e60d216SFlorian Hahn  %iv = phi i16 [ 0, %entry ], [ %iv.next, %if.end ]
81055fb779SNikita Popov  %lv = load i16, ptr %A, align 1
82055fb779SNikita Popov  store i16 %lv, ptr %A, align 1
83*3a4376b8SRamkumar Ramachandra  br i1 %cond, label %if.then, label %if.end
843e60d216SFlorian Hahn
853e60d216SFlorian Hahnif.then:                                          ; preds = %for.body
86055fb779SNikita Popov  %lv2 = load i16, ptr %A, align 1
873e60d216SFlorian Hahn  br label %if.end
883e60d216SFlorian Hahn
893e60d216SFlorian Hahnif.end:                                           ; preds = %if.then, %for.body
90055fb779SNikita Popov  %c.sink = phi ptr [ %B, %if.then ], [ %C, %for.body ]
91055fb779SNikita Popov  %lv3 = load i16, ptr %c.sink
923e60d216SFlorian Hahn  %add = add i16 %lv3, 10
93055fb779SNikita Popov  store i16 %add, ptr %c.sink, align 1
943e60d216SFlorian Hahn  %iv.next = add nuw nsw i16 %iv, 1
953e60d216SFlorian Hahn  %tobool.not = icmp eq i16 %iv.next, 1000
963e60d216SFlorian Hahn  br i1 %tobool.not, label %for.end.loopexit, label %for.body
973e60d216SFlorian Hahn
983e60d216SFlorian Hahnfor.end.loopexit:                                 ; preds = %if.end
993e60d216SFlorian Hahn  ret void
1003e60d216SFlorian Hahn}
1013e60d216SFlorian Hahn
10234493031SRamkumar Ramachandradefine void @phi_load_distribute(i1 %cond, ptr %A, ptr %B, ptr %C) {
1033e60d216SFlorian Hahn; CHECK-LABEL: @phi_load_distribute(
1043e60d216SFlorian Hahn; CHECK-NEXT:  entry:
10534493031SRamkumar Ramachandra; CHECK-NEXT:    br label [[FOR_BODY_LVER_ORIG:%.*]]
106*3a4376b8SRamkumar Ramachandra; CHECK:       for.body:
107*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[IV_LVER_ORIG:%.*]] = phi i16 [ 0, [[FOR_BODY_PH_LVER_ORIG:%.*]] ], [ [[IV_NEXT_LVER_ORIG:%.*]], [[IF_END_LVER_ORIG:%.*]] ]
108*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[LV_LVER_ORIG:%.*]] = load i16, ptr [[A:%.*]], align 1
10934493031SRamkumar Ramachandra; CHECK-NEXT:    store i16 [[LV_LVER_ORIG]], ptr [[A]], align 1
11034493031SRamkumar Ramachandra; CHECK-NEXT:    br i1 [[COND:%.*]], label [[IF_THEN_LVER_ORIG:%.*]], label [[IF_END_LVER_ORIG]]
11134493031SRamkumar Ramachandra; CHECK:       if.then:
112*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[LV2:%.*]] = load i16, ptr [[A]], align 1
113*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    br label [[IF_END_LVER_ORIG]]
11434493031SRamkumar Ramachandra; CHECK:       if.end:
115*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[C_SINK:%.*]] = phi ptr [ [[B:%.*]], [[IF_THEN_LVER_ORIG]] ], [ [[C:%.*]], [[FOR_BODY_LVER_ORIG]] ]
11634493031SRamkumar Ramachandra; CHECK-NEXT:    [[LV3:%.*]] = load i16, ptr [[C_SINK]], align 2
117*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[IV_NEXT_LVER_ORIG]] = add nuw nsw i16 [[IV_LVER_ORIG]], 1
118*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    [[TOBOOL_NOT:%.*]] = icmp eq i16 [[IV_NEXT_LVER_ORIG]], 1000
119*3a4376b8SRamkumar Ramachandra; CHECK-NEXT:    br i1 [[TOBOOL_NOT]], label [[FOR_END_LOOPEXIT:%.*]], label [[FOR_BODY_LVER_ORIG]]
1203e60d216SFlorian Hahn; CHECK:       for.end.loopexit:
1213e60d216SFlorian Hahn; CHECK-NEXT:    ret void
1223e60d216SFlorian Hahn;
1233e60d216SFlorian Hahnentry:
1243e60d216SFlorian Hahn  br label %for.body
1253e60d216SFlorian Hahn
1263e60d216SFlorian Hahnfor.body:                                         ; preds = %if.end, %entry
1273e60d216SFlorian Hahn  %iv = phi i16 [ 0, %entry ], [ %iv.next, %if.end ]
128055fb779SNikita Popov  %lv = load i16, ptr %A, align 1
129055fb779SNikita Popov  store i16 %lv, ptr %A, align 1
13034493031SRamkumar Ramachandra  br i1 %cond, label %if.then, label %if.end
1313e60d216SFlorian Hahn
1323e60d216SFlorian Hahnif.then:                                          ; preds = %for.body
133055fb779SNikita Popov  %lv2 = load i16, ptr %A, align 1
1343e60d216SFlorian Hahn  br label %if.end
1353e60d216SFlorian Hahn
1363e60d216SFlorian Hahnif.end:                                           ; preds = %if.then, %for.body
137055fb779SNikita Popov  %c.sink = phi ptr [ %B, %if.then ], [ %C, %for.body ]
138055fb779SNikita Popov  %lv3 = load i16, ptr %c.sink
1393e60d216SFlorian Hahn  %iv.next = add nuw nsw i16 %iv, 1
1403e60d216SFlorian Hahn  %tobool.not = icmp eq i16 %iv.next, 1000
1413e60d216SFlorian Hahn  br i1 %tobool.not, label %for.end.loopexit, label %for.body
1423e60d216SFlorian Hahn
1433e60d216SFlorian Hahnfor.end.loopexit:                                 ; preds = %if.end
1443e60d216SFlorian Hahn  ret void
1453e60d216SFlorian Hahn}
1463e60d216SFlorian Hahn
1473e60d216SFlorian Hahn
148