; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 2 ; RUN: opt -S -loop-reduce %s | FileCheck --check-prefixes=LEGACYPM %s ; RUN: opt -S -passes=loop-reduce %s | FileCheck --check-prefixes=NEWPM %s target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" target triple = "x86_64-unknown-linux-gnu" define void @function_0(i32 %val_i32_8, i32 %val_i32_9) { ; LEGACYPM-LABEL: define void @function_0 ; LEGACYPM-SAME: (i32 [[VAL_I32_8:%.*]], i32 [[VAL_I32_9:%.*]]) { ; LEGACYPM-NEXT: [[VAL_I1_22:%.*]] = trunc i8 -66 to i1 ; LEGACYPM-NEXT: br i1 [[VAL_I1_22]], label [[BB_2_PREHEADER:%.*]], label [[BB_2_PREHEADER]] ; LEGACYPM: bb_2.preheader: ; LEGACYPM-NEXT: br label [[BB_2:%.*]] ; LEGACYPM: bb_2: ; LEGACYPM-NEXT: br label [[PRHDR_LOOP_3:%.*]] ; LEGACYPM: prhdr_loop_3: ; LEGACYPM-NEXT: br label [[LOOP_4:%.*]] ; LEGACYPM: loop_4: ; LEGACYPM-NEXT: [[LSR_IV:%.*]] = phi i32 [ [[LSR_IV_NEXT:%.*]], [[BE_6:%.*]] ], [ 7851, [[PRHDR_LOOP_3]] ] ; LEGACYPM-NEXT: br i1 [[VAL_I1_22]], label [[BE_6]], label [[LOOP_EXIT_7SPLIT:%.*]] ; LEGACYPM: bb_5: ; LEGACYPM-NEXT: [[VAL_I32_40:%.*]] = mul i32 [[VAL_I32_9]], [[VAL_I32_24_LCSSA:%.*]] ; LEGACYPM-NEXT: br label [[BB_2]] ; LEGACYPM: be_6: ; LEGACYPM-NEXT: [[LSR_IV_NEXT]] = add i32 [[LSR_IV]], 1 ; LEGACYPM-NEXT: br i1 [[VAL_I1_22]], label [[LOOP_4]], label [[BE_6_LOOP_EXIT_7_CRIT_EDGE:%.*]] ; LEGACYPM: loop_exit_7split: ; LEGACYPM-NEXT: [[LSR_IV_LCSSA:%.*]] = phi i32 [ [[LSR_IV]], [[LOOP_4]] ] ; LEGACYPM-NEXT: br label [[LOOP_EXIT_7:%.*]] ; LEGACYPM: be_6.loop_exit_7_crit_edge: ; LEGACYPM-NEXT: [[LSR_IV_LCSSA1:%.*]] = phi i32 [ [[LSR_IV]], [[BE_6]] ] ; LEGACYPM-NEXT: br label [[LOOP_EXIT_7]] ; LEGACYPM: loop_exit_7: ; LEGACYPM-NEXT: [[VAL_I32_24_LCSSA]] = phi i32 [ [[LSR_IV_LCSSA1]], [[BE_6_LOOP_EXIT_7_CRIT_EDGE]] ], [ [[LSR_IV_LCSSA]], [[LOOP_EXIT_7SPLIT]] ] ; LEGACYPM-NEXT: br label [[BB_5:%.*]] ; ; NEWPM-LABEL: define void @function_0 ; NEWPM-SAME: (i32 [[VAL_I32_8:%.*]], i32 [[VAL_I32_9:%.*]]) { ; NEWPM-NEXT: [[VAL_I1_22:%.*]] = trunc i8 -66 to i1 ; NEWPM-NEXT: br i1 [[VAL_I1_22]], label [[BB_2_PREHEADER:%.*]], label [[BB_2_PREHEADER]] ; NEWPM: bb_2.preheader: ; NEWPM-NEXT: br label [[BB_2:%.*]] ; NEWPM: bb_2: ; NEWPM-NEXT: br label [[PRHDR_LOOP_3:%.*]] ; NEWPM: prhdr_loop_3: ; NEWPM-NEXT: br label [[LOOP_4:%.*]] ; NEWPM: loop_4: ; NEWPM-NEXT: [[LSR_IV:%.*]] = phi i32 [ [[LSR_IV_NEXT:%.*]], [[BE_6:%.*]] ], [ 7851, [[PRHDR_LOOP_3]] ] ; NEWPM-NEXT: br i1 [[VAL_I1_22]], label [[BE_6]], label [[LOOP_EXIT_7SPLIT:%.*]] ; NEWPM: bb_5: ; NEWPM-NEXT: [[VAL_I32_40:%.*]] = mul i32 [[VAL_I32_9]], [[VAL_I32_24_LCSSA:%.*]] ; NEWPM-NEXT: br label [[BB_2]] ; NEWPM: be_6: ; NEWPM-NEXT: [[LSR_IV_NEXT]] = add i32 [[LSR_IV]], 1 ; NEWPM-NEXT: br i1 [[VAL_I1_22]], label [[LOOP_4]], label [[BE_6_LOOP_EXIT_7_CRIT_EDGE:%.*]] ; NEWPM: loop_exit_7split: ; NEWPM-NEXT: [[LSR_IV_LCSSA:%.*]] = phi i32 [ [[LSR_IV]], [[LOOP_4]] ] ; NEWPM-NEXT: br label [[LOOP_EXIT_7:%.*]] ; NEWPM: be_6.loop_exit_7_crit_edge: ; NEWPM-NEXT: [[LSR_IV_LCSSA1:%.*]] = phi i32 [ [[LSR_IV]], [[BE_6]] ] ; NEWPM-NEXT: br label [[LOOP_EXIT_7]] ; NEWPM: loop_exit_7: ; NEWPM-NEXT: [[VAL_I32_24_LCSSA]] = phi i32 [ [[LSR_IV_LCSSA1]], [[BE_6_LOOP_EXIT_7_CRIT_EDGE]] ], [ [[LSR_IV_LCSSA]], [[LOOP_EXIT_7SPLIT]] ] ; NEWPM-NEXT: br label [[BB_5:%.*]] ; %val_i1_22 = trunc i8 -66 to i1 br i1 %val_i1_22, label %bb_2, label %bb_2 bb_2: ; preds = %bb_5, %entry_1, %entry_1 br label %prhdr_loop_3 prhdr_loop_3: ; preds = %bb_2 br label %loop_4 loop_4: ; preds = %be_6, %prhdr_loop_3 %loop_cnt_i32_11 = phi i32 [ 7850, %prhdr_loop_3 ], [ %val_i32_24, %be_6 ] %val_i32_24 = add i32 %loop_cnt_i32_11, 1 br i1 %val_i1_22, label %be_6, label %loop_exit_7 bb_5: ; preds = %loop_exit_7 %val_i32_40 = mul i32 %val_i32_9, %val_i32_24.lcssa br label %bb_2 be_6: ; preds = %loop_4 br i1 %val_i1_22, label %loop_4, label %loop_exit_7 loop_exit_7: ; preds = %be_6, %loop_4 %val_i32_24.lcssa = phi i32 [ %val_i32_24, %be_6 ], [ %val_i32_24, %loop_4 ] br label %bb_5 }