@@ -66,8 +66,9 @@ define void @replicating_load_used_as_store_addr_2(ptr noalias %invar.dst, ptr n
6666; CHECK-NEXT: [[TMP5:%.*]] = icmp eq i64 [[INDEX_NEXT]], 100
6767; CHECK-NEXT: br i1 [[TMP5]], label %[[MIDDLE_BLOCK:.*]], label %[[VECTOR_BODY]], !llvm.loop [[LOOP4:![0-9]+]]
6868; CHECK: [[MIDDLE_BLOCK]]:
69- ; CHECK-NEXT: br [[EXIT:label %.*]]
70- ; CHECK: [[SCALAR_PH:.*:]]
69+ ; CHECK-NEXT: br label %[[EXIT:.*]]
70+ ; CHECK: [[EXIT]]:
71+ ; CHECK-NEXT: ret void
7172;
7273entry:
7374 br label %loop
@@ -107,15 +108,15 @@ define void @replicating_load_used_as_store_addr_3(ptr noalias %src, ptr noalias
107108; CHECK-NEXT: [[TMP6:%.*]] = zext i32 [[TMP4]] to i64
108109; CHECK-NEXT: [[TMP7:%.*]] = getelementptr i8, ptr [[DST]], i64 [[TMP6]]
109110; CHECK-NEXT: store i8 0, ptr [[TMP7]], align 1
110- ; CHECK-NEXT: store i8 0, ptr [[TMP7]], align 1
111111; CHECK-NEXT: [[TMP8:%.*]] = trunc i32 [[TMP5]] to i8
112112; CHECK-NEXT: store i8 [[TMP8]], ptr [[INVAR_DST]], align 1
113113; CHECK-NEXT: [[INDEX_NEXT]] = add nuw i64 [[INDEX]], 2
114114; CHECK-NEXT: [[TMP9:%.*]] = icmp eq i64 [[INDEX_NEXT]], 100
115115; CHECK-NEXT: br i1 [[TMP9]], label %[[MIDDLE_BLOCK:.*]], label %[[VECTOR_BODY]], !llvm.loop [[LOOP5:![0-9]+]]
116116; CHECK: [[MIDDLE_BLOCK]]:
117- ; CHECK-NEXT: br [[EXIT:label %.*]]
118- ; CHECK: [[SCALAR_PH:.*:]]
117+ ; CHECK-NEXT: br label %[[EXIT:.*]]
118+ ; CHECK: [[EXIT]]:
119+ ; CHECK-NEXT: ret void
119120;
120121entry:
121122 br label %loop
@@ -463,21 +464,21 @@ define void @test_prefer_vector_addressing(ptr %start, ptr %ms, ptr noalias %src
463464; CHECK-NEXT: [[NEXT_GEP3:%.*]] = getelementptr i8, ptr [[START]], i64 [[TMP11]]
464465; CHECK-NEXT: [[NEXT_GEP4:%.*]] = getelementptr i8, ptr [[START]], i64 [[TMP12]]
465466; CHECK-NEXT: [[NEXT_GEP5:%.*]] = getelementptr i8, ptr [[START]], i64 [[TMP13]]
466- ; CHECK-NEXT: [[TMP14:%.*]] = load i64, ptr [[NEXT_GEP]], align 1, !tbaa [[LONG_LONG_TBAA14 :![0-9]+]]
467- ; CHECK-NEXT: [[TMP15:%.*]] = load i64, ptr [[NEXT_GEP3]], align 1, !tbaa [[LONG_LONG_TBAA14 ]]
468- ; CHECK-NEXT: [[TMP16:%.*]] = load i64, ptr [[NEXT_GEP4]], align 1, !tbaa [[LONG_LONG_TBAA14 ]]
469- ; CHECK-NEXT: [[TMP17:%.*]] = load i64, ptr [[NEXT_GEP5]], align 1, !tbaa [[LONG_LONG_TBAA14 ]]
467+ ; CHECK-NEXT: [[TMP14:%.*]] = load i64, ptr [[NEXT_GEP]], align 1, !tbaa [[LONG_LONG_TBAA12 :![0-9]+]]
468+ ; CHECK-NEXT: [[TMP15:%.*]] = load i64, ptr [[NEXT_GEP3]], align 1, !tbaa [[LONG_LONG_TBAA12 ]]
469+ ; CHECK-NEXT: [[TMP16:%.*]] = load i64, ptr [[NEXT_GEP4]], align 1, !tbaa [[LONG_LONG_TBAA12 ]]
470+ ; CHECK-NEXT: [[TMP17:%.*]] = load i64, ptr [[NEXT_GEP5]], align 1, !tbaa [[LONG_LONG_TBAA12 ]]
470471; CHECK-NEXT: [[TMP18:%.*]] = getelementptr i8, ptr [[SRC]], i64 [[TMP14]]
471472; CHECK-NEXT: [[TMP19:%.*]] = getelementptr i8, ptr [[SRC]], i64 [[TMP15]]
472473; CHECK-NEXT: [[TMP20:%.*]] = getelementptr i8, ptr [[SRC]], i64 [[TMP16]]
473474; CHECK-NEXT: [[TMP21:%.*]] = getelementptr i8, ptr [[SRC]], i64 [[TMP17]]
474- ; CHECK-NEXT: store i32 0, ptr [[TMP18]], align 4, !tbaa [[INT_TBAA19 :![0-9]+]]
475- ; CHECK-NEXT: store i32 0, ptr [[TMP19]], align 4, !tbaa [[INT_TBAA19 ]]
476- ; CHECK-NEXT: store i32 0, ptr [[TMP20]], align 4, !tbaa [[INT_TBAA19 ]]
477- ; CHECK-NEXT: store i32 0, ptr [[TMP21]], align 4, !tbaa [[INT_TBAA19 ]]
475+ ; CHECK-NEXT: store i32 0, ptr [[TMP18]], align 4, !tbaa [[INT_TBAA17 :![0-9]+]]
476+ ; CHECK-NEXT: store i32 0, ptr [[TMP19]], align 4, !tbaa [[INT_TBAA17 ]]
477+ ; CHECK-NEXT: store i32 0, ptr [[TMP20]], align 4, !tbaa [[INT_TBAA17 ]]
478+ ; CHECK-NEXT: store i32 0, ptr [[TMP21]], align 4, !tbaa [[INT_TBAA17 ]]
478479; CHECK-NEXT: [[INDEX_NEXT]] = add nuw i64 [[INDEX]], 4
479480; CHECK-NEXT: [[TMP22:%.*]] = icmp eq i64 [[INDEX_NEXT]], [[N_VEC]]
480- ; CHECK-NEXT: br i1 [[TMP22]], label %[[MIDDLE_BLOCK:.*]], label %[[VECTOR_BODY]], !llvm.loop [[LOOP21 :![0-9]+]]
481+ ; CHECK-NEXT: br i1 [[TMP22]], label %[[MIDDLE_BLOCK:.*]], label %[[VECTOR_BODY]], !llvm.loop [[LOOP19 :![0-9]+]]
481482; CHECK: [[MIDDLE_BLOCK]]:
482483; CHECK-NEXT: [[CMP_N:%.*]] = icmp eq i64 [[TMP6]], [[N_VEC]]
483484; CHECK-NEXT: br i1 [[CMP_N]], [[EXIT:label %.*]], label %[[SCALAR_PH]]
@@ -578,10 +579,11 @@ define double @test_scalarization_cost_for_load_of_address(ptr %src.0, ptr %src.
578579; CHECK-NEXT: [[TMP20:%.*]] = fmul <2 x double> [[TMP9]], [[TMP19]]
579580; CHECK-NEXT: [[TMP21]] = call double @llvm.vector.reduce.fadd.v2f64(double [[VEC_PHI]], <2 x double> [[TMP20]])
580581; CHECK-NEXT: [[INDEX_NEXT]] = add nuw i64 [[INDEX]], 2
581- ; CHECK-NEXT: br i1 true, label %[[MIDDLE_BLOCK:.*]], label %[[VECTOR_BODY]], !llvm.loop [[LOOP23 :![0-9]+]]
582+ ; CHECK-NEXT: br i1 true, label %[[MIDDLE_BLOCK:.*]], label %[[VECTOR_BODY]], !llvm.loop [[LOOP21 :![0-9]+]]
582583; CHECK: [[MIDDLE_BLOCK]]:
583- ; CHECK-NEXT: br [[EXIT:label %.*]]
584- ; CHECK: [[SCALAR_PH:.*:]]
584+ ; CHECK-NEXT: br label %[[EXIT:.*]]
585+ ; CHECK: [[EXIT]]:
586+ ; CHECK-NEXT: ret double [[TMP21]]
585587;
586588entry:
587589 br label %loop
0 commit comments